OSDN Git Service

* semantics.c (finish_compound_literal): Always build a
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 6 Sep 2010 04:48:58 +0000 (04:48 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 6 Sep 2010 04:48:58 +0000 (04:48 +0000)
TARGET_EXPR.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@163893 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/semantics.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/initlist43.C [new file with mode: 0644]

index 071f8d6..b2da825 100644 (file)
@@ -1,3 +1,8 @@
+2010-09-06  Jason Merrill  <jason@redhat.com>
+
+       * semantics.c (finish_compound_literal): Always build a
+       TARGET_EXPR.
+
 2010-08-30  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/45043
index 0afa8f9..17c795f 100644 (file)
@@ -2203,20 +2203,7 @@ finish_compound_literal (tree type, tree compound_literal)
   if (TREE_CODE (type) == ARRAY_TYPE)
     cp_complete_array_type (&type, compound_literal, false);
   compound_literal = digest_init (type, compound_literal);
-  if ((!at_function_scope_p () || CP_TYPE_CONST_P (type))
-      && initializer_constant_valid_p (compound_literal, type))
-    {
-      tree decl = create_temporary_var (type);
-      DECL_INITIAL (decl) = compound_literal;
-      TREE_STATIC (decl) = 1;
-      cp_apply_type_quals_to_decl (cp_type_quals (type), decl);
-      decl = pushdecl_top_level (decl);
-      DECL_NAME (decl) = make_anon_name ();
-      SET_DECL_ASSEMBLER_NAME (decl, DECL_NAME (decl));
-      return decl;
-    }
-  else
-    return get_target_expr (compound_literal);
+  return get_target_expr (compound_literal);
 }
 
 /* Return the declaration for the function-name variable indicated by
index d72be50..eb19f0e 100644 (file)
@@ -1,3 +1,7 @@
+2010-09-06  Jason Merrill  <jason@redhat.com>
+
+       * g++.dg/cpp0x/initlist43.C: New.
+
 2010-09-05  Giuseppe Scrivano  <gscrivano@gnu.org>
 
        * gcc.dg/tree-ssa/tailrecursion-7.c: New file.
diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist43.C b/gcc/testsuite/g++.dg/cpp0x/initlist43.C
new file mode 100644 (file)
index 0000000..72a09bd
--- /dev/null
@@ -0,0 +1,7 @@
+// Test that using T{} at file scope doesn't create a static temporary.
+// { dg-options -std=c++0x }
+// { dg-final { scan-assembler-not "local" } }
+
+struct A { };
+
+A a = A{};