commit eb4fac6f23514329f261f89258f69982057acdcc from: murilo ijanc date: Fri Nov 21 22:35:33 2025 UTC Move git commands to function commit - 91a09e95f6bcca55fd30c7516810dd070e7b33c1 commit + eb4fac6f23514329f261f89258f69982057acdcc blob - 2b15f84fbb2f99ad2fe7d64a28e8691f3ae09cdf blob + 6efb53f28d81c72906e42ab51bcbdc9f0c406fb5 --- build.rs +++ build.rs @@ -1,10 +1,10 @@ // // Copyright (c) 2025 murilo ijanc' -// +// // Permission to use, copy, modify, and distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice appear in all copies. -// +// // THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES // WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR @@ -14,24 +14,29 @@ // OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. // -use std::process::Command; - fn main() { - let git_hash = Command::new("git") - .args(["rev-parse", "--short=6", "HEAD"]) - .output() - .map(|out| String::from_utf8_lossy(&out.stdout).trim().to_string()) - .unwrap_or_else(|_| "unknown".into()); - - let git_date = Command::new("git") - .args(["show", "-s", "--format=%cd", "--date=short", "HEAD"]) - .output() - .map(|out| String::from_utf8_lossy(&out.stdout).trim().to_string()) - .unwrap_or_else(|_| "unknown".into()); - - println!("cargo:rustc-env=GIT_HASH={}", git_hash); - println!("cargo:rustc-env=BUILD_DATE={}", git_date); - println!("cargo:rerun-if-changed=.git/HEAD"); println!("cargo:rerun-if-changed=.git/refs/heads"); + + let git_hash = git_cmd(&["rev-parse", "--short=6", "HEAD"]); + + let git_date = + git_cmd(&["show", "-s", "--format=%cd", "--date=short", "HEAD"]); + + println!("cargo:rustc-env=GIT_HASH={}", git_hash); + println!("cargo:rustc-env=BUILD_DATE={}", git_date); } + +fn git_cmd(args: &[&str]) -> String { + use std::process::Command; + + Command::new("git") + .args(args) + .output() + .ok() + .filter(|output| output.status.success()) + .and_then(|output| String::from_utf8(output.stdout).ok()) + .map(|s| s.to_string()) + .filter(|s| !s.is_empty()) + .unwrap_or_else(|| "unknown".to_string()) +}