| // RUN: rm -rf %t |
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -I%S/Inputs/submodule-visibility -verify %s -DALLOW_NAME_LEAKAGE |
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-local-submodule-visibility -fmodules-cache-path=%t -I%S/Inputs/submodule-visibility -verify %s -DIMPORT |
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-local-submodule-visibility -fmodules-cache-path=%t -fmodule-name=x -I%S/Inputs/submodule-visibility -verify %s |
| // RUN: %clang_cc1 -fimplicit-module-maps -fmodules-local-submodule-visibility -fmodules-cache-path=%t -I%S/Inputs/submodule-visibility -verify %s |
| |
| #include "a.h" |
| #include "b.h" |
| |
| #if ALLOW_NAME_LEAKAGE |
| // expected-no-diagnostics |
| #elif IMPORT |
| // expected-error@-6 {{could not build module 'x'}} |
| #else |
| // The use of -fmodule-name=x causes us to textually include the above headers. |
| // The submodule visibility rules are still applied in this case. |
| // |
| // expected-error@b.h:1 {{declaration of 'n' must be imported from module 'x.a'}} |
| // expected-note@a.h:1 {{here}} |
| #endif |
| |
| int k = n + m; // OK, a and b are visible here. |
| |
| #ifndef A |
| #error A is not defined |
| #endif |
| |
| #ifndef B |
| #error B is not defined |
| #endif |
| |
| // Ensure we don't compute the linkage of this struct before we find it has a |
| // typedef name for linkage purposes. |
| typedef struct { |
| int p; |
| void (*f)(int p); |
| } name_for_linkage; |