diff options
| author | nathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-11-28 10:23:03 +0000 |
|---|---|---|
| committer | nathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-11-28 10:23:03 +0000 |
| commit | afc97bfd1d7bc15bf5b892bc42b49786823bb871 (patch) | |
| tree | 23878c0662c756fdd96927e7e0fa17452fb40257 | |
| parent | 102f80297d5c4fcd36d750d6439b6e7dbd6ac3f4 (diff) | |
| download | ppe42-gcc-afc97bfd1d7bc15bf5b892bc42b49786823bb871.tar.gz ppe42-gcc-afc97bfd1d7bc15bf5b892bc42b49786823bb871.zip | |
cp:
* spew.c (yyerror): Cope if yylval.ttype is NULL.
testsuite:
* g++.old-deja/g++.other/parse2.C: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@37816 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/cp/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/cp/spew.c | 12 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/testsuite/g++.old-deja/g++.other/parse2.C | 11 |
4 files changed, 27 insertions, 4 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 7f18e81350c..9d486f6a59c 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2000-11-28 Nathan Sidwell <nathan@codesourcery.com> + * spew.c (yyerror): Cope if yylval.ttype is NULL. + +2000-11-28 Nathan Sidwell <nathan@codesourcery.com> + * decl.c (grokdeclarator): Diagnose undefined template contexts. 2000-11-28 Nathan Sidwell <nathan@codesourcery.com> diff --git a/gcc/cp/spew.c b/gcc/cp/spew.c index 070cf2fef98..38d8bd00bdc 100644 --- a/gcc/cp/spew.c +++ b/gcc/cp/spew.c @@ -1398,9 +1398,13 @@ yyerror (msgid) || last_token == CPP_INT || last_token == CPP_FLOAT) error ("%s before numeric constant", string); - else if (last_token == CPP_NAME - && TREE_CODE (yylval.ttype) == IDENTIFIER_NODE) - error ("%s before \"%s\"", string, IDENTIFIER_POINTER (yylval.ttype)); + else if (last_token == CPP_NAME) + { + if (yylval.ttype && TREE_CODE (yylval.ttype) == IDENTIFIER_NODE) + error ("%s before `%s'", string, IDENTIFIER_POINTER (yylval.ttype)); + else + error ("%s before `%c'", string, yychar); + } else - error ("%s before '%s' token", string, NAME(last_token)); + error ("%s before `%s' token", string, NAME (last_token)); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f827bf055e2..06f689b7083 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,9 @@ 2000-11-28 Nathan Sidwell <nathan@codesourcery.com> + * g++.old-deja/g++.other/parse2.C: New test. + +2000-11-28 Nathan Sidwell <nathan@codesourcery.com> + * g++.old-deja/g++.pt/incomplete1.C: New test. 2000-11-28 Nathan Sidwell <nathan@codesourcery.com> diff --git a/gcc/testsuite/g++.old-deja/g++.other/parse2.C b/gcc/testsuite/g++.old-deja/g++.other/parse2.C new file mode 100644 index 00000000000..6ecc6e55c81 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.other/parse2.C @@ -0,0 +1,11 @@ +// Build don't link: + +// Copyright (C) 2000 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 24 Nov 2000 <nathan@codesourcery.com> + +// Bug 531: We ICEd trying to give a parse error. + +struct X +{ + bool operator (const X &) const; // ERROR - parse error +}; |

