From dd9123cd6e0d670fa5ad0d307d8f237072371ff4 Mon Sep 17 00:00:00 2001 From: Marek Kaput Date: Tue, 4 Jun 2024 17:07:44 +0200 Subject: [PATCH] Unify `mtime` constant used on Unix and Windows (#346) * Unify `mtime` constant used on Unix and Windows fix #341 * Extract `DETERMINISTIC_TIMESTAMP` --- src/header.rs | 25 ++++++++++++++----------- tests/header/mod.rs | 1 + 2 files changed, 15 insertions(+), 11 deletions(-) diff --git a/src/header.rs b/src/header.rs index 7e507fc7..65f665e0 100644 --- a/src/header.rs +++ b/src/header.rs @@ -16,6 +16,14 @@ use std::str; use crate::other; use crate::EntryType; +/// A deterministic, arbitrary, non-zero timestamp that use used as `mtime` +/// of headers when [`HeaderMode::Deterministic`] is used. +/// +/// This value, chosen after careful deliberation, corresponds to _Jul 23, 2006_, +/// which is the date of the first commit for what would become Rust. +#[cfg(any(unix, windows))] +const DETERMINISTIC_TIMESTAMP: u64 = 1153704088; + /// Representation of the header of an entry in an archive #[repr(C)] #[allow(missing_docs)] @@ -748,16 +756,11 @@ impl Header { self.set_mode(meta.mode() as u32); } HeaderMode::Deterministic => { - // We could in theory set the mtime to zero here, but not all - // tools seem to behave well when ingesting files with a 0 - // timestamp. For example rust-lang/cargo#9512 shows that lldb - // doesn't ingest files with a zero timestamp correctly. - // - // We just need things to be deterministic here so just pick - // something that isn't zero. This time, chosen after careful - // deliberation, corresponds to Jul 23, 2006 -- the date of the - // first commit for what would become Rust. - self.set_mtime(1153704088); + // We could in theory set the mtime to zero here, but not all tools seem to behave + // well when ingesting files with a 0 timestamp. + // For example, rust-lang/cargo#9512 shows that lldb doesn't ingest files with a + // zero timestamp correctly. + self.set_mtime(DETERMINISTIC_TIMESTAMP); self.set_uid(0); self.set_gid(0); @@ -825,7 +828,7 @@ impl Header { HeaderMode::Deterministic => { self.set_uid(0); self.set_gid(0); - self.set_mtime(123456789); // see above in unix + self.set_mtime(DETERMINISTIC_TIMESTAMP); // see above in unix let fs_mode = if meta.is_dir() { 0o755 } else { 0o644 }; self.set_mode(fs_mode); } diff --git a/tests/header/mod.rs b/tests/header/mod.rs index 86692e33..14865b86 100644 --- a/tests/header/mod.rs +++ b/tests/header/mod.rs @@ -204,6 +204,7 @@ fn set_metadata_deterministic() { // Would not match without `Deterministic`. assert_eq!(t!(one.mtime()), t!(two.mtime())); + assert_eq!(t!(one.mtime()), 1153704088); // TODO: No great way to validate that these would not be filled, but // check them anyway. assert_eq!(t!(one.uid()), t!(two.uid()));