mirror of
https://github.com/dtolnay/thiserror.git
synced 2025-04-04 21:37:57 +03:00
Clean up dep-info files from OUT_DIR
This commit is contained in:
parent
a72ea77c45
commit
f563b1dc76
1 changed files with 24 additions and 2 deletions
26
build.rs
26
build.rs
|
@ -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 {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue