diff options
| author | Douglas Gregor <dgregor@apple.com> | 2009-05-21 18:34:44 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2009-05-21 18:34:44 +0000 |
| commit | aa85d8221cb203f42e44d98110a3ac17b404d030 (patch) | |
| tree | 81da4b5ccd850a71b20893d6984c6b2879218cb0 /clang/lib/Sema/SemaTemplateInstantiateExpr.cpp | |
| parent | 728d41bbb95b70d6dd1695dbbfc31f778b022e6a (diff) | |
| download | bcm5719-llvm-aa85d8221cb203f42e44d98110a3ac17b404d030.tar.gz bcm5719-llvm-aa85d8221cb203f42e44d98110a3ac17b404d030.zip | |
Template instantiation for C++ "typeid" expressions.
llvm-svn: 72218
Diffstat (limited to 'clang/lib/Sema/SemaTemplateInstantiateExpr.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateExpr.cpp | 34 |
1 files changed, 33 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp b/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp index 55be2c2c8fe..2a1ee886b5d 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateExpr.cpp @@ -82,7 +82,7 @@ namespace { OwningExprResult VisitCXXThisExpr(CXXThisExpr *E); OwningExprResult VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *E); OwningExprResult VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *E); - // FIXME: CXXTypeIdExpr + OwningExprResult VisitCXXTypeidExpr(CXXTypeidExpr *E); OwningExprResult VisitCXXThrowExpr(CXXThrowExpr *E); // FIXME: CXXDefaultArgExpr OwningExprResult VisitCXXConstructExpr(CXXConstructExpr *E); @@ -813,6 +813,38 @@ TemplateExprInstantiator::VisitCXXThisExpr(CXXThisExpr *E) { } Sema::OwningExprResult +TemplateExprInstantiator::VisitCXXTypeidExpr(CXXTypeidExpr *E) { + if (E->isTypeOperand()) { + QualType T = SemaRef.InstantiateType(E->getTypeOperand(), + TemplateArgs, + /*FIXME*/E->getSourceRange().getBegin(), + DeclarationName()); + if (T.isNull()) + return SemaRef.ExprError(); + + return SemaRef.ActOnCXXTypeid(E->getSourceRange().getBegin(), + /*FIXME*/E->getSourceRange().getBegin(), + true, T.getAsOpaquePtr(), + E->getSourceRange().getEnd()); + } + + OwningExprResult Operand = Visit(E->getExprOperand()); + if (Operand.isInvalid()) + return SemaRef.ExprError(); + + OwningExprResult Result + = SemaRef.ActOnCXXTypeid(E->getSourceRange().getBegin(), + /*FIXME*/E->getSourceRange().getBegin(), + false, Operand.get(), + E->getSourceRange().getEnd()); + if (Result.isInvalid()) + return SemaRef.ExprError(); + + Operand.release(); // FIXME: since ActOnCXXTypeid silently took ownership + return move(Result); +} + +Sema::OwningExprResult TemplateExprInstantiator::VisitCXXThrowExpr(CXXThrowExpr *E) { OwningExprResult SubExpr(SemaRef, (void *)0); if (E->getSubExpr()) { |

