diff options
| author | Zalathar <Zalathar@users.noreply.github.com> | 2025-10-01 21:45:50 +1000 | 
|---|---|---|
| committer | Zalathar <Zalathar@users.noreply.github.com> | 2025-10-02 11:16:03 +1000 | 
| commit | 59c4dfe59d587f0f09746958bf9a16c271cc02a7 (patch) | |
| tree | fd69c16e5adf9e3cdc8a50b60489318c5317338d /src | |
| parent | 3369e82c6bc03c5cdb66f730dba6f738b74c8e1d (diff) | |
| download | rust-59c4dfe59d587f0f09746958bf9a16c271cc02a7.tar.gz rust-59c4dfe59d587f0f09746958bf9a16c271cc02a7.zip | |
Forbid `//@ compile-flags: -Cincremental=` in tests
Tests should not try to manually enable incremental compilation with `-Cincremental`, because that typically results in stray directories being created in the repository root. Instead, use the `//@ incremental` directive, which instructs compiletest to handle the details of passing `-Cincremental` with a fresh directory.
Diffstat (limited to 'src')
| -rw-r--r-- | src/tools/compiletest/src/directives.rs | 10 | 
1 files changed, 9 insertions, 1 deletions
| diff --git a/src/tools/compiletest/src/directives.rs b/src/tools/compiletest/src/directives.rs index e6916610190..0d85e76c2cc 100644 --- a/src/tools/compiletest/src/directives.rs +++ b/src/tools/compiletest/src/directives.rs @@ -415,10 +415,18 @@ impl TestProps { config.parse_name_value_directive(ln, COMPILE_FLAGS, testfile) { let flags = split_flags(&flags); - for flag in &flags { + for (i, flag) in flags.iter().enumerate() { if flag == "--edition" || flag.starts_with("--edition=") { panic!("you must use `//@ edition` to configure the edition"); } + if (flag == "-C" + && flags.get(i + 1).is_some_and(|v| v.starts_with("incremental="))) + || flag.starts_with("-Cincremental=") + { + panic!( + "you must use `//@ incremental` to enable incremental compilation" + ); + } } self.compile_flags.extend(flags); } | 
