diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2016-08-24 21:25:37 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2016-08-24 21:25:37 +0000 |
commit | 4b054b26652e1c614265976c6fcfd3ce3c45ad97 (patch) | |
tree | 86d3e16b287617be6b616c132d3f5229c8a69c15 /clang/test/PCH/cxx1y-default-initializer.cpp | |
parent | eedcd9c1ea4c98b97714bcc7fc4167fd4cb47b37 (diff) | |
download | bcm5719-llvm-4b054b26652e1c614265976c6fcfd3ce3c45ad97.tar.gz bcm5719-llvm-4b054b26652e1c614265976c6fcfd3ce3c45ad97.zip |
PR29097: add an update record when we instantiate the default member
initializer of an imported field.
llvm-svn: 279667
Diffstat (limited to 'clang/test/PCH/cxx1y-default-initializer.cpp')
-rw-r--r-- | clang/test/PCH/cxx1y-default-initializer.cpp | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/clang/test/PCH/cxx1y-default-initializer.cpp b/clang/test/PCH/cxx1y-default-initializer.cpp index 1f8d9a5d08d..c9593a56d2e 100644 --- a/clang/test/PCH/cxx1y-default-initializer.cpp +++ b/clang/test/PCH/cxx1y-default-initializer.cpp @@ -1,10 +1,10 @@ -// RUN: %clang_cc1 -pedantic -std=c++1y %s -o %t -// RUN: %clang_cc1 -pedantic -std=c++1y -emit-pch %s -o %t -// RUN: %clang_cc1 -pedantic -std=c++1y -include-pch %t -verify %s +// RUN: %clang_cc1 -pedantic -std=c++1y -include %s -include %s -verify %s +// RUN: %clang_cc1 -pedantic -std=c++1y -emit-pch -o %t.1 %s +// RUN: %clang_cc1 -pedantic -std=c++1y -include-pch %t.1 -emit-pch -o %t.2 %s +// RUN: %clang_cc1 -pedantic -std=c++1y -include-pch %t.2 -verify %s -#ifndef HEADER_INCLUDED - -#define HEADER_INCLUDED +#ifndef HEADER_1 +#define HEADER_1 struct A { int x; @@ -19,6 +19,20 @@ struct B { constexpr B(int k) : z1(k) {} }; +template<typename T> struct C { + constexpr C() {} + T c = T(); + struct U {}; +}; +// Instantiate C<int> but not the default initializer. +C<int>::U ciu; + +#elif !defined(HEADER_2) +#define HEADER_2 + +// Instantiate the default initializer now, should create an update record. +C<int> ci; + #else static_assert(A{}.z == 3, ""); @@ -27,5 +41,6 @@ static_assert(A{.y = 5}.z == 5, ""); // expected-warning {{C99}} static_assert(A{3, .y = 1}.z == 4, ""); // expected-warning {{C99}} static_assert(make<int>().z == 3, ""); static_assert(make<int>(12).z == 15, ""); +static_assert(C<int>().c == 0, ""); #endif |