summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaTemplateInstantiateStmt.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-05-15 21:56:04 +0000
committerDouglas Gregor <dgregor@apple.com>2009-05-15 21:56:04 +0000
commit3daa82dba01b3964f31c15c8af231e5bcccb4523 (patch)
tree9415c39ff142fd0cfa40f1c242fd69980b8583fd /clang/lib/Sema/SemaTemplateInstantiateStmt.cpp
parent19573e7d29eda4e4c20d1df1bdc5df53ae8136db (diff)
downloadbcm5719-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.cpp16
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())
OpenPOWER on IntegriCloud