================ @@ -0,0 +1,50 @@ +// REQUIRES: !system-windows + +// RUN: rm -rf %t +// RUN: split-file %s %t +// RUN: cd %t +// +// RUN: %clang_cc1 -std=c++20 %t/layer1.cppm -triple %itanium_abi_triple \ +// RUN: -emit-module-interface -o %t/foo-layer1.pcm +// RUN: %clang_cc1 -std=c++20 %t/layer2.cppm -triple %itanium_abi_triple \ +// RUN: -emit-module-interface -fmodule-file=foo:layer1=%t/foo-layer1.pcm \ +// RUN: -o %t/foo-layer2.pcm +// RUN: %clang_cc1 -std=c++20 %t/foo-layer1.pcm -S -emit-llvm -o - | FileCheck %t/layer1.cppm +// RUN: %clang_cc1 -std=c++20 %t/foo-layer2.pcm -S -emit-llvm -o - \ +// RUN: -fmodule-file=foo:layer1=%t/foo-layer1.pcm | FileCheck %t/layer2.cppm + +//--- layer1.cppm +export module foo:layer1; +struct Fruit { + virtual ~Fruit() = default; + virtual void eval() = 0; +}; +struct Banana : public Fruit { + Banana() {} + void eval() override; +}; + +// CHECK-DAG: @_ZTVW3foo6Banana = unnamed_addr constant +// CHECK-DAG: @_ZTSW3foo6Banana = constant +// CHECK-DAG: @_ZTIW3foo6Banana = constant +// +// CHECK-DAG: @_ZTVW3foo5Fruit = unnamed_addr constant +// CHECK-DAG: @_ZTSW3foo5Fruit = constant +// CHECK-DAG: @_ZTIW3foo5Fruit = constant + +//--- layer2.cppm +export module foo:layer2; +import :layer1; +export void layer2_fun() { + Banana *b = new Banana(); + b->eval(); +} +void Banana::eval() { +} + ---------------- ChuanqiXu9 wrote:
We're testing: (1) The use of virtual functions won't produce the vtable. (2) The definition of key functions won't produce the vtable. I'll try to add a comment here. https://github.com/llvm/llvm-project/pull/75912 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits