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/test.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/test.cpp')
-rw-r--r-- | clang/test/ASTMerge/namespace/test.cpp | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/clang/test/ASTMerge/namespace/test.cpp b/clang/test/ASTMerge/namespace/test.cpp index 8cc0fa2a6d9..f1796c03b07 100644 --- a/clang/test/ASTMerge/namespace/test.cpp +++ b/clang/test/ASTMerge/namespace/test.cpp @@ -1,6 +1,17 @@ -// RUN: %clang_cc1 -emit-pch -o %t.1.ast %S/Inputs/namespace1.cpp -// RUN: %clang_cc1 -emit-pch -o %t.2.ast %S/Inputs/namespace2.cpp -// RUN: not %clang_cc1 -ast-merge %t.1.ast -ast-merge %t.2.ast -fsyntax-only %s 2>&1 | FileCheck %s +// RUN: %clang_cc1 -emit-pch -std=c++1z -o %t.1.ast %S/Inputs/namespace1.cpp +// RUN: %clang_cc1 -emit-pch -std=c++1z -o %t.2.ast %S/Inputs/namespace2.cpp +// RUN: not %clang_cc1 -std=c++1z -ast-merge %t.1.ast -ast-merge %t.2.ast -fsyntax-only %s 2>&1 | FileCheck %s + +static_assert(TestAliasName::z == 4); +static_assert(ContainsInline::z == 10); + +void testImport() { + typedef TestUnresolvedTypenameAndValueDecls::Derived<int> Imported; + Imported a; // Successfull instantiation + static_assert(sizeof(Imported::foo) == sizeof(int)); + static_assert(sizeof(TestUnresolvedTypenameAndValueDecls::Derived<double>::NewUnresolvedUsingType) == sizeof(double)); +} + // CHECK: namespace2.cpp:16:17: error: external variable 'z' declared with incompatible types in different translation units ('double' vs. 'float') // CHECK: namespace1.cpp:16:16: note: declared here with type 'float' |