From 7ca122c00947c15169a97bd881350a9bae16f7a9 Mon Sep 17 00:00:00 2001 From: Weihang Lo Date: Sun, 12 Nov 2023 14:43:41 -0500 Subject: [PATCH] fix: do not panic when failed to parse rustc commit-hash In some situation the commit-hash in `rustc -vV` output is "unknown". The debug assertion must not block any progress on others like miri. --- src/cargo/util/rustc.rs | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/src/cargo/util/rustc.rs b/src/cargo/util/rustc.rs index c313ec795bf..80a9fe802f2 100644 --- a/src/cargo/util/rustc.rs +++ b/src/cargo/util/rustc.rs @@ -83,14 +83,20 @@ impl Rustc { ) })?; let commit_hash = extract("commit-hash: ").ok().map(|hash| { - debug_assert!( - hash.chars().all(|ch| ch.is_ascii_hexdigit()), - "commit hash must be a hex string, got: {hash:?}" - ); - debug_assert!( - hash.len() == 40 || hash.len() == 64, - "hex string must be generated from sha1 or sha256 (i.e., it must be 40 or 64 characters long)\ngot: {hash:?}" - ); + // Possible commit-hash values from rustc are SHA hex string and "unknown". See: + // * https://github.com/rust-lang/rust/blob/531cb83fc/src/bootstrap/src/utils/channel.rs#L73 + // * https://github.com/rust-lang/rust/blob/531cb83fc/compiler/rustc_driver_impl/src/lib.rs#L911-L913 + #[cfg(debug_assertions)] + if hash != "unknown" { + debug_assert!( + hash.chars().all(|ch| ch.is_ascii_hexdigit()), + "commit hash must be a hex string, got: {hash:?}" + ); + debug_assert!( + hash.len() == 40 || hash.len() == 64, + "hex string must be generated from sha1 or sha256 (i.e., it must be 40 or 64 characters long)\ngot: {hash:?}" + ); + } hash.to_string() });