re PR c/28419 (ICE using __FUNCTION__ in invalid code)

PR c/28419
	* c-decl.c (c_make_fname_decl): Do not segfault in case where
	current_function_decl is set but current_function_scope is not.

	* gcc.dg/pr28319.c: New test.

From-SVN: r117684
This commit is contained in:
Jan Hubicka 2006-10-13 09:41:53 +02:00 committed by Jan Hubicka
parent f19218e504
commit 1a4259dca6
4 changed files with 24 additions and 2 deletions

View File

@ -1,3 +1,9 @@
2006-10-12 Jan Hubicka <jh@suse.cz>
PR c/28419
* c-decl.c (c_make_fname_decl): Do not segfault in case where
current_function_decl is set but current_function_scope is not.
2006-10-12 Jie Zhang <jie.zhang@analog.com>
* config/bfin/bfin.md (eh_return): Call emit_jump_insn instead of

View File

@ -2791,7 +2791,16 @@ c_make_fname_decl (tree id, int type_dep)
TREE_USED (decl) = 1;
if (current_function_decl)
if (current_function_decl
/* For invalid programs like this:
void foo()
const char* p = __FUNCTION__;
the __FUNCTION__ is believed to appear in K&R style function
parameter declarator. In that case we still don't have
function_scope. */
&& (!errorcount || current_function_scope))
{
DECL_CONTEXT (decl) = current_function_decl;
bind (id, decl, current_function_scope,

View File

@ -1,5 +1,9 @@
2006-10-12 Mark Mitchell <mark@codesourcery.com>
2006-10-12 Jan Hubicka <jh@suse.cz>
PR c/28419
* gcc.dg/pr28319.c: New test.
2006-10-12 Mark Mitchell <mark@codesourcery.com>
PR c++/29318
* g++.dg/ext/vla4.C: New test.

View File

@ -0,0 +1,3 @@
/* { dg-do compile } */
void foo()
const char* p = __FUNCTION__; /* { dg-error "" } */