about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorZalathar <Zalathar@users.noreply.github.com>2025-10-01 21:45:50 +1000
committerZalathar <Zalathar@users.noreply.github.com>2025-10-02 11:16:03 +1000
commit59c4dfe59d587f0f09746958bf9a16c271cc02a7 (patch)
treefd69c16e5adf9e3cdc8a50b60489318c5317338d /src
parent3369e82c6bc03c5cdb66f730dba6f738b74c8e1d (diff)
downloadrust-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.rs10
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);
                     }