From 8d3cd35412dd08da74cad94f76ce5f5404d74d2b Mon Sep 17 00:00:00 2001 From: Gavin Zhao Date: Thu, 18 Jan 2024 07:22:35 -0500 Subject: [PATCH] fix(src/compiler/c): take common_args into account during preprocessor hashing (#2039) Signed-off-by: Gavin Zhao --- src/compiler/c.rs | 2 ++ src/compiler/compiler.rs | 63 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 65 insertions(+) diff --git a/src/compiler/c.rs b/src/compiler/c.rs index 3aa9ea5a1..35d947715 100644 --- a/src/compiler/c.rs +++ b/src/compiler/c.rs @@ -303,6 +303,8 @@ where // use in creating a hash key let mut preprocessor_and_arch_args = parsed_args.preprocessor_args.clone(); preprocessor_and_arch_args.extend(parsed_args.arch_args.to_vec()); + // common_args is used in preprocessing too + preprocessor_and_arch_args.extend(parsed_args.common_args.to_vec()); let absolute_input_path: Cow<'_, _> = if parsed_args.input.is_absolute() { Cow::Borrowed(&parsed_args.input) diff --git a/src/compiler/compiler.rs b/src/compiler/compiler.rs index a5768be93..c12563a3c 100644 --- a/src/compiler/compiler.rs +++ b/src/compiler/compiler.rs @@ -1726,6 +1726,69 @@ LLVM version: 6.0", assert_ne!(results[0].key, results[1].key); } + #[test_case(true ; "with preprocessor cache")] + #[test_case(false ; "without preprocessor cache")] + fn test_common_args_affects_hash(preprocessor_cache_mode: bool) { + let f = TestFixture::new(); + let creator = new_creator(); + let runtime = single_threaded_runtime(); + let pool = runtime.handle(); + let output = "compiler_id=clang\ncompiler_version=\"16.0.0\""; + let arguments = vec![ + ovec!["-c", "foo.c", "-o", "foo.o", "-DHELLO"], + ovec!["-c", "foo.c", "-o", "foo.o", "-DHI"], + ovec!["-c", "foo.c", "-o", "foo.o"], + ]; + let cwd = f.tempdir.path(); + // Write a dummy input file so the preprocessor cache mode can work + std::fs::write(f.tempdir.path().join("foo.c"), "whatever").unwrap(); + + let results: Vec<_> = arguments + .iter() + .map(|argument| { + next_command(&creator, Ok(MockChild::new(exit_status(0), output, ""))); + let c = detect_compiler( + creator.clone(), + &f.bins[0], + f.tempdir.path(), + &[], + &[], + pool, + None, + ) + .wait() + .unwrap() + .0; + next_command( + &creator, + Ok(MockChild::new(exit_status(0), "preprocessor output", "")), + ); + let hasher = match c.parse_arguments(argument, ".".as_ref(), &[]) { + CompilerArguments::Ok(h) => h, + o => panic!("Bad result from parse_arguments: {:?}", o), + }; + hasher + .generate_hash_key( + &creator, + cwd.to_path_buf(), + vec![], + false, + pool, + false, + Arc::new(MockStorage::new(None, preprocessor_cache_mode)), + CacheControl::Default, + ) + .wait() + .unwrap() + }) + .collect(); + + assert_eq!(results.len(), 3); + assert_ne!(results[0].key, results[1].key); + assert_ne!(results[1].key, results[2].key); + assert_ne!(results[0].key, results[2].key); + } + #[test] fn test_get_compiler_info() { let creator = new_creator();