forked from llvm/llvm-project
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[C++20] [Modules] Introduce -fskip-odr-check-in-gmf (llvm#79959)
Close llvm#79240 Cite the comment from @mizvekov in //github.com/llvm/issues/79240: > There are two kinds of bugs / issues relevant here: > > Clang bugs that this change hides > Here we can add a Frontend flag that disables the GMF ODR check, just > so > we can keep tracking, testing and fixing these issues. > The Driver would just always pass that flag. > We could add that flag in this current issue. > Bugs in user code: > I don't think it's worth adding a corresponding Driver flag for > controlling the above Frontend flag, since we intend it's behavior to > become default as we fix the problems, and users interested in testing > the more strict behavior can just use the Frontend flag directly. This patch follows the suggestion: - Introduce the CC1 flag `-fskip-odr-check-in-gmf` which is by default off, so that the every existing test will still be tested with checking ODR violations. - Passing `-fskip-odr-check-in-gmf` in the driver to keep the behavior we intended. - Edit the document to tell the users who are still interested in more strict checks can use `-Xclang -fno-skip-odr-check-in-gmf` to get the existing behavior.
- Loading branch information
1 parent
5e52156
commit ba26932
Showing
15 changed files
with
167 additions
and
30 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
// RUN: %clang -std=c++20 -### -c %s 2>&1 | FileCheck %s | ||
// RUN: %clang -std=c++20 -fno-skip-odr-check-in-gmf -### -c %s 2>&1 \ | ||
// RUN: | FileCheck %s --check-prefix=UNUSED | ||
// RUN: %clang -std=c++20 -Xclang -fno-skip-odr-check-in-gmf -### -c %s 2>&1 \ | ||
// RUN: | FileCheck %s --check-prefix=NO-SKIP | ||
|
||
// CHECK: -fskip-odr-check-in-gmf | ||
// UNUSED: warning: argument unused during compilation: '-fno-skip-odr-check-in-gmf' | ||
// UNUSED-NOT: -fno-skip-odr-check-in-gmf | ||
// NO-SKIP: -fskip-odr-check-in-gmf{{.*}}-fno-skip-odr-check-in-gmf |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,6 +5,12 @@ | |
// RUN: %clang_cc1 -std=c++20 %t/A.cppm -emit-module-interface -o %t/A.pcm | ||
// RUN: %clang_cc1 -std=c++20 -fprebuilt-module-path=%t -I%t -DDIFFERENT %t/B.cppm -verify | ||
// RUN: %clang_cc1 -std=c++20 -fprebuilt-module-path=%t -I%t %t/B.cppm -verify | ||
// | ||
// Testing the behavior of `-fskip-odr-check-in-gmf` | ||
// RUN: %clang_cc1 -std=c++20 -fskip-odr-check-in-gmf %t/A.cppm -emit-module-interface -o %t/A.pcm | ||
// RUN: %clang_cc1 -std=c++20 -fskip-odr-check-in-gmf -fprebuilt-module-path=%t -I%t \ | ||
// RUN: -DDIFFERENT -DSKIP_ODR_CHECK_IN_GMF %t/B.cppm -verify | ||
|
||
|
||
//--- foo.h | ||
#ifndef FOO_H | ||
|
@@ -70,6 +76,16 @@ module; | |
export module B; | ||
import A; | ||
|
||
#ifdef SKIP_ODR_CHECK_IN_GMF | ||
// [email protected]:* {{call to object of type '__fn' is ambiguous}} | ||
// expected-note@* 1+{{candidate function}} | ||
#elif defined(DIFFERENT) | ||
// [email protected]:41 {{'__fn::operator()' from module 'A.<global>' is not present in definition of '__fn' provided earlier}} | ||
// expected-note@* 1+{{declaration of 'operator()' does not match}} | ||
#else | ||
// expected-no-diagnostics | ||
#endif | ||
|
||
template <class T> | ||
struct U { | ||
auto operator+(U) { return 0; } | ||
|
@@ -87,10 +103,3 @@ void foo() { | |
|
||
__fn{}(U<int>(), U<int>()); | ||
} | ||
|
||
#ifdef DIFFERENT | ||
// [email protected]:* {{call to object of type '__fn' is ambiguous}} | ||
// expected-note@* 1+{{candidate function}} | ||
#else | ||
// expected-no-diagnostics | ||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,6 +10,12 @@ | |
// RUN: %clang_cc1 -std=c++20 %t/mod4.cppm -fmodule-file=mod3=%t/mod3.pcm \ | ||
// RUN: -fsyntax-only -verify | ||
|
||
// Testing the behavior of `-fskip-odr-check-in-gmf` | ||
// RUN: %clang_cc1 -std=c++20 %t/mod3.cppm -fskip-odr-check-in-gmf \ | ||
// RUN: -emit-module-interface -o %t/mod3.pcm | ||
// RUN: %clang_cc1 -std=c++20 %t/mod4.cppm -fmodule-file=mod3=%t/mod3.pcm \ | ||
// RUN: -fskip-odr-check-in-gmf -DSKIP_ODR_CHECK_IN_GMF -fsyntax-only -verify | ||
|
||
//--- size_t.h | ||
|
||
extern "C" { | ||
|
@@ -57,13 +63,17 @@ export module mod3; | |
export using std::align_val_t; | ||
|
||
//--- mod4.cppm | ||
// This is actually an ODR violation. But given https://github.com/llvm/llvm-project/issues/79240, | ||
// we don't count it as an ODR violation now. | ||
// expected-no-diagnostics | ||
module; | ||
#include "signed_size_t.h" | ||
#include "csize_t" | ||
#include "align.h" | ||
export module mod4; | ||
import mod3; | ||
export using std::align_val_t; | ||
|
||
#ifdef SKIP_ODR_CHECK_IN_GMF | ||
// expected-no-diagnostics | ||
#else | ||
// [email protected]:* {{'std::align_val_t' has different definitions in different modules; defined here first difference is enum with specified type 'size_t' (aka 'int')}} | ||
// [email protected]:* {{but in 'mod3.<global>' found enum with specified type 'size_t' (aka 'unsigned int')}} | ||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
// RUN: rm -rf %t | ||
// RUN: mkdir -p %t | ||
// RUN: split-file %s %t | ||
// | ||
// Baseline testing to make sure we can detect the ODR violation from the CC1 invocation. | ||
// RUNX: %clang_cc1 -std=c++20 %t/a.cppm -emit-module-interface -o %t/a.pcm | ||
// RUNX: %clang_cc1 -std=c++20 %t/b.cppm -emit-module-interface -o %t/b.pcm | ||
// RUNX: %clang_cc1 -std=c++20 %t/test.cc -fprebuilt-module-path=%t -fsyntax-only -verify | ||
// | ||
// Testing that we can ignore the ODR violation from the driver invocation. | ||
// RUN: %clang -std=c++20 %t/a.cppm --precompile -o %t/a.pcm | ||
// RUN: %clang -std=c++20 %t/b.cppm --precompile -o %t/b.pcm | ||
// RUN: %clang -std=c++20 %t/test.cc -fprebuilt-module-path=%t -fsyntax-only -Xclang -verify \ | ||
// RUN: -DIGNORE_ODR_VIOLATION | ||
// | ||
// Testing that the driver can require to check the ODR violation. | ||
// RUN: %clang -std=c++20 -Xclang -fno-skip-odr-check-in-gmf %t/a.cppm --precompile -o %t/a.pcm | ||
// RUN: %clang -std=c++20 -Xclang -fno-skip-odr-check-in-gmf %t/b.cppm --precompile -o %t/b.pcm | ||
// RUN: %clang -std=c++20 -Xclang -fno-skip-odr-check-in-gmf %t/test.cc -fprebuilt-module-path=%t \ | ||
// RUN: -fsyntax-only -Xclang -verify | ||
|
||
//--- func1.h | ||
bool func(int x, int y) { | ||
return true; | ||
} | ||
|
||
//--- func2.h | ||
bool func(int x, int y) { | ||
return false; | ||
} | ||
|
||
//--- a.cppm | ||
module; | ||
#include "func1.h" | ||
export module a; | ||
export using ::func; | ||
|
||
//--- b.cppm | ||
module; | ||
#include "func2.h" | ||
export module b; | ||
export using ::func; | ||
|
||
//--- test.cc | ||
import a; | ||
import b; | ||
bool test() { | ||
return func(1, 2); | ||
} | ||
|
||
#ifdef IGNORE_ODR_VIOLATION | ||
// expected-no-diagnostics | ||
#else | ||
// [email protected]:1 {{'func' has different definitions in different modules;}} | ||
// [email protected]:1 {{but in 'a.<global>' found a different body}} | ||
#endif |