summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2015-06-25 21:42:33 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2015-06-25 21:42:33 +0000
commit1e02a5aac82a41db5092998349f2fc4de459da19 (patch)
treeede4840ab374ce2ca5c8d7c76ea60f520dade7cb /clang/test
parente4aedb55d696ef9f02b1d511ca48c66a4c48f9d5 (diff)
downloadbcm5719-llvm-1e02a5aac82a41db5092998349f2fc4de459da19.tar.gz
bcm5719-llvm-1e02a5aac82a41db5092998349f2fc4de459da19.zip
[modules] Properly merge visibility of class definitions that got merged while
parsing then merged again when the module was loaded. llvm-svn: 240700
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/Modules/Inputs/merge-class-definition-visibility/b.h2
-rw-r--r--clang/test/Modules/Inputs/merge-class-definition-visibility/d.h2
-rw-r--r--clang/test/Modules/Inputs/merge-class-definition-visibility/e.h3
-rw-r--r--clang/test/Modules/Inputs/merge-class-definition-visibility/modmap3
-rw-r--r--clang/test/Modules/merge-class-definition-visibility.cpp14
5 files changed, 19 insertions, 5 deletions
diff --git a/clang/test/Modules/Inputs/merge-class-definition-visibility/b.h b/clang/test/Modules/Inputs/merge-class-definition-visibility/b.h
index 2b8f5f868ed..03c0ad98dfd 100644
--- a/clang/test/Modules/Inputs/merge-class-definition-visibility/b.h
+++ b/clang/test/Modules/Inputs/merge-class-definition-visibility/b.h
@@ -1,2 +1,4 @@
// Include definition of A into the same module as c.h
#include "a.h"
+
+struct B {};
diff --git a/clang/test/Modules/Inputs/merge-class-definition-visibility/d.h b/clang/test/Modules/Inputs/merge-class-definition-visibility/d.h
index 2243de1baf9..c51edab1416 100644
--- a/clang/test/Modules/Inputs/merge-class-definition-visibility/d.h
+++ b/clang/test/Modules/Inputs/merge-class-definition-visibility/d.h
@@ -1 +1 @@
-#include "a.h"
+struct B {};
diff --git a/clang/test/Modules/Inputs/merge-class-definition-visibility/e.h b/clang/test/Modules/Inputs/merge-class-definition-visibility/e.h
new file mode 100644
index 00000000000..f126b504b9b
--- /dev/null
+++ b/clang/test/Modules/Inputs/merge-class-definition-visibility/e.h
@@ -0,0 +1,3 @@
+#include "a.h"
+
+struct B {};
diff --git a/clang/test/Modules/Inputs/merge-class-definition-visibility/modmap b/clang/test/Modules/Inputs/merge-class-definition-visibility/modmap
index 7d988fbba00..dcb65871886 100644
--- a/clang/test/Modules/Inputs/merge-class-definition-visibility/modmap
+++ b/clang/test/Modules/Inputs/merge-class-definition-visibility/modmap
@@ -3,5 +3,6 @@ module Def1 {
module C { header "c.h" }
}
module Def2 {
- header "d.h"
+ module D { header "d.h" }
+ module E { header "e.h" }
}
diff --git a/clang/test/Modules/merge-class-definition-visibility.cpp b/clang/test/Modules/merge-class-definition-visibility.cpp
index e8602c0d548..ac4c9515844 100644
--- a/clang/test/Modules/merge-class-definition-visibility.cpp
+++ b/clang/test/Modules/merge-class-definition-visibility.cpp
@@ -1,15 +1,23 @@
// RUN: rm -rf %t
// RUN: %clang_cc1 -fmodules -fmodule-map-file=%S/Inputs/merge-class-definition-visibility/modmap \
// RUN: -I%S/Inputs/merge-class-definition-visibility \
-// RUN: -fmodules-cache-path=%t %s -verify
+// RUN: -fmodules-cache-path=%t %s -verify \
+// RUN: -fmodules-local-submodule-visibility
// expected-no-diagnostics
#include "c.h"
template<typename T> struct X { T t; };
typedef X<A> XA;
+struct B;
-#include "d.h"
-// Ensure that this triggers the import of the second definition from d.h,
+#include "e.h"
+// Ensure that this triggers the import of the second definition from e.h,
// which is necessary to make the definition of A visible in the template
// instantiation.
XA xa;
+
+// Ensure that we make the definition of B visible. We made the parse-merged
+// definition from e.h visible, which makes the definition from d.h visible,
+// and that definition was merged into the canonical definition from b.h,
+// so that becomes visible, and we have a visible definition.
+B b;
OpenPOWER on IntegriCloud