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/b.h | |
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/b.h')
-rw-r--r-- | clang/test/Modules/Inputs/merge-using-decls/b.h | 50 |
1 files changed, 50 insertions, 0 deletions
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; |