diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2015-01-28 22:06:01 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2015-01-28 22:06:01 +0000 |
commit | 1ae689c2b8759e4cb5bc9ff334b02c58752f2717 (patch) | |
tree | 27052790b91041b39277fa060bb46918de0e98fd /clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp | |
parent | 80bd3c9e5fb2b5080435a7288267ab18d21a57ac (diff) | |
download | bcm5719-llvm-1ae689c2b8759e4cb5bc9ff334b02c58752f2717.tar.gz bcm5719-llvm-1ae689c2b8759e4cb5bc9ff334b02c58752f2717.zip |
PR22367: Don't forget to create a CXXFunctionalCastExpr around
list-initialization that gets converted to some form other than an
InitListExpr. CXXTemporaryObjectExpr is a special case here, because it
represents a fused CXXFunctionalCastExpr + CXXConstructExpr. That, in
itself, is probably a design error...
llvm-svn: 227377
Diffstat (limited to 'clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp')
-rw-r--r-- | clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp b/clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp index 70f7c642a54..e7b515305d4 100644 --- a/clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp +++ b/clang/test/SemaCXX/cxx0x-initializer-stdinitializerlist.cpp @@ -259,3 +259,18 @@ namespace ListInitInstantiate { template<typename T> void g() { int k = f({0}); } template void g<int>(); } + +namespace TemporaryInitListSourceRange_PR22367 { + struct A { + constexpr A() {} + A(std::initializer_list<int>); // expected-note {{here}} + }; + constexpr int f(A) { return 0; } + constexpr int k = f( // expected-error {{must be initialized by a constant expression}} + // The point of this test is to check that the caret points to + // 'std::initializer_list', not to '{0}'. + std::initializer_list // expected-note {{constructor}} + <int> + {0} + ); +} |