Chuanqi Xu 47615ff234
[C++20] [Modules] Don't insert class not in named modules to PendingEmittingVTables (#106501)
Close https://github.com/llvm/llvm-project/issues/102933

The root cause of the issue is an oversight in
https://github.com/llvm/llvm-project/pull/102287 that I didn't notice
that PendingEmittingVTables should only accept classes in named modules.
2024-08-29 15:42:57 +08:00

42 lines
812 B
C++

// RUN: rm -rf %t
// RUN: mkdir -p %t
// RUN: split-file %s %t
//
// RUN: %clang_cc1 -std=c++23 %t/a.cppm -emit-module-interface -o %t/a.pcm
// RUN: %clang_cc1 -std=c++23 %t/b.cppm -emit-module-interface -o %t/b.pcm \
// RUN: -fprebuilt-module-path=%t
// RUN: %clang_cc1 -std=c++23 -fprebuilt-module-path=%t %t/b.pcm -emit-llvm \
// RUN: -disable-llvm-passes -o - | FileCheck %t/b.cppm
//--- a.cppm
module;
struct base {
virtual void f() const;
};
inline void base::f() const {
}
export module a;
export using ::base;
//--- b.cppm
module;
struct base {
virtual void f() const;
};
inline void base::f() const {
}
export module b;
import a;
export using ::base;
export extern "C" void func() {}
// We only need to check that the IR are successfully emitted instead of crash.
// CHECK: func