aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Mitchell <mark@codesourcery.com>2004-11-01 00:07:10 +0000
committerMark Mitchell <mark@codesourcery.com>2004-11-01 00:07:10 +0000
commit7ab1863e6275ba880314727e8157d97edf94eac3 (patch)
treeec81a164c2f746c8558e3f7779a015d4d716b7c0
parent58202c8a132ce14eb0cb8392c0a72657a0ad8712 (diff)
PR c++/15172
* typeck2.c (store_init_value): Use split_nonconstant_init even for types that require construction. PR c++/15172 * g++.dg/init/aggr2.C: New test. git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@89922 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/typeck2.c26
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/init/aggr2.C46
4 files changed, 66 insertions, 17 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index fee23b58b78..3337312dc7e 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2004-10-31 Mark Mitchell <mark@codesourcery.com>
+
+ PR c++/15172
+ * typeck2.c (store_init_value): Use split_nonconstant_init even
+ for types that require construction.
+
1004-10-28 Matt Austern <austern@apple.com>
PR c++/17542
diff --git a/gcc/cp/typeck2.c b/gcc/cp/typeck2.c
index d28949c55bf..46cbaeaa079 100644
--- a/gcc/cp/typeck2.c
+++ b/gcc/cp/typeck2.c
@@ -604,24 +604,16 @@ store_init_value (tree decl, tree init)
/* Digest the specified initializer into an expression. */
value = digest_init (type, init, (tree *) 0);
-
- /* Store the expression if valid; else report error. */
-
- if (TREE_CODE (value) == ERROR_MARK)
- ;
- /* Other code expects that initializers for objects of types that need
- constructing never make it into DECL_INITIAL, and passes 'init' to
- build_aggr_init without checking DECL_INITIAL. So just return. */
- else if (TYPE_NEEDS_CONSTRUCTING (type))
- return build2 (INIT_EXPR, type, decl, value);
- else if (TREE_STATIC (decl)
- && (TREE_SIDE_EFFECTS (value)
- || ! initializer_constant_valid_p (value, TREE_TYPE (value))))
+ /* If the initializer is not a constant, fill in DECL_INITIAL with
+ the bits that are constant, and then return an expression that
+ will perform the dynamic initialization. */
+ if (value != error_mark_node
+ && (TREE_SIDE_EFFECTS (value)
+ || ! initializer_constant_valid_p (value, TREE_TYPE (value))))
return split_nonconstant_init (decl, value);
-
- /* Store the VALUE in DECL_INITIAL. If we're building a
- statement-tree we will actually expand the initialization later
- when we output this function. */
+ /* If the value is a constant, just put it in DECL_INITIAL. If DECL
+ is an automatic variable, the middle end will turn this into a
+ dynamic initialization later. */
DECL_INITIAL (decl) = value;
return NULL_TREE;
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index d4ecff0e4bf..994723eb5c4 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2004-10-31 Mark Mitchell <mark@codesourcery.com>
+
+ PR c++/15172
+ * g++.dg/init/aggr2.C: New test.
+
2004-10-30 Ziemowit Laski <zlaski@apple.com>
* objc.dg/local-decl-1.m: New test.
diff --git a/gcc/testsuite/g++.dg/init/aggr2.C b/gcc/testsuite/g++.dg/init/aggr2.C
new file mode 100644
index 00000000000..97dbeb6190b
--- /dev/null
+++ b/gcc/testsuite/g++.dg/init/aggr2.C
@@ -0,0 +1,46 @@
+// PR c++/15172
+// { dg-do run }
+
+extern "C" int printf (const char *, ...);
+extern "C" void abort ();
+
+struct A {
+ static A* p;
+
+ A() { p = this; }
+ A(const A&);
+ ~A() { if (this != p) abort (); }
+ void print () { }
+};
+
+A* A::p;
+
+struct B {
+ A a;
+};
+
+B b = { A () };
+
+struct A2 {
+ static A2* p;
+
+ A2() { p = this; }
+ A2(const A2&);
+ ~A2() { if (this != p) abort (); }
+ void print () { }
+};
+
+A2* A2::p;
+
+struct B2 {
+ A2 a2;
+};
+
+int main () {
+ b.a.print ();
+ {
+ B2 b2 = { A2() };
+ b2.a2.print ();
+ }
+}
+