diff options
| author | nathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-02-14 17:50:58 +0000 |
|---|---|---|
| committer | nathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-02-14 17:50:58 +0000 |
| commit | 7ff3aeed0b9abf2fbefa0bc3bca638d070f36f20 (patch) | |
| tree | c4a556e8532e7b3fed4462d2fca4e630ff7f9a8c | |
| parent | 1928904fc905dda7a5a503647034e602178f5fca (diff) | |
| download | ppe42-gcc-7ff3aeed0b9abf2fbefa0bc3bca638d070f36f20.tar.gz ppe42-gcc-7ff3aeed0b9abf2fbefa0bc3bca638d070f36f20.zip | |
cp:
PR c++/19608
* parser.c (cp_parser_late_parsing_for_member): Use
current_function_decl as scope to push to and from.
testsuite:
PR c++/19608
* g++.dg/parse/local-class1.C: New.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@95036 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/cp/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/cp/parser.c | 7 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 3 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/parse/local-class1.C | 14 |
4 files changed, 25 insertions, 3 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index add1476e0d8..b8f356fd758 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2005-02-14 Nathan Sidwell <nathan@codesourcery.com> + PR c++/19608 + * parser.c (cp_parser_late_parsing_for_member): Use + current_function_decl as scope to push to and from. + PR c++/19884 * pt.c (check_explicit_specialization): Make sure namespace binding lookup found an overloaded function. diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index 453bc693665..f38f6fbc78f 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -15286,9 +15286,10 @@ cp_parser_late_parsing_for_member (cp_parser* parser, tree member_function) tokens = DECL_PENDING_INLINE_INFO (member_function); DECL_PENDING_INLINE_INFO (member_function) = NULL; DECL_PENDING_INLINE_P (member_function) = 0; - /* If this was an inline function in a local class, enter the scope - of the containing function. */ - function_scope = decl_function_context (member_function); + + /* If this is a local class, enter the scope of the containing + function. */ + function_scope = current_function_decl; if (function_scope) push_function_context_to (function_scope); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 61fef177c41..8384855351f 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2005-02-14 Nathan Sidwell <nathan@codesourcery.com> + PR c++/19608 + * g++.dg/parse/local-class1.C: New. + PR c++/19895 * g++.dg/parse/ptrmem3.C: New. diff --git a/gcc/testsuite/g++.dg/parse/local-class1.C b/gcc/testsuite/g++.dg/parse/local-class1.C new file mode 100644 index 00000000000..4fc7e6ebb13 --- /dev/null +++ b/gcc/testsuite/g++.dg/parse/local-class1.C @@ -0,0 +1,14 @@ + // Copyright (C) 2005 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 14 Feb 2005 <nathan@codesourcery.com> + +// Origin: Jorn Wolfgang Rennecke <amylaar@gcc.gnu.org> +// Bug 19608: ICE on invalid + + +void f () +{ + class c + { + friend void g () { } // { dg-error "local class definition" "" } + }; +} |

