diff options
author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2012-03-07 16:10:45 +0000 |
---|---|---|
committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2012-03-07 16:10:45 +0000 |
commit | e0691eae7d0d626b27d5a6175995b9d998e1122e (patch) | |
tree | 23219393c640eb0d99eaddbf2cfe6777c6cf9f1d | |
parent | 5c0e7190ff5c47f28ad26e011224783fe1204dcd (diff) | |
download | bcm5719-llvm-e0691eae7d0d626b27d5a6175995b9d998e1122e.tar.gz bcm5719-llvm-e0691eae7d0d626b27d5a6175995b9d998e1122e.zip |
Be smarter in discovering list-initialization of temporaries. Fixes PR12182.
llvm-svn: 152231
-rw-r--r-- | clang/lib/Sema/SemaInit.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/cxx0x-initializer-references.cpp | 8 |
2 files changed, 9 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index 5d2536ae1b6..f18c344b8b0 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -5110,7 +5110,7 @@ InitializationSequence::Perform(Sema &S, // unwrap references here and rewrap them afterwards. // We also need to create a InitializeTemporary entity for this. QualType Ty = ResultType ? ResultType->getNonReferenceType() : Step->Type; - bool IsTemporary = ResultType && (*ResultType)->isReferenceType(); + bool IsTemporary = Entity.getType()->isReferenceType(); InitializedEntity TempEntity = InitializedEntity::InitializeTemporary(Ty); InitListChecker PerformInitList(S, IsTemporary ? TempEntity : Entity, InitList, Ty, /*VerifyOnly=*/false, diff --git a/clang/test/SemaCXX/cxx0x-initializer-references.cpp b/clang/test/SemaCXX/cxx0x-initializer-references.cpp index fb962641de8..d8fdd5a5a07 100644 --- a/clang/test/SemaCXX/cxx0x-initializer-references.cpp +++ b/clang/test/SemaCXX/cxx0x-initializer-references.cpp @@ -77,3 +77,11 @@ namespace reference { } } + +namespace PR12182 { + void f(int const(&)[3]); + + void g() { + f({1, 2}); + } +} |