Files
clang-p2996/clang/test/Modules/no-import-func-body.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

47 lines
1.2 KiB
C++

// RUN: rm -rf %t
// RUN: split-file %s %t
// RUN: cd %t
//
// RUN: %clang_cc1 -std=c++20 -O1 -triple %itanium_abi_triple %t/a.cppm \
// RUN: -emit-module-interface -o %t/a.pcm
// RUN: %clang_cc1 -std=c++20 -O1 -triple %itanium_abi_triple %t/b.cppm \
// RUN: -emit-module-interface -fprebuilt-module-path=%t -o %t/b.pcm
// RUN: %clang_cc1 -std=c++20 -O1 -triple %itanium_abi_triple %t/c.cppm \
// RUN: -emit-module-interface -fprebuilt-module-path=%t -o %t/c.pcm
// RUN: %clang_cc1 -std=c++20 -O1 -triple %itanium_abi_triple %t/c.pcm -S \
// RUN: -fprebuilt-module-path=%t -emit-llvm -disable-llvm-passes -o - \
// RUN: | FileCheck %t/c.cppm
//--- a.cppm
export module a;
export int a() {
return 43;
}
export __attribute__((noinline)) int a_noinline() {
return 44;
}
//--- b.cppm
export module b;
export import a;
export int b() {
return 43 + a();
}
export __attribute__((noinline)) int b_noinline() {
return 43 + a();
}
//--- c.cppm
export module c;
export import b;
export int c() {
return 43 + b() + a() + b_noinline() + a_noinline();
}
// CHECK: declare{{.*}}@_ZW1b1bv(
// CHECK: declare{{.*}}@_ZW1a1av(
// CHECK: declare{{.*}}@_ZW1b10b_noinlinev()
// CHECK: declare{{.*}}@_ZW1a10a_noinlinev()