Upstream-Status: Inappropriate [Backport] From 19692feb0bd83e8e6b3a1e1e0b43119d7e12ce96 Mon Sep 17 00:00:00 2001 From: jason Date: Thu, 21 Apr 2011 04:27:30 +0000 Subject: [PATCH 160/200] * semantics.c (finish_compound_literal): Don't put an array with a dtor in a static variable. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_6-branch@172806 138bc75d-0d04-0410-961f-82ee72b054a4 index cf8d329..0d80771 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -2333,6 +2333,7 @@ finish_compound_literal (tree type, tree compound_literal) represent class temporaries with TARGET_EXPR so we elide copies. */ if ((!at_function_scope_p () || CP_TYPE_CONST_P (type)) && TREE_CODE (type) == ARRAY_TYPE + && !TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type) && initializer_constant_valid_p (compound_literal, type)) { tree decl = create_temporary_var (type); new file mode 100644 index 0000000..b76fb58 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/initlist47.C @@ -0,0 +1,9 @@ +// { dg-options -std=c++0x } + +struct A { ~A() = delete; }; // { dg-error "declared" } + +int main() +{ + typedef const A cA[2]; + cA{}; // { dg-error "deleted" } +} -- 1.7.0.4