diff options
author | Jason Merrill <jason@gcc.gnu.org> | 2003-12-18 16:03:42 -0500 |
---|---|---|
committer | Jason Merrill <jason@gcc.gnu.org> | 2003-12-18 16:03:42 -0500 |
commit | d20db242047837c79801fc3caaddc43a1fe95378 (patch) | |
tree | 297f97f5645cfbbbb995c6e2665df951c2c59ce7 | |
parent | a3bf324c4674ca8a2d09f739c48be2cc59f1a789 (diff) | |
download | gcc-d20db242047837c79801fc3caaddc43a1fe95378.zip gcc-d20db242047837c79801fc3caaddc43a1fe95378.tar.gz gcc-d20db242047837c79801fc3caaddc43a1fe95378.tar.bz2 |
re PR c++/12253 ([tree-ssa] ICE on conversion to std::string inside array initialization)
PR c++/12253
* init.c (build_vec_init): Initialization of an element from
an initializer list is also a full-expression.
From-SVN: r74798
-rw-r--r-- | gcc/testsuite/g++.dg/init/array12.C | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.dg/init/array12.C b/gcc/testsuite/g++.dg/init/array12.C new file mode 100644 index 0000000..3bb4800 --- /dev/null +++ b/gcc/testsuite/g++.dg/init/array12.C @@ -0,0 +1,28 @@ +// PR c++/12253 +// Bug: We were failing to destroy the temporary A passed to the +// constructor for b[0] before going on to construct b[1]. + +// { dg-do run } + +extern "C" int printf (const char *, ...); + +int c; +int r; + +struct A +{ + A() { printf ("A()\n"); if (c++) r = 1; } + A(const A&) { printf ("A(const A&)\n"); ++c; } + ~A() { printf ("~A()\n"); --c; } +}; + +struct B +{ + B(int, const A& = A()) { printf ("B()\n"); } +}; + +int main() +{ + B b[] = { 0, 0 }; + return r; +} |