2016-06-12 03:38:03 -05:00
|
|
|
extern crate walkdir;
|
|
|
|
|
|
|
|
use std::env;
|
|
|
|
use std::fs::File;
|
|
|
|
use std::io::Write;
|
|
|
|
use std::path::Path;
|
|
|
|
use std::process::Command;
|
|
|
|
|
|
|
|
use walkdir::WalkDir;
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let out_dir = env::var("OUT_DIR").unwrap();
|
|
|
|
let dest_path = Path::new(&out_dir).join("git_info.rs");
|
|
|
|
let mut f = File::create(&dest_path).unwrap();
|
|
|
|
|
|
|
|
writeln!(f,
|
|
|
|
"const COMMIT_HASH: Option<&'static str> = {:?};",
|
|
|
|
git_head_sha1())
|
2017-02-21 21:20:50 -06:00
|
|
|
.unwrap();
|
2016-06-12 03:38:03 -05:00
|
|
|
writeln!(f,
|
|
|
|
"const WORKTREE_CLEAN: Option<bool> = {:?};",
|
|
|
|
git_tree_is_clean())
|
2017-02-21 21:20:50 -06:00
|
|
|
.unwrap();
|
2016-06-12 03:38:03 -05:00
|
|
|
|
|
|
|
// cargo:rerun-if-changed requires one entry per individual file.
|
|
|
|
for entry in WalkDir::new("src") {
|
|
|
|
let entry = entry.unwrap();
|
|
|
|
println!("cargo:rerun-if-changed={}", entry.path().display());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns `None` if git is not available.
|
|
|
|
fn git_head_sha1() -> Option<String> {
|
|
|
|
Command::new("git")
|
|
|
|
.arg("rev-parse")
|
|
|
|
.arg("--short")
|
|
|
|
.arg("HEAD")
|
|
|
|
.output()
|
|
|
|
.ok()
|
|
|
|
.and_then(|o| String::from_utf8(o.stdout).ok())
|
|
|
|
.map(|mut s| {
|
2017-02-22 13:52:52 -06:00
|
|
|
let len = s.trim_right().len();
|
|
|
|
s.truncate(len);
|
|
|
|
s
|
|
|
|
})
|
2016-06-12 03:38:03 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// Returns `None` if git is not available.
|
|
|
|
fn git_tree_is_clean() -> Option<bool> {
|
|
|
|
Command::new("git")
|
|
|
|
.arg("status")
|
|
|
|
.arg("--porcelain")
|
|
|
|
.arg("--untracked-files=no")
|
|
|
|
.output()
|
|
|
|
.ok()
|
|
|
|
.map(|o| o.stdout.is_empty())
|
|
|
|
}
|