summaryrefslogtreecommitdiffstats
path: root/clang/test/Modules/Inputs/merge-using-decls/a.h
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2014-10-14 02:00:47 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2014-10-14 02:00:47 +0000
commit32952e1e42ce69c232b37b26173ef301a2318f38 (patch)
tree4a227dc92a8f5be29cf2dcd8e5375319e9e7acd7 /clang/test/Modules/Inputs/merge-using-decls/a.h
parent5bbe3df63f4788b42ead0344d431ecd9656d7ced (diff)
downloadbcm5719-llvm-32952e1e42ce69c232b37b26173ef301a2318f38.tar.gz
bcm5719-llvm-32952e1e42ce69c232b37b26173ef301a2318f38.zip
[modules] Merging for class-scope using-declarations.
llvm-svn: 219657
Diffstat (limited to 'clang/test/Modules/Inputs/merge-using-decls/a.h')
-rw-r--r--clang/test/Modules/Inputs/merge-using-decls/a.h43
1 files changed, 43 insertions, 0 deletions
diff --git a/clang/test/Modules/Inputs/merge-using-decls/a.h b/clang/test/Modules/Inputs/merge-using-decls/a.h
new file mode 100644
index 00000000000..0fe0067bf23
--- /dev/null
+++ b/clang/test/Modules/Inputs/merge-using-decls/a.h
@@ -0,0 +1,43 @@
+struct X {
+ int v;
+ typedef int t;
+};
+
+struct YA {
+ int value;
+ typedef int type;
+};
+
+template<typename T> struct C : X, T {
+ using T::value;
+ using typename T::type;
+ using X::v;
+ using typename X::t;
+};
+
+template<typename T> struct D : X, T {
+ using T::value;
+ using typename T::type;
+ using X::v;
+ using typename X::t;
+};
+
+template<typename T> struct E : X, T {
+ using T::value;
+ using typename T::type;
+ using X::v;
+ using typename X::t;
+};
+
+template<typename T> struct F : X, T {
+ using T::value;
+ using typename T::type;
+ using X::v;
+ using typename X::t;
+};
+
+// Force instantiation.
+typedef C<YA>::type I;
+typedef D<YA>::type I;
+typedef E<YA>::type I;
+typedef F<YA>::type I;
OpenPOWER on IntegriCloud