diff options
author | Bernd Schmidt <bernds@cygnus.co.uk> | 1999-09-05 01:06:48 +0000 |
---|---|---|
committer | Mark Mitchell <mmitchel@gcc.gnu.org> | 1999-09-05 01:06:48 +0000 |
commit | e2ecd91c7bff7cc5180c3bbd6dd1ff62b801350b (patch) | |
tree | 18e6552fb690c4b3e5efbd8f45b8ffa8e5ea1546 /gcc/c-parse.in | |
parent | 6308c57495b0a537146807560d60b8618e45e038 (diff) | |
download | gcc-e2ecd91c7bff7cc5180c3bbd6dd1ff62b801350b.zip gcc-e2ecd91c7bff7cc5180c3bbd6dd1ff62b801350b.tar.gz gcc-e2ecd91c7bff7cc5180c3bbd6dd1ff62b801350b.tar.bz2 |
c-decl.c (struct language_function): Renamed from struct c_function.
* c-decl.c (struct language_function): Renamed from struct c_function.
Delete elt NEXT.
(c_function_chain): Delete.
(push_c_function_context): New arg F. Don't warn about nested
functions here. Fill LANGUAGE elt of F. Delete code to update
c_function_chain. Don't call push_function_context.
(pop_c_function_context): New arg F. Restore from there instead of
from c_function_chain. Don't call pop_function_context. Clear out
LANGUAGE field of F when done.
* c-lang.c: Include "function.h"
(lang_init): Initialize save_lang_status and restore_lang_status.
* c-parse.in (nested_function, nested_function_notype): Warn about
nested functions. Call push_function_context/pop_function_context
instead of the _c_ variants.
* c-tree.h (push_c_function_context, pop_c_function_context): Update
prototype.
* Makefile.in (c-lang.o): Update dependencies.
* emit-rtl.c (init_emit): Use xmalloc to allocate regno_reg_rtx,
regno_pointer_flag, regno_pointer_align.
(gen_reg_rtx): Use xrealloc to enlarge them.
(free_emit_status): New function.
* function.c (mark_machine_status, mark_lang_status): New variables.
(assign_stack_local_1): Renamed from assign_outer_stack_local. Merge
in some bits from assign_stack_local. All callers changed to use new
name.
(assign_stack_local): Just call assign_stack_local_1.
(free_after_compilation): New function.
(put_reg_into_stack): Simplify to always call assign_stack_local_1.
(trampoline_address): Likewise.
(assign_parms): Use xcalloc/xrealloc to allocate parm_reg_stack_loc.
(prepare_function_start): Explicitly clear some more variables.
* function.h (struct function): New elt can_garbage_collect.
(mark_machine_status, mark_lang_status): Declare variables.
(free_after_compilation, free_emit_status, free_varasm_status,
init_varasm_status): Declare functions.
* toplev.c (rest_of_compilation): Call free_after_compilation when
done with the current function.
* varasm.c (free_varasm_status): New function.
From-SVN: r29117
Diffstat (limited to 'gcc/c-parse.in')
-rw-r--r-- | gcc/c-parse.in | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/gcc/c-parse.in b/gcc/c-parse.in index a329a16..7dd6520 100644 --- a/gcc/c-parse.in +++ b/gcc/c-parse.in @@ -1301,11 +1301,14 @@ end ifc nested_function: declarator - { push_c_function_context (); + { if (pedantic) + pedwarn ("ANSI C forbids nested functions"); + + push_function_context (); if (! start_function (current_declspecs, $1, prefix_attributes, NULL_TREE, 1)) { - pop_c_function_context (); + pop_function_context (); YYERROR1; } reinit_parse_for_function (); } @@ -1319,16 +1322,19 @@ nested_function: which called YYERROR1 again, and so on. */ compstmt { finish_function (1); - pop_c_function_context (); } + pop_function_context (); } ; notype_nested_function: notype_declarator - { push_c_function_context (); + { if (pedantic) + pedwarn ("ANSI C forbids nested functions"); + + push_function_context (); if (! start_function (current_declspecs, $1, prefix_attributes, NULL_TREE, 1)) { - pop_c_function_context (); + pop_function_context (); YYERROR1; } reinit_parse_for_function (); } @@ -1342,7 +1348,7 @@ notype_nested_function: which called YYERROR1 again, and so on. */ compstmt { finish_function (1); - pop_c_function_context (); } + pop_function_context (); } ; /* Any kind of declarator (thus, all declarators allowed |