diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2017-05-17 20:22:49 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2017-05-17 20:22:49 +0000 |
commit | 1ce08792766261dcaa25d8215f9d1c2f70d7b7e9 (patch) | |
tree | 4022bfb5dc1b2e6f7fc5c337048e370656cc2260 /test/Modules/submodule-visibility.cpp | |
parent | 2410013d9382b8129702fa3a3bf19a370ae7afc3 (diff) |
Diffstat (limited to 'test/Modules/submodule-visibility.cpp')
-rw-r--r-- | test/Modules/submodule-visibility.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/test/Modules/submodule-visibility.cpp b/test/Modules/submodule-visibility.cpp index 345ae155bb323..4c066e6ab9b09 100644 --- a/test/Modules/submodule-visibility.cpp +++ b/test/Modules/submodule-visibility.cpp @@ -3,6 +3,11 @@ // 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 +// +// Explicit module builds. +// RUN: %clang_cc1 -fmodules -fmodules-local-submodule-visibility -emit-module -x c++-module-map %S/Inputs/submodule-visibility/module.modulemap -fmodule-name=other -o %t/other.pcm +// RUN: %clang_cc1 -fmodules -fmodule-map-file=%S/Inputs/submodule-visibility/module.modulemap -fmodules-local-submodule-visibility -fmodule-file=%t/other.pcm -verify -fmodule-name=x -I%S/Inputs/submodule-visibility %s +// RUN: %clang_cc1 -fmodules -fmodule-map-file=%S/Inputs/submodule-visibility/module.modulemap -fmodule-file=%t/other.pcm -verify -fmodule-name=x -I%S/Inputs/submodule-visibility %s -DALLOW_TEXTUAL_NAME_LEAKAGE #include "a.h" #include "b.h" @@ -11,6 +16,8 @@ // expected-no-diagnostics #elif IMPORT // expected-error@-6 {{could not build module 'x'}} +#elif ALLOW_TEXTUAL_NAME_LEAKAGE +// expected-warning@b.h:7 {{A is defined}} #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. @@ -35,3 +42,5 @@ typedef struct { int p; void (*f)(int p); } name_for_linkage; + +void g() { b_template<int>(); } |