diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2014-10-14 02:00:47 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2014-10-14 02:00:47 +0000 |
commit | 32952e1e42ce69c232b37b26173ef301a2318f38 (patch) | |
tree | 4a227dc92a8f5be29cf2dcd8e5375319e9e7acd7 /clang/test/Modules/Inputs/merge-using-decls | |
parent | 5bbe3df63f4788b42ead0344d431ecd9656d7ced (diff) | |
download | bcm5719-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')
-rw-r--r-- | clang/test/Modules/Inputs/merge-using-decls/a.h | 43 | ||||
-rw-r--r-- | clang/test/Modules/Inputs/merge-using-decls/b.h | 50 | ||||
-rw-r--r-- | clang/test/Modules/Inputs/merge-using-decls/module.modulemap | 2 |
3 files changed, 95 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; diff --git a/clang/test/Modules/Inputs/merge-using-decls/b.h b/clang/test/Modules/Inputs/merge-using-decls/b.h new file mode 100644 index 00000000000..359555570a4 --- /dev/null +++ b/clang/test/Modules/Inputs/merge-using-decls/b.h @@ -0,0 +1,50 @@ +struct X { + int v; + typedef int t; +}; + +struct YB { + typedef YB Y; + int value; + typedef int type; +}; + +struct YBRev { + typedef int value; + 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 { + // Mismatch in type/non-type-ness. + using typename T::value; + using T::type; + using X::v; + using typename X::t; +}; + +template<typename T> struct E : X, T { + // Mismatch in using/access-declaration-ness. + T::value; + X::v; +}; + +template<typename T> struct F : X, T { + // Mismatch in nested-name-specifier. + using T::Y::value; + using typename T::Y::type; + using ::X::v; + using typename ::X::t; +}; + +// Force instantiation. +typedef C<YB>::type I; +typedef D<YBRev>::t I; +typedef E<YB>::type I; +typedef F<YB>::type I; diff --git a/clang/test/Modules/Inputs/merge-using-decls/module.modulemap b/clang/test/Modules/Inputs/merge-using-decls/module.modulemap new file mode 100644 index 00000000000..a415527813c --- /dev/null +++ b/clang/test/Modules/Inputs/merge-using-decls/module.modulemap @@ -0,0 +1,2 @@ +module A { header "a.h" } +module B { header "b.h" } |