From: Chuanqi Xu Date: Mon, 6 Mar 2023 06:39:27 +0000 (+0800) Subject: [NFC] Add an invalid test case for C++20 Modules X-Git-Tag: upstream/17.0.6~15817 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5b769ff3e6a47eb2ffe8aa9e86f701ef046cf0a9;p=platform%2Fupstream%2Fllvm.git [NFC] Add an invalid test case for C++20 Modules Address https://github.com/llvm/llvm-project/issues/61150. The test is intended to show the polluted operator&& will affect the ODR checking and the ODR checking here is correct. --- diff --git a/clang/test/Modules/polluted-operator.cppm b/clang/test/Modules/polluted-operator.cppm new file mode 100644 index 0000000..b24464a --- /dev/null +++ b/clang/test/Modules/polluted-operator.cppm @@ -0,0 +1,57 @@ +// RUN: rm -rf %t +// RUN: mkdir -p %t +// RUN: split-file %s %t +// +// RUN: %clang_cc1 -std=c++20 -emit-module-interface %t/a.cppm -o %t/a.pcm +// RUN: %clang_cc1 -std=c++20 %t/b.cppm -fprebuilt-module-path=%t -emit-module-interface -o %t/b.pcm -verify + +//--- foo.h + +namespace std +{ + template + void operator &&(_Dom1 __v, _Dom1 __w) + { + return; + } +} + +//--- bar.h +namespace std +{ + template + struct _Traits + { + static constexpr bool _S_copy_ctor = + (__is_trivial(_Types) && ...); + }; + + template + struct variant + { + void + swap(variant& __rhs) + noexcept((__is_trivial(_Types) && ...)) + { + } + }; +} + +//--- a.cppm +module; +// The operator&& defined in 'foo.h' will pollute the +// expression '__is_trivial(_Types) && ...' in bar.h +#include "foo.h" +#include "bar.h" +export module a; + +//--- b.cppm +module; +#include "bar.h" +export module b; +import a; + +// expected-error@* {{has different definitions in different modules; first difference is defined here found data member '_S_copy_ctor' with an initializer}} +// expected-note@* {{but in 'a.' found data member '_S_copy_ctor' with a different initializer}} +// expected-error@* {{from module 'a.' is not present in definition of 'variant<_Types...>' provided earlier}} +// expected-note@* {{declaration of 'swap' does not match}}