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
3 changed files with 45 additions and 2 deletions
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 {
|
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>;
|
pub type ExtensionWorktree = Arc<dyn LspAdapterDelegate>;
|
||||||
|
|
|
@ -37,7 +37,7 @@ wasmtime::component::bindgen!({
|
||||||
pub use self::zed::extension::*;
|
pub use self::zed::extension::*;
|
||||||
|
|
||||||
mod settings {
|
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>;
|
pub type ExtensionWorktree = Arc<dyn LspAdapterDelegate>;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue