mirror of
https://github.com/zed-industries/zed.git
synced 2024-11-08 07:35:01 +03:00
Copy extension_api
Rust files to OUT_DIR
when building extension
to work around rust-analyzer limitation (#16064)
Copies rust files from extension_api/wit to the OUT_DIR to allow including them from within the crate, which is supported by rust-analyzer. This allows rust-analyzer to deal with the included files. It doesn't currently support files outside the crate. Release Notes: - N/A
This commit is contained in:
parent
550e139b61
commit
6f104fecad
43
crates/extension/build.rs
Normal file
43
crates/extension/build.rs
Normal file
@ -0,0 +1,43 @@
|
||||
use std::env;
|
||||
use std::fs;
|
||||
use std::path::PathBuf;
|
||||
|
||||
fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||
copy_extension_api_rust_files()
|
||||
}
|
||||
|
||||
// rust-analyzer doesn't support include! for files from outside the crate.
|
||||
// Copy them to the OUT_DIR, so we can include them from there, which is supported.
|
||||
fn copy_extension_api_rust_files() -> Result<(), Box<dyn std::error::Error>> {
|
||||
let out_dir = env::var("OUT_DIR")?;
|
||||
let input_dir = PathBuf::from("../extension_api/wit");
|
||||
let output_dir = PathBuf::from(out_dir);
|
||||
|
||||
for entry in fs::read_dir(&input_dir)? {
|
||||
let entry = entry?;
|
||||
let path = entry.path();
|
||||
if path.is_dir() {
|
||||
for subentry in fs::read_dir(&path)? {
|
||||
let subentry = subentry?;
|
||||
let subpath = subentry.path();
|
||||
if subpath.extension() == Some(std::ffi::OsStr::new("rs")) {
|
||||
let relative_path = subpath.strip_prefix(&input_dir)?;
|
||||
let destination = output_dir.join(relative_path);
|
||||
|
||||
fs::create_dir_all(destination.parent().unwrap())?;
|
||||
fs::copy(&subpath, &destination)?;
|
||||
println!("cargo:rerun-if-changed={}", subpath.display());
|
||||
}
|
||||
}
|
||||
} else if path.extension() == Some(std::ffi::OsStr::new("rs")) {
|
||||
let relative_path = path.strip_prefix(&input_dir)?;
|
||||
let destination = output_dir.join(relative_path);
|
||||
|
||||
fs::create_dir_all(destination.parent().unwrap())?;
|
||||
fs::copy(&path, &destination)?;
|
||||
println!("cargo:rerun-if-changed={}", path.display());
|
||||
}
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
@ -23,7 +23,7 @@ wasmtime::component::bindgen!({
|
||||
});
|
||||
|
||||
mod settings {
|
||||
include!("../../../../extension_api/wit/since_v0.0.6/settings.rs");
|
||||
include!(concat!(env!("OUT_DIR"), "/since_v0.0.6/settings.rs"));
|
||||
}
|
||||
|
||||
pub type ExtensionWorktree = Arc<dyn LspAdapterDelegate>;
|
||||
|
@ -37,7 +37,7 @@ wasmtime::component::bindgen!({
|
||||
pub use self::zed::extension::*;
|
||||
|
||||
mod settings {
|
||||
include!("../../../../extension_api/wit/since_v0.0.7/settings.rs");
|
||||
include!(concat!(env!("OUT_DIR"), "/since_v0.0.7/settings.rs"));
|
||||
}
|
||||
|
||||
pub type ExtensionWorktree = Arc<dyn LspAdapterDelegate>;
|
||||
|
Loading…
Reference in New Issue
Block a user