diff options
| author | Douglas Gregor <dgregor@apple.com> | 2009-05-21 17:37:52 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2009-05-21 17:37:52 +0000 |
| commit | 728d41bbb95b70d6dd1695dbbfc31f778b022e6a (patch) | |
| tree | 67c5251647950ce58efa1d1a24b1902fe4de8d14 /clang/lib/Sema/SemaTemplateInstantiateExpr.cpp | |
| parent | 29fe6aeef345cc6141765d8d29f26e3ffda67cba (diff) | |
| download | bcm5719-llvm-728d41bbb95b70d6dd1695dbbfc31f778b022e6a.tar.gz bcm5719-llvm-728d41bbb95b70d6dd1695dbbfc31f778b022e6a.zip | |
Template instantiation for C++ throw expressions
llvm-svn: 72217
Diffstat (limited to 'clang/lib/Sema/SemaTemplateInstantiateExpr.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateExpr.cpp | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp b/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp index b9671c2c176..55be2c2c8fe 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp @@ -83,7 +83,7 @@ namespace { OwningExprResult VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *E); OwningExprResult VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *E); // FIXME: CXXTypeIdExpr - // FIXME: CXXThrowExpr + OwningExprResult VisitCXXThrowExpr(CXXThrowExpr *E); // FIXME: CXXDefaultArgExpr OwningExprResult VisitCXXConstructExpr(CXXConstructExpr *E); OwningExprResult VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *E); @@ -813,6 +813,18 @@ TemplateExprInstantiator::VisitCXXThisExpr(CXXThisExpr *E) { } Sema::OwningExprResult +TemplateExprInstantiator::VisitCXXThrowExpr(CXXThrowExpr *E) { + OwningExprResult SubExpr(SemaRef, (void *)0); + if (E->getSubExpr()) { + SubExpr = Visit(E->getSubExpr()); + if (SubExpr.isInvalid()) + return SemaRef.ExprError(); + } + + return SemaRef.ActOnCXXThrow(E->getThrowLoc(), move(SubExpr)); +} + +Sema::OwningExprResult TemplateExprInstantiator::VisitCXXConstructExpr(CXXConstructExpr *E) { assert(!cast<CXXRecordDecl>(E->getConstructor()->getDeclContext()) ->isDependentType() && "Dependent constructor shouldn't be here"); |

