diff options
| author | nathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-11-20 16:13:47 +0000 |
|---|---|---|
| committer | nathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-11-20 16:13:47 +0000 |
| commit | 337ff82183bfe56c086817800e2795e1b7ed7718 (patch) | |
| tree | 9ece9daeef3840fc2030973735bdec2731f9bfb4 /gcc | |
| parent | c649459c6eb0a6f31db270b1bb4e2de55498a58e (diff) | |
| download | ppe42-gcc-337ff82183bfe56c086817800e2795e1b7ed7718.tar.gz ppe42-gcc-337ff82183bfe56c086817800e2795e1b7ed7718.zip | |
cp:
* lex.c (rid_to_yy, RID_EXPORT): Make unique keyword.
* parse.y (extdef): Add EXPORT reduction.
* spew.c (yylex): Don't skip export here.
testsuite:
* g++.old-deja/g++.pt/export1.C: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@37585 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
| -rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
| -rw-r--r-- | gcc/cp/lex.c | 2 | ||||
| -rw-r--r-- | gcc/cp/parse.y | 7 | ||||
| -rw-r--r-- | gcc/cp/spew.c | 11 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/testsuite/g++.old-deja/g++.pt/export1.C | 18 |
6 files changed, 35 insertions, 13 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 7886ddca74a..3e6af41fbc5 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2000-11-20 Nathan Sidwell <nathan@codesourcery.com> + + * lex.c (rid_to_yy, RID_EXPORT): Make unique keyword. + * parse.y (extdef): Add EXPORT reduction. + * spew.c (yylex): Don't skip export here. + 2000-11-19 Mark Mitchell <mark@codesourcery.com> * decl.c (init_decl_processing): Correct name of pure virtual diff --git a/gcc/cp/lex.c b/gcc/cp/lex.c index df5dc94f393..b0553e0434f 100644 --- a/gcc/cp/lex.c +++ b/gcc/cp/lex.c @@ -544,7 +544,7 @@ const short rid_to_yy[RID_MAX] = /* RID_FRIEND */ SCSPEC, /* RID_VIRTUAL */ SCSPEC, /* RID_EXPLICIT */ SCSPEC, - /* RID_EXPORT */ SCSPEC, + /* RID_EXPORT */ EXPORT, /* RID_MUTABLE */ SCSPEC, /* ObjC */ diff --git a/gcc/cp/parse.y b/gcc/cp/parse.y index b8dff069e90..13c678b7b2a 100644 --- a/gcc/cp/parse.y +++ b/gcc/cp/parse.y @@ -278,7 +278,7 @@ cp_parse_init () %token NAMESPACE TYPENAME_KEYWORD USING %token LEFT_RIGHT TEMPLATE %token TYPEID DYNAMIC_CAST STATIC_CAST REINTERPRET_CAST CONST_CAST -%token SCOPE +%token SCOPE EXPORT /* Define the operator tokens and their precedences. The value is an integer because, if used, it is the tree code @@ -485,6 +485,11 @@ extdef: { do_pending_inlines (); } | datadef { do_pending_inlines (); } + + | EXPORT + { cp_warning ("keyword `export' not implemented, and will be ignored"); } + template_def + { do_pending_inlines (); } | template_def { do_pending_inlines (); } | asm_keyword '(' string ')' ';' diff --git a/gcc/cp/spew.c b/gcc/cp/spew.c index 9e6b65ba3b8..0894993a8b6 100644 --- a/gcc/cp/spew.c +++ b/gcc/cp/spew.c @@ -803,17 +803,6 @@ yylex () consume_token (); } } - /* If export, warn that it's unimplemented and go on. */ - else if (nth_token (0)->yylval.ttype == ridpointers[RID_EXPORT]) - { - warning ("keyword 'export' not implemented and will be ignored"); -#ifdef SPEW_DEBUG - if (spew_debug) - debug_yychar (yychr); -#endif - consume_token (); - goto retry; - } /* do_aggr needs to know if the previous token was `friend'. */ else if (nth_token (0)->yylval.ttype == ridpointers[RID_FRIEND]) after_friend = 1; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 2db948fa1e5..efb25913a33 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2000-11-20 Nathan Sidwell <nathan@codesourcery.com> + + * g++.old-deja/g++.pt/export1.C: New test. + 2000-11-20 Jakub Jelinek <jakub@redhat.com> * gcc.dg/20001117-1.c: New test. diff --git a/gcc/testsuite/g++.old-deja/g++.pt/export1.C b/gcc/testsuite/g++.old-deja/g++.pt/export1.C new file mode 100644 index 00000000000..43f79737c76 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.pt/export1.C @@ -0,0 +1,18 @@ +// Build don't link: +// Copyright (C) 2000 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 17 Nov 2000 <nathan@codesourcery.com> + + +// bug 721, we died horribly when export was used wrongly + +struct test { +int export(void); // ERROR - parse error +}; + +int test::export(void) // ERROR - parse error +{ +return 0; +} + +template <class T> class Y; +export template <class T> class X; // WARNING - export not implemented |

