PR c++/50866
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 25 Oct 2011 18:24:28 +0000 (18:24 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 25 Oct 2011 18:24:28 +0000 (18:24 +0000)
PR c++/41449
* semantics.c (maybe_cleanup_point_expr_void): No longer static.
* typeck2.c (split_nonconstant_init_1): Use it.
* cp-tree.h: Declare it.
* decl.c (wrap_cleanups_r): Stop at CLEANUP_POINT_EXPR.

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

gcc/cp/ChangeLog
gcc/cp/cp-tree.h
gcc/cp/decl.c
gcc/cp/semantics.c
gcc/cp/typeck2.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/init/aggr7.C [new file with mode: 0644]

index 0586fe1..2ca141d 100644 (file)
@@ -1,5 +1,12 @@
 2011-10-25  Jason Merrill  <jason@redhat.com>
 
+       PR c++/50866
+       PR c++/41449
+       * semantics.c (maybe_cleanup_point_expr_void): No longer static.
+       * typeck2.c (split_nonconstant_init_1): Use it.
+       * cp-tree.h: Declare it.
+       * decl.c (wrap_cleanups_r): Stop at CLEANUP_POINT_EXPR.
+
        PR c++/49996
        * tree.c (stabilize_init): Stabilize scalar elements of a
        CONSTRUCTOR, too.
index d0e874b..b20e7d1 100644 (file)
@@ -5372,6 +5372,7 @@ extern int stmts_are_full_exprs_p         (void);
 extern void init_cp_semantics                  (void);
 extern tree do_poplevel                                (tree);
 extern void add_decl_expr                      (tree);
+extern tree maybe_cleanup_point_expr_void      (tree);
 extern tree finish_expr_stmt                   (tree);
 extern tree begin_if_stmt                      (void);
 extern void finish_if_stmt_cond                        (tree, tree);
index a21cf46..26e9847 100644 (file)
@@ -5718,7 +5718,9 @@ make_rtl_for_nonlocal_decl (tree decl, tree init, const char* asmspec)
 static tree
 wrap_cleanups_r (tree *stmt_p, int *walk_subtrees, void *data)
 {
-  if (TYPE_P (*stmt_p))
+  /* Stop at types or full-expression boundaries.  */
+  if (TYPE_P (*stmt_p)
+      || TREE_CODE (*stmt_p) == CLEANUP_POINT_EXPR)
     {
       *walk_subtrees = 0;
       return NULL_TREE;
index 42195be..84f112c 100644 (file)
@@ -424,7 +424,7 @@ maybe_cleanup_point_expr (tree expr)
    expression.  The reason why we do this is because the original type might be
    an aggregate and we cannot create a temporary variable for that type.  */
 
-static tree
+tree
 maybe_cleanup_point_expr_void (tree expr)
 {
   if (!processing_template_decl && stmts_are_full_exprs_p ())
index 0cb1104..57cd5e0 100644 (file)
@@ -573,6 +573,7 @@ split_nonconstant_init_1 (tree dest, tree init)
 
              code = build2 (INIT_EXPR, inner_type, sub, value);
              code = build_stmt (input_location, EXPR_STMT, code);
+             code = maybe_cleanup_point_expr_void (code);
              add_stmt (code);
              if (!TYPE_HAS_TRIVIAL_DESTRUCTOR (inner_type))
                {
index 7a82af0..2696fb6 100644 (file)
@@ -1,5 +1,8 @@
 2011-10-25  Jason Merrill  <jason@redhat.com>
 
+       PR c++/50866
+       * g++.dg/init/aggr7.C: New.
+
        PR c++/49996
        * g++.dg/cpp0x/initlist59.C: New.
 
diff --git a/gcc/testsuite/g++.dg/init/aggr7.C b/gcc/testsuite/g++.dg/init/aggr7.C
new file mode 100644 (file)
index 0000000..bec952c
--- /dev/null
@@ -0,0 +1,13 @@
+// PR c++/50866
+
+struct A { A(); ~A(); };
+struct B { B(const char *, const A& = A()); ~B(); };
+struct C {
+  B b1, b2;
+};
+void f()
+{
+     C c = {
+          "a","b"
+     };
+}