diff options
author | Anders Carlsson <andersca@mac.com> | 2009-05-17 18:26:53 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-05-17 18:26:53 +0000 |
commit | 5262746c280993c80525afdbcd93d5a10dfccd6a (patch) | |
tree | 6639e609c17a5818c7c00b784da9c03189ea97d3 /clang/lib | |
parent | 23ca0b4869ca5f054f67f59333bcb15638514eed (diff) | |
download | bcm5719-llvm-5262746c280993c80525afdbcd93d5a10dfccd6a.tar.gz bcm5719-llvm-5262746c280993c80525afdbcd93d5a10dfccd6a.zip |
Add the FullExprArg wrapper and use it for if statement conditions.
llvm-svn: 71982
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Parse/ParseStmt.cpp | 2 | ||||
-rw-r--r-- | clang/lib/Sema/Sema.h | 6 | ||||
-rw-r--r-- | clang/lib/Sema/SemaStmt.cpp | 10 | ||||
-rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateStmt.cpp | 6 |
4 files changed, 15 insertions, 9 deletions
diff --git a/clang/lib/Parse/ParseStmt.cpp b/clang/lib/Parse/ParseStmt.cpp index 50db966aedb..16b7a9f07f2 100644 --- a/clang/lib/Parse/ParseStmt.cpp +++ b/clang/lib/Parse/ParseStmt.cpp @@ -632,7 +632,7 @@ Parser::OwningStmtResult Parser::ParseIfStatement() { if (ElseStmt.isInvalid()) ElseStmt = Actions.ActOnNullStmt(ElseStmtLoc); - return Actions.ActOnIfStmt(IfLoc, move(CondExp), move(ThenStmt), + return Actions.ActOnIfStmt(IfLoc, Actions.FullExpr(CondExp), move(ThenStmt), ElseLoc, move(ElseStmt)); } diff --git a/clang/lib/Sema/Sema.h b/clang/lib/Sema/Sema.h index 9a12dfd9713..c4890499a6d 100644 --- a/clang/lib/Sema/Sema.h +++ b/clang/lib/Sema/Sema.h @@ -1172,9 +1172,9 @@ public: IdentifierInfo *II, SourceLocation ColonLoc, StmtArg SubStmt); - virtual OwningStmtResult ActOnIfStmt(SourceLocation IfLoc, ExprArg CondVal, - StmtArg ThenVal, SourceLocation ElseLoc, - StmtArg ElseVal); + virtual OwningStmtResult ActOnIfStmt(SourceLocation IfLoc, + FullExprArg CondVal, StmtArg ThenVal, + SourceLocation ElseLoc, StmtArg ElseVal); virtual OwningStmtResult ActOnStartOfSwitchStmt(ExprArg Cond); virtual OwningStmtResult ActOnFinishSwitchStmt(SourceLocation SwitchLoc, StmtArg Switch, StmtArg Body); diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp index d59443b2cbc..5c04c2491f6 100644 --- a/clang/lib/Sema/SemaStmt.cpp +++ b/clang/lib/Sema/SemaStmt.cpp @@ -180,17 +180,19 @@ Sema::ActOnLabelStmt(SourceLocation IdentLoc, IdentifierInfo *II, } Action::OwningStmtResult -Sema::ActOnIfStmt(SourceLocation IfLoc, ExprArg CondVal, +Sema::ActOnIfStmt(SourceLocation IfLoc, FullExprArg CondVal, StmtArg ThenVal, SourceLocation ElseLoc, StmtArg ElseVal) { - Expr *condExpr = CondVal.takeAs<Expr>(); + OwningExprResult CondResult(CondVal.release()); + + Expr *condExpr = CondResult.takeAs<Expr>(); assert(condExpr && "ActOnIfStmt(): missing expression"); if (!condExpr->isTypeDependent()) { DefaultFunctionArrayConversion(condExpr); // Take ownership again until we're past the error checking. - CondVal = condExpr; + CondResult = condExpr; QualType condType = condExpr->getType(); if (getLangOptions().CPlusPlus) { @@ -213,7 +215,7 @@ Sema::ActOnIfStmt(SourceLocation IfLoc, ExprArg CondVal, Diag(stmt->getSemiLoc(), diag::warn_empty_if_body); } - CondVal.release(); + CondResult.release(); return Owned(new (Context) IfStmt(IfLoc, condExpr, thenStmt, ElseLoc, ElseVal.takeAs<Stmt>())); } diff --git a/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp b/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp index 716bea7f7ea..ce5ebb58dc7 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp @@ -25,6 +25,10 @@ namespace { Sema &SemaRef; const TemplateArgumentList &TemplateArgs; + Sema::FullExprArg FullExpr(Sema::ExprArg &expr) { + return SemaRef.FullExpr(expr); + } + public: typedef Sema::OwningExprResult OwningExprResult; typedef Sema::OwningStmtResult OwningStmtResult; @@ -225,7 +229,7 @@ Sema::OwningStmtResult TemplateStmtInstantiator::VisitIfStmt(IfStmt *S) { if (Else.isInvalid()) return SemaRef.StmtError(); - return SemaRef.ActOnIfStmt(S->getIfLoc(), move(Cond), move(Then), + return SemaRef.ActOnIfStmt(S->getIfLoc(), FullExpr(Cond), move(Then), S->getElseLoc(), move(Else)); } |