diff options
| author | bors <bors@rust-lang.org> | 2024-01-09 10:12:57 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2024-01-09 10:12:57 +0000 |
| commit | e3575a87ded3e5f26b9c856aeea5b672855f5a18 (patch) | |
| tree | f9e29434004e200e3a4a4a2c2244c4f118c94a86 | |
| parent | acafce33894fd4aa0664a3e1380a7de26a13de9b (diff) | |
| parent | a8c94eaf131cdadad07296fd1d69edeb51aa0970 (diff) | |
| download | rust-e3575a87ded3e5f26b9c856aeea5b672855f5a18.tar.gz rust-e3575a87ded3e5f26b9c856aeea5b672855f5a18.zip | |
Auto merge of #16312 - Veykril:win-proc-macro-srv, r=Veykril
fix: Fix rust-analyzer-proc-macro-srv failing to spawn on windows
| -rw-r--r-- | crates/proc-macro-api/src/process.rs | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/crates/proc-macro-api/src/process.rs b/crates/proc-macro-api/src/process.rs index a22d8628f16..5ce601bce69 100644 --- a/crates/proc-macro-api/src/process.rs +++ b/crates/proc-macro-api/src/process.rs @@ -162,12 +162,19 @@ impl Process { } fn mk_child(path: &AbsPath, null_stderr: bool) -> io::Result<Child> { - Command::new(path.as_os_str()) - .env("RUST_ANALYZER_INTERNALS_DO_NOT_USE", "this is unstable") + let mut cmd = Command::new(path.as_os_str()); + cmd.env("RUST_ANALYZER_INTERNALS_DO_NOT_USE", "this is unstable") .stdin(Stdio::piped()) .stdout(Stdio::piped()) - .stderr(if null_stderr { Stdio::null() } else { Stdio::inherit() }) - .spawn() + .stderr(if null_stderr { Stdio::null() } else { Stdio::inherit() }); + if cfg!(windows) { + let mut path_var = std::ffi::OsString::new(); + path_var.push(path.parent().unwrap().parent().unwrap().as_os_str()); + path_var.push("\\bin;"); + path_var.push(std::env::var_os("PATH").unwrap_or_default()); + cmd.env("PATH", path_var); + } + cmd.spawn() } fn send_request( |
