From: Jason Merrill Date: Tue, 1 Apr 2014 19:14:00 +0000 (-0400) Subject: re PR c++/60708 (An array temporary causes an ICE in gimplify) X-Git-Tag: basepoints/gcc-5~123 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=24991604f284ddfc6463152f5ae16fb3e6a27619;p=thirdparty%2Fgcc.git re PR c++/60708 (An array temporary causes an ICE in gimplify) PR c++/60708 * call.c (build_array_conv): Call complete_type. From-SVN: r208996 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 453e2c58b5f7..2e6fd96afd31 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,8 @@ 2014-04-01 Jason Merrill + PR c++/60708 + * call.c (build_array_conv): Call complete_type. + PR c++/60713 * typeck2.c (PICFLAG_SIDE_EFFECTS): New. (picflag_from_initializer): Return it. diff --git a/gcc/cp/call.c b/gcc/cp/call.c index 877f6d9cf172..ae0d4fff9744 100644 --- a/gcc/cp/call.c +++ b/gcc/cp/call.c @@ -948,6 +948,9 @@ build_array_conv (tree type, tree ctor, int flags, tsubst_flags_t complain) bool user = false; enum conversion_rank rank = cr_exact; + /* We might need to propagate the size from the element to the array. */ + complete_type (type); + if (TYPE_DOMAIN (type) && !variably_modified_type_p (TYPE_DOMAIN (type), NULL_TREE)) { diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist82.C b/gcc/testsuite/g++.dg/cpp0x/initlist82.C new file mode 100644 index 000000000000..3b9ccad6667e --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/initlist82.C @@ -0,0 +1,20 @@ +// PR c++/60708 +// { dg-do compile { target c++11 } } + +template struct mypair { + mypair(T, U) {} +}; + +template struct S { + mypair get_pair() noexcept { + return mypair(nullptr, 0); + } +}; + +static void foo(const mypair (&a)[2]) noexcept { } + +int main() +{ + S s; + foo({s.get_pair(), s.get_pair()}); +}