Files
clang-p2996/clang/test/Modules/no-duplicate-codegen-in-GMF.cppm
Chuanqi Xu dc4e85bd79 [C++20] [Modules] Remove hardcoded path to imported module in BMIs
Close https://github.com/llvm/llvm-project/issues/62707

As we discussed before, we'll forbid the use of implicit generated path
for C++20 modules. And as I mentioned in
https://github.com/llvm/llvm-project/issues/62707, we've emitted a
warning for clang17 and we'll make it a hard error in clang18. And the
patch addresses the decision.
2024-01-12 13:47:59 +08:00

42 lines
933 B
C++

// Tests that the declaration won't get emitted after being merged.
//
// RUN: rm -rf %t
// RUN: mkdir -p %t
// RUN: split-file %s %t
//
// RUN: %clang_cc1 -std=c++20 -triple %itanium_abi_triple %t/A.cppm -emit-module-interface -o %t/A.pcm
// RUN: %clang_cc1 -std=c++20 -triple %itanium_abi_triple %t/B.cppm -emit-module-interface -o %t/B.pcm \
// RUN: -fprebuilt-module-path=%t
// RUN: %clang_cc1 -std=c++20 -triple %itanium_abi_triple %t/B.pcm -S -emit-llvm -o - \
// RUN: -fprebuilt-module-path=%t | FileCheck %t/B.cppm
//--- foo.h
template <class T>
class foo {
public:
T value;
T GetValue() { return value; }
};
template class foo<int>;
//--- A.cppm
module;
#include "foo.h"
export module A;
export using ::foo;
//--- B.cppm
module;
#include "foo.h"
export module B;
import A;
export using ::foo;
export int B() {
foo<int> f;
return f.GetValue();
}
// CHECK-NOT: define{{.*}}@_ZN3fooIiE8GetValueEv