From: James A. Morrison Date: Thu, 11 Aug 2005 04:21:55 +0000 (+0000) Subject: re PR c++/23225 (tree check: expected class type, have exceptional (error_mark) in... X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a4faac50ad558b6e7cfb3f90f2e510363915bdc1;p=platform%2Fupstream%2Fgcc.git re PR c++/23225 (tree check: expected class type, have exceptional (error_mark) in build_pointer_type_for_mode, at tree.c:4246) 2005-08-10 James A. Morrison PR c++/23225 * tree.c (build_pointer_type_for_mode): Robustify. From-SVN: r102977 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8faec78..2c09505 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2005-08-10 James A. Morrison + + PR c++/23225 + * tree.c (build_pointer_type_for_mode): Robustify. + 2005-08-10 James E Wilson * defaults.h, config/alpha/alpha.h, config/ia64/ia64.h diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 7d4d8f2..7af9d40 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,7 +1,12 @@ +2005-08-10 James A. Morrison + + PR c++/23225 + * g++.dg/testsuite/parse/crash27.C: new test. + 2005-08-10 Thomas Koenig PR libfortran/22143 - gfortran.dg/shift-kind.f90: New testcase. + * gfortran.dg/shift-kind.f90: New testcase. 2005-08-10 Richard Sandiford diff --git a/gcc/testsuite/g++.dg/parse/crash27.C b/gcc/testsuite/g++.dg/parse/crash27.C new file mode 100644 index 0000000..4d65177 --- /dev/null +++ b/gcc/testsuite/g++.dg/parse/crash27.C @@ -0,0 +1,9 @@ +// Bug: 23225 + +void Dispatcher() + (__builtin_offsetof (ArgsType, largeMsgLen)) + /* { dg-error "function " "function" { target *-*-* } 4 } */ + /* { dg-error "expected type" "expected 1" { target *-*-* } 4 } */ + /* { dg-error "expected `,' before" "expected 2" { target *-*-* } 4 } */ + /* { dg-error "expected `\\\)" "expected 3" { target *-*-* } 4 } */ + /* { dg-error "expected ',' or" "expected 4" { target *-*-* } 4 } */ diff --git a/gcc/tree.c b/gcc/tree.c index 39e2f1f..849482d3 100644 --- a/gcc/tree.c +++ b/gcc/tree.c @@ -4684,6 +4684,9 @@ build_pointer_type_for_mode (tree to_type, enum machine_mode mode, { tree t; + if (to_type == error_mark_node) + return error_mark_node; + /* In some cases, languages will have things that aren't a POINTER_TYPE (such as a RECORD_TYPE for fat pointers in Ada) as TYPE_POINTER_TO. In that case, return that type without regard to the rest of our