]> granicus.if.org Git - clang/commitdiff
Remove previous patch for pr5296 due to further clarification
authorFariborz Jahanian <fjahanian@apple.com>
Tue, 3 Nov 2009 20:38:53 +0000 (20:38 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Tue, 3 Nov 2009 20:38:53 +0000 (20:38 +0000)
of value-initialization and trivial constructors.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@85935 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExprCXX.cpp
test/SemaCXX/value-initialization.cpp

index ed6b67787a3828810443f12c39f2f5f63c03e278..4868c14835f491d4f40be5d98c2914a713a138fe 100644 (file)
@@ -253,20 +253,6 @@ Sema::ActOnCXXTypeConstructExpr(SourceRange TypeRange, TypeTy *TypeRep,
       << FullRange);
 
   assert(NumExprs == 0 && "Expected 0 expressions");
-  
-  if (const RecordType *Record = Ty->getAs<RecordType>()) {
-    if (!Record->getDecl()->isUnion()) {
-    // As clarified in C++ DR302, generate constructor for 
-    // value-initialization cases, even if the implementation technique 
-    // doesn't call the constructor at that point.
-      ASTOwningVector<&ActionBase::DeleteExpr> ConstructorArgs(*this);
-      (void)PerformInitializationByConstructor(Ty, MultiExprArg(*this, 0, 0), 
-                                               TypeRange.getBegin(), 
-                                               TypeRange, DeclarationName(),
-                                               IK_Default, ConstructorArgs);
-    }
-  }
-                                           
   // C++ [expr.type.conv]p2:
   // The expression T(), where T is a simple-type-specifier for a non-array
   // complete object type or the (possibly cv-qualified) void type, creates an
@@ -467,21 +453,7 @@ Sema::BuildCXXNew(SourceLocation StartLoc, bool UseGlobal,
         return ExprError(Diag(StartLoc, diag::err_new_uninitialized_const)
                            << TypeRange);
     } else if (NumConsArgs == 0) {
-      // Object is value-initialized. 
-      if (const RecordType *Record = AllocType->getAs<RecordType>()) {
-        if (!Record->getDecl()->isUnion()) {
-        // As clarified in C++ DR302, generate constructor for 
-        // value-initialization cases, even if the implementation technique 
-        // doesn't call the constructor at that point.
-          ASTOwningVector<&ActionBase::DeleteExpr> ConstructorArgs(*this);
-          (void)PerformInitializationByConstructor(AllocType, 
-                                                   MultiExprArg(*this, 0, 0), 
-                                                   TypeRange.getBegin(), 
-                                                   TypeRange, DeclarationName(),
-                                                   IK_Default, 
-                                                   ConstructorArgs);
-        }
-      }
+      // Object is value-initialized. Do nothing.
     } else if (NumConsArgs == 1) {
       // Object is direct-initialized.
       // FIXME: What DeclarationName do we pass in here?
index 6b992973614ca38e1b2d82aedef89f6c1972a942..29d866fa64de1c3f013a755290af80db81a9d64f 100644 (file)
@@ -1,23 +1,10 @@
 // RUN: clang-cc -fsyntax-only -verify %s -std=c++0x
 
 struct A {
-      ~A();
-      const int i;     // expected-note {{declared at}}
-};
-
-struct B {
-      // B is a non-POD with no user-written constructor.
-      // It has a nontrivial generated constructor.
-      const int i[12]; // expected-note {{declared at}}
-      A a;
+     const int i;      // expected-note {{declared at}}
+     virtual void f() { } 
 };
 
 int main () {
-      // Value-initializing a "B" doesn't call the default constructor for
-      // "B"; it value-initializes the members of B.  Therefore it shouldn't
-      // cause an error on generation of the default constructor for the
-      // following:
-      new B(); // expected-error {{cannot define the implicit default constructor for 'struct B', because const member 'i'}}
-      (void)B();
-      (void)A(); // expected-error {{cannot define the implicit default constructor for 'struct A', because const member 'i'}}
+      (void)A();       // expected-error {{cannot define the implicit default constructor for 'struct A', because const member 'i' cannot be default-initialized}}
 }