diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-05-15 21:56:04 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-05-15 21:56:04 +0000 |
commit | 3daa82dba01b3964f31c15c8af231e5bcccb4523 (patch) | |
tree | 9415c39ff142fd0cfa40f1c242fd69980b8583fd /clang/lib/Sema/SemaTemplateInstantiateStmt.cpp | |
parent | 19573e7d29eda4e4c20d1df1bdc5df53ae8136db (diff) | |
download | bcm5719-llvm-3daa82dba01b3964f31c15c8af231e5bcccb4523.tar.gz bcm5719-llvm-3daa82dba01b3964f31c15c8af231e5bcccb4523.zip |
Template instantiation for do-while statements.
llvm-svn: 71899
Diffstat (limited to 'clang/lib/Sema/SemaTemplateInstantiateStmt.cpp')
-rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateStmt.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp b/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp index 9a4d75e117a..c18966a878b 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp @@ -41,6 +41,7 @@ namespace { OwningStmtResult VisitCompoundStmt(CompoundStmt *S); OwningStmtResult VisitIfStmt(IfStmt *S); OwningStmtResult VisitWhileStmt(WhileStmt *S); + OwningStmtResult VisitDoStmt(DoStmt *S); OwningStmtResult VisitExpr(Expr *E); OwningStmtResult VisitLabelStmt(LabelStmt *S); OwningStmtResult VisitGotoStmt(GotoStmt *S); @@ -171,6 +172,21 @@ Sema::OwningStmtResult TemplateStmtInstantiator::VisitWhileStmt(WhileStmt *S) { return SemaRef.ActOnWhileStmt(S->getWhileLoc(), move(Cond), move(Body)); } +Sema::OwningStmtResult TemplateStmtInstantiator::VisitDoStmt(DoStmt *S) { + // Instantiate the condition + OwningExprResult Cond = SemaRef.InstantiateExpr(S->getCond(), TemplateArgs); + if (Cond.isInvalid()) + return SemaRef.StmtError(); + + // Instantiate the body + OwningStmtResult Body = SemaRef.InstantiateStmt(S->getBody(), TemplateArgs); + if (Body.isInvalid()) + return SemaRef.StmtError(); + + return SemaRef.ActOnDoStmt(S->getDoLoc(), move(Body), S->getWhileLoc(), + move(Cond)); +} + Sema::OwningStmtResult TemplateStmtInstantiator::VisitExpr(Expr *E) { Sema::OwningExprResult Result = SemaRef.InstantiateExpr(E, TemplateArgs); if (Result.isInvalid()) |