diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2014-03-20 21:47:22 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2014-03-20 21:47:22 +0000 |
commit | 564417a071794203dfff574b0aee897fc4643266 (patch) | |
tree | e372f810b434a87770d0d41a85f57b20194b612f /clang/test/PCH/cxx11-exception-spec.cpp | |
parent | 56b26a5707f482a480c124d84f25e427caa0513b (diff) | |
download | bcm5719-llvm-564417a071794203dfff574b0aee897fc4643266.tar.gz bcm5719-llvm-564417a071794203dfff574b0aee897fc4643266.zip |
When the exception specification for a function in an imported PCH or module is
resolved, emit an update record.
llvm-svn: 204403
Diffstat (limited to 'clang/test/PCH/cxx11-exception-spec.cpp')
-rw-r--r-- | clang/test/PCH/cxx11-exception-spec.cpp | 47 |
1 files changed, 38 insertions, 9 deletions
diff --git a/clang/test/PCH/cxx11-exception-spec.cpp b/clang/test/PCH/cxx11-exception-spec.cpp index 446619ed1c9..8c7388a767b 100644 --- a/clang/test/PCH/cxx11-exception-spec.cpp +++ b/clang/test/PCH/cxx11-exception-spec.cpp @@ -1,18 +1,47 @@ -// RUN: %clang_cc1 -pedantic-errors -std=c++11 -emit-pch %s -o %t -// RUN: %clang_cc1 -pedantic-errors -std=c++11 -include-pch %t -verify %s +// RUN: %clang_cc1 -pedantic-errors -std=c++11 -emit-pch %s -o %t.1 +// RUN: %clang_cc1 -pedantic-errors -std=c++11 -include-pch %t.1 -emit-pch %s -o %t.2 +// RUN: %clang_cc1 -pedantic-errors -std=c++11 -include-pch %t.2 -verify %s +// RUN: %clang_cc1 -pedantic-errors -std=c++11 -include-pch %t.2 -emit-llvm-only %s // expected-no-diagnostics -#ifndef HEADER_INCLUDED +#ifndef PHASE1_DONE +#define PHASE1_DONE -#define HEADER_INCLUDED +template<int n> int f() noexcept(n % 2) { return 0; } +template<int n> int g() noexcept(n % 2); -template<bool b> int f() noexcept(b) {} -decltype(f<false>()) a; -decltype(f<true>()) b; +decltype(f<2>()) f0; +decltype(f<3>()) f1; +template int f<4>(); +template int f<5>(); +decltype(f<6>()) f6; +decltype(f<7>()) f7; + +struct A { + A(); + A(const A&); +}; + +decltype(g<0>()) g0; + +#elif !defined(PHASE2_DONE) +#define PHASE2_DONE + +template int f<6>(); +template int f<7>(); +decltype(f<8>()) f8; +decltype(f<9>()) f9; +template int f<10>(); +template int f<11>(); + +A::A() = default; +A::A(const A&) = default; + +int g0val = g<0>(); #else -static_assert(!noexcept(f<false>()), ""); -static_assert(noexcept(f<true>()), ""); +static_assert(!noexcept(f<0>()), ""); +static_assert(noexcept(f<1>()), ""); #endif |