use std::process::Command;
fn main() {
copy_bundle_lock();
let calver = Command::new("git")
.args(["describe", "--tags", "--abbrev=0"])
.output()
.ok()
.and_then(|o| {
if o.status.success() {
String::from_utf8(o.stdout).ok()
} else {
None
}
})
.map(|s| s.trim().to_string())
.unwrap_or_else(|| "dev".to_string());
let commit = Command::new("git")
.args(["rev-parse", "--short", "HEAD"])
.output()
.ok()
.and_then(|o| {
if o.status.success() {
String::from_utf8(o.stdout).ok()
} else {
None
}
})
.map(|s| s.trim().to_string())
.unwrap_or_else(|| "unknown".to_string());
let dirty = Command::new("git")
.args(["status", "--porcelain"])
.output()
.ok()
.map(|o| !o.stdout.is_empty())
.unwrap_or(false);
let dirty_suffix = if dirty { "-dirty" } else { "" };
println!("cargo:rustc-env=SENTINEL_CALVER={}", calver);
println!("cargo:rustc-env=SENTINEL_COMMIT={}{}", commit, dirty_suffix);
println!("cargo:rerun-if-changed=.git/HEAD");
println!("cargo:rerun-if-changed=.git/refs/tags");
}
fn copy_bundle_lock() {
use std::path::PathBuf;
let out_dir = PathBuf::from(std::env::var("OUT_DIR").unwrap());
let dest = out_dir.join("bundle-versions.lock");
let manifest_dir = PathBuf::from(std::env::var("CARGO_MANIFEST_DIR").unwrap());
let workspace_path = manifest_dir.join("../../bundle-versions.lock");
let crate_path = manifest_dir.join("bundle-versions.lock");
let source = if workspace_path.exists() {
workspace_path
} else if crate_path.exists() {
crate_path
} else {
let fallback = r#"[bundle]
version = "0.0.0"
[agents]
[repositories]
"#;
std::fs::write(&dest, fallback).expect("Failed to write fallback bundle-versions.lock");
println!("cargo:rerun-if-changed=bundle-versions.lock");
return;
};
std::fs::copy(&source, &dest).expect("Failed to copy bundle-versions.lock to OUT_DIR");
println!("cargo:rerun-if-changed={}", source.display());
}