xref: /aosp_15_r20/external/clang/test/Modules/submodules-merge-defs.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: rm -rf %t
2*67e74705SXin Li // RUN: %clang_cc1 -x c++ -std=c++11 -fmodules-cache-path=%t -fmodules -fimplicit-module-maps -I %S/Inputs/submodules-merge-defs %s -verify -fno-modules-error-recovery -DTEXTUAL
3*67e74705SXin Li // RUN: %clang_cc1 -x c++ -std=c++11 -fmodules-cache-path=%t -fmodules -fimplicit-module-maps -I %S/Inputs/submodules-merge-defs %s -verify -fno-modules-error-recovery
4*67e74705SXin Li // RUN: %clang_cc1 -x c++ -std=c++11 -fmodules-cache-path=%t -fmodules -fimplicit-module-maps -I %S/Inputs/submodules-merge-defs %s -verify -fno-modules-error-recovery -fmodules-local-submodule-visibility -DTEXTUAL
5*67e74705SXin Li // RUN: %clang_cc1 -x c++ -std=c++11 -fmodules-cache-path=%t -fmodules -fimplicit-module-maps -I %S/Inputs/submodules-merge-defs %s -verify -fno-modules-error-recovery -fmodules-local-submodule-visibility
6*67e74705SXin Li // RUN: %clang_cc1 -x c++ -std=c++11 -fmodules-cache-path=%t -fimplicit-module-maps -I %S/Inputs/submodules-merge-defs %s -verify -fno-modules-error-recovery -fmodules-local-submodule-visibility -DTEXTUAL -DEARLY_INDIRECT_INCLUDE
7*67e74705SXin Li // RUN: %clang_cc1 -x c++ -std=c++11 -fmodules-cache-path=%t -fmodules -fimplicit-module-maps -I %S/Inputs/submodules-merge-defs %s -verify -fno-modules-error-recovery -fmodules-local-submodule-visibility -fmodule-feature use_defs_twice -DIMPORT_USE_2
8*67e74705SXin Li 
9*67e74705SXin Li // Trigger import of definitions, but don't make them visible.
10*67e74705SXin Li #include "empty.h"
11*67e74705SXin Li #ifdef EARLY_INDIRECT_INCLUDE
12*67e74705SXin Li #include "indirect.h"
13*67e74705SXin Li #endif
14*67e74705SXin Li 
15*67e74705SXin Li A pre_a;
16*67e74705SXin Li #ifdef IMPORT_USE_2
17*67e74705SXin Li // expected-error-re@-2 {{must be imported from one of {{.*}}stuff.use{{.*}}stuff.use-2}}
18*67e74705SXin Li #elif EARLY_INDIRECT_INCLUDE
19*67e74705SXin Li // expected-error@-4 {{must be imported from module 'merged-defs'}}
20*67e74705SXin Li #else
21*67e74705SXin Li // expected-error@-6 {{must be imported from module 'stuff.use'}}
22*67e74705SXin Li #endif
23*67e74705SXin Li // [email protected]:1 +{{here}}
24*67e74705SXin Li extern class A pre_a2;
25*67e74705SXin Li int pre_use_a = use_a(pre_a2); // expected-error 2{{'A' must be imported}} expected-error {{'use_a' must be imported}}
26*67e74705SXin Li // [email protected]:2 +{{here}}
27*67e74705SXin Li 
28*67e74705SXin Li B::Inner2 pre_bi; // expected-error +{{must be imported}}
29*67e74705SXin Li // [email protected]:4 +{{here}}
30*67e74705SXin Li // [email protected]:17 +{{here}}
pre_bfi(B b)31*67e74705SXin Li void pre_bfi(B b) { // expected-error +{{must be imported}}
32*67e74705SXin Li   b.f<int>(); // expected-error +{{}}
33*67e74705SXin Li }
34*67e74705SXin Li 
35*67e74705SXin Li C_Base<1> pre_cb1; // expected-error +{{must be imported}}
36*67e74705SXin Li // [email protected]:23 +{{here}}
37*67e74705SXin Li C1 pre_c1; // expected-error +{{must be imported}}
38*67e74705SXin Li // [email protected]:25 +{{here}}
39*67e74705SXin Li C2 pre_c2; // expected-error +{{must be imported}}
40*67e74705SXin Li // [email protected]:26 +{{here}}
41*67e74705SXin Li 
42*67e74705SXin Li D::X pre_dx; // expected-error +{{must be imported}}
43*67e74705SXin Li // [email protected]:28 +{{here}}
44*67e74705SXin Li // [email protected]:29 +{{here}}
45*67e74705SXin Li int pre_use_dx = use_dx(pre_dx); // ignored; pre_dx is invalid
46*67e74705SXin Li 
47*67e74705SXin Li int pre_e = E(0); // expected-error {{must be imported}}
48*67e74705SXin Li // [email protected]:32 +{{here}}
49*67e74705SXin Li 
50*67e74705SXin Li int pre_ff = F<int>().f(); // expected-error +{{must be imported}}
51*67e74705SXin Li int pre_fg = F<int>().g<int>(); // expected-error +{{must be imported}} expected-error 2{{expected}}
52*67e74705SXin Li // [email protected]:34 +{{here}}
53*67e74705SXin Li 
54*67e74705SXin Li G::A pre_ga // expected-error +{{must be imported}}
55*67e74705SXin Li   = G::a; // expected-error +{{must be imported}}
56*67e74705SXin Li // [email protected]:49 +{{here}}
57*67e74705SXin Li // [email protected]:50 +{{here}}
58*67e74705SXin Li decltype(G::h) pre_gh = G::h; // expected-error +{{must be imported}}
59*67e74705SXin Li // [email protected]:51 +{{here}}
60*67e74705SXin Li 
61*67e74705SXin Li J<> pre_j; // expected-error {{declaration of 'J' must be imported}}
62*67e74705SXin Li #ifdef IMPORT_USE_2
63*67e74705SXin Li // expected-error-re@-2 {{default argument of 'J' must be imported from one of {{.*}}stuff.use{{.*}}stuff.use-2}}
64*67e74705SXin Li #elif EARLY_INDIRECT_INCLUDE
65*67e74705SXin Li // expected-error@-4 {{default argument of 'J' must be imported from module 'merged-defs'}}
66*67e74705SXin Li #else
67*67e74705SXin Li // expected-error@-6 {{default argument of 'J' must be imported from module 'stuff.use'}}
68*67e74705SXin Li #endif
69*67e74705SXin Li // [email protected]:58 +{{here}}
70*67e74705SXin Li 
71*67e74705SXin Li ScopedEnum pre_scopedenum; // expected-error {{must be imported}}
72*67e74705SXin Li // [email protected]:105 0-1{{here}}
73*67e74705SXin Li // [email protected]:106 0-1{{here}}
74*67e74705SXin Li enum ScopedEnum : int;
75*67e74705SXin Li ScopedEnum pre_scopedenum_declared; // ok
76*67e74705SXin Li 
77*67e74705SXin Li // Make definitions from second module visible.
78*67e74705SXin Li #ifdef TEXTUAL
79*67e74705SXin Li #include "import-and-redefine.h"
80*67e74705SXin Li #elif defined IMPORT_USE_2
81*67e74705SXin Li #include "use-defs-2.h"
82*67e74705SXin Li #else
83*67e74705SXin Li #include "merged-defs.h"
84*67e74705SXin Li #endif
85*67e74705SXin Li 
86*67e74705SXin Li A post_a;
87*67e74705SXin Li int post_use_a = use_a(post_a);
88*67e74705SXin Li B::Inner2 post_bi;
post_bfi(B b)89*67e74705SXin Li void post_bfi(B b) {
90*67e74705SXin Li   b.f<int>();
91*67e74705SXin Li }
92*67e74705SXin Li C_Base<1> post_cb1;
93*67e74705SXin Li C1 c1;
94*67e74705SXin Li C2 c2;
95*67e74705SXin Li D::X post_dx;
96*67e74705SXin Li int post_use_dx = use_dx(post_dx);
97*67e74705SXin Li int post_e = E(0);
98*67e74705SXin Li int post_ff = F<char>().f();
99*67e74705SXin Li int post_fg = F<char>().g<int>();
100*67e74705SXin Li G::A post_ga = G::a;
101*67e74705SXin Li decltype(G::h) post_gh = G::h;
102*67e74705SXin Li J<> post_j;
103*67e74705SXin Li template<typename T, int N, template<typename> class K> struct J;
104*67e74705SXin Li J<> post_j2;
105*67e74705SXin Li FriendDefArg::Y<int> friend_def_arg;
106*67e74705SXin Li FriendDefArg::D<> friend_def_arg_d;
107*67e74705SXin Li int post_anon_x_n = Anon::X().n;
108*67e74705SXin Li 
109*67e74705SXin Li MergeFunctionTemplateSpecializations::X<int>::Q<char> xiqc;
110*67e74705SXin Li 
111*67e74705SXin Li #ifdef TEXTUAL
112*67e74705SXin Li #include "use-defs.h"
use_static_inline()113*67e74705SXin Li void use_static_inline() { StaticInline::g({}); }
114*67e74705SXin Li #ifdef EARLY_INDIRECT_INCLUDE
115*67e74705SXin Li // expected-warning@-2 {{ambiguous use of internal linkage declaration 'g' defined in multiple modules}}
116*67e74705SXin Li // [email protected]:71 {{declared here in module 'redef'}}
117*67e74705SXin Li // [email protected]:71 {{declared here in module 'stuff.use'}}
118*67e74705SXin Li #endif
119*67e74705SXin Li int use_anon_enum = G::g;
120*67e74705SXin Li #ifdef EARLY_INDIRECT_INCLUDE
121*67e74705SXin Li // expected-warning@-2 3{{ambiguous use of internal linkage declaration 'g' defined in multiple modules}}
122*67e74705SXin Li // FIXME: These notes are produced, but -verify can't match them?
123*67e74705SXin Li // [email protected]:51 3{{declared here in module 'redef'}}
124*67e74705SXin Li // [email protected]:51 3{{declared here in module 'stuff.use'}}
125*67e74705SXin Li #endif
126*67e74705SXin Li int use_named_enum = G::i;
127*67e74705SXin Li #endif
128