mirror of
https://gcc.gnu.org/git/gcc.git
synced 2025-01-02 08:53:44 +08:00
re PR c++/49216 ([C++0x] ICE on compiling new-expression with braced-init-list for arrays)
PR c++/49216 * init.c (build_vec_init): Don't try to use a CONSTRUCTOR when base is a pointer. * typeck2.c (process_init_constructor_array): Use {} for classes, too. * call.c (convert_like_real): Handle substitution failure. From-SVN: r175237
This commit is contained in:
parent
344bf2e1a2
commit
fe7eb484d3
@ -1,5 +1,12 @@
|
||||
2011-06-20 Jason Merrill <jason@redhat.com>
|
||||
|
||||
PR c++/49216
|
||||
* init.c (build_vec_init): Don't try to use a CONSTRUCTOR when
|
||||
base is a pointer.
|
||||
* typeck2.c (process_init_constructor_array): Use {} for classes,
|
||||
too.
|
||||
* call.c (convert_like_real): Handle substitution failure.
|
||||
|
||||
PR c++/48138
|
||||
* pt.c (canonicalize_type_argument): New.
|
||||
(convert_template_argument, unify): Use it.
|
||||
|
@ -5621,7 +5621,7 @@ convert_like_real (conversion *convs, tree expr, tree fn, int argnum,
|
||||
expr = build_cplus_new (totype, expr, complain);
|
||||
|
||||
/* Remember that this was list-initialization. */
|
||||
if (convs->check_narrowing)
|
||||
if (convs->check_narrowing && expr != error_mark_node)
|
||||
TARGET_EXPR_LIST_INIT_P (expr) = true;
|
||||
}
|
||||
|
||||
|
@ -3082,8 +3082,9 @@ build_vec_init (tree base, tree maxindex, tree init,
|
||||
unsigned HOST_WIDE_INT idx;
|
||||
tree field, elt;
|
||||
/* Should we try to create a constant initializer? */
|
||||
bool try_const = (literal_type_p (inner_elt_type)
|
||||
|| TYPE_HAS_CONSTEXPR_CTOR (inner_elt_type));
|
||||
bool try_const = (TREE_CODE (atype) == ARRAY_TYPE
|
||||
&& (literal_type_p (inner_elt_type)
|
||||
|| TYPE_HAS_CONSTEXPR_CTOR (inner_elt_type)));
|
||||
bool saw_non_const = false;
|
||||
bool saw_const = false;
|
||||
/* If we're initializing a static array, we want to do static
|
||||
|
@ -1051,13 +1051,8 @@ process_init_constructor_array (tree type, tree init,
|
||||
if (type_build_ctor_call (TREE_TYPE (type)))
|
||||
{
|
||||
/* If this type needs constructors run for default-initialization,
|
||||
we can't rely on the back end to do it for us, so build up
|
||||
TARGET_EXPRs. If the type in question is a class, just build
|
||||
one up; if it's an array, recurse. */
|
||||
if (MAYBE_CLASS_TYPE_P (TREE_TYPE (type)))
|
||||
next = build_functional_cast (TREE_TYPE (type), NULL_TREE,
|
||||
complain);
|
||||
else
|
||||
we can't rely on the back end to do it for us, so make the
|
||||
initialization explicit by list-initializing from {}. */
|
||||
next = build_constructor (init_list_type_node, NULL);
|
||||
next = digest_init (TREE_TYPE (type), next, complain);
|
||||
}
|
||||
|
@ -1,3 +1,8 @@
|
||||
2011-06-20 Jason Merrill <jason@redhat.com>
|
||||
|
||||
PR c++/49216
|
||||
* g++.dg/cpp0x/initlist53.C: New.
|
||||
|
||||
2011-06-20 Tobias Burnus <burnus@net-b.de>
|
||||
|
||||
PR fortran/18918
|
||||
|
20
gcc/testsuite/g++.dg/cpp0x/initlist53.C
Normal file
20
gcc/testsuite/g++.dg/cpp0x/initlist53.C
Normal file
@ -0,0 +1,20 @@
|
||||
// PR c++/49216
|
||||
// { dg-options -std=c++0x }
|
||||
// { dg-do run }
|
||||
|
||||
#include <initializer_list>
|
||||
extern "C" void abort();
|
||||
|
||||
bool constructed;
|
||||
|
||||
struct A
|
||||
{
|
||||
A(std::initializer_list<int>) { constructed = true; }
|
||||
};
|
||||
|
||||
int main() {
|
||||
new A[1]{};
|
||||
int *p = new int[1]{};
|
||||
if (p[0] != 0 || !constructed)
|
||||
abort();
|
||||
}
|
Loading…
Reference in New Issue
Block a user