diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 79e0d8f60dc..29287c8d0bb 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2018-03-02 Marek Polacek + + PR c++/84663 + * decl.c (cp_complete_array_type): Check error_mark_node. + 2018-03-02 Jakub Jelinek PR c++/84662 diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 735ed5d63d2..1866e8f3574 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -8323,7 +8323,7 @@ cp_complete_array_type (tree *ptype, tree initial_value, bool do_default) bits. See also complete_type which does the same thing for arrays of fixed size. */ type = *ptype; - if (TYPE_DOMAIN (type)) + if (type != error_mark_node && TYPE_DOMAIN (type)) { elt_type = TREE_TYPE (type); TYPE_NEEDS_CONSTRUCTING (type) = TYPE_NEEDS_CONSTRUCTING (elt_type); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a848cd3f2da..42160721e0e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -3,6 +3,9 @@ PR c++/84171 * g++.dg/warn/Wsign-compare-8.C: New test. + PR c++/84663 + * g++.dg/parse/array-size3.C: New test. + 2018-03-02 Jakub Jelinek PR c++/84662 diff --git a/gcc/testsuite/g++.dg/parse/array-size3.C b/gcc/testsuite/g++.dg/parse/array-size3.C new file mode 100644 index 00000000000..c3a824a91d7 --- /dev/null +++ b/gcc/testsuite/g++.dg/parse/array-size3.C @@ -0,0 +1,7 @@ +// PR c++/84663 + +struct S { + typedef S T[8]; + int f : -1ULL; // { dg-warning "exceeds its type" } + S () { struct { T d; } e[]; } // { dg-error "size" } +};