summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Redl <sebastian.redl@getdesigned.at>2012-03-07 16:10:45 +0000
committerSebastian Redl <sebastian.redl@getdesigned.at>2012-03-07 16:10:45 +0000
commite0691eae7d0d626b27d5a6175995b9d998e1122e (patch)
tree23219393c640eb0d99eaddbf2cfe6777c6cf9f1d
parent5c0e7190ff5c47f28ad26e011224783fe1204dcd (diff)
downloadbcm5719-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.cpp2
-rw-r--r--clang/test/SemaCXX/cxx0x-initializer-references.cpp8
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});
+ }
+}
OpenPOWER on IntegriCloud