diff options
| author | Anders Carlsson <andersca@mac.com> | 2010-01-29 02:47:33 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2010-01-29 02:47:33 +0000 |
| commit | a91be641a7268f84f5b096fa84f3d33282295630 (patch) | |
| tree | 59ce4808d6f14d39eb986944734f4bad9dddc720 | |
| parent | 94af575e9c457856524994418ce295cd6259c2b1 (diff) | |
| download | bcm5719-llvm-a91be641a7268f84f5b096fa84f3d33282295630.tar.gz bcm5719-llvm-a91be641a7268f84f5b096fa84f3d33282295630.zip | |
Simplify InitListChecker::CheckReferenceType
llvm-svn: 94793
| -rw-r--r-- | clang/lib/Sema/SemaInit.cpp | 21 |
1 files changed, 10 insertions, 11 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index bc7210c568a..a70582dd53a 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -785,17 +785,16 @@ void InitListChecker::CheckReferenceType(const InitializedEntity &Entity, return; } - Expr *savExpr = expr; // Might be promoted by CheckSingleInitializer. - if (SemaRef.CheckReferenceInit(expr, DeclType, - /*FIXME:*/expr->getLocStart(), - /*SuppressUserConversions=*/false, - /*AllowExplicit=*/false, - /*ForceRValue=*/false)) + Sema::OwningExprResult Result = + SemaRef.PerformCopyInitialization(Entity, expr->getLocStart(), + SemaRef.Owned(expr)); + + if (Result.isInvalid()) hadError = true; - else if (savExpr != expr) { - // The type was promoted, update initializer list. - IList->setInit(Index, expr); - } + + expr = Result.takeAs<Expr>(); + IList->setInit(Index, expr); + if (hadError) ++StructuredIndex; else @@ -3270,7 +3269,7 @@ InitializationSequence::Perform(Sema &S, S.Diag(BitField->getLocation(), diag::note_bitfield_decl); return S.ExprError(); } - + // Reference binding does not have any corresponding ASTs. // Check exception specifications |

