Clean up dep-info files from OUT_DIR

This commit is contained in:
David Tolnay 2024-10-22 10:46:24 -07:00
parent a72ea77c45
commit f563b1dc76
No known key found for this signature in database
GPG key ID: F9BA143B95FF6D82

View file

@ -1,5 +1,7 @@
use std::env; use std::env;
use std::ffi::OsString; use std::ffi::OsString;
use std::fs;
use std::io::ErrorKind;
use std::iter; use std::iter;
use std::path::Path; use std::path::Path;
use std::process::{self, Command, Stdio}; use std::process::{self, Command, Stdio};
@ -68,8 +70,16 @@ fn compile_probe(rustc_bootstrap: bool) -> bool {
let rustc = cargo_env_var("RUSTC"); let rustc = cargo_env_var("RUSTC");
let out_dir = cargo_env_var("OUT_DIR"); let out_dir = cargo_env_var("OUT_DIR");
let out_subdir = Path::new(&out_dir).join("probe");
let probefile = Path::new("build").join("probe.rs"); let probefile = Path::new("build").join("probe.rs");
if let Err(err) = fs::create_dir(&out_subdir) {
if err.kind() != ErrorKind::AlreadyExists {
eprintln!("Failed to create {}: {}", out_subdir.display(), err);
process::exit(1);
}
}
let rustc_wrapper = env::var_os("RUSTC_WRAPPER").filter(|wrapper| !wrapper.is_empty()); let rustc_wrapper = env::var_os("RUSTC_WRAPPER").filter(|wrapper| !wrapper.is_empty());
let rustc_workspace_wrapper = let rustc_workspace_wrapper =
env::var_os("RUSTC_WORKSPACE_WRAPPER").filter(|wrapper| !wrapper.is_empty()); env::var_os("RUSTC_WORKSPACE_WRAPPER").filter(|wrapper| !wrapper.is_empty());
@ -91,7 +101,7 @@ fn compile_probe(rustc_bootstrap: bool) -> bool {
.arg("--cap-lints=allow") .arg("--cap-lints=allow")
.arg("--emit=dep-info,metadata") .arg("--emit=dep-info,metadata")
.arg("--out-dir") .arg("--out-dir")
.arg(out_dir) .arg(&out_subdir)
.arg(probefile); .arg(probefile);
if let Some(target) = env::var_os("TARGET") { if let Some(target) = env::var_os("TARGET") {
@ -107,10 +117,22 @@ fn compile_probe(rustc_bootstrap: bool) -> bool {
} }
} }
match cmd.status() { let success = match cmd.status() {
Ok(status) => status.success(), Ok(status) => status.success(),
Err(_) => false, Err(_) => false,
};
// Clean up to avoid leaving nondeterministic absolute paths in the dep-info
// file in OUT_DIR, which causes nonreproducible builds in build systems
// that treat the entire OUT_DIR as an artifact.
if let Err(err) = fs::remove_dir_all(&out_subdir) {
if err.kind() != ErrorKind::NotFound {
eprintln!("Failed to clean up {}: {}", out_subdir.display(), err);
process::exit(1);
}
} }
success
} }
fn cargo_env_var(key: &str) -> OsString { fn cargo_env_var(key: &str) -> OsString {