]> granicus.if.org Git - clang/commitdiff
add support for codegening CXXZeroInitValueExprs
authorNuno Lopes <nunoplopes@sapo.pt>
Sun, 18 Oct 2009 15:18:11 +0000 (15:18 +0000)
committerNuno Lopes <nunoplopes@sapo.pt>
Sun, 18 Oct 2009 15:18:11 +0000 (15:18 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@84418 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExprAgg.cpp
test/CodeGenCXX/default-arg-temps.cpp

index 01f719386c7aa61ff4ddcfde5ec7dc58c7738d6b..88fdb542f3cb41c5d3d700b38d01aa8ece968ae1 100644 (file)
@@ -112,6 +112,7 @@ public:
   void VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E);
   void VisitCXXConstructExpr(const CXXConstructExpr *E);
   void VisitCXXExprWithTemporaries(CXXExprWithTemporaries *E);
+  void VisitCXXZeroInitValueExpr(CXXZeroInitValueExpr *E);
 
   void VisitVAArgExpr(VAArgExpr *E);
 
@@ -439,6 +440,11 @@ void AggExprEmitter::VisitCXXExprWithTemporaries(CXXExprWithTemporaries *E) {
   CGF.EmitCXXExprWithTemporaries(E, DestPtr, VolatileDest, IsInitializer);
 }
 
+void AggExprEmitter::VisitCXXZeroInitValueExpr(CXXZeroInitValueExpr *E) {
+  LValue lvalue = LValue::MakeAddr(DestPtr, Qualifiers());
+  EmitNullInitializationToLValue(lvalue, E->getType());
+}
+
 void AggExprEmitter::EmitInitializationToLValue(Expr* E, LValue LV) {
   // FIXME: Ignore result?
   // FIXME: Are initializers affected by volatile?
index 2651446669b8a951b4bf10182e8aa7d603588f67..8385aff6291c755c16fc2d0e17db448fa0709180 100644 (file)
@@ -15,7 +15,7 @@ public:
 
 void g() {
   // RUN: grep "call void @_ZN1TC1Ev" %t | count 4 &&
-  // RUN: grep "call void @_ZN1TD1Ev" %t | count 4
+  // RUN: grep "call void @_ZN1TD1Ev" %t | count 4 &&
   f();
   f();
 
@@ -23,3 +23,10 @@ void g() {
   X b(a);
   X c = a;
 }
+
+
+// RUN: grep memset %t
+class obj{ int a; float b; double d; };
+void h() {
+  obj o = obj();
+}