Files
llvm-project/clang/test/Modules/include-between-imports-enums.cppm
Chuanqi Xu c97e08e331 [C++20] [Modules] Add VisiblePromoted module ownership kind (#189903)
This patch adds a new ModuleOwnershipKind::VisiblePromoted to handle
declarations that are not visible to the current TU but are promoted to
be visible to avoid re-parsing.

Originally we set the visible visiblity directly in such cases. But
https://github.com/llvm/llvm-project/issues/188853 shows such decls may
be excluded later if we import #include and then import. So we have to
introduce a new visibility to express the intention that the visibility
of the decl is intentionally promoted.

Close https://github.com/llvm/llvm-project/issues/188853
2026-04-02 10:01:32 +08:00

48 lines
1.2 KiB
C++

// 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/B.cppm -emit-module-interface -o %t/B.pcm
// RUN: %clang_cc1 -std=c++20 %t/use.cpp -fprebuilt-module-path=%t -verify -fsyntax-only
//
// RUN: %clang_cc1 -std=c++20 %t/A.cppm -emit-reduced-module-interface -o %t/A.pcm
// RUN: %clang_cc1 -std=c++20 %t/B.cppm -emit-reduced-module-interface -o %t/B.pcm
// RUN: %clang_cc1 -std=c++20 %t/use.cpp -fprebuilt-module-path=%t -verify -fsyntax-only
// Test that a textual #include sandwiched between two import declarations
// of modules that both include the same header in their GMFs does not lose
// enum declarations. See https://github.com/llvm/llvm-project/issues/188853
//--- enum.h
#ifndef ENUM_H
#define ENUM_H
namespace ns {
enum E { Value1, Value2, Value3 };
}
#endif
//--- A.cppm
module;
#include "enum.h"
export module A;
export auto a = ns::Value1;
//--- B.cppm
module;
#include "enum.h"
export module B;
export auto b = ns::Value2;
//--- use.cpp
// expected-no-diagnostics
import A;
#include "enum.h"
import B;
auto x = ns::Value3;
namespace ns {
auto y = Value1;
}