From: Douglas Gregor Date: Fri, 5 Feb 2010 07:56:11 +0000 (+0000) Subject: A dependent initializer with zero arguments should return a NULL X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=67fa05b9ed29923b7b905a09cfb95c2ac91b5835;p=clang A dependent initializer with zero arguments should return a NULL initializer (for no initialization) rather than a ParenListExpr with zero arguments in it. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@95382 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 28f49d0798..1415f73f64 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -3727,7 +3727,8 @@ void Sema::ActOnUninitializedDecl(DeclPtrTy dcl, if (Init.isInvalid()) Var->setInvalidDecl(); else { - Var->setInit(Context, + if (Init.get()) + Var->setInit(Context, MaybeCreateCXXExprWithTemporaries(Init.takeAs())); FinalizeVarWithDestructor(Var, InitType->getAs()); } diff --git a/lib/Sema/SemaInit.cpp b/lib/Sema/SemaInit.cpp index 1f1e76c999..45cd930ba0 100644 --- a/lib/Sema/SemaInit.cpp +++ b/lib/Sema/SemaInit.cpp @@ -3190,6 +3190,9 @@ InitializationSequence::Perform(Sema &S, if (Kind.getKind() == InitializationKind::IK_Copy || Kind.isExplicitCast()) return Sema::OwningExprResult(S, Args.release()[0]); + if (Args.size() == 0) + return S.Owned((Expr *)0); + unsigned NumArgs = Args.size(); return S.Owned(new (S.Context) ParenListExpr(S.Context, SourceLocation(), diff --git a/test/SemaTemplate/instantiate-decl-init.cpp b/test/SemaTemplate/instantiate-decl-init.cpp index 69c7721b51..6b76d72e32 100644 --- a/test/SemaTemplate/instantiate-decl-init.cpp +++ b/test/SemaTemplate/instantiate-decl-init.cpp @@ -34,3 +34,13 @@ void f0() { template void f0(); template void f0(); + +struct NonTrivial { + NonTrivial(); + ~NonTrivial(); +}; + +template void f1() { + NonTrivial array[N]; +} +template<> void f1<2>();