From e0691eae7d0d626b27d5a6175995b9d998e1122e Mon Sep 17 00:00:00 2001 From: Sebastian Redl Date: Wed, 7 Mar 2012 16:10:45 +0000 Subject: [PATCH] Be smarter in discovering list-initialization of temporaries. Fixes PR12182. llvm-svn: 152231 --- clang/lib/Sema/SemaInit.cpp | 2 +- clang/test/SemaCXX/cxx0x-initializer-references.cpp | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index 5d2536ae1b6b..f18c344b8b08 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 fb962641de82..d8fdd5a5a07a 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}); + } +}