diff options
author | Aleksei Sidorin <a.sidorin@samsung.com> | 2017-11-21 16:08:41 +0000 |
---|---|---|
committer | Aleksei Sidorin <a.sidorin@samsung.com> | 2017-11-21 16:08:41 +0000 |
commit | 2697f8e4b2c024d387598ce2e38f186ec4caa35e (patch) | |
tree | 3b190ceb887d95d2dcf2fd4ddf861f8cf994288e /clang/test/ASTMerge/namespace/Inputs/namespace2.cpp | |
parent | 2e96469465f8f8282163f9ac77c660ec8696cd78 (diff) | |
download | bcm5719-llvm-2697f8e4b2c024d387598ce2e38f186ec4caa35e.tar.gz bcm5719-llvm-2697f8e4b2c024d387598ce2e38f186ec4caa35e.zip |
[ASTImporter] Support new AST nodes:
* UnresolvedUsingType
* EmptyDecl
* NamespaceAliasDecl
* UsingDecl
* UsingShadowDecl
* UsingDirectiveDecl
* UnresolvedUsingValueDecl
* UnresolvedUsingTypenameDecl
Refactor error handling in ImportTemplateArgumentLoc() method.
Add a test for inline namespaces.
llvm-svn: 318776
Diffstat (limited to 'clang/test/ASTMerge/namespace/Inputs/namespace2.cpp')
-rw-r--r-- | clang/test/ASTMerge/namespace/Inputs/namespace2.cpp | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/clang/test/ASTMerge/namespace/Inputs/namespace2.cpp b/clang/test/ASTMerge/namespace/Inputs/namespace2.cpp index 80429f700b1..f65057d1ca6 100644 --- a/clang/test/ASTMerge/namespace/Inputs/namespace2.cpp +++ b/clang/test/ASTMerge/namespace/Inputs/namespace2.cpp @@ -15,3 +15,46 @@ namespace N2 { namespace N3 { extern double z; } + +namespace Enclosing { +namespace Nested { + const int z = 4; +} +} + +namespace ContainsInline { + inline namespace Inline { + const int z = 10; + } +} + +namespace TestAliasName = Enclosing::Nested; +// NOTE: There is no warning on this alias. +namespace AliasWithSameName = Enclosing::Nested; + +namespace TestUsingDecls { + +namespace A { +void foo(); +} +namespace B { +using A::foo; // <- a UsingDecl creating a UsingShadow +} + +}// end namespace TestUsingDecls + +namespace TestUnresolvedTypenameAndValueDecls { + +template <class T> class Base; +template <class T> class Derived : public Base<T> { +public: + using typename Base<T>::foo; + using Base<T>::bar; + typedef typename Derived::foo NewUnresolvedUsingType; +}; + +} // end namespace TestUnresolvedTypenameAndValueDecls + +namespace TestUsingNamespace { + using namespace Enclosing; +} |