]> granicus.if.org Git - clang/commitdiff
Template instantiation for unary type traits, e.g., __is_pod
authorDouglas Gregor <dgregor@apple.com>
Thu, 21 May 2009 18:55:48 +0000 (18:55 +0000)
committerDouglas Gregor <dgregor@apple.com>
Thu, 21 May 2009 18:55:48 +0000 (18:55 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72220 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaTemplateInstantiateExpr.cpp
test/SemaTemplate/instantiate-expr-4.cpp

index 2a1ee886b5d3f9b670c901033cff093ce907ca50..8cd60edb67198ecd39e29f2d2f76c96ffaac1066 100644 (file)
@@ -90,7 +90,7 @@ namespace {
     OwningExprResult VisitCXXZeroInitValueExpr(CXXZeroInitValueExpr *E);
     OwningExprResult VisitCXXNewExpr(CXXNewExpr *E);
     OwningExprResult VisitCXXDeleteExpr(CXXDeleteExpr *E);
-    // FIXME: UnaryTypeTraitExpr
+    OwningExprResult VisitUnaryTypeTraitExpr(UnaryTypeTraitExpr *E);
     // FIXME: QualifiedDeclRefExpr
     OwningExprResult VisitCXXExprWithTemporaries(CXXExprWithTemporaries *E);
     OwningExprResult VisitCXXUnresolvedConstructExpr(
@@ -991,6 +991,23 @@ TemplateExprInstantiator::VisitCXXDeleteExpr(CXXDeleteExpr *E) {
                                 move(Operand));
 }
 
+Sema::OwningExprResult 
+TemplateExprInstantiator::VisitUnaryTypeTraitExpr(UnaryTypeTraitExpr *E) {
+  QualType T = SemaRef.InstantiateType(E->getQueriedType(), TemplateArgs,
+                                       /*FIXME*/E->getSourceRange().getBegin(),
+                                       DeclarationName());
+  if (T.isNull())
+    return SemaRef.ExprError();
+
+  SourceLocation FakeLParenLoc
+    = SemaRef.PP.getLocForEndOfToken(E->getSourceRange().getBegin());
+  return SemaRef.ActOnUnaryTypeTrait(E->getTrait(),
+                                     E->getSourceRange().getBegin(),
+                                     /*FIXME*/FakeLParenLoc,
+                                     T.getAsOpaquePtr(),
+                                     E->getSourceRange().getEnd());
+}
+
 Sema::OwningExprResult 
 TemplateExprInstantiator::VisitCXXExprWithTemporaries(
                                                   CXXExprWithTemporaries *E) {
index 1511c7aaf8f2e51497b87ed8aafc53e633e67c97..5c32d8c1976a055cf817bb4f80aed71b744b42f4 100644 (file)
@@ -139,3 +139,14 @@ struct Abstract {
 template struct TypeId0<int>;
 template struct TypeId0<Incomplete>;
 template struct TypeId0<Abstract>;
+
+// ---------------------------------------------------------------------
+// type traits
+// ---------------------------------------------------------------------
+template<typename T>
+struct is_pod {
+  static const bool value = __is_pod(T);
+};
+
+static const int is_pod0[is_pod<X>::value? -1 : 1];
+static const int is_pod1[is_pod<Y>::value? 1 : -1];