// RUN: rm -rf %t // RUN: mkdir -p %t // RUN: split-file %s %t // // RUN: %clang_cc1 -std=c++20 %t/a.cppm -emit-module-interface -o %t/a.pcm // RUN: %clang_cc1 -std=c++20 %t/use.cc -fmodule-file=a=%t/a.pcm -fsyntax-only -verify // RUN: %clang_cc1 -std=c++20 %t/a-part.cppm -fmodule-file=a=%t/a.pcm -fsyntax-only -verify // // Test again with reduced BMI // RUN: %clang_cc1 -std=c++20 %t/a.cppm -emit-reduced-module-interface -o %t/a.pcm // RUN: %clang_cc1 -std=c++20 %t/use.cc -fmodule-file=a=%t/a.pcm -fsyntax-only -verify // RUN: %clang_cc1 -std=c++20 %t/a-part.cppm -fmodule-file=a=%t/a.pcm -fsyntax-only -verify // RUN: %clang_cc1 -std=c++20 %t/a.cc -fmodule-file=a=%t/a.pcm -fsyntax-only -verify //--- a.cppm export module a; constexpr int x = 43; export constexpr int f() { return x; } export template constexpr T g() { return x; } namespace nn { constexpr int x = 88; export constexpr int f() { return x; } export template constexpr T g() { return x; } } //--- use.cc // expected-no-diagnostics import a; static_assert(f() == 43, ""); constexpr int x = 99; static_assert(g() == 43, ""); static_assert(x == 99, ""); namespace nn { static_assert(f() == 88, ""); constexpr int x = 1000; static_assert(g() == 88, ""); static_assert(x == 1000, ""); } //--- a-part.cppm module a:impl; import a; static_assert(x == 43, ""); constexpr int x = 1000; // expected-error {{redefinition of 'x'}} // expected-note@* {{previous definition is here}} //--- a.cc module a; static_assert(x == 43, ""); constexpr int x = 1000; // expected-error {{redefinition of 'x'}} // expected-note@* {{previous definition is here}}