...and aggregate POD types.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72676 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp
index 9e20530..febfbac 100644
--- a/lib/CodeGen/CGCXX.cpp
+++ b/lib/CodeGen/CGCXX.cpp
@@ -299,10 +299,8 @@
Builder.CreateStore(EmitScalarExpr(Init), NewPtr);
else if (AllocType->isAnyComplexType())
EmitComplexExprIntoAddr(Init, NewPtr, AllocType.isVolatileQualified());
- else {
- ErrorUnsupported(E, "new expression");
- return llvm::UndefValue::get(ConvertType(E->getType()));
- }
+ else
+ EmitAggExpr(Init, NewPtr, AllocType.isVolatileQualified());
}
return NewPtr;
diff --git a/test/CodeGenCXX/new.cpp b/test/CodeGenCXX/new.cpp
index dde7bfe..bf959c9 100644
--- a/test/CodeGenCXX/new.cpp
+++ b/test/CodeGenCXX/new.cpp
@@ -11,8 +11,15 @@
int* b = new (a) int;
}
+struct S {
+ int a;
+};
+
void t3() {
int *a = new int(10);
_Complex int* b = new _Complex int(10i);
+ S s;
+ s.a = 10;
+ S *sp = new S(s);
}