From: Mark Mitchell Date: Thu, 10 Feb 2005 07:55:04 +0000 (+0000) Subject: re PR c++/19811 (g++ 4.0: ICE on vector delete of undefined class) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6e5bdc64c74f8c08bcba3b78c7a34a9dd0804f3a;p=gcc.git re PR c++/19811 (g++ 4.0: ICE on vector delete of undefined class) PR c++/19811 * call.c (build_op_delete_call): Check COMPLETE_TYPE_P before attempting name lookup. PR c++/19811 * g++.dg/init/delete1.C: New test. From-SVN: r94799 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 02b1c0bc118..4aa0118a62a 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2005-02-09 Mark Mitchell + PR c++/19811 + * call.c (build_op_delete_call): Check COMPLETE_TYPE_P before + attempting name lookup. + * parser.c (cp_parser_unqualified_id): Initialize type_decl. PR c++/19787 diff --git a/gcc/cp/call.c b/gcc/cp/call.c index 5d931c8b6e3..4655430a2bd 100644 --- a/gcc/cp/call.c +++ b/gcc/cp/call.c @@ -3924,7 +3924,9 @@ build_op_delete_call (enum tree_code code, tree addr, tree size, fnname = ansi_opname (code); - if (IS_AGGR_TYPE (type) && !global_p) + if (CLASS_TYPE_P (type) + && COMPLETE_TYPE_P (complete_type (type)) + && !global_p) /* In [class.free] If the result of the lookup is ambiguous or inaccessible, or if diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 210102d5896..e3fe0377147 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-02-09 Mark Mitchell + + PR c++/19811 + * g++.dg/init/delete1.C: New test. + 2005-02-09 Andrew Pinski PR c++/18470 diff --git a/gcc/testsuite/g++.dg/init/delete1.C b/gcc/testsuite/g++.dg/init/delete1.C new file mode 100644 index 00000000000..698b127714a --- /dev/null +++ b/gcc/testsuite/g++.dg/init/delete1.C @@ -0,0 +1,7 @@ +// PR c++/19811 + +class C; // { dg-error "forward" } + +void foo(void *p) { + delete [] ((C*)p) ; // { dg-error "" } +}