diff options
-rw-r--r-- | gcc/ChangeLog | 191 | ||||
-rw-r--r-- | gcc/c-lang.c | 9 | ||||
-rw-r--r-- | gcc/c-lex.c | 30 | ||||
-rw-r--r-- | gcc/c-lex.h | 6 | ||||
-rw-r--r-- | gcc/c-parse.c | 850 | ||||
-rw-r--r-- | gcc/c-parse.in | 169 | ||||
-rw-r--r-- | gcc/c-parse.y | 100 | ||||
-rw-r--r-- | gcc/c-tree.h | 2 | ||||
-rw-r--r-- | gcc/c-typeck.c | 92 | ||||
-rw-r--r-- | gcc/objc/objc-act.c | 21 | ||||
-rw-r--r-- | gcc/objc/objc-parse.c | 1171 | ||||
-rw-r--r-- | gcc/objc/objc-parse.y | 161 |
12 files changed, 1137 insertions, 1665 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 799c076..e0e8ae6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,22 @@ +2000-06-19 Zack Weinberg <zack@wolery.cumb.org> + + * c-parse.in (undeclared_variable_notice): Moved to c-typeck.c. + (primary: IDENTIFIER): Just call build_external_ref. + * c-parse.y, c-parse.c, objc/objc-parse.y, objc/objc-parse.c: + Regenerate. + * c-lex.c (lastiddecl): Remove. + (yylex): Replace all instances of lastiddecl with local + variables. + + * c-typeck.c (build_external_ref): New function. Treat decls + with C_DECL_ANTICIPATED mostly the same as nonexistent decls. + Look up the decl from the id here. Call lookup_objc_ivar. + * c-lang.c (lookup_objc_ivar): Stub. + * objc/objc-act.c (lookup_objc_ivar): New function. + + * c-tree.h: Prototype lookup_objc_ivar and build_external_ref. + * c-lex.h: Don't declare lastiddecl. + 2000-06-19 Benjamin Chelf <chelf@codesourcery.com> * c-common.h (IF_COND): Added documentation. @@ -28,9 +47,9 @@ (STMT_EXPR_STMT): Likewise. (LABEL_STMT_LABEL): Likewise. - * c-common.def: Added documenetion for SRCLOC, EXPR_STMT, - COMPOUND_STMT, DECL_STMT, IF_STMT, FOR_STMT, WHILE_STMT, DO_STMT, - RETURN_STMT, BREAK_STMT, CONTINUE_STMT, SWITCH_STMT, GOTO_STMT, + * c-common.def: Added documenetion for SRCLOC, EXPR_STMT, + COMPOUND_STMT, DECL_STMT, IF_STMT, FOR_STMT, WHILE_STMT, DO_STMT, + RETURN_STMT, BREAK_STMT, CONTINUE_STMT, SWITCH_STMT, GOTO_STMT, LABEL_STMT, ASM_STMT, SCOPE_STMT, CASE_LABEL, STMT_EXPR. 2000-06-19 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> @@ -114,7 +133,7 @@ Sat Jun 17 10:33:59 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> (enum c_tree_code): New enum. * c-lex.c (init_parse): Added call to add_c_tree_codes. - + 2000-06-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * fixinc/inclhack.def (ctrl_quotes_def, io_quotes_def): Modify @@ -200,7 +219,7 @@ Wed Jun 14 23:46:26 2000 J"orn Rennecke <amylaar@cygnus.co.uk> SCOPE_STMT, CASE_LABEL, STMT_EXPR. * gencheck.c (tree_codes[]): Added '#include "c-common.def"'. - + 2000-06-14 David O'Brien <obrien@FreeBSD.org> * gcc.c (main): Quiet compiler warnings. argv is assumed to be @@ -409,7 +428,7 @@ Mon Jun 12 17:04:17 2000 Jeffrey A Law (law@cygnus.com) 2000-06-12 J. David Anglin <dave@hiauly1.hia.nrc.ca> - * config/float-vax.h: Add GFLOAT defines. + * config/float-vax.h: Add GFLOAT defines. Mon Jun 12 9:44:00 2000 Mark Klein <mklein@dis.com> @@ -482,8 +501,8 @@ Mon Jun 12 9:44:00 2000 Mark Klein <mklein@dis.com> 2000-06-09 Rodney Brown <RodneyBrown@mynd.com> - * mcore-protos.h: discards const warning removal. - * mcore.c: discards const warning removal. + * mcore-protos.h: discards const warning removal. + * mcore.c: discards const warning removal. 2000-06-09 Kazu Hirata <kazu@hxi.com> @@ -509,7 +528,7 @@ Mon Jun 12 9:44:00 2000 Mark Klein <mklein@dis.com> obstack tricks (this routine is no longer a bottleneck). * tree.c (make_node): Clear the new node always. (make_tree_vec): Likewise. - (tree_cons): Clear the common structure always. + (tree_cons): Clear the common structure always. (build1): Likewise; also, clear TREE_COMPLEXITY. * gengenrtl.c: Use puts wherever possible. Remove extra newlines. @@ -593,7 +612,7 @@ Fri Jun 9 20:35:13 2000 Denis Chertykov <denisc@overta.ru> ASM_OUTPUT_DWARF_CONST_DOUBLE. * tree.c (host_integerp): Accept unsigned HOST_WIDE_INT values when pos is zero. - + * config/ia64/ia64-protos.h (ia64_output_end_prologue): Add. (output_function_prologue): Fix mispelling. (output_function_prologue, output_function_epilogue): Reorder to @@ -604,7 +623,7 @@ Fri Jun 9 20:35:13 2000 Denis Chertykov <denisc@overta.ru> (ia64_output_end_prologue): New function. (process_set): Emit ".restore sp" for epilogue stack restores. * config/ia64/ia64.h (FUNCTION_END_PROLOGUE): Define. - + 2000-06-08 Jakub Jelinek <jakub@redhat.com> * dbxout.c (dbxout_type_fields): Don't segfault on fields with @@ -621,7 +640,7 @@ Fri Jun 9 20:35:13 2000 Denis Chertykov <denisc@overta.ru> 2000-06-07 Zack Weinberg <zack@wolery.cumb.org> * c-decl.c (pushdecl): Do not call COMPLETE_TYPE_P on - error_mark_node. + error_mark_node. * print-tree.c (print_node): The transparent_union_flag means different things for unions and arrays. Do not inspect it with TYPE_TRANSPARENT_UNION. @@ -659,7 +678,7 @@ Wed Jun 7 20:34:33 2000 Denis Chertykov <denisc@overta.ru> 2000-06-06 Philipp Thomas <pthomas@suse.de> - * configure.in (AC_C_INLINE): Added. + * configure.in (AC_C_INLINE): Added. * aclocal.m4 (AM_WITH_NLS): Enable --with-included-gettext by default. * configure: Regenerate. @@ -673,8 +692,8 @@ Wed Jun 7 20:34:33 2000 Denis Chertykov <denisc@overta.ru> * c-lex.c (doing_objc_thang): Remove. * c-tree.h (doing_objc_thang): Make it a macro. * objc/objc-act.c (lang_decode_option): Set c_language, not - doing_objc_thang. - + doing_objc_thang. + 2000-06-06 Gabriel Dos Reis <gdr@codesourcery.com> * diagnostic.c (output_maximum_width): Remove. @@ -688,7 +707,7 @@ Wed Jun 7 20:34:33 2000 Denis Chertykov <denisc@overta.ru> (output_clear): Tweak. (line_wrapper_printf): Adjust call to init_output_buffer. (vline_wrapper_message_with_location): Likewise. Use - output_destroy_prefix. + output_destroy_prefix. (v_message_with_decl): Likewise. * diagnostic.h (struct output_buffer): Constify prefix. @@ -733,7 +752,7 @@ Tue Jun 6 19:25:32 2000 Philippe De Muyter <phdm@macqel.be> 2000-06-06 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * m68k.c (legitimize_pic_address): Move prototype ... - + * m68k-protos.h (legitimize_pic_address): ... here. * m68k.md (legitimize_pic_address): Delete prototypes. @@ -850,7 +869,7 @@ Mon Jun 5 06:46:28 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> (dyn-string.o): Delete rule. * dyn-string.c: Delete file * dyn-string.h: Likewise. - + 2000-06-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * Makefile.in (intl.*): Honor non-zero exit codes in the intl @@ -858,8 +877,8 @@ Mon Jun 5 06:46:28 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> 2000-06-03 Geoff Keating <geoffk@cygnus.com> - * alias.c (record_component_aliases): Don't inspect - DECL_NONADDRESSABLE_P of non-FIELD_DECL components of structures. + * alias.c (record_component_aliases): Don't inspect + DECL_NONADDRESSABLE_P of non-FIELD_DECL components of structures. Sat Jun 3 19:05:30 2000 Michael Meissner <meissner@redhat.com> @@ -939,7 +958,7 @@ Fri Jun 2 19:31:03 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * c-common.h (c_get_alias_set): Don't declare. * c-decl.c (init_decl_processing): Don't set lang_get_alias_set. * expr.h (lang_get_alias_set): Declare as function, not pointer. - + 2000-06-02 Bruce Korb <bkorb@gnu.org> * fixinc/server.c(sig_handler): resume closing server on SIGPIPE @@ -983,7 +1002,7 @@ Fri Jun 2 00:22:52 2000 J"orn Rennecke <amylaar@cygnus.co.uk> * cpplex.c (maybe_macroexpand): Use CPP_WTRADITIONAL. Improve error message. - * cpplib.c (parse_include): Remove support for VAX-C + * cpplib.c (parse_include): Remove support for VAX-C "#include starlet" misfeature. 2000-05-31 Laurynas Biveinis <lauras@softhome.net> @@ -1019,7 +1038,7 @@ Thu Jun 1 09:37:35 2000 Clinton Popetz <cpopetz@cygnus.com> * config/i386/i386-protos.h (ix86_use_fcomi_compare): Declare. * config/i386/i386.md (*fp_jcc_3, *fp_jcc_4): Disable if we will use FCOMI. - + 2000-06-01 Richard Henderson <rth@cygnus.com> * Makefile.in (c-decl.o): Depend on $(EXPR_H), not expr.h. @@ -1046,7 +1065,7 @@ Thu Jun 1 09:37:35 2000 Clinton Popetz <cpopetz@cygnus.com> 2000-05-31 Richard Henderson <rth@cygnus.com> - * ifcvt.c (merge_if_block): Be prepared for JOIN to have no + * ifcvt.c (merge_if_block): Be prepared for JOIN to have no remaining edges. (find_if_block): Allow THEN with no outgoing edges. * flow.c (merge_blocks_nomove): Remove a barrier not following @@ -1055,7 +1074,7 @@ Thu Jun 1 09:37:35 2000 Clinton Popetz <cpopetz@cygnus.com> 2000-05-31 Richard Henderson <rth@cygnus.com> * flow.c (propagate_block): Move initialization of mem_set_list ... - (init_propagate_block_info): ... here. Also track blocks with + (init_propagate_block_info): ... here. Also track blocks with no successors; don't scan insns if ! PROP_SCAN_DEAD_CODE. 2000-05-31 Richard Henderson <rth@cygnus.com> @@ -1072,7 +1091,7 @@ Thu Jun 1 09:37:35 2000 Clinton Popetz <cpopetz@cygnus.com> 2000-05-31 Philipp Thomas <pthomas@suse.de> - * configure.in (enable-nls): Enable if build == host, i.e. when + * configure.in (enable-nls): Enable if build == host, i.e. when not building a canadian cross compiler. (enable-maintainer-mode): Added for use with i18n. * aclocal.m4 (AM_GNU_GETTEXT): Only build catalogs that are a @@ -1180,7 +1199,7 @@ Wed May 31 08:07:52 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> (get_alias_set, new_alias_set, lang_get_alias_set): Deleted from here. * varasm.c (make_function_rtl, make_decl_rtl): Call set_mem_attributes. (output_constant_def, force_const_mem): Likewise. - + * flow.c (propagate_block): If block has no successors, stores to frame are dead if not used. @@ -1240,7 +1259,7 @@ Tue May 30 09:57:32 2000 Philippe De Muyter <phdm@macqel.be> 2000-05-29 Richard Earnshaw (rearnsha@arm.com) - * flow.c (mark_used_reg): If a register is unconditionally live, + * flow.c (mark_used_reg): If a register is unconditionally live, remove any conditional death information. 2000-05-29 Richard Henderson <rth@cygnus.com> @@ -1327,7 +1346,7 @@ Tue May 30 09:57:32 2000 Philippe De Muyter <phdm@macqel.be> * toplev.c (rest_of_compilation): Set no_new_pseudos after flow1; instead track register_life_up_to_date. Toggle no_new_pseudos - around if_convert. + around if_convert. 2000-05-28 Geoff Keating <geoffk@cygnus.com> @@ -1337,7 +1356,7 @@ Tue May 30 09:57:32 2000 Philippe De Muyter <phdm@macqel.be> Sun May 28 18:37:07 2000 Clinton Popetz <cpopetz@cygnus.com> * lcm.c (make_preds_opaque): Fix comment. - (optimize_mode_switching): Use NORMAL_MODE instead of + (optimize_mode_switching): Use NORMAL_MODE instead of MODE_USES_IN_EXIT_BLOCK. Change leftover instance of FP_MODE_NONE to no_mode. Rename MODE_AT_ENTRY to NORMAL_MODE. Handle insertions before an existing NOTE_INSN_BASIC_BLOCK. @@ -1536,11 +1555,11 @@ Sun May 28 23:26:59 2000 Philippe De Muyter <phdm@macqel.be> (gen_insn): Put all insns on the same obstack. (main): Generate prototypes for everything unconditionally. - * configure.in: Add AC_CHECK_TYPE(ssize_t). Remove commented + * configure.in: Add AC_CHECK_TYPE(ssize_t). Remove commented out check for wchar_t. * acconfig.h: Add template for ssize_t. Remove @TOP@. - * system.h: Add infrastructure for defining missing - TYPE_MAX/TYPE_MIN macros. Use it to provide fallback + * system.h: Add infrastructure for defining missing + TYPE_MAX/TYPE_MIN macros. Use it to provide fallback definitions of UCHAR_MAX and SSIZE_MAX. * configure: Regenerate. * config.in: Regenerate. @@ -1676,7 +1695,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> 2000-05-26 Richard Earnshaw <rearnsha@arm.com> * flow.c (find_label_refs): New function. - (find_basic_blocks_1): Call it for each alternative of a call + (find_basic_blocks_1): Call it for each alternative of a call placeholder. 2000-05-26 Richard Earnshaw <rearnsha@arm.com> @@ -1759,7 +1778,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * except.h (can_throw): Declare it. * except.c (can_throw): Give it external linkage. * resource.c (find_dead_or_set_registers): Use can_throw. - + 2000-05-25 Richard Henderson <rth@cygnus.com> * flow.c (mark_set_1): Don't record conditionally dead memory. @@ -1839,7 +1858,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> from frame.c. * frame.c: Remove all DWARF 2 specific code. * config/ia64/frame-ia64.c: New file. - (gthread_stuff): Make all gthread available with + (gthread_stuff): Make all gthread available with IA64_UNWIND_INFO. (dwarf_fde): Define an IA64 struct for dwarf_fde. (__register_frame_info, __register_frame): Move to common area of file. @@ -1862,7 +1881,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> (execute_one_ia64_descriptor): Execute one descriptor record. (rse_address_add): Calculate the position of a local reg in memory. (normalize_reg_loc): Turn a location descriptor into a memory address. - (maybe_normalize_reg_loc): Only normalize a descriptor if it falls + (maybe_normalize_reg_loc): Only normalize a descriptor if it falls within a specified PC offset range. (get_real_reg_value): Given a register location, retrieve its value. (set_real_reg_value): Change the value of a register location. @@ -1870,7 +1889,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> (copy_saved_reg_state): Copy all registers that need to be copied. (process_state_between): Normalize all frame register records that fall within the specified PC range. - (frame_translate): Take a processed frame description, and turn + (frame_translate): Take a processed frame description, and turn everything into addresses. (build_ia64_frame_state ): Find and create frame state record for a PC. (get_personality): Get the personality routine for a given frame. @@ -1887,7 +1906,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> (struct unw_p_record, unw_b_record, unw_x_record) : New unwind records. (struct unw_r_record, unwind_record): New unwind record structs. (struct unwind_info_ptr): Unwind information layout. - (IA64_UNW_LOC_TYPE_*): Macros for different types for location + (IA64_UNW_LOC_TYPE_*): Macros for different types for location descriptors. (struct ia64_reg_loc): Register location description. (struct ia64_frame_state): Location of all registers in a frame. @@ -1895,27 +1914,27 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * libgcc2.c (__ia64_personality_v1): Personality routine. (__calc_caller_bsp): Calculate the bsp register for the caller's frame. - (ia64_throw_helper): Figure out who to return to and set up the + (ia64_throw_helper): Figure out who to return to and set up the registers. (__throw): Throw routine. * output.h (assemble_eh_align, assemble_eh_label): New functions - to generate EH info where we want it. + to generate EH info where we want it. (assemble_eh_integer): New function. * toplev.c (compile_file): Output module level exception table for non-ia64 targets. - (main): Set exceptions_via_longjump and flag_new_exceptions based + (main): Set exceptions_via_longjump and flag_new_exceptions based on IA64_UNWIND_INFO too. * varasm.c (assemble_eh_label): Generate a label via ASM_OUTPUT_EH_LABEL if it has been specified. - (assemble_eh_align): Generate an alignment directive via + (assemble_eh_align): Generate an alignment directive via ASM_OUTPUT_EH_ALIGN if it has been specified. (assemble_eh_label): Generate an integer value via ASM_OUTPUT_EH_type if they have been specified. * config/ia64/ia64.c (rtx_needs_barrier): Add flushrs. (ia64_init_builtins): Add __builtin_ia64_bsp - and __builtin_ia64_flushrs. + and __builtin_ia64_flushrs. (ia64_expand_builtin): Add IA64_BUILTIN_BSP and IA64_BUILTIN_FLUSHRS. * config/ia64/ia64.h (ia64_builtins): Add IA64_BUILTIN_BSP and @@ -1930,7 +1949,7 @@ Sat May 27 11:01:27 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * config/ia64/t-ia64 (LIB2ADDEH): Add. * Makefile.in (LIB2ADDEH): Add. (LIB2ADD): Use LIB2ADDEH. - + 2000-05-24 Richard Henderson <rth@cygnus.com> * recog.c (offsettable_address_p): If mode size is zero, assume @@ -2069,9 +2088,9 @@ Tue May 23 13:58:52 2000 Philippe De Muyter <phdm@macqel.be> 2000-05-23 Zack Weinberg <zack@wolery.cumb.org> * simplify-rtx.c (SIGN_EXTEND): New macro. - (simplify_unary_operation, simplify_binary_operation, + (simplify_unary_operation, simplify_binary_operation, simplify_relational_operation): Use SIGN_EXTEND. Make low - halves of (low, high) pairs unsigned if they weren't already. + halves of (low, high) pairs unsigned if they weren't already. (simplify_ternary_operation): Cast INTVAL to unsigned before comparing to a MODE_BITSIZE. @@ -2079,7 +2098,7 @@ Tue May 23 13:58:52 2000 Philippe De Muyter <phdm@macqel.be> * aclocal.m4 (gcc_AC_CHECK_DECL, gcc_AC_CHECK_DECLS): New macros rewritten from the internals of gcc_AC_NEED_DECLARATION{S}. - + * configure.in (gcc_AC_CHECK_DECLS): Call this instead of gcc_AC_NEED_DECLARATIONS. @@ -2123,7 +2142,7 @@ Tue May 23 06:50:29 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> 2000-05-22 Richard Henderson <rth@cygnus.com> - * function.c (thread_prologue_and_epilogue_insns): Make sure + * function.c (thread_prologue_and_epilogue_insns): Make sure existing line number notes appear after the prologue. Mon May 22 21:49:00 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> @@ -2149,7 +2168,7 @@ Mon May 22 13:14:03 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * optabs.c (can_extend_p): Allow unsignedp to have any nonzero value. (gen_extend_insn, can_fix_p, can_float_p): Likewise. - + * final.c (final_scan_insn, case NOTE_INSN_FUNCTION_BEG): Remove dangling "else" that causes "break" to be conditional. Also remove unneeded code at start. @@ -2208,7 +2227,7 @@ Sun May 21 16:42:31 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * gensupport.c (process_rtx): Use XVEC to initialize vector slot of 'split'. - * print-rtl.c: If DEBUG_REGISTER_NAMES, define static + * print-rtl.c: If DEBUG_REGISTER_NAMES, define static debug_reg_names instead of static reg_names. If not, define global reg_names. * regclass.c: Don't define global reg_names unless @@ -2360,7 +2379,7 @@ Fri May 19 18:16:31 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> Fri May 19 12:05:13 2000 Clinton Popetz <cpopetz@cygnus.com> - * ssa.c (convert_from_ssa): Tell life_analysis we need death + * ssa.c (convert_from_ssa): Tell life_analysis we need death notes. (make_regs_equivalent_over_bad_edges): Only look at abnormal critical edges. @@ -2368,7 +2387,7 @@ Fri May 19 12:05:13 2000 Clinton Popetz <cpopetz@cygnus.com> 2000-05-19 Zack Weinberg <zack@wolery.cumb.org> * cpphash.c (funlike_macroexpand): Make sure not to walk p1 - past l1 when deleting whitespace and markers. + past l1 when deleting whitespace and markers. * cpplex.c (_cpp_scan_until): Clear AUX field of tokens. * cpplib.c (do_unassert): Put the list to compare against on @@ -2520,7 +2539,7 @@ Thu May 18 12:10:18 2000 Philippe De Muyter <phdm@macqel.be> as normal directives. (do_define): Don't set parsing_define_directive. Use _cpp_scan_until. The list does not have a VSPACE at the end. - (do_if): Save, clear, and restore only_seen_white around + (do_if): Save, clear, and restore only_seen_white around _cpp_parse_expr. (skip_if_group): s/CPP_DIRECTIVE/CPP_HASH/ (do_assert, do_unassert): Rewrite. @@ -2817,7 +2836,7 @@ Mon May 15 19:01:42 MET DST 2000 Jan Hubicka <jh@suse.cz> * config/rs6000/rs6000.h (RETURN_ADDRESS_OFFSET): Correct for 64-bit ABI. - * config/rs6000/rs6000.c (logical_operand): Rewrite to take MODE + * config/rs6000/rs6000.c (logical_operand): Rewrite to take MODE into account. (logical_u_operand): Delete. (non_logical_cint_operand): Rewrite to take MODE into account. @@ -2835,7 +2854,7 @@ Mon May 15 19:01:42 MET DST 2000 Jan Hubicka <jh@suse.cz> * config/rs6000/rs6000.h (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P): There is no such thing as a DImode CONST_DOUBLE. * config/rs6000/rs6000.c (output_toc): Likewise. - + * config/rs6000/rs6000.c (output_cbranch): Don't output prediction codes when old mnemonics are in use. Print register names for cc registers when requested. @@ -2864,14 +2883,14 @@ Sun May 14 17:58:59 2000 Hans-Peter Nilsson <hp@axis.com> * mklibgcc.in (building libgcc1) [Xlibgcc1.a]: Do not use unset variables $src and $dst. - + 2000-05-13 Gabriel Dos Reis <gdr@codesourcery.com> * diagnostic.h (DIAGNOSTICS_SHOW_PREFIX_ONCE): New macro. (DIAGNOSTICS_SHOW_PREFIX_NEVER): Likewise. (DIAGNOSTICS_SHOW_PREFIX_EVERY_LINE): Likewise. (struct output_buffer: emitted_prefix_p, prefixing_rule): New - fields. + fields. (set_message_prefixing_rule): Declare. * diagnostic.c: (current_prefixing_rule): New variable. @@ -2879,7 +2898,7 @@ Sun May 14 17:58:59 2000 Hans-Peter Nilsson <hp@axis.com> (output_set_prefix): Adjust buffer->emitted_prefix_p. (init_output_buffer): Adjust Initialization. (output_emit_prefix): Rewrite. Take prefixing rules into account. - + Sat May 13 11:05:47 2000 Philippe De Muyter <phdm@macqel.be> * ifcvt.c (if_convert): Do not free NULL. @@ -3153,7 +3172,7 @@ Wed 10 May 09:36:47 2000 Neil Booth <NeilB@earthling.net> * cpplex.c (spell_token): New function. (spell_string, spell_comment, spell_name): fold into - spell_token. + spell_token. (I, S): Add macros. (E, H): Remove macros. (save_comment): Save comment opening characters too. @@ -3250,7 +3269,7 @@ Tue May 9 20:52:43 2000 Denis Chertykov <denisc@overta.ru> * config/avr/avr-protos.h (extra_constraint): change a type of second argument from char to int to avoid warnings. (asm_output_byte): Likewise. - + * config/avr/avr.c (MAX_LD_OFFSET) New macro. (initial_elimination_offset): Handle elimination from FRAME_POINTER_REGNUM to STACK_POINTER_REGNUM. @@ -3276,7 +3295,7 @@ Tue May 9 20:52:43 2000 Denis Chertykov <denisc@overta.ru> scratch register. Run `fatal_insn' if shift count is a CONSTANT_P, but not a CONST_INT. (lshrqi3_out): Coding style modifications. Run `fatal_insn' if - shift count is a CONSTANT_P, but not a CONST_INT. + shift count is a CONSTANT_P, but not a CONST_INT. (extra_constraint): change a type of second argument from char to int to avoid warnings. (asm_output_byte): Likewise. @@ -3294,7 +3313,7 @@ Tue May 9 20:52:43 2000 Denis Chertykov <denisc@overta.ru> (lshrqi3): Shift count uses constraints 'n' instead of 'i'. (call_insn): Correct test for which_alternative == 1 (was 0). (call_value_insn): Likewise. - + * config/avr/t-avr: Remove definition of FLOAT while generates fp-bit.c @@ -3310,7 +3329,7 @@ Tue May 9 16:30:27 MET DST 2000 Jan Hubicka <jh@suse.cz> * calls.c (expand_call): Reorganize somewhat in order to avoid unnecesary recalculation inside loop and make tail call failure code cleaner. - + Tue May 9 06:30:20 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * alias.c (nonlocal_reference_p): Minor reformatting. @@ -3593,7 +3612,7 @@ Sun May 7 00:54:57 EDT 2000 John Wehle (john@feith.com) * arm.c (thumb_code): Define it. (arm_override_options): Set it. * arm.h (thumb_code): Declare it. - + 2000-05-06 Richard Earnshaw (reanrsha@arm.com) * arm-protos.h (arm_dllexport_name_p, arm_dllimport_name_p): Constify. @@ -3602,7 +3621,7 @@ Sun May 7 00:54:57 EDT 2000 John Wehle (john@feith.com) * arm.c (arm_gen_load_multiple, arm_gen_store_mulitple): Don't add bogus clobber to insns. - (load_multiple_operation, store_mulitple_operation): Don't check + (load_multiple_operation, store_mulitple_operation): Don't check for it. * arm.md (ldmsi_postinc, stmsi_postinc): Adjust accordingly. @@ -3611,7 +3630,7 @@ Sun May 7 00:54:57 EDT 2000 John Wehle (john@feith.com) * arm.md (call_value_symbol): Remove predicate from op2. * arm.h (SPECIAL_MODE_PREDICATES): Define. - + Sat May 6 06:25:56 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> * expr.c (get_subtarget): New function. @@ -3634,7 +3653,7 @@ Sat May 6 06:25:56 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> -maix64 is error. * rs6000.c (print_operand): Fix lossage typo. (output_cbranch): Remove "cr" decoration for now. - * rs6000.h (ASM_OUTPUT_DEF_FROM_DECLS): Make alias 'const char *'. + * rs6000.h (ASM_OUTPUT_DEF_FROM_DECLS): Make alias 'const char *'. Sat May 6 06:55:32 2000 Denis Chertykov <denisc@overta.ru> @@ -3649,7 +3668,7 @@ Sat May 6 06:55:32 2000 Denis Chertykov <denisc@overta.ru> * c-common.c (decl_attributes): For TYPE_DECLs attach the attribute to the decl. - * c-decl.c (pushdecl): Propagate the USED attribute to the + * c-decl.c (pushdecl): Propagate the USED attribute to the type copy. 2000-05-05 Richard Henderson <rth@cygnus.com> @@ -3670,7 +3689,7 @@ Sat May 6 06:55:32 2000 Denis Chertykov <denisc@overta.ru> Fri May 5 10:29:21 2000 Marc Espie <espie@cvs.openbsd.org> - * config/openbsd.h (LINK_SPEC): pass correct flags to ld + * config/openbsd.h (LINK_SPEC): pass correct flags to ld to support -shared, on platforms with dynamic libraries. Fri May 5 10:27:06 2000 Philippe De Muyter <phdm@macqel.be> @@ -3783,12 +3802,12 @@ Thu May 4 14:37:23 2000 Jeffrey A Law (law@cygnus.com) 2000-05-04 Mumit Khan <khan@xraylith.wisc.edu> - * i386/cygwin.h (CPP_PREDEFINES): Don't define __STDC__. Move + * i386/cygwin.h (CPP_PREDEFINES): Don't define __STDC__. Move attribute macros from here ... (CPP_SPEC): to here. * i386/mingw32.h (CPP_PREDEFINES): Likewise. (CPP_SPEC): Likewise. - * i386/crtdll.h (CPP_PREDEFINES): Delete attribute macros. + * i386/crtdll.h (CPP_PREDEFINES): Delete attribute macros. * Makefile.in ($(HOST_PREFIX_1)gensupport.o): Add build rule. (libgcc.a): Pass LIB1ASMSRC to libgcc.mk. @@ -3796,7 +3815,7 @@ Thu May 4 14:37:23 2000 Jeffrey A Law (law@cygnus.com) 2000-05-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * bb-reorder.c (get_next_bb_note, get_prev_bb_note): Prototype. - + * diagnostic (vbuild_message_string, build_message_string, build_location_prefix, output_get_prefix, init_output_buffer, output_notice, vline_wrapper_message_with_location, @@ -3880,7 +3899,7 @@ Thu May 4 09:45:12 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> MEM_COPY_ATTRIBUTES. 2000-05-03 Robert Lipe <robertlipe@usa.net> - + * configure.in (i[34567]86-*-isc*) [tmake_file]: Add t-i386bare to suppress libgcc1. (i[34567]86-*-sco3.2v5*) Likewise. @@ -4078,15 +4097,15 @@ Wed May 3 12:40:53 2000 Clinton Popetz <cpopetz@cygnus.com> * Makefile.in (HOST_RTL): Depend on gensupport. (gensupport.o) New rule. * genattr.c: Use gensupport for reading .md files. - * genattrtab.c: Ditto. - * gencodes.c: Ditto. - * genconfig.c: Ditto. - * genemit.c: Ditto. - * genextract.c: Ditto. - * genflags.c: Ditto. - * genopinit.c: Ditto. - * genoutput.c: Ditto. - * genpeep.c: Ditto. + * genattrtab.c: Ditto. + * gencodes.c: Ditto. + * genconfig.c: Ditto. + * genemit.c: Ditto. + * genextract.c: Ditto. + * genflags.c: Ditto. + * genopinit.c: Ditto. + * genoutput.c: Ditto. + * genpeep.c: Ditto. * genrecog.c: Ditto. * rtl.def (define_insn_and_split): New DEF_RTL_EXPR. * md.texi (Insn Splitting): Document define_insn_and_split. @@ -4123,11 +4142,11 @@ Tue May 2 23:38:37 2000 Jason Eckhardt <jle@cygnus.com> Tue May 2 18:20:31 2000 Donald Lindsay <dlindsay@hound.cygnus.com> - * config/mips/mips.c (mips_build_va_list,mips_va_start,mips_va_arg): new + * config/mips/mips.c (mips_build_va_list,mips_va_start,mips_va_arg): new ABI for varargs, across all MIPS. This is incompatible because the va_list (__builtin_va_list) structure is different, so a compilation unit passing a va_list and a compilation unit being passed one, should - both be compiled with the same ABI. (The old structure had two + both be compiled with the same ABI. (The old structure had two pointers, now it has three.) Tue May 2 19:18:43 2000 Jason Eckhardt <jle@cygnus.com> @@ -4208,7 +4227,7 @@ Tue May 2 17:06:53 2000 Jason Eckhardt <jle@cygnus.com> * config/ia64/ia64.c (ia64_encode_section_info): Handle the case where this function is called for the second time on a decl that has had its section info changed in such a way as to move it out - of small data/bss. + of small data/bss. * config/ia64/ia64.h (REDO_SECTION_INFO_P): New definition. 2000-05-01 Richard Henderson <rth@cygnus.com> diff --git a/gcc/c-lang.c b/gcc/c-lang.c index 331ff54..620ed78 100644 --- a/gcc/c-lang.c +++ b/gcc/c-lang.c @@ -171,6 +171,15 @@ build_objc_string (len, str) return NULL_TREE; } +/* Used by c-typeck.c (build_external_ref), but only for objc. */ + +tree +lookup_objc_ivar (id) + tree id ATTRIBUTE_UNUSED; +{ + return 0; +} + /* Called at end of parsing, but before end-of-file processing. */ void diff --git a/gcc/c-lex.c b/gcc/c-lex.c index 2e6e5a9..41a88b0 100644 --- a/gcc/c-lex.c +++ b/gcc/c-lex.c @@ -126,12 +126,6 @@ put_back (ch) int linemode; -/* the declaration found for the last IDENTIFIER token read in. - yylex must look this up to detect typedefs, which get token type TYPENAME, - so it is left around in case the identifier is not a typedef but is - used in a context which makes it a reference to a variable. */ -tree lastiddecl; - extern int yydebug; /* File used for outputting assembler code. */ @@ -1400,10 +1394,10 @@ yylex () /* Only return OBJECTNAME if it is a typedef. */ if (doing_objc_thang && value == OBJECTNAME) { - lastiddecl = lookup_name(yylval.ttype); + tree decl = lookup_name(yylval.ttype); - if (lastiddecl == NULL_TREE - || TREE_CODE (lastiddecl) != TYPE_DECL) + if (decl == NULL_TREE + || TREE_CODE (decl) != TYPE_DECL) value = IDENTIFIER; } @@ -1422,24 +1416,26 @@ yylex () if (value == IDENTIFIER) { + tree decl; + if (token_buffer[0] == '@') error("invalid identifier `%s'", token_buffer); yylval.ttype = get_identifier (token_buffer); - lastiddecl = lookup_name (yylval.ttype); + decl = lookup_name (yylval.ttype); - if (lastiddecl != 0 && TREE_CODE (lastiddecl) == TYPE_DECL) + if (decl != 0 && TREE_CODE (decl) == TYPE_DECL) value = TYPENAME; /* A user-invisible read-only initialized variable should be replaced by its value. We handle only strings since that's the only case used in C. */ - else if (lastiddecl != 0 && TREE_CODE (lastiddecl) == VAR_DECL - && DECL_IGNORED_P (lastiddecl) - && TREE_READONLY (lastiddecl) - && DECL_INITIAL (lastiddecl) != 0 - && TREE_CODE (DECL_INITIAL (lastiddecl)) == STRING_CST) + else if (decl != 0 && TREE_CODE (decl) == VAR_DECL + && DECL_IGNORED_P (decl) + && TREE_READONLY (decl) + && DECL_INITIAL (decl) != 0 + && TREE_CODE (DECL_INITIAL (decl)) == STRING_CST) { - tree stringval = DECL_INITIAL (lastiddecl); + tree stringval = DECL_INITIAL (decl); /* Copy the string value so that we won't clobber anything if we put something in the TREE_CHAIN of this one. */ diff --git a/gcc/c-lex.h b/gcc/c-lex.h index c1e25cb..532027e 100644 --- a/gcc/c-lex.h +++ b/gcc/c-lex.h @@ -69,12 +69,6 @@ enum rid It is indexed by a RID_... value. */ extern tree ridpointers[(int) RID_MAX]; -/* the declaration found for the last IDENTIFIER token read in. - yylex must look this up to detect typedefs, which get token type TYPENAME, - so it is left around in case the identifier is not a typedef but is - used in a context which makes it a reference to a variable. */ -extern tree lastiddecl; - extern char *token_buffer; /* Pointer to token buffer. */ extern tree make_pointer_declarator PARAMS ((tree, tree)); diff --git a/gcc/c-parse.c b/gcc/c-parse.c index cd51c24..6d730c8 100644 --- a/gcc/c-parse.c +++ b/gcc/c-parse.c @@ -120,9 +120,6 @@ static tree prefix_attributes = NULL_TREE; /* Stack of saved values of current_declspecs and prefix_attributes. */ static tree declspec_stack; -/* 1 if we explained undeclared var errors. */ -static int undeclared_variable_notice; - /* For __extension__, save/restore the warning flags which are controlled by __extension__. */ #define SAVE_WARN_FLAGS() \ @@ -383,47 +380,47 @@ static const short yyrhs[] = { -1, #if YYDEBUG != 0 static const short yyrline[] = { 0, - 236, 241, 255, 257, 257, 258, 260, 262, 263, 271, - 275, 285, 289, 293, 295, 297, 298, 299, 304, 311, - 313, 317, 321, 327, 329, 333, 337, 343, 345, 349, - 355, 357, 360, 362, 364, 366, 368, 370, 372, 376, - 380, 383, 386, 389, 393, 395, 398, 401, 405, 433, - 439, 442, 445, 448, 450, 452, 456, 460, 464, 466, - 469, 473, 500, 502, 504, 506, 508, 510, 512, 514, - 516, 518, 520, 522, 524, 526, 530, 532, 536, 538, - 541, 545, 547, 554, 557, 565, 576, 674, 675, 677, - 683, 685, 708, 717, 719, 721, 725, 731, 733, 738, - 740, 748, 750, 751, 761, 766, 768, 769, 770, 777, - 782, 786, 789, 797, 802, 804, 805, 806, 813, 823, - 827, 832, 836, 840, 844, 846, 848, 857, 860, 864, - 866, 868, 873, 877, 880, 884, 887, 889, 901, 904, - 906, 908, 912, 916, 918, 921, 934, 937, 941, 943, - 951, 952, 953, 957, 959, 965, 966, 967, 970, 972, - 975, 977, 980, 983, 989, 996, 998, 1005, 1012, 1015, - 1022, 1025, 1029, 1032, 1036, 1041, 1044, 1048, 1051, 1053, - 1055, 1057, 1064, 1066, 1067, 1068, 1073, 1075, 1077, 1079, - 1084, 1088, 1091, 1093, 1098, 1100, 1101, 1104, 1104, 1107, - 1110, 1112, 1114, 1117, 1119, 1122, 1128, 1130, 1134, 1148, - 1156, 1160, 1174, 1182, 1189, 1191, 1196, 1199, 1204, 1206, - 1208, 1215, 1217, 1225, 1231, 1236, 1238, 1240, 1247, 1249, - 1255, 1261, 1263, 1265, 1270, 1272, 1279, 1281, 1284, 1287, - 1291, 1294, 1298, 1301, 1305, 1310, 1312, 1316, 1318, 1320, - 1322, 1326, 1328, 1330, 1333, 1335, 1338, 1342, 1344, 1347, - 1349, 1354, 1357, 1362, 1364, 1366, 1380, 1386, 1399, 1404, - 1409, 1411, 1416, 1418, 1422, 1426, 1430, 1440, 1442, 1447, - 1452, 1455, 1459, 1462, 1466, 1469, 1472, 1475, 1479, 1482, - 1486, 1490, 1492, 1494, 1496, 1498, 1500, 1502, 1504, 1508, - 1516, 1524, 1526, 1528, 1532, 1534, 1537, 1540, 1550, 1552, - 1557, 1559, 1562, 1576, 1579, 1582, 1584, 1586, 1590, 1594, - 1600, 1618, 1623, 1628, 1631, 1645, 1654, 1658, 1662, 1666, - 1672, 1676, 1681, 1684, 1689, 1692, 1693, 1709, 1714, 1717, - 1729, 1731, 1741, 1751, 1752, 1759, 1761, 1773, 1777, 1791, - 1797, 1803, 1804, 1809, 1814, 1818, 1822, 1833, 1840, 1847, - 1854, 1865, 1871, 1874, 1879, 1902, 1932, 1963, 1994, 2009, - 2023, 2027, 2031, 2034, 2039, 2041, 2044, 2046, 2050, 2055, - 2058, 2064, 2069, 2074, 2076, 2085, 2086, 2092, 2094, 2104, - 2106, 2110, 2113, 2119, 2128, 2136, 2144, 2153, 2166, 2171, - 2176, 2178, 2187, 2190, 2195, 2198, 2202 + 233, 238, 252, 254, 254, 255, 257, 259, 260, 268, + 272, 282, 286, 290, 292, 294, 295, 296, 301, 308, + 310, 314, 318, 324, 326, 330, 334, 340, 342, 346, + 352, 354, 357, 359, 361, 363, 365, 367, 369, 373, + 377, 380, 383, 386, 390, 392, 395, 398, 402, 430, + 436, 439, 442, 445, 447, 449, 453, 457, 461, 463, + 466, 470, 497, 499, 501, 503, 505, 507, 509, 511, + 513, 515, 517, 519, 521, 523, 527, 529, 533, 535, + 538, 542, 544, 551, 554, 562, 573, 580, 581, 583, + 589, 591, 614, 623, 625, 627, 631, 637, 639, 644, + 646, 654, 656, 657, 667, 672, 674, 675, 676, 683, + 688, 692, 695, 703, 708, 710, 711, 712, 719, 729, + 733, 738, 742, 746, 750, 752, 754, 763, 766, 770, + 772, 774, 779, 783, 786, 790, 793, 795, 807, 810, + 812, 814, 818, 822, 824, 827, 840, 843, 847, 849, + 857, 858, 859, 863, 865, 871, 872, 873, 876, 878, + 881, 883, 886, 889, 895, 902, 904, 911, 918, 921, + 928, 931, 935, 938, 942, 947, 950, 954, 957, 959, + 961, 963, 970, 972, 973, 974, 979, 981, 983, 985, + 990, 994, 997, 999, 1004, 1006, 1007, 1010, 1010, 1013, + 1016, 1018, 1020, 1023, 1025, 1028, 1034, 1036, 1040, 1054, + 1062, 1066, 1080, 1088, 1095, 1097, 1102, 1105, 1110, 1112, + 1114, 1121, 1123, 1131, 1137, 1142, 1144, 1146, 1153, 1155, + 1161, 1167, 1169, 1171, 1176, 1178, 1185, 1187, 1190, 1193, + 1197, 1200, 1204, 1207, 1211, 1216, 1218, 1222, 1224, 1226, + 1228, 1232, 1234, 1236, 1239, 1241, 1244, 1248, 1250, 1253, + 1255, 1260, 1263, 1268, 1270, 1272, 1286, 1292, 1305, 1310, + 1315, 1317, 1322, 1324, 1328, 1332, 1336, 1346, 1348, 1353, + 1358, 1361, 1365, 1368, 1372, 1375, 1378, 1381, 1385, 1388, + 1392, 1396, 1398, 1400, 1402, 1404, 1406, 1408, 1410, 1414, + 1422, 1430, 1432, 1434, 1438, 1440, 1443, 1446, 1456, 1458, + 1463, 1465, 1468, 1482, 1485, 1488, 1490, 1492, 1496, 1500, + 1506, 1524, 1529, 1534, 1537, 1551, 1560, 1564, 1568, 1572, + 1578, 1582, 1587, 1590, 1595, 1598, 1599, 1615, 1620, 1623, + 1635, 1637, 1647, 1657, 1658, 1665, 1667, 1679, 1683, 1697, + 1703, 1709, 1710, 1715, 1720, 1724, 1728, 1739, 1746, 1753, + 1760, 1771, 1777, 1780, 1785, 1808, 1838, 1869, 1900, 1915, + 1929, 1933, 1937, 1940, 1945, 1947, 1950, 1952, 1956, 1961, + 1964, 1970, 1975, 1980, 1982, 1991, 1992, 1998, 2000, 2010, + 2012, 2016, 2019, 2025, 2034, 2042, 2050, 2059, 2072, 2077, + 2082, 2084, 2093, 2096, 2101, 2104, 2108 }; #endif @@ -1274,7 +1271,7 @@ static const short yycheck[] = { 38, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57 }; /* -*-C-*- Note some compilers choke on comments on `#line' lines. */ -#line 3 "/usr/lib/bison.simple" +#line 3 "/usr/share/misc/bison.simple" /* This file comes from bison-1.28. */ /* Skeleton output parser for bison, @@ -1488,7 +1485,7 @@ __yy_memcpy (char *to, char *from, unsigned int count) #endif #endif -#line 217 "/usr/lib/bison.simple" +#line 217 "/usr/share/misc/bison.simple" /* The user can define YYPARSE_PARAM as the name of an argument to be passed into yyparse. The argument should have type void *. @@ -1817,14 +1814,14 @@ yyreduce: switch (yyn) { case 1: -#line 237 "c-parse.y" +#line 234 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids an empty source file"); finish_file (); ; break;} case 2: -#line 242 "c-parse.y" +#line 239 "c-parse.y" { /* In case there were missing closebraces, get us back to the global binding level. */ @@ -1834,15 +1831,15 @@ case 2: ; break;} case 3: -#line 256 "c-parse.y" +#line 253 "c-parse.y" {yyval.ttype = NULL_TREE; ; break;} case 5: -#line 257 "c-parse.y" +#line 254 "c-parse.y" {yyval.ttype = NULL_TREE; ; break;} case 9: -#line 264 "c-parse.y" +#line 261 "c-parse.y" { STRIP_NOPS (yyvsp[-2].ttype); if ((TREE_CODE (yyvsp[-2].ttype) == ADDR_EXPR && TREE_CODE (TREE_OPERAND (yyvsp[-2].ttype, 0)) == STRING_CST) @@ -1852,11 +1849,11 @@ case 9: error ("argument of `asm' is not a constant string"); ; break;} case 10: -#line 272 "c-parse.y" +#line 269 "c-parse.y" { RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 11: -#line 277 "c-parse.y" +#line 274 "c-parse.y" { if (pedantic) error ("ANSI C forbids data definition with no type or storage class"); else if (!flag_traditional) @@ -1867,162 +1864,162 @@ case 11: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 12: -#line 286 "c-parse.y" +#line 283 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 13: -#line 290 "c-parse.y" +#line 287 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 14: -#line 294 "c-parse.y" +#line 291 "c-parse.y" { pedwarn ("empty declaration"); ; break;} case 15: -#line 296 "c-parse.y" +#line 293 "c-parse.y" { shadow_tag (yyvsp[-1].ttype); ; break;} case 18: -#line 300 "c-parse.y" +#line 297 "c-parse.y" { if (pedantic) pedwarn ("ANSI C does not allow extra `;' outside of a function"); ; break;} case 19: -#line 306 "c-parse.y" +#line 303 "c-parse.y" { if (! start_function (current_declspecs, yyvsp[0].ttype, prefix_attributes, NULL_TREE)) YYERROR1; reinit_parse_for_function (); ; break;} case 20: -#line 311 "c-parse.y" +#line 308 "c-parse.y" { store_parm_decls (); ; break;} case 21: -#line 313 "c-parse.y" +#line 310 "c-parse.y" { finish_function (0); current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 22: -#line 318 "c-parse.y" +#line 315 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 23: -#line 322 "c-parse.y" +#line 319 "c-parse.y" { if (! start_function (current_declspecs, yyvsp[0].ttype, prefix_attributes, NULL_TREE)) YYERROR1; reinit_parse_for_function (); ; break;} case 24: -#line 327 "c-parse.y" +#line 324 "c-parse.y" { store_parm_decls (); ; break;} case 25: -#line 329 "c-parse.y" +#line 326 "c-parse.y" { finish_function (0); current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 26: -#line 334 "c-parse.y" +#line 331 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 27: -#line 338 "c-parse.y" +#line 335 "c-parse.y" { if (! start_function (NULL_TREE, yyvsp[0].ttype, prefix_attributes, NULL_TREE)) YYERROR1; reinit_parse_for_function (); ; break;} case 28: -#line 343 "c-parse.y" +#line 340 "c-parse.y" { store_parm_decls (); ; break;} case 29: -#line 345 "c-parse.y" +#line 342 "c-parse.y" { finish_function (0); current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 30: -#line 350 "c-parse.y" +#line 347 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 33: -#line 361 "c-parse.y" +#line 358 "c-parse.y" { yyval.code = ADDR_EXPR; ; break;} case 34: -#line 363 "c-parse.y" +#line 360 "c-parse.y" { yyval.code = NEGATE_EXPR; ; break;} case 35: -#line 365 "c-parse.y" +#line 362 "c-parse.y" { yyval.code = CONVERT_EXPR; ; break;} case 36: -#line 367 "c-parse.y" +#line 364 "c-parse.y" { yyval.code = PREINCREMENT_EXPR; ; break;} case 37: -#line 369 "c-parse.y" +#line 366 "c-parse.y" { yyval.code = PREDECREMENT_EXPR; ; break;} case 38: -#line 371 "c-parse.y" +#line 368 "c-parse.y" { yyval.code = BIT_NOT_EXPR; ; break;} case 39: -#line 373 "c-parse.y" +#line 370 "c-parse.y" { yyval.code = TRUTH_NOT_EXPR; ; break;} case 40: -#line 377 "c-parse.y" +#line 374 "c-parse.y" { yyval.ttype = build_compound_expr (yyvsp[0].ttype); ; break;} case 41: -#line 382 "c-parse.y" +#line 379 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 43: -#line 388 "c-parse.y" +#line 385 "c-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 44: -#line 390 "c-parse.y" +#line 387 "c-parse.y" { chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 46: -#line 396 "c-parse.y" +#line 393 "c-parse.y" { yyval.ttype = build_indirect_ref (yyvsp[0].ttype, "unary *"); ; break;} case 47: -#line 399 "c-parse.y" +#line 396 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 48: -#line 402 "c-parse.y" +#line 399 "c-parse.y" { yyval.ttype = build_unary_op (yyvsp[-1].code, yyvsp[0].ttype, 0); overflow_warning (yyval.ttype); ; break;} case 49: -#line 406 "c-parse.y" +#line 403 "c-parse.y" { tree label = lookup_label (yyvsp[0].ttype); if (pedantic) pedwarn ("ANSI C forbids `&&'"); @@ -2037,7 +2034,7 @@ case 49: ; break;} case 50: -#line 434 "c-parse.y" +#line 431 "c-parse.y" { skip_evaluation--; if (TREE_CODE (yyvsp[0].ttype) == COMPONENT_REF && DECL_C_BIT_FIELD (TREE_OPERAND (yyvsp[0].ttype, 1))) @@ -2045,53 +2042,53 @@ case 50: yyval.ttype = c_sizeof (TREE_TYPE (yyvsp[0].ttype)); ; break;} case 51: -#line 440 "c-parse.y" +#line 437 "c-parse.y" { skip_evaluation--; yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ttype)); ; break;} case 52: -#line 443 "c-parse.y" +#line 440 "c-parse.y" { skip_evaluation--; yyval.ttype = c_alignof_expr (yyvsp[0].ttype); ; break;} case 53: -#line 446 "c-parse.y" +#line 443 "c-parse.y" { skip_evaluation--; yyval.ttype = c_alignof (groktypename (yyvsp[-1].ttype)); ; break;} case 54: -#line 449 "c-parse.y" +#line 446 "c-parse.y" { yyval.ttype = build_unary_op (REALPART_EXPR, yyvsp[0].ttype, 0); ; break;} case 55: -#line 451 "c-parse.y" +#line 448 "c-parse.y" { yyval.ttype = build_unary_op (IMAGPART_EXPR, yyvsp[0].ttype, 0); ; break;} case 56: -#line 453 "c-parse.y" +#line 450 "c-parse.y" { yyval.ttype = build_va_arg (yyvsp[-3].ttype, groktypename (yyvsp[-1].ttype)); ; break;} case 57: -#line 457 "c-parse.y" +#line 454 "c-parse.y" { skip_evaluation++; ; break;} case 58: -#line 461 "c-parse.y" +#line 458 "c-parse.y" { skip_evaluation++; ; break;} case 60: -#line 467 "c-parse.y" +#line 464 "c-parse.y" { tree type = groktypename (yyvsp[-2].ttype); yyval.ttype = build_c_cast (type, yyvsp[0].ttype); ; break;} case 61: -#line 470 "c-parse.y" +#line 467 "c-parse.y" { start_init (NULL_TREE, NULL, 0); yyvsp[-2].ttype = groktypename (yyvsp[-2].ttype); really_start_incremental_init (yyvsp[-2].ttype); ; break;} case 62: -#line 474 "c-parse.y" +#line 471 "c-parse.y" { const char *name; tree result = pop_init_level (0); tree type = yyvsp[-5].ttype; @@ -2118,90 +2115,90 @@ case 62: ; break;} case 64: -#line 503 "c-parse.y" +#line 500 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 65: -#line 505 "c-parse.y" +#line 502 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 66: -#line 507 "c-parse.y" +#line 504 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 67: -#line 509 "c-parse.y" +#line 506 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 68: -#line 511 "c-parse.y" +#line 508 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 69: -#line 513 "c-parse.y" +#line 510 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 70: -#line 515 "c-parse.y" +#line 512 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 71: -#line 517 "c-parse.y" +#line 514 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 72: -#line 519 "c-parse.y" +#line 516 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 73: -#line 521 "c-parse.y" +#line 518 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 74: -#line 523 "c-parse.y" +#line 520 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 75: -#line 525 "c-parse.y" +#line 522 "c-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 76: -#line 527 "c-parse.y" +#line 524 "c-parse.y" { yyvsp[-1].ttype = truthvalue_conversion (default_conversion (yyvsp[-1].ttype)); skip_evaluation += yyvsp[-1].ttype == boolean_false_node; ; break;} case 77: -#line 530 "c-parse.y" +#line 527 "c-parse.y" { skip_evaluation -= yyvsp[-3].ttype == boolean_false_node; yyval.ttype = parser_build_binary_op (TRUTH_ANDIF_EXPR, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 78: -#line 533 "c-parse.y" +#line 530 "c-parse.y" { yyvsp[-1].ttype = truthvalue_conversion (default_conversion (yyvsp[-1].ttype)); skip_evaluation += yyvsp[-1].ttype == boolean_true_node; ; break;} case 79: -#line 536 "c-parse.y" +#line 533 "c-parse.y" { skip_evaluation -= yyvsp[-3].ttype == boolean_true_node; yyval.ttype = parser_build_binary_op (TRUTH_ORIF_EXPR, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 80: -#line 539 "c-parse.y" +#line 536 "c-parse.y" { yyvsp[-1].ttype = truthvalue_conversion (default_conversion (yyvsp[-1].ttype)); skip_evaluation += yyvsp[-1].ttype == boolean_false_node; ; break;} case 81: -#line 542 "c-parse.y" +#line 539 "c-parse.y" { skip_evaluation += ((yyvsp[-4].ttype == boolean_true_node) - (yyvsp[-4].ttype == boolean_false_node)); ; break;} case 82: -#line 545 "c-parse.y" +#line 542 "c-parse.y" { skip_evaluation -= yyvsp[-6].ttype == boolean_true_node; yyval.ttype = build_conditional_expr (yyvsp[-6].ttype, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 83: -#line 548 "c-parse.y" +#line 545 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids omitting the middle term of a ?: expression"); /* Make sure first operand is calculated only once. */ @@ -2210,12 +2207,12 @@ case 83: skip_evaluation += yyvsp[-1].ttype == boolean_true_node; ; break;} case 84: -#line 555 "c-parse.y" +#line 552 "c-parse.y" { skip_evaluation -= yyvsp[-4].ttype == boolean_true_node; yyval.ttype = build_conditional_expr (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 85: -#line 558 "c-parse.y" +#line 555 "c-parse.y" { char class; yyval.ttype = build_modify_expr (yyvsp[-2].ttype, NOP_EXPR, yyvsp[0].ttype); class = TREE_CODE_CLASS (TREE_CODE (yyval.ttype)); @@ -2225,7 +2222,7 @@ case 85: ; break;} case 86: -#line 566 "c-parse.y" +#line 563 "c-parse.y" { char class; yyval.ttype = build_modify_expr (yyvsp[-2].ttype, yyvsp[-1].code, yyvsp[0].ttype); /* This inhibits warnings in truthvalue_conversion. */ @@ -2236,110 +2233,19 @@ case 86: ; break;} case 87: -#line 578 "c-parse.y" +#line 575 "c-parse.y" { - yyval.ttype = lastiddecl; - if (!yyval.ttype || yyval.ttype == error_mark_node) - { - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - { - /* Ordinary implicit function declaration. */ - yyval.ttype = implicitly_declare (yyvsp[0].ttype); - assemble_external (yyval.ttype); - TREE_USED (yyval.ttype) = 1; - } - } - else if (current_function_decl == 0) - { - error ("`%s' undeclared here (not in a function)", - IDENTIFIER_POINTER (yyvsp[0].ttype)); - yyval.ttype = error_mark_node; - } - else - { - { - if (IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) != error_mark_node - || IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) != current_function_decl) - { - error ("`%s' undeclared (first use in this function)", - IDENTIFIER_POINTER (yyvsp[0].ttype)); - - if (! undeclared_variable_notice) - { - error ("(Each undeclared identifier is reported only once"); - error ("for each function it appears in.)"); - undeclared_variable_notice = 1; - } - } - yyval.ttype = error_mark_node; - /* Prevent repeated error messages. */ - IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) = error_mark_node; - IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) = current_function_decl; - } - } - } - else if (TREE_TYPE (yyval.ttype) == error_mark_node) - yyval.ttype = error_mark_node; - else if (C_DECL_ANTICIPATED (yyval.ttype)) - { - /* The first time we see a build-in function used, - if it has not been declared. */ - C_DECL_ANTICIPATED (yyval.ttype) = 0; - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - /* Omit the implicit declaration we - would ordinarily do, so we don't lose - the actual built in type. - But print a diagnostic for the mismatch. */ - if (TREE_CODE (yyval.ttype) != FUNCTION_DECL) - error ("`%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE (yyval.ttype))) - != TYPE_MODE (integer_type_node)) - && !VOID_TYPE_P (TREE_TYPE (TREE_TYPE (yyval.ttype)))) - pedwarn ("type mismatch in implicit declaration for built-in function `%s'", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - /* If it really returns void, change that to int. */ - if (TREE_TYPE (TREE_TYPE (yyval.ttype)) == void_type_node) - TREE_TYPE (yyval.ttype) - = build_function_type (integer_type_node, - TYPE_ARG_TYPES (TREE_TYPE (yyval.ttype))); - } - else - pedwarn ("built-in function `%s' used without declaration", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - - /* Do what we would ordinarily do when a fn is used. */ - assemble_external (yyval.ttype); - TREE_USED (yyval.ttype) = 1; - } - else - { - assemble_external (yyval.ttype); - TREE_USED (yyval.ttype) = 1; - } - - if (TREE_CODE (yyval.ttype) == CONST_DECL) - { - yyval.ttype = DECL_INITIAL (yyval.ttype); - /* This is to prevent an enum whose value is 0 - from being considered a null pointer constant. */ - yyval.ttype = build1 (NOP_EXPR, TREE_TYPE (yyval.ttype), yyval.ttype); - TREE_CONSTANT (yyval.ttype) = 1; - } + if (yychar == YYEMPTY) + yychar = YYLEX; + yyval.ttype = build_external_ref (yyvsp[0].ttype, yychar == '('); ; break;} case 89: -#line 676 "c-parse.y" +#line 582 "c-parse.y" { yyval.ttype = combine_strings (yyvsp[0].ttype); ; break;} case 90: -#line 678 "c-parse.y" +#line 584 "c-parse.y" { char class = TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype)); if (class == 'e' || class == '1' || class == '2' || class == '<') @@ -2347,11 +2253,11 @@ case 90: yyval.ttype = yyvsp[-1].ttype; ; break;} case 91: -#line 684 "c-parse.y" +#line 590 "c-parse.y" { yyval.ttype = error_mark_node; ; break;} case 92: -#line 686 "c-parse.y" +#line 592 "c-parse.y" { tree rtl_exp; if (pedantic) pedwarn ("ANSI C forbids braced-groups within expressions"); @@ -2376,7 +2282,7 @@ case 92: ; break;} case 93: -#line 709 "c-parse.y" +#line 615 "c-parse.y" { /* Make sure we call expand_end_stmt_expr. Otherwise we are likely to lose sequences and crash later. */ @@ -2387,21 +2293,21 @@ case 93: ; break;} case 94: -#line 718 "c-parse.y" +#line 624 "c-parse.y" { yyval.ttype = build_function_call (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 95: -#line 720 "c-parse.y" +#line 626 "c-parse.y" { yyval.ttype = build_array_ref (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 96: -#line 722 "c-parse.y" +#line 628 "c-parse.y" { yyval.ttype = build_component_ref (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 97: -#line 726 "c-parse.y" +#line 632 "c-parse.y" { tree expr = build_indirect_ref (yyvsp[-2].ttype, "->"); @@ -2409,57 +2315,57 @@ case 97: ; break;} case 98: -#line 732 "c-parse.y" +#line 638 "c-parse.y" { yyval.ttype = build_unary_op (POSTINCREMENT_EXPR, yyvsp[-1].ttype, 0); ; break;} case 99: -#line 734 "c-parse.y" +#line 640 "c-parse.y" { yyval.ttype = build_unary_op (POSTDECREMENT_EXPR, yyvsp[-1].ttype, 0); ; break;} case 101: -#line 741 "c-parse.y" +#line 647 "c-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); if (warn_traditional && !in_system_header) warning ("Use of ANSI string concatenation"); ; break;} case 104: -#line 753 "c-parse.y" +#line 659 "c-parse.y" { c_mark_varargs (); if (pedantic) pedwarn ("ANSI C does not permit use of `varargs.h'"); ; break;} case 105: -#line 763 "c-parse.y" +#line 669 "c-parse.y" { ; break;} case 110: -#line 779 "c-parse.y" +#line 685 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 111: -#line 783 "c-parse.y" +#line 689 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 112: -#line 787 "c-parse.y" +#line 693 "c-parse.y" { shadow_tag_warned (yyvsp[-1].ttype, 1); pedwarn ("empty declaration"); ; break;} case 113: -#line 790 "c-parse.y" +#line 696 "c-parse.y" { pedwarn ("empty declaration"); ; break;} case 114: -#line 799 "c-parse.y" +#line 705 "c-parse.y" { ; break;} case 119: -#line 814 "c-parse.y" +#line 720 "c-parse.y" { pending_xref_error (); declspec_stack = tree_cons (prefix_attributes, current_declspecs, @@ -2468,127 +2374,127 @@ case 119: ¤t_declspecs, &prefix_attributes); ; break;} case 120: -#line 824 "c-parse.y" +#line 730 "c-parse.y" { prefix_attributes = chainon (prefix_attributes, yyvsp[0].ttype); ; break;} case 121: -#line 829 "c-parse.y" +#line 735 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 122: -#line 833 "c-parse.y" +#line 739 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 123: -#line 837 "c-parse.y" +#line 743 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 124: -#line 841 "c-parse.y" +#line 747 "c-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 125: -#line 845 "c-parse.y" +#line 751 "c-parse.y" { shadow_tag (yyvsp[-1].ttype); ; break;} case 126: -#line 847 "c-parse.y" +#line 753 "c-parse.y" { pedwarn ("empty declaration"); ; break;} case 127: -#line 849 "c-parse.y" +#line 755 "c-parse.y" { RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 128: -#line 859 "c-parse.y" +#line 765 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 129: -#line 861 "c-parse.y" +#line 767 "c-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ; break;} case 130: -#line 865 "c-parse.y" +#line 771 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 131: -#line 867 "c-parse.y" +#line 773 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 132: -#line 869 "c-parse.y" +#line 775 "c-parse.y" { if (extra_warnings) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 133: -#line 874 "c-parse.y" +#line 780 "c-parse.y" { yyval.ttype = tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 134: -#line 879 "c-parse.y" +#line 785 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 135: -#line 881 "c-parse.y" +#line 787 "c-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ; break;} case 136: -#line 886 "c-parse.y" +#line 792 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 137: -#line 888 "c-parse.y" +#line 794 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 138: -#line 890 "c-parse.y" +#line 796 "c-parse.y" { if (extra_warnings) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 139: -#line 903 "c-parse.y" +#line 809 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 140: -#line 905 "c-parse.y" +#line 811 "c-parse.y" { yyval.ttype = tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ; break;} case 141: -#line 907 "c-parse.y" +#line 813 "c-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 142: -#line 909 "c-parse.y" +#line 815 "c-parse.y" { yyval.ttype = tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 143: -#line 914 "c-parse.y" +#line 820 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); TREE_STATIC (yyval.ttype) = 1; ; break;} case 144: -#line 917 "c-parse.y" +#line 823 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 145: -#line 919 "c-parse.y" +#line 825 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); TREE_STATIC (yyval.ttype) = 1; ; break;} case 146: -#line 922 "c-parse.y" +#line 828 "c-parse.y" { if (extra_warnings && TREE_STATIC (yyvsp[-1].ttype)) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); @@ -2596,176 +2502,176 @@ case 146: TREE_STATIC (yyval.ttype) = TREE_STATIC (yyvsp[-1].ttype); ; break;} case 147: -#line 936 "c-parse.y" +#line 842 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 148: -#line 938 "c-parse.y" +#line 844 "c-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ; break;} case 149: -#line 942 "c-parse.y" +#line 848 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 150: -#line 944 "c-parse.y" +#line 850 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 153: -#line 954 "c-parse.y" +#line 860 "c-parse.y" { /* For a typedef name, record the meaning, not the name. In case of `foo foo, bar;'. */ yyval.ttype = lookup_name (yyvsp[0].ttype); ; break;} case 154: -#line 958 "c-parse.y" +#line 864 "c-parse.y" { yyval.ttype = TREE_TYPE (yyvsp[-1].ttype); ; break;} case 155: -#line 960 "c-parse.y" +#line 866 "c-parse.y" { yyval.ttype = groktypename (yyvsp[-1].ttype); ; break;} case 163: -#line 982 "c-parse.y" +#line 888 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 164: -#line 984 "c-parse.y" +#line 890 "c-parse.y" { if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype); yyval.ttype = yyvsp[-1].ttype; ; break;} case 165: -#line 991 "c-parse.y" +#line 897 "c-parse.y" { yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1, yyvsp[-1].ttype, prefix_attributes); start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ; break;} case 166: -#line 996 "c-parse.y" +#line 902 "c-parse.y" { finish_init (); finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 167: -#line 999 "c-parse.y" +#line 905 "c-parse.y" { tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0, yyvsp[0].ttype, prefix_attributes); finish_decl (d, NULL_TREE, yyvsp[-1].ttype); ; break;} case 168: -#line 1007 "c-parse.y" +#line 913 "c-parse.y" { yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1, yyvsp[-1].ttype, prefix_attributes); start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ; break;} case 169: -#line 1012 "c-parse.y" +#line 918 "c-parse.y" { finish_init (); decl_attributes (yyvsp[-1].ttype, yyvsp[-3].ttype, prefix_attributes); finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 170: -#line 1016 "c-parse.y" +#line 922 "c-parse.y" { tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0, yyvsp[0].ttype, prefix_attributes); finish_decl (d, NULL_TREE, yyvsp[-1].ttype); ; break;} case 171: -#line 1024 "c-parse.y" +#line 930 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 172: -#line 1026 "c-parse.y" +#line 932 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 173: -#line 1031 "c-parse.y" +#line 937 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 174: -#line 1033 "c-parse.y" +#line 939 "c-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 175: -#line 1038 "c-parse.y" +#line 944 "c-parse.y" { yyval.ttype = yyvsp[-2].ttype; ; break;} case 176: -#line 1043 "c-parse.y" +#line 949 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 177: -#line 1045 "c-parse.y" +#line 951 "c-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 178: -#line 1050 "c-parse.y" +#line 956 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 179: -#line 1052 "c-parse.y" +#line 958 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ; break;} case 180: -#line 1054 "c-parse.y" +#line 960 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ; break;} case 181: -#line 1056 "c-parse.y" +#line 962 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ; break;} case 182: -#line 1058 "c-parse.y" +#line 964 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 188: -#line 1076 "c-parse.y" +#line 982 "c-parse.y" { really_start_incremental_init (NULL_TREE); ; break;} case 189: -#line 1078 "c-parse.y" +#line 984 "c-parse.y" { yyval.ttype = pop_init_level (0); ; break;} case 190: -#line 1080 "c-parse.y" +#line 986 "c-parse.y" { yyval.ttype = error_mark_node; ; break;} case 191: -#line 1086 "c-parse.y" +#line 992 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids empty initializer braces"); ; break;} case 197: -#line 1102 "c-parse.y" +#line 1008 "c-parse.y" { set_init_label (yyvsp[-1].ttype); ; break;} case 200: -#line 1109 "c-parse.y" +#line 1015 "c-parse.y" { push_init_level (0); ; break;} case 201: -#line 1111 "c-parse.y" +#line 1017 "c-parse.y" { process_init_element (pop_init_level (0)); ; break;} case 202: -#line 1113 "c-parse.y" +#line 1019 "c-parse.y" { process_init_element (yyvsp[0].ttype); ; break;} case 206: -#line 1124 "c-parse.y" +#line 1030 "c-parse.y" { set_init_label (yyvsp[0].ttype); ; break;} case 207: -#line 1129 "c-parse.y" +#line 1035 "c-parse.y" { set_init_index (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 208: -#line 1131 "c-parse.y" +#line 1037 "c-parse.y" { set_init_index (yyvsp[-1].ttype, NULL_TREE); ; break;} case 209: -#line 1136 "c-parse.y" +#line 1042 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids nested functions"); @@ -2779,16 +2685,16 @@ case 209: reinit_parse_for_function (); ; break;} case 210: -#line 1148 "c-parse.y" +#line 1054 "c-parse.y" { store_parm_decls (); ; break;} case 211: -#line 1156 "c-parse.y" +#line 1062 "c-parse.y" { finish_function (1); pop_function_context (); ; break;} case 212: -#line 1162 "c-parse.y" +#line 1068 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids nested functions"); @@ -2802,216 +2708,216 @@ case 212: reinit_parse_for_function (); ; break;} case 213: -#line 1174 "c-parse.y" +#line 1080 "c-parse.y" { store_parm_decls (); ; break;} case 214: -#line 1182 "c-parse.y" +#line 1088 "c-parse.y" { finish_function (1); pop_function_context (); ; break;} case 217: -#line 1198 "c-parse.y" +#line 1104 "c-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 218: -#line 1200 "c-parse.y" +#line 1106 "c-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 219: -#line 1205 "c-parse.y" +#line 1111 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 220: -#line 1207 "c-parse.y" +#line 1113 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 221: -#line 1209 "c-parse.y" +#line 1115 "c-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 222: -#line 1216 "c-parse.y" +#line 1122 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 224: -#line 1227 "c-parse.y" +#line 1133 "c-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 225: -#line 1232 "c-parse.y" +#line 1138 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, NULL_TREE); if (! flag_isoc99) error ("`[*]' in parameter declaration only allowed in ISO C 99"); ; break;} case 226: -#line 1237 "c-parse.y" +#line 1143 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 227: -#line 1239 "c-parse.y" +#line 1145 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 228: -#line 1241 "c-parse.y" +#line 1147 "c-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 229: -#line 1248 "c-parse.y" +#line 1154 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 231: -#line 1257 "c-parse.y" +#line 1163 "c-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 232: -#line 1262 "c-parse.y" +#line 1168 "c-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 233: -#line 1264 "c-parse.y" +#line 1170 "c-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 234: -#line 1266 "c-parse.y" +#line 1172 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, NULL_TREE); if (! flag_isoc99) error ("`[*]' in parameter declaration only allowed in ISO C 99"); ; break;} case 235: -#line 1271 "c-parse.y" +#line 1177 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 236: -#line 1273 "c-parse.y" +#line 1179 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 237: -#line 1280 "c-parse.y" +#line 1186 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 239: -#line 1286 "c-parse.y" +#line 1192 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 240: -#line 1288 "c-parse.y" +#line 1194 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 241: -#line 1293 "c-parse.y" +#line 1199 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 242: -#line 1295 "c-parse.y" +#line 1201 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 243: -#line 1300 "c-parse.y" +#line 1206 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 244: -#line 1302 "c-parse.y" +#line 1208 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 245: -#line 1307 "c-parse.y" +#line 1213 "c-parse.y" { yyval.ttype = start_struct (RECORD_TYPE, yyvsp[-1].ttype); /* Start scope of tag before parsing components. */ ; break;} case 246: -#line 1311 "c-parse.y" +#line 1217 "c-parse.y" { yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, chainon (yyvsp[-6].ttype, yyvsp[0].ttype)); ; break;} case 247: -#line 1313 "c-parse.y" +#line 1219 "c-parse.y" { yyval.ttype = finish_struct (start_struct (RECORD_TYPE, NULL_TREE), yyvsp[-2].ttype, chainon (yyvsp[-4].ttype, yyvsp[0].ttype)); ; break;} case 248: -#line 1317 "c-parse.y" +#line 1223 "c-parse.y" { yyval.ttype = xref_tag (RECORD_TYPE, yyvsp[0].ttype); ; break;} case 249: -#line 1319 "c-parse.y" +#line 1225 "c-parse.y" { yyval.ttype = start_struct (UNION_TYPE, yyvsp[-1].ttype); ; break;} case 250: -#line 1321 "c-parse.y" +#line 1227 "c-parse.y" { yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, chainon (yyvsp[-6].ttype, yyvsp[0].ttype)); ; break;} case 251: -#line 1323 "c-parse.y" +#line 1229 "c-parse.y" { yyval.ttype = finish_struct (start_struct (UNION_TYPE, NULL_TREE), yyvsp[-2].ttype, chainon (yyvsp[-4].ttype, yyvsp[0].ttype)); ; break;} case 252: -#line 1327 "c-parse.y" +#line 1233 "c-parse.y" { yyval.ttype = xref_tag (UNION_TYPE, yyvsp[0].ttype); ; break;} case 253: -#line 1329 "c-parse.y" +#line 1235 "c-parse.y" { yyval.ttype = start_enum (yyvsp[-1].ttype); ; break;} case 254: -#line 1331 "c-parse.y" +#line 1237 "c-parse.y" { yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), chainon (yyvsp[-7].ttype, yyvsp[0].ttype)); ; break;} case 255: -#line 1334 "c-parse.y" +#line 1240 "c-parse.y" { yyval.ttype = start_enum (NULL_TREE); ; break;} case 256: -#line 1336 "c-parse.y" +#line 1242 "c-parse.y" { yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), chainon (yyvsp[-6].ttype, yyvsp[0].ttype)); ; break;} case 257: -#line 1339 "c-parse.y" +#line 1245 "c-parse.y" { yyval.ttype = xref_tag (ENUMERAL_TYPE, yyvsp[0].ttype); ; break;} case 261: -#line 1350 "c-parse.y" +#line 1256 "c-parse.y" { if (pedantic && ! flag_isoc99) pedwarn ("comma at end of enumerator list"); ; break;} case 262: -#line 1356 "c-parse.y" +#line 1262 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 263: -#line 1358 "c-parse.y" +#line 1264 "c-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); pedwarn ("no semicolon at end of struct or union"); ; break;} case 264: -#line 1363 "c-parse.y" +#line 1269 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 265: -#line 1365 "c-parse.y" +#line 1271 "c-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 266: -#line 1367 "c-parse.y" +#line 1273 "c-parse.y" { if (pedantic) pedwarn ("extra semicolon in struct or union specified"); ; break;} case 267: -#line 1382 "c-parse.y" +#line 1288 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 268: -#line 1387 "c-parse.y" +#line 1293 "c-parse.y" { /* Support for unnamed structs or unions as members of structs or unions (which is [a] useful and [b] supports @@ -3026,151 +2932,151 @@ case 268: ; break;} case 269: -#line 1400 "c-parse.y" +#line 1306 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 270: -#line 1405 "c-parse.y" +#line 1311 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids member declarations with no members"); shadow_tag(yyvsp[0].ttype); yyval.ttype = NULL_TREE; ; break;} case 271: -#line 1410 "c-parse.y" +#line 1316 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 272: -#line 1412 "c-parse.y" +#line 1318 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 274: -#line 1419 "c-parse.y" +#line 1325 "c-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 275: -#line 1424 "c-parse.y" +#line 1330 "c-parse.y" { yyval.ttype = grokfield (yyvsp[-3].filename, yyvsp[-2].lineno, yyvsp[-1].ttype, current_declspecs, NULL_TREE); decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ; break;} case 276: -#line 1428 "c-parse.y" +#line 1334 "c-parse.y" { yyval.ttype = grokfield (yyvsp[-5].filename, yyvsp[-4].lineno, yyvsp[-3].ttype, current_declspecs, yyvsp[-1].ttype); decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ; break;} case 277: -#line 1431 "c-parse.y" +#line 1337 "c-parse.y" { yyval.ttype = grokfield (yyvsp[-4].filename, yyvsp[-3].lineno, NULL_TREE, current_declspecs, yyvsp[-1].ttype); decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ; break;} case 279: -#line 1443 "c-parse.y" +#line 1349 "c-parse.y" { if (yyvsp[-2].ttype == error_mark_node) yyval.ttype = yyvsp[-2].ttype; else yyval.ttype = chainon (yyvsp[0].ttype, yyvsp[-2].ttype); ; break;} case 280: -#line 1448 "c-parse.y" +#line 1354 "c-parse.y" { yyval.ttype = error_mark_node; ; break;} case 281: -#line 1454 "c-parse.y" +#line 1360 "c-parse.y" { yyval.ttype = build_enumerator (yyvsp[0].ttype, NULL_TREE); ; break;} case 282: -#line 1456 "c-parse.y" +#line 1362 "c-parse.y" { yyval.ttype = build_enumerator (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 283: -#line 1461 "c-parse.y" +#line 1367 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 284: -#line 1463 "c-parse.y" +#line 1369 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 285: -#line 1468 "c-parse.y" +#line 1374 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 287: -#line 1474 "c-parse.y" +#line 1380 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 288: -#line 1476 "c-parse.y" +#line 1382 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 289: -#line 1481 "c-parse.y" +#line 1387 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 290: -#line 1483 "c-parse.y" +#line 1389 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 291: -#line 1488 "c-parse.y" +#line 1394 "c-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 292: -#line 1491 "c-parse.y" +#line 1397 "c-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 293: -#line 1493 "c-parse.y" +#line 1399 "c-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ; break;} case 294: -#line 1495 "c-parse.y" +#line 1401 "c-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 295: -#line 1497 "c-parse.y" +#line 1403 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 296: -#line 1499 "c-parse.y" +#line 1405 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 297: -#line 1501 "c-parse.y" +#line 1407 "c-parse.y" { yyval.ttype = build_nt (CALL_EXPR, NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 298: -#line 1503 "c-parse.y" +#line 1409 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ; break;} case 299: -#line 1505 "c-parse.y" +#line 1411 "c-parse.y" { yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, NULL_TREE); ; break;} case 300: -#line 1509 "c-parse.y" +#line 1415 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 301: -#line 1518 "c-parse.y" +#line 1424 "c-parse.y" { if (pedantic && yyvsp[0].ends_in_label) pedwarn ("ANSI C forbids label at end of compound statement"); ; break;} case 303: -#line 1527 "c-parse.y" +#line 1433 "c-parse.y" { yyval.ends_in_label = yyvsp[0].ends_in_label; ; break;} case 304: -#line 1529 "c-parse.y" +#line 1435 "c-parse.y" { yyval.ends_in_label = 0; ; break;} case 308: -#line 1541 "c-parse.y" +#line 1447 "c-parse.y" { emit_line_note (input_filename, lineno); pushlevel (0); clear_last_expr (); @@ -3178,12 +3084,12 @@ case 308: ; break;} case 310: -#line 1553 "c-parse.y" +#line 1459 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids label declarations"); ; break;} case 313: -#line 1564 "c-parse.y" +#line 1470 "c-parse.y" { tree link; for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link)) { @@ -3194,37 +3100,37 @@ case 313: ; break;} case 314: -#line 1578 "c-parse.y" +#line 1484 "c-parse.y" {; break;} case 316: -#line 1582 "c-parse.y" +#line 1488 "c-parse.y" { compstmt_count++; ; break;} case 317: -#line 1585 "c-parse.y" +#line 1491 "c-parse.y" { yyval.ttype = convert (void_type_node, integer_zero_node); ; break;} case 318: -#line 1587 "c-parse.y" +#line 1493 "c-parse.y" { emit_line_note (input_filename, lineno); expand_end_bindings (getdecls (), 1, 0); yyval.ttype = poplevel (1, 1, 0); ; break;} case 319: -#line 1591 "c-parse.y" +#line 1497 "c-parse.y" { emit_line_note (input_filename, lineno); expand_end_bindings (getdecls (), kept_level_p (), 0); yyval.ttype = poplevel (kept_level_p (), 0, 0); ; break;} case 320: -#line 1595 "c-parse.y" +#line 1501 "c-parse.y" { emit_line_note (input_filename, lineno); expand_end_bindings (getdecls (), kept_level_p (), 0); yyval.ttype = poplevel (kept_level_p (), 0, 0); ; break;} case 321: -#line 1602 "c-parse.y" +#line 1508 "c-parse.y" { if (current_function_decl == 0) { error ("braced-group within expression allowed only inside a function"); @@ -3242,11 +3148,11 @@ case 321: ; break;} case 322: -#line 1619 "c-parse.y" +#line 1525 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 325: -#line 1633 "c-parse.y" +#line 1539 "c-parse.y" { emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno); c_expand_start_cond (truthvalue_conversion (yyvsp[-1].ttype), 0, compstmt_count); @@ -3256,7 +3162,7 @@ case 325: position_after_white_space (); ; break;} case 326: -#line 1647 "c-parse.y" +#line 1553 "c-parse.y" { stmt_count++; compstmt_count++; emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno); @@ -3266,43 +3172,43 @@ case 326: position_after_white_space (); ; break;} case 327: -#line 1655 "c-parse.y" +#line 1561 "c-parse.y" { expand_loop_continue_here (); ; break;} case 328: -#line 1659 "c-parse.y" +#line 1565 "c-parse.y" { yyval.filename = input_filename; ; break;} case 329: -#line 1663 "c-parse.y" +#line 1569 "c-parse.y" { yyval.lineno = lineno; ; break;} case 330: -#line 1668 "c-parse.y" +#line 1574 "c-parse.y" { ; break;} case 331: -#line 1673 "c-parse.y" +#line 1579 "c-parse.y" { ; break;} case 332: -#line 1678 "c-parse.y" +#line 1584 "c-parse.y" { yyval.ends_in_label = yyvsp[0].ends_in_label; ; break;} case 333: -#line 1683 "c-parse.y" +#line 1589 "c-parse.y" { yyval.ends_in_label = 0; ; break;} case 334: -#line 1685 "c-parse.y" +#line 1591 "c-parse.y" { yyval.ends_in_label = 1; ; break;} case 335: -#line 1691 "c-parse.y" +#line 1597 "c-parse.y" { stmt_count++; ; break;} case 337: -#line 1694 "c-parse.y" +#line 1600 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); /* It appears that this should not be done--that a non-lvalue array @@ -3320,19 +3226,19 @@ case 337: iterator_expand (yyvsp[-1].ttype); ; break;} case 338: -#line 1710 "c-parse.y" +#line 1616 "c-parse.y" { c_expand_start_else (); yyvsp[-1].itype = stmt_count; position_after_white_space (); ; break;} case 339: -#line 1714 "c-parse.y" +#line 1620 "c-parse.y" { c_expand_end_cond (); if (extra_warnings && stmt_count == yyvsp[-3].itype) warning ("empty body in an else-statement"); ; break;} case 340: -#line 1718 "c-parse.y" +#line 1624 "c-parse.y" { c_expand_end_cond (); /* This warning is here instead of in simple_if, because we do not want a warning if an empty if is followed by an @@ -3343,11 +3249,11 @@ case 340: "empty body in an if-statement"); ; break;} case 341: -#line 1730 "c-parse.y" +#line 1636 "c-parse.y" { c_expand_end_cond (); ; break;} case 342: -#line 1732 "c-parse.y" +#line 1638 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno); /* The emit_nop used to come before emit_line_note, @@ -3359,7 +3265,7 @@ case 342: emit_nop (); ; break;} case 343: -#line 1742 "c-parse.y" +#line 1648 "c-parse.y" { /* Don't start the loop till we have succeeded in parsing the end test. This is to make sure that we end every loop we start. */ @@ -3370,22 +3276,22 @@ case 343: position_after_white_space (); ; break;} case 344: -#line 1751 "c-parse.y" +#line 1657 "c-parse.y" { expand_end_loop (); ; break;} case 345: -#line 1754 "c-parse.y" +#line 1660 "c-parse.y" { emit_line_note (input_filename, lineno); expand_exit_loop_if_false (NULL_PTR, truthvalue_conversion (yyvsp[-2].ttype)); expand_end_loop (); ; break;} case 346: -#line 1760 "c-parse.y" +#line 1666 "c-parse.y" { expand_end_loop (); ; break;} case 347: -#line 1763 "c-parse.y" +#line 1669 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno); /* See comment in `while' alternative, above. */ @@ -3398,12 +3304,12 @@ case 347: ; break;} case 348: -#line 1775 "c-parse.y" +#line 1681 "c-parse.y" { yyvsp[0].lineno = lineno; yyval.filename = input_filename; ; break;} case 349: -#line 1778 "c-parse.y" +#line 1684 "c-parse.y" { /* Start the loop. Doing this after parsing all the expressions ensures we will end the loop. */ @@ -3418,7 +3324,7 @@ case 349: position_after_white_space (); ; break;} case 350: -#line 1791 "c-parse.y" +#line 1697 "c-parse.y" { /* Emit the increment expression, with a line number. */ emit_line_note (yyvsp[-4].filename, yyvsp[-5].lineno); expand_loop_continue_here (); @@ -3427,44 +3333,44 @@ case 350: expand_end_loop (); ; break;} case 351: -#line 1798 "c-parse.y" +#line 1704 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno); c_expand_start_case (yyvsp[-1].ttype); position_after_white_space (); ; break;} case 352: -#line 1803 "c-parse.y" +#line 1709 "c-parse.y" { expand_end_case (yyvsp[-3].ttype); ; break;} case 353: -#line 1805 "c-parse.y" +#line 1711 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); if ( ! expand_exit_something ()) error ("break statement not within loop or switch"); ; break;} case 354: -#line 1810 "c-parse.y" +#line 1716 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); if (! expand_continue_loop (NULL_PTR)) error ("continue statement not within a loop"); ; break;} case 355: -#line 1815 "c-parse.y" +#line 1721 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); c_expand_return (NULL_TREE); ; break;} case 356: -#line 1819 "c-parse.y" +#line 1725 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno); c_expand_return (yyvsp[-1].ttype); ; break;} case 357: -#line 1823 "c-parse.y" +#line 1729 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-7].filename, yyvsp[-6].lineno); STRIP_NOPS (yyvsp[-2].ttype); @@ -3476,7 +3382,7 @@ case 357: error ("argument of `asm' is not a constant string"); ; break;} case 358: -#line 1834 "c-parse.y" +#line 1740 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-9].filename, yyvsp[-8].lineno); c_expand_asm_operands (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE, @@ -3484,7 +3390,7 @@ case 358: input_filename, lineno); ; break;} case 359: -#line 1841 "c-parse.y" +#line 1747 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-11].filename, yyvsp[-10].lineno); c_expand_asm_operands (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, @@ -3492,7 +3398,7 @@ case 359: input_filename, lineno); ; break;} case 360: -#line 1849 "c-parse.y" +#line 1755 "c-parse.y" { stmt_count++; emit_line_note (yyvsp[-13].filename, yyvsp[-12].lineno); c_expand_asm_operands (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, @@ -3500,7 +3406,7 @@ case 360: input_filename, lineno); ; break;} case 361: -#line 1855 "c-parse.y" +#line 1761 "c-parse.y" { tree decl; stmt_count++; emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno); @@ -3513,7 +3419,7 @@ case 361: ; break;} case 362: -#line 1866 "c-parse.y" +#line 1772 "c-parse.y" { if (pedantic) pedwarn ("ANSI C forbids `goto *expr;'"); stmt_count++; @@ -3521,7 +3427,7 @@ case 362: expand_computed_goto (convert (ptr_type_node, yyvsp[-1].ttype)); ; break;} case 365: -#line 1881 "c-parse.y" +#line 1787 "c-parse.y" { /* The value returned by this action is */ /* 1 if everything is OK */ @@ -3544,14 +3450,14 @@ case 365: ; break;} case 366: -#line 1902 "c-parse.y" +#line 1808 "c-parse.y" { if (yyvsp[-1].itype) iterator_for_loop_end (yyvsp[-3].ttype); ; break;} case 367: -#line 1933 "c-parse.y" +#line 1839 "c-parse.y" { register tree value = check_case_value (yyvsp[-1].ttype); register tree label = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE); @@ -3584,7 +3490,7 @@ case 367: position_after_white_space (); ; break;} case 368: -#line 1964 "c-parse.y" +#line 1870 "c-parse.y" { register tree value1 = check_case_value (yyvsp[-3].ttype); register tree value2 = check_case_value (yyvsp[-1].ttype); register tree label @@ -3617,7 +3523,7 @@ case 368: position_after_white_space (); ; break;} case 369: -#line 1995 "c-parse.y" +#line 1901 "c-parse.y" { tree duplicate; register tree label @@ -3634,7 +3540,7 @@ case 369: position_after_white_space (); ; break;} case 370: -#line 2010 "c-parse.y" +#line 1916 "c-parse.y" { tree label = define_label (input_filename, lineno, yyvsp[-2].ttype); stmt_count++; emit_nop (); @@ -3646,52 +3552,52 @@ case 370: position_after_white_space (); ; break;} case 371: -#line 2025 "c-parse.y" +#line 1931 "c-parse.y" { emit_line_note (input_filename, lineno); yyval.ttype = NULL_TREE; ; break;} case 372: -#line 2028 "c-parse.y" +#line 1934 "c-parse.y" { emit_line_note (input_filename, lineno); ; break;} case 373: -#line 2033 "c-parse.y" +#line 1939 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 375: -#line 2040 "c-parse.y" +#line 1946 "c-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 378: -#line 2047 "c-parse.y" +#line 1953 "c-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 379: -#line 2052 "c-parse.y" +#line 1958 "c-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 380: -#line 2057 "c-parse.y" +#line 1963 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), NULL_TREE); ; break;} case 381: -#line 2059 "c-parse.y" +#line 1965 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), yyvsp[-2].ttype); ; break;} case 382: -#line 2065 "c-parse.y" +#line 1971 "c-parse.y" { pushlevel (0); clear_parm_order (); declare_parm_level (0); ; break;} case 383: -#line 2069 "c-parse.y" +#line 1975 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; parmlist_tags_warning (); poplevel (0, 0, 0); ; break;} case 385: -#line 2077 "c-parse.y" +#line 1983 "c-parse.y" { tree parm; if (pedantic) pedwarn ("ANSI C forbids forward parameter declarations"); @@ -3701,19 +3607,19 @@ case 385: clear_parm_order (); ; break;} case 386: -#line 2085 "c-parse.y" +#line 1991 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 387: -#line 2087 "c-parse.y" +#line 1993 "c-parse.y" { yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, NULL_TREE); ; break;} case 388: -#line 2093 "c-parse.y" +#line 1999 "c-parse.y" { yyval.ttype = get_parm_info (0); ; break;} case 389: -#line 2095 "c-parse.y" +#line 2001 "c-parse.y" { yyval.ttype = get_parm_info (0); /* Gcc used to allow this as an extension. However, it does not work for all targets, and thus has been disabled. @@ -3725,23 +3631,23 @@ case 389: ; break;} case 390: -#line 2105 "c-parse.y" +#line 2011 "c-parse.y" { yyval.ttype = get_parm_info (1); ; break;} case 391: -#line 2107 "c-parse.y" +#line 2013 "c-parse.y" { yyval.ttype = get_parm_info (0); ; break;} case 392: -#line 2112 "c-parse.y" +#line 2018 "c-parse.y" { push_parm_decl (yyvsp[0].ttype); ; break;} case 393: -#line 2114 "c-parse.y" +#line 2020 "c-parse.y" { push_parm_decl (yyvsp[0].ttype); ; break;} case 394: -#line 2121 "c-parse.y" +#line 2027 "c-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -3751,7 +3657,7 @@ case 394: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 395: -#line 2129 "c-parse.y" +#line 2035 "c-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -3761,7 +3667,7 @@ case 395: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 396: -#line 2137 "c-parse.y" +#line 2043 "c-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -3771,7 +3677,7 @@ case 396: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 397: -#line 2145 "c-parse.y" +#line 2051 "c-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -3781,7 +3687,7 @@ case 397: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 398: -#line 2154 "c-parse.y" +#line 2060 "c-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -3791,19 +3697,19 @@ case 398: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 399: -#line 2167 "c-parse.y" +#line 2073 "c-parse.y" { pushlevel (0); clear_parm_order (); declare_parm_level (1); ; break;} case 400: -#line 2171 "c-parse.y" +#line 2077 "c-parse.y" { yyval.ttype = yyvsp[0].ttype; parmlist_tags_warning (); poplevel (0, 0, 0); ; break;} case 402: -#line 2179 "c-parse.y" +#line 2085 "c-parse.y" { tree t; for (t = yyvsp[-1].ttype; t; t = TREE_CHAIN (t)) if (TREE_VALUE (t) == NULL_TREE) @@ -3811,30 +3717,30 @@ case 402: yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, yyvsp[-1].ttype); ; break;} case 403: -#line 2189 "c-parse.y" +#line 2095 "c-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 404: -#line 2191 "c-parse.y" +#line 2097 "c-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 405: -#line 2197 "c-parse.y" +#line 2103 "c-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 406: -#line 2199 "c-parse.y" +#line 2105 "c-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 407: -#line 2204 "c-parse.y" +#line 2110 "c-parse.y" { yyval.ttype = SAVE_WARN_FLAGS(); pedantic = 0; warn_pointer_arith = 0; ; break;} } /* the action file gets copied in in place of this dollarsign */ -#line 543 "/usr/lib/bison.simple" +#line 543 "/usr/share/misc/bison.simple" yyvsp -= yylen; yyssp -= yylen; @@ -4054,5 +3960,5 @@ yyerrhandle: } return 1; } -#line 2209 "c-parse.y" +#line 2115 "c-parse.y" diff --git a/gcc/c-parse.in b/gcc/c-parse.in index aa54751..7efe9cd 100644 --- a/gcc/c-parse.in +++ b/gcc/c-parse.in @@ -226,9 +226,6 @@ static tree prefix_attributes = NULL_TREE; /* Stack of saved values of current_declspecs and prefix_attributes. */ static tree declspec_stack; -/* 1 if we explained undeclared var errors. */ -static int undeclared_variable_notice; - /* For __extension__, save/restore the warning flags which are controlled by __extension__. */ #define SAVE_WARN_FLAGS() \ @@ -628,169 +625,9 @@ expr_no_commas: primary: IDENTIFIER { - $$ = lastiddecl; - if (!$$ || $$ == error_mark_node) - { - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { -ifobjc - tree decl; - - if (objc_receiver_context - && ! (objc_receiver_context - && strcmp (IDENTIFIER_POINTER ($1), "super"))) - /* we have a message to super */ - $$ = get_super_receiver (); - else if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, $1))) - { - if (is_private (decl)) - $$ = error_mark_node; - else - $$ = build_ivar_reference ($1); - } - else -end ifobjc - { - /* Ordinary implicit function declaration. */ - $$ = implicitly_declare ($1); - assemble_external ($$); - TREE_USED ($$) = 1; - } - } - else if (current_function_decl == 0) - { - error ("`%s' undeclared here (not in a function)", - IDENTIFIER_POINTER ($1)); - $$ = error_mark_node; - } - else - { -ifobjc - tree decl; - - if (objc_receiver_context - && ! strcmp (IDENTIFIER_POINTER ($1), "super")) - /* we have a message to super */ - $$ = get_super_receiver (); - else if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, $1))) - { - if (is_private (decl)) - $$ = error_mark_node; - else - $$ = build_ivar_reference ($1); - } - else -end ifobjc - { - if (IDENTIFIER_GLOBAL_VALUE ($1) != error_mark_node - || IDENTIFIER_ERROR_LOCUS ($1) != current_function_decl) - { - error ("`%s' undeclared (first use in this function)", - IDENTIFIER_POINTER ($1)); - - if (! undeclared_variable_notice) - { - error ("(Each undeclared identifier is reported only once"); - error ("for each function it appears in.)"); - undeclared_variable_notice = 1; - } - } - $$ = error_mark_node; - /* Prevent repeated error messages. */ - IDENTIFIER_GLOBAL_VALUE ($1) = error_mark_node; - IDENTIFIER_ERROR_LOCUS ($1) = current_function_decl; - } - } - } - else if (TREE_TYPE ($$) == error_mark_node) - $$ = error_mark_node; - else if (C_DECL_ANTICIPATED ($$)) - { - /* The first time we see a build-in function used, - if it has not been declared. */ - C_DECL_ANTICIPATED ($$) = 0; - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - /* Omit the implicit declaration we - would ordinarily do, so we don't lose - the actual built in type. - But print a diagnostic for the mismatch. */ -ifobjc - if (objc_method_context - && is_ivar (objc_ivar_chain, $1)) - error ("Instance variable `%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME ($$))); - else -end ifobjc - if (TREE_CODE ($$) != FUNCTION_DECL) - error ("`%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME ($$))); - else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE ($$))) - != TYPE_MODE (integer_type_node)) - && !VOID_TYPE_P (TREE_TYPE (TREE_TYPE ($$)))) - pedwarn ("type mismatch in implicit declaration for built-in function `%s'", - IDENTIFIER_POINTER (DECL_NAME ($$))); - /* If it really returns void, change that to int. */ - if (TREE_TYPE (TREE_TYPE ($$)) == void_type_node) - TREE_TYPE ($$) - = build_function_type (integer_type_node, - TYPE_ARG_TYPES (TREE_TYPE ($$))); - } - else - pedwarn ("built-in function `%s' used without declaration", - IDENTIFIER_POINTER (DECL_NAME ($$))); - - /* Do what we would ordinarily do when a fn is used. */ - assemble_external ($$); - TREE_USED ($$) = 1; - } - else - { - assemble_external ($$); - TREE_USED ($$) = 1; -ifobjc - /* we have a definition - still check if iVariable */ - - if (!objc_receiver_context - || (objc_receiver_context - && strcmp (IDENTIFIER_POINTER ($1), "super"))) - { - tree decl; - - if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, $1))) - { - if (IDENTIFIER_LOCAL_VALUE ($1)) - warning ("local declaration of `%s' hides instance variable", - IDENTIFIER_POINTER ($1)); - else - { - if (is_private (decl)) - $$ = error_mark_node; - else - $$ = build_ivar_reference ($1); - } - } - } - else /* we have a message to super */ - $$ = get_super_receiver (); -end ifobjc - } - - if (TREE_CODE ($$) == CONST_DECL) - { - $$ = DECL_INITIAL ($$); - /* This is to prevent an enum whose value is 0 - from being considered a null pointer constant. */ - $$ = build1 (NOP_EXPR, TREE_TYPE ($$), $$); - TREE_CONSTANT ($$) = 1; - } + if (yychar == YYEMPTY) + yychar = YYLEX; + $$ = build_external_ref ($1, yychar == '('); } | CONSTANT | string diff --git a/gcc/c-parse.y b/gcc/c-parse.y index e86cbda..e7c1d88 100644 --- a/gcc/c-parse.y +++ b/gcc/c-parse.y @@ -201,9 +201,6 @@ static tree prefix_attributes = NULL_TREE; /* Stack of saved values of current_declspecs and prefix_attributes. */ static tree declspec_stack; -/* 1 if we explained undeclared var errors. */ -static int undeclared_variable_notice; - /* For __extension__, save/restore the warning flags which are controlled by __extension__. */ #define SAVE_WARN_FLAGS() \ @@ -576,100 +573,9 @@ expr_no_commas: primary: IDENTIFIER { - $$ = lastiddecl; - if (!$$ || $$ == error_mark_node) - { - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - { - /* Ordinary implicit function declaration. */ - $$ = implicitly_declare ($1); - assemble_external ($$); - TREE_USED ($$) = 1; - } - } - else if (current_function_decl == 0) - { - error ("`%s' undeclared here (not in a function)", - IDENTIFIER_POINTER ($1)); - $$ = error_mark_node; - } - else - { - { - if (IDENTIFIER_GLOBAL_VALUE ($1) != error_mark_node - || IDENTIFIER_ERROR_LOCUS ($1) != current_function_decl) - { - error ("`%s' undeclared (first use in this function)", - IDENTIFIER_POINTER ($1)); - - if (! undeclared_variable_notice) - { - error ("(Each undeclared identifier is reported only once"); - error ("for each function it appears in.)"); - undeclared_variable_notice = 1; - } - } - $$ = error_mark_node; - /* Prevent repeated error messages. */ - IDENTIFIER_GLOBAL_VALUE ($1) = error_mark_node; - IDENTIFIER_ERROR_LOCUS ($1) = current_function_decl; - } - } - } - else if (TREE_TYPE ($$) == error_mark_node) - $$ = error_mark_node; - else if (C_DECL_ANTICIPATED ($$)) - { - /* The first time we see a build-in function used, - if it has not been declared. */ - C_DECL_ANTICIPATED ($$) = 0; - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - /* Omit the implicit declaration we - would ordinarily do, so we don't lose - the actual built in type. - But print a diagnostic for the mismatch. */ - if (TREE_CODE ($$) != FUNCTION_DECL) - error ("`%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME ($$))); - else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE ($$))) - != TYPE_MODE (integer_type_node)) - && !VOID_TYPE_P (TREE_TYPE (TREE_TYPE ($$)))) - pedwarn ("type mismatch in implicit declaration for built-in function `%s'", - IDENTIFIER_POINTER (DECL_NAME ($$))); - /* If it really returns void, change that to int. */ - if (TREE_TYPE (TREE_TYPE ($$)) == void_type_node) - TREE_TYPE ($$) - = build_function_type (integer_type_node, - TYPE_ARG_TYPES (TREE_TYPE ($$))); - } - else - pedwarn ("built-in function `%s' used without declaration", - IDENTIFIER_POINTER (DECL_NAME ($$))); - - /* Do what we would ordinarily do when a fn is used. */ - assemble_external ($$); - TREE_USED ($$) = 1; - } - else - { - assemble_external ($$); - TREE_USED ($$) = 1; - } - - if (TREE_CODE ($$) == CONST_DECL) - { - $$ = DECL_INITIAL ($$); - /* This is to prevent an enum whose value is 0 - from being considered a null pointer constant. */ - $$ = build1 (NOP_EXPR, TREE_TYPE ($$), $$); - TREE_CONSTANT ($$) = 1; - } + if (yychar == YYEMPTY) + yychar = YYLEX; + $$ = build_external_ref ($1, yychar == '('); } | CONSTANT | string diff --git a/gcc/c-tree.h b/gcc/c-tree.h index ae27e61..7c86e26 100644 --- a/gcc/c-tree.h +++ b/gcc/c-tree.h @@ -163,6 +163,7 @@ extern tree maybe_building_objc_message_expr PARAMS ((void)); extern tree maybe_objc_method_name PARAMS ((tree)); extern int recognize_objc_keyword PARAMS ((void)); extern tree build_objc_string PARAMS ((int, const char *)); +extern tree lookup_objc_ivar PARAMS ((tree)); /* in c-parse.in */ extern void c_parse_init PARAMS ((void)); @@ -263,6 +264,7 @@ extern tree default_conversion PARAMS ((tree)); extern tree build_component_ref PARAMS ((tree, tree)); extern tree build_indirect_ref PARAMS ((tree, const char *)); extern tree build_array_ref PARAMS ((tree, tree)); +extern tree build_external_ref PARAMS ((tree, int)); extern tree build_function_call PARAMS ((tree, tree)); extern tree parser_build_binary_op PARAMS ((enum tree_code, tree, tree)); diff --git a/gcc/c-typeck.c b/gcc/c-typeck.c index 6f19fc4..ec7eaf9 100644 --- a/gcc/c-typeck.c +++ b/gcc/c-typeck.c @@ -47,6 +47,9 @@ Boston, MA 02111-1307, USA. */ message within this initializer. */ static int missing_braces_mentioned; +/* 1 if we explained undeclared var errors. */ +static int undeclared_variable_notice; + static tree qualify_type PARAMS ((tree, tree)); static int comp_target_types PARAMS ((tree, tree)); static int function_types_compatible_p PARAMS ((tree, tree)); @@ -1389,6 +1392,95 @@ build_array_ref (array, index) } } +/* Build an external reference to identifier ID. FUN indicates + whether this will be used for a function call. */ +tree +build_external_ref (id, fun) + tree id; + int fun; +{ + tree ref; + tree decl = lookup_name (id); + tree objc_ivar = lookup_objc_ivar (id); + + if (!decl || decl == error_mark_node || C_DECL_ANTICIPATED (decl)) + { + if (objc_ivar) + ref = objc_ivar; + else if (fun) + { + if (!decl || decl == error_mark_node) + /* Ordinary implicit function declaration. */ + ref = implicitly_declare (id); + else + { + /* Implicit declaration of built-in function. Don't + change the built-in declaration, but don't let this + go by silently, either. */ + pedwarn ("implicit declaration of function `%s'", + IDENTIFIER_POINTER (DECL_NAME (decl))); + C_DECL_ANTICIPATED (decl) = 0; /* only issue this warning once */ + ref = decl; + } + } + else + { + /* Reference to undeclared variable, including reference to + builtin outside of function-call context. */ + if (current_function_decl == 0) + error ("`%s' undeclared here (not in a function)", + IDENTIFIER_POINTER (id)); + else + { + if (IDENTIFIER_GLOBAL_VALUE (id) != error_mark_node + || IDENTIFIER_ERROR_LOCUS (id) != current_function_decl) + { + error ("`%s' undeclared (first use in this function)", + IDENTIFIER_POINTER (id)); + + if (! undeclared_variable_notice) + { + error ("(Each undeclared identifier is reported only once"); + error ("for each function it appears in.)"); + undeclared_variable_notice = 1; + } + } + IDENTIFIER_GLOBAL_VALUE (id) = error_mark_node; + IDENTIFIER_ERROR_LOCUS (id) = current_function_decl; + } + return error_mark_node; + } + } + else + { + /* Properly declared variable or function reference. */ + if (!objc_ivar) + ref = decl; + else if (decl != objc_ivar && IDENTIFIER_LOCAL_VALUE (id)) + { + warning ("local declaration of `%s' hides instance variable", + IDENTIFIER_POINTER (id)); + ref = decl; + } + else + ref = objc_ivar; + } + + if (TREE_TYPE (ref) == error_mark_node) + return error_mark_node; + + assemble_external (ref); + TREE_USED (ref) = 1; + + if (TREE_CODE (ref) == CONST_DECL) + { + ref = DECL_INITIAL (ref); + TREE_CONSTANT (ref) = 1; + } + + return ref; +} + /* Build a function call to function FUNCTION with parameters PARAMS. PARAMS is a list--a chain of TREE_LIST nodes--in which the TREE_VALUE of each node is a parameter-expression. diff --git a/gcc/objc/objc-act.c b/gcc/objc/objc-act.c index e1b9cd3..ac33492 100644 --- a/gcc/objc/objc-act.c +++ b/gcc/objc/objc-act.c @@ -8614,3 +8614,24 @@ objc_act_parse_init () ggc_add_root (&nst_method_hash_list, 1, sizeof nst_method_hash_list, ggc_mark_hash_table); ggc_add_root (&cls_method_hash_list, 1, sizeof cls_method_hash_list, ggc_mark_hash_table); } + +/* Look up ID as an instance variable. */ +tree +lookup_objc_ivar (id) + tree id; +{ + tree decl; + + if (objc_receiver_context && !strcmp (IDENTIFIER_POINTER (id), "super")) + /* we have a message to super */ + return get_super_receiver (); + else if (objc_method_context && (decl = is_ivar (objc_ivar_chain, id))) + { + if (is_private (decl)) + return error_mark_node; + else + return build_ivar_reference (id); + } + else + return 0; +} diff --git a/gcc/objc/objc-parse.c b/gcc/objc/objc-parse.c index d8c1d25..78040a2 100644 --- a/gcc/objc/objc-parse.c +++ b/gcc/objc/objc-parse.c @@ -121,9 +121,6 @@ static tree prefix_attributes = NULL_TREE; /* Stack of saved values of current_declspecs and prefix_attributes. */ static tree declspec_stack; -/* 1 if we explained undeclared var errors. */ -static int undeclared_variable_notice; - /* For __extension__, save/restore the warning flags which are controlled by __extension__. */ #define SAVE_WARN_FLAGS() \ @@ -462,63 +459,63 @@ static const short yyrhs[] = { -1, #if YYDEBUG != 0 static const short yyrline[] = { 0, - 264, 269, 283, 285, 285, 286, 288, 290, 291, 292, - 300, 304, 314, 318, 322, 324, 326, 327, 328, 333, - 340, 342, 346, 350, 356, 358, 362, 366, 372, 374, - 378, 384, 386, 387, 388, 391, 393, 395, 397, 399, - 401, 403, 407, 411, 414, 417, 420, 424, 426, 429, - 432, 436, 464, 470, 473, 476, 479, 481, 483, 487, - 491, 495, 497, 500, 504, 531, 533, 535, 537, 539, - 541, 543, 545, 547, 549, 551, 553, 555, 557, 561, - 563, 567, 569, 572, 576, 578, 585, 588, 596, 607, - 766, 767, 769, 775, 777, 800, 809, 811, 813, 825, - 839, 841, 843, 845, 847, 849, 851, 856, 858, 865, - 867, 871, 873, 874, 884, 889, 891, 892, 893, 900, - 905, 909, 912, 920, 925, 927, 928, 929, 936, 946, - 950, 955, 959, 963, 967, 969, 971, 980, 983, 987, - 989, 991, 996, 1000, 1003, 1007, 1010, 1012, 1024, 1027, - 1029, 1031, 1035, 1039, 1041, 1044, 1057, 1060, 1064, 1066, - 1074, 1075, 1076, 1080, 1082, 1087, 1089, 1091, 1097, 1098, - 1099, 1102, 1104, 1107, 1109, 1112, 1115, 1121, 1128, 1130, - 1137, 1144, 1147, 1154, 1157, 1161, 1164, 1168, 1173, 1176, - 1180, 1183, 1185, 1187, 1189, 1196, 1198, 1199, 1200, 1205, - 1207, 1209, 1211, 1216, 1220, 1223, 1225, 1230, 1232, 1233, - 1236, 1236, 1239, 1242, 1244, 1246, 1249, 1251, 1254, 1262, - 1276, 1284, 1288, 1302, 1310, 1317, 1319, 1324, 1327, 1332, - 1334, 1336, 1343, 1345, 1346, 1354, 1360, 1362, 1364, 1371, - 1373, 1379, 1385, 1387, 1389, 1391, 1398, 1400, 1403, 1406, - 1410, 1413, 1417, 1420, 1424, 1429, 1431, 1435, 1437, 1439, - 1441, 1445, 1447, 1449, 1452, 1454, 1457, 1461, 1463, 1466, - 1468, 1473, 1476, 1481, 1483, 1485, 1489, 1513, 1519, 1532, - 1537, 1542, 1544, 1549, 1551, 1555, 1559, 1563, 1573, 1575, - 1580, 1585, 1588, 1592, 1595, 1599, 1602, 1605, 1608, 1612, - 1615, 1619, 1623, 1625, 1627, 1629, 1631, 1633, 1635, 1637, - 1641, 1649, 1657, 1659, 1661, 1665, 1667, 1670, 1673, 1685, - 1687, 1692, 1694, 1697, 1711, 1714, 1717, 1719, 1721, 1725, - 1729, 1735, 1753, 1758, 1763, 1766, 1780, 1789, 1793, 1797, - 1801, 1807, 1811, 1816, 1819, 1824, 1827, 1828, 1844, 1849, - 1852, 1864, 1866, 1876, 1886, 1887, 1894, 1896, 1908, 1912, - 1926, 1932, 1938, 1939, 1944, 1949, 1953, 1957, 1968, 1975, - 1982, 1989, 2000, 2006, 2009, 2014, 2037, 2067, 2098, 2129, - 2144, 2158, 2162, 2166, 2169, 2174, 2176, 2179, 2181, 2185, - 2190, 2193, 2199, 2204, 2209, 2211, 2220, 2221, 2227, 2229, - 2239, 2241, 2245, 2248, 2254, 2263, 2271, 2279, 2288, 2301, - 2306, 2311, 2313, 2322, 2325, 2330, 2333, 2337, 2346, 2348, - 2349, 2350, 2351, 2352, 2366, 2369, 2373, 2379, 2385, 2392, - 2397, 2403, 2410, 2416, 2422, 2427, 2433, 2440, 2446, 2452, - 2458, 2466, 2472, 2478, 2486, 2493, 2499, 2508, 2515, 2523, - 2528, 2531, 2541, 2543, 2546, 2548, 2549, 2552, 2557, 2558, - 2575, 2581, 2586, 2590, 2593, 2594, 2597, 2605, 2611, 2620, - 2630, 2637, 2641, 2646, 2655, 2662, 2666, 2676, 2678, 2679, - 2681, 2683, 2684, 2685, 2686, 2688, 2690, 2693, 2701, 2708, - 2708, 2715, 2721, 2723, 2729, 2734, 2739, 2748, 2750, 2756, - 2758, 2761, 2763, 2764, 2765, 2768, 2773, 2775, 2779, 2782, - 2789, 2795, 2800, 2807, 2812, 2817, 2822, 2829, 2833, 2836, - 2842, 2844, 2845, 2846, 2849, 2851, 2852, 2853, 2854, 2855, - 2856, 2857, 2858, 2859, 2860, 2861, 2862, 2863, 2864, 2865, - 2866, 2867, 2868, 2869, 2869, 2872, 2878, 2883, 2888, 2894, - 2896, 2899, 2901, 2908, 2920, 2925, 2931, 2933, 2939, 2943, - 2944, 2950, 2952, 2955, 2957, 2963, 2968, 2974, 2981, 2990 + 261, 266, 280, 282, 282, 283, 285, 287, 288, 289, + 297, 301, 311, 315, 319, 321, 323, 324, 325, 330, + 337, 339, 343, 347, 353, 355, 359, 363, 369, 371, + 375, 381, 383, 384, 385, 388, 390, 392, 394, 396, + 398, 400, 404, 408, 411, 414, 417, 421, 423, 426, + 429, 433, 461, 467, 470, 473, 476, 478, 480, 484, + 488, 492, 494, 497, 501, 528, 530, 532, 534, 536, + 538, 540, 542, 544, 546, 548, 550, 552, 554, 558, + 560, 564, 566, 569, 573, 575, 582, 585, 593, 604, + 611, 612, 614, 620, 622, 645, 654, 656, 658, 670, + 684, 686, 688, 690, 692, 694, 696, 701, 703, 710, + 712, 716, 718, 719, 729, 734, 736, 737, 738, 745, + 750, 754, 757, 765, 770, 772, 773, 774, 781, 791, + 795, 800, 804, 808, 812, 814, 816, 825, 828, 832, + 834, 836, 841, 845, 848, 852, 855, 857, 869, 872, + 874, 876, 880, 884, 886, 889, 902, 905, 909, 911, + 919, 920, 921, 925, 927, 932, 934, 936, 942, 943, + 944, 947, 949, 952, 954, 957, 960, 966, 973, 975, + 982, 989, 992, 999, 1002, 1006, 1009, 1013, 1018, 1021, + 1025, 1028, 1030, 1032, 1034, 1041, 1043, 1044, 1045, 1050, + 1052, 1054, 1056, 1061, 1065, 1068, 1070, 1075, 1077, 1078, + 1081, 1081, 1084, 1087, 1089, 1091, 1094, 1096, 1099, 1107, + 1121, 1129, 1133, 1147, 1155, 1162, 1164, 1169, 1172, 1177, + 1179, 1181, 1188, 1190, 1191, 1199, 1205, 1207, 1209, 1216, + 1218, 1224, 1230, 1232, 1234, 1236, 1243, 1245, 1248, 1251, + 1255, 1258, 1262, 1265, 1269, 1274, 1276, 1280, 1282, 1284, + 1286, 1290, 1292, 1294, 1297, 1299, 1302, 1306, 1308, 1311, + 1313, 1318, 1321, 1326, 1328, 1330, 1334, 1358, 1364, 1377, + 1382, 1387, 1389, 1394, 1396, 1400, 1404, 1408, 1418, 1420, + 1425, 1430, 1433, 1437, 1440, 1444, 1447, 1450, 1453, 1457, + 1460, 1464, 1468, 1470, 1472, 1474, 1476, 1478, 1480, 1482, + 1486, 1494, 1502, 1504, 1506, 1510, 1512, 1515, 1518, 1530, + 1532, 1537, 1539, 1542, 1556, 1559, 1562, 1564, 1566, 1570, + 1574, 1580, 1598, 1603, 1608, 1611, 1625, 1634, 1638, 1642, + 1646, 1652, 1656, 1661, 1664, 1669, 1672, 1673, 1689, 1694, + 1697, 1709, 1711, 1721, 1731, 1732, 1739, 1741, 1753, 1757, + 1771, 1777, 1783, 1784, 1789, 1794, 1798, 1802, 1813, 1820, + 1827, 1834, 1845, 1851, 1854, 1859, 1882, 1912, 1943, 1974, + 1989, 2003, 2007, 2011, 2014, 2019, 2021, 2024, 2026, 2030, + 2035, 2038, 2044, 2049, 2054, 2056, 2065, 2066, 2072, 2074, + 2084, 2086, 2090, 2093, 2099, 2108, 2116, 2124, 2133, 2146, + 2151, 2156, 2158, 2167, 2170, 2175, 2178, 2182, 2191, 2193, + 2194, 2195, 2196, 2197, 2211, 2214, 2218, 2224, 2230, 2237, + 2242, 2248, 2255, 2261, 2267, 2272, 2278, 2285, 2291, 2297, + 2303, 2311, 2317, 2323, 2331, 2338, 2344, 2353, 2360, 2368, + 2373, 2376, 2386, 2388, 2391, 2393, 2394, 2397, 2402, 2403, + 2420, 2426, 2431, 2435, 2438, 2439, 2442, 2450, 2456, 2465, + 2475, 2482, 2486, 2491, 2500, 2507, 2511, 2521, 2523, 2524, + 2526, 2528, 2529, 2530, 2531, 2533, 2535, 2538, 2546, 2553, + 2553, 2560, 2566, 2568, 2574, 2579, 2584, 2593, 2595, 2601, + 2603, 2606, 2608, 2609, 2610, 2613, 2618, 2620, 2624, 2627, + 2634, 2640, 2645, 2652, 2657, 2662, 2667, 2674, 2678, 2681, + 2687, 2689, 2690, 2691, 2694, 2696, 2697, 2698, 2699, 2700, + 2701, 2702, 2703, 2704, 2705, 2706, 2707, 2708, 2709, 2710, + 2711, 2712, 2713, 2714, 2714, 2717, 2723, 2728, 2733, 2739, + 2741, 2744, 2746, 2753, 2765, 2770, 2776, 2778, 2784, 2788, + 2789, 2795, 2797, 2800, 2802, 2808, 2813, 2819, 2826, 2835 }; #endif @@ -1758,7 +1755,7 @@ static const short yycheck[] = { 56, 50, 51, 52, 53, 54, 55, 56, 57 }; /* -*-C-*- Note some compilers choke on comments on `#line' lines. */ -#line 3 "/usr/lib/bison.simple" +#line 3 "/usr/share/misc/bison.simple" /* This file comes from bison-1.28. */ /* Skeleton output parser for bison, @@ -1972,7 +1969,7 @@ __yy_memcpy (char *to, char *from, unsigned int count) #endif #endif -#line 217 "/usr/lib/bison.simple" +#line 217 "/usr/share/misc/bison.simple" /* The user can define YYPARSE_PARAM as the name of an argument to be passed into yyparse. The argument should have type void *. @@ -2301,14 +2298,14 @@ yyreduce: switch (yyn) { case 1: -#line 265 "objc-parse.y" +#line 262 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids an empty source file"); finish_file (); ; break;} case 2: -#line 270 "objc-parse.y" +#line 267 "objc-parse.y" { /* In case there were missing closebraces, get us back to the global binding level. */ @@ -2318,15 +2315,15 @@ case 2: ; break;} case 3: -#line 284 "objc-parse.y" +#line 281 "objc-parse.y" {yyval.ttype = NULL_TREE; ; break;} case 5: -#line 285 "objc-parse.y" +#line 282 "objc-parse.y" {yyval.ttype = NULL_TREE; ; break;} case 10: -#line 293 "objc-parse.y" +#line 290 "objc-parse.y" { STRIP_NOPS (yyvsp[-2].ttype); if ((TREE_CODE (yyvsp[-2].ttype) == ADDR_EXPR && TREE_CODE (TREE_OPERAND (yyvsp[-2].ttype, 0)) == STRING_CST) @@ -2336,11 +2333,11 @@ case 10: error ("argument of `asm' is not a constant string"); ; break;} case 11: -#line 301 "objc-parse.y" +#line 298 "objc-parse.y" { RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 12: -#line 306 "objc-parse.y" +#line 303 "objc-parse.y" { if (pedantic) error ("ANSI C forbids data definition with no type or storage class"); else if (!flag_traditional) @@ -2351,162 +2348,162 @@ case 12: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 13: -#line 315 "objc-parse.y" +#line 312 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 14: -#line 319 "objc-parse.y" +#line 316 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 15: -#line 323 "objc-parse.y" +#line 320 "objc-parse.y" { pedwarn ("empty declaration"); ; break;} case 16: -#line 325 "objc-parse.y" +#line 322 "objc-parse.y" { shadow_tag (yyvsp[-1].ttype); ; break;} case 19: -#line 329 "objc-parse.y" +#line 326 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C does not allow extra `;' outside of a function"); ; break;} case 20: -#line 335 "objc-parse.y" +#line 332 "objc-parse.y" { if (! start_function (current_declspecs, yyvsp[0].ttype, prefix_attributes, NULL_TREE)) YYERROR1; reinit_parse_for_function (); ; break;} case 21: -#line 340 "objc-parse.y" +#line 337 "objc-parse.y" { store_parm_decls (); ; break;} case 22: -#line 342 "objc-parse.y" +#line 339 "objc-parse.y" { finish_function (0); current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 23: -#line 347 "objc-parse.y" +#line 344 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 24: -#line 351 "objc-parse.y" +#line 348 "objc-parse.y" { if (! start_function (current_declspecs, yyvsp[0].ttype, prefix_attributes, NULL_TREE)) YYERROR1; reinit_parse_for_function (); ; break;} case 25: -#line 356 "objc-parse.y" +#line 353 "objc-parse.y" { store_parm_decls (); ; break;} case 26: -#line 358 "objc-parse.y" +#line 355 "objc-parse.y" { finish_function (0); current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 27: -#line 363 "objc-parse.y" +#line 360 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 28: -#line 367 "objc-parse.y" +#line 364 "objc-parse.y" { if (! start_function (NULL_TREE, yyvsp[0].ttype, prefix_attributes, NULL_TREE)) YYERROR1; reinit_parse_for_function (); ; break;} case 29: -#line 372 "objc-parse.y" +#line 369 "objc-parse.y" { store_parm_decls (); ; break;} case 30: -#line 374 "objc-parse.y" +#line 371 "objc-parse.y" { finish_function (0); current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 31: -#line 379 "objc-parse.y" +#line 376 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 36: -#line 392 "objc-parse.y" +#line 389 "objc-parse.y" { yyval.code = ADDR_EXPR; ; break;} case 37: -#line 394 "objc-parse.y" +#line 391 "objc-parse.y" { yyval.code = NEGATE_EXPR; ; break;} case 38: -#line 396 "objc-parse.y" +#line 393 "objc-parse.y" { yyval.code = CONVERT_EXPR; ; break;} case 39: -#line 398 "objc-parse.y" +#line 395 "objc-parse.y" { yyval.code = PREINCREMENT_EXPR; ; break;} case 40: -#line 400 "objc-parse.y" +#line 397 "objc-parse.y" { yyval.code = PREDECREMENT_EXPR; ; break;} case 41: -#line 402 "objc-parse.y" +#line 399 "objc-parse.y" { yyval.code = BIT_NOT_EXPR; ; break;} case 42: -#line 404 "objc-parse.y" +#line 401 "objc-parse.y" { yyval.code = TRUTH_NOT_EXPR; ; break;} case 43: -#line 408 "objc-parse.y" +#line 405 "objc-parse.y" { yyval.ttype = build_compound_expr (yyvsp[0].ttype); ; break;} case 44: -#line 413 "objc-parse.y" +#line 410 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 46: -#line 419 "objc-parse.y" +#line 416 "objc-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 47: -#line 421 "objc-parse.y" +#line 418 "objc-parse.y" { chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 49: -#line 427 "objc-parse.y" +#line 424 "objc-parse.y" { yyval.ttype = build_indirect_ref (yyvsp[0].ttype, "unary *"); ; break;} case 50: -#line 430 "objc-parse.y" +#line 427 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 51: -#line 433 "objc-parse.y" +#line 430 "objc-parse.y" { yyval.ttype = build_unary_op (yyvsp[-1].code, yyvsp[0].ttype, 0); overflow_warning (yyval.ttype); ; break;} case 52: -#line 437 "objc-parse.y" +#line 434 "objc-parse.y" { tree label = lookup_label (yyvsp[0].ttype); if (pedantic) pedwarn ("ANSI C forbids `&&'"); @@ -2521,7 +2518,7 @@ case 52: ; break;} case 53: -#line 465 "objc-parse.y" +#line 462 "objc-parse.y" { skip_evaluation--; if (TREE_CODE (yyvsp[0].ttype) == COMPONENT_REF && DECL_C_BIT_FIELD (TREE_OPERAND (yyvsp[0].ttype, 1))) @@ -2529,53 +2526,53 @@ case 53: yyval.ttype = c_sizeof (TREE_TYPE (yyvsp[0].ttype)); ; break;} case 54: -#line 471 "objc-parse.y" +#line 468 "objc-parse.y" { skip_evaluation--; yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ttype)); ; break;} case 55: -#line 474 "objc-parse.y" +#line 471 "objc-parse.y" { skip_evaluation--; yyval.ttype = c_alignof_expr (yyvsp[0].ttype); ; break;} case 56: -#line 477 "objc-parse.y" +#line 474 "objc-parse.y" { skip_evaluation--; yyval.ttype = c_alignof (groktypename (yyvsp[-1].ttype)); ; break;} case 57: -#line 480 "objc-parse.y" +#line 477 "objc-parse.y" { yyval.ttype = build_unary_op (REALPART_EXPR, yyvsp[0].ttype, 0); ; break;} case 58: -#line 482 "objc-parse.y" +#line 479 "objc-parse.y" { yyval.ttype = build_unary_op (IMAGPART_EXPR, yyvsp[0].ttype, 0); ; break;} case 59: -#line 484 "objc-parse.y" +#line 481 "objc-parse.y" { yyval.ttype = build_va_arg (yyvsp[-3].ttype, groktypename (yyvsp[-1].ttype)); ; break;} case 60: -#line 488 "objc-parse.y" +#line 485 "objc-parse.y" { skip_evaluation++; ; break;} case 61: -#line 492 "objc-parse.y" +#line 489 "objc-parse.y" { skip_evaluation++; ; break;} case 63: -#line 498 "objc-parse.y" +#line 495 "objc-parse.y" { tree type = groktypename (yyvsp[-2].ttype); yyval.ttype = build_c_cast (type, yyvsp[0].ttype); ; break;} case 64: -#line 501 "objc-parse.y" +#line 498 "objc-parse.y" { start_init (NULL_TREE, NULL, 0); yyvsp[-2].ttype = groktypename (yyvsp[-2].ttype); really_start_incremental_init (yyvsp[-2].ttype); ; break;} case 65: -#line 505 "objc-parse.y" +#line 502 "objc-parse.y" { const char *name; tree result = pop_init_level (0); tree type = yyvsp[-5].ttype; @@ -2602,90 +2599,90 @@ case 65: ; break;} case 67: -#line 534 "objc-parse.y" +#line 531 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 68: -#line 536 "objc-parse.y" +#line 533 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 69: -#line 538 "objc-parse.y" +#line 535 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 70: -#line 540 "objc-parse.y" +#line 537 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 71: -#line 542 "objc-parse.y" +#line 539 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 72: -#line 544 "objc-parse.y" +#line 541 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 73: -#line 546 "objc-parse.y" +#line 543 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 74: -#line 548 "objc-parse.y" +#line 545 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 75: -#line 550 "objc-parse.y" +#line 547 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 76: -#line 552 "objc-parse.y" +#line 549 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 77: -#line 554 "objc-parse.y" +#line 551 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 78: -#line 556 "objc-parse.y" +#line 553 "objc-parse.y" { yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 79: -#line 558 "objc-parse.y" +#line 555 "objc-parse.y" { yyvsp[-1].ttype = truthvalue_conversion (default_conversion (yyvsp[-1].ttype)); skip_evaluation += yyvsp[-1].ttype == boolean_false_node; ; break;} case 80: -#line 561 "objc-parse.y" +#line 558 "objc-parse.y" { skip_evaluation -= yyvsp[-3].ttype == boolean_false_node; yyval.ttype = parser_build_binary_op (TRUTH_ANDIF_EXPR, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 81: -#line 564 "objc-parse.y" +#line 561 "objc-parse.y" { yyvsp[-1].ttype = truthvalue_conversion (default_conversion (yyvsp[-1].ttype)); skip_evaluation += yyvsp[-1].ttype == boolean_true_node; ; break;} case 82: -#line 567 "objc-parse.y" +#line 564 "objc-parse.y" { skip_evaluation -= yyvsp[-3].ttype == boolean_true_node; yyval.ttype = parser_build_binary_op (TRUTH_ORIF_EXPR, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 83: -#line 570 "objc-parse.y" +#line 567 "objc-parse.y" { yyvsp[-1].ttype = truthvalue_conversion (default_conversion (yyvsp[-1].ttype)); skip_evaluation += yyvsp[-1].ttype == boolean_false_node; ; break;} case 84: -#line 573 "objc-parse.y" +#line 570 "objc-parse.y" { skip_evaluation += ((yyvsp[-4].ttype == boolean_true_node) - (yyvsp[-4].ttype == boolean_false_node)); ; break;} case 85: -#line 576 "objc-parse.y" +#line 573 "objc-parse.y" { skip_evaluation -= yyvsp[-6].ttype == boolean_true_node; yyval.ttype = build_conditional_expr (yyvsp[-6].ttype, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 86: -#line 579 "objc-parse.y" +#line 576 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids omitting the middle term of a ?: expression"); /* Make sure first operand is calculated only once. */ @@ -2694,12 +2691,12 @@ case 86: skip_evaluation += yyvsp[-1].ttype == boolean_true_node; ; break;} case 87: -#line 586 "objc-parse.y" +#line 583 "objc-parse.y" { skip_evaluation -= yyvsp[-4].ttype == boolean_true_node; yyval.ttype = build_conditional_expr (yyvsp[-4].ttype, yyvsp[-3].ttype, yyvsp[0].ttype); ; break;} case 88: -#line 589 "objc-parse.y" +#line 586 "objc-parse.y" { char class; yyval.ttype = build_modify_expr (yyvsp[-2].ttype, NOP_EXPR, yyvsp[0].ttype); class = TREE_CODE_CLASS (TREE_CODE (yyval.ttype)); @@ -2709,7 +2706,7 @@ case 88: ; break;} case 89: -#line 597 "objc-parse.y" +#line 594 "objc-parse.y" { char class; yyval.ttype = build_modify_expr (yyvsp[-2].ttype, yyvsp[-1].code, yyvsp[0].ttype); /* This inhibits warnings in truthvalue_conversion. */ @@ -2720,171 +2717,19 @@ case 89: ; break;} case 90: -#line 609 "objc-parse.y" +#line 606 "objc-parse.y" { - yyval.ttype = lastiddecl; - if (!yyval.ttype || yyval.ttype == error_mark_node) - { - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - tree decl; - - if (objc_receiver_context - && ! (objc_receiver_context - && strcmp (IDENTIFIER_POINTER (yyvsp[0].ttype), "super"))) - /* we have a message to super */ - yyval.ttype = get_super_receiver (); - else if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, yyvsp[0].ttype))) - { - if (is_private (decl)) - yyval.ttype = error_mark_node; - else - yyval.ttype = build_ivar_reference (yyvsp[0].ttype); - } - else - { - /* Ordinary implicit function declaration. */ - yyval.ttype = implicitly_declare (yyvsp[0].ttype); - assemble_external (yyval.ttype); - TREE_USED (yyval.ttype) = 1; - } - } - else if (current_function_decl == 0) - { - error ("`%s' undeclared here (not in a function)", - IDENTIFIER_POINTER (yyvsp[0].ttype)); - yyval.ttype = error_mark_node; - } - else - { - tree decl; - - if (objc_receiver_context - && ! strcmp (IDENTIFIER_POINTER (yyvsp[0].ttype), "super")) - /* we have a message to super */ - yyval.ttype = get_super_receiver (); - else if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, yyvsp[0].ttype))) - { - if (is_private (decl)) - yyval.ttype = error_mark_node; - else - yyval.ttype = build_ivar_reference (yyvsp[0].ttype); - } - else - { - if (IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) != error_mark_node - || IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) != current_function_decl) - { - error ("`%s' undeclared (first use in this function)", - IDENTIFIER_POINTER (yyvsp[0].ttype)); - - if (! undeclared_variable_notice) - { - error ("(Each undeclared identifier is reported only once"); - error ("for each function it appears in.)"); - undeclared_variable_notice = 1; - } - } - yyval.ttype = error_mark_node; - /* Prevent repeated error messages. */ - IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) = error_mark_node; - IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) = current_function_decl; - } - } - } - else if (TREE_TYPE (yyval.ttype) == error_mark_node) - yyval.ttype = error_mark_node; - else if (C_DECL_ANTICIPATED (yyval.ttype)) - { - /* The first time we see a build-in function used, - if it has not been declared. */ - C_DECL_ANTICIPATED (yyval.ttype) = 0; - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - /* Omit the implicit declaration we - would ordinarily do, so we don't lose - the actual built in type. - But print a diagnostic for the mismatch. */ - if (objc_method_context - && is_ivar (objc_ivar_chain, yyvsp[0].ttype)) - error ("Instance variable `%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - else - if (TREE_CODE (yyval.ttype) != FUNCTION_DECL) - error ("`%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE (yyval.ttype))) - != TYPE_MODE (integer_type_node)) - && !VOID_TYPE_P (TREE_TYPE (TREE_TYPE (yyval.ttype)))) - pedwarn ("type mismatch in implicit declaration for built-in function `%s'", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - /* If it really returns void, change that to int. */ - if (TREE_TYPE (TREE_TYPE (yyval.ttype)) == void_type_node) - TREE_TYPE (yyval.ttype) - = build_function_type (integer_type_node, - TYPE_ARG_TYPES (TREE_TYPE (yyval.ttype))); - } - else - pedwarn ("built-in function `%s' used without declaration", - IDENTIFIER_POINTER (DECL_NAME (yyval.ttype))); - - /* Do what we would ordinarily do when a fn is used. */ - assemble_external (yyval.ttype); - TREE_USED (yyval.ttype) = 1; - } - else - { - assemble_external (yyval.ttype); - TREE_USED (yyval.ttype) = 1; - /* we have a definition - still check if iVariable */ - - if (!objc_receiver_context - || (objc_receiver_context - && strcmp (IDENTIFIER_POINTER (yyvsp[0].ttype), "super"))) - { - tree decl; - - if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, yyvsp[0].ttype))) - { - if (IDENTIFIER_LOCAL_VALUE (yyvsp[0].ttype)) - warning ("local declaration of `%s' hides instance variable", - IDENTIFIER_POINTER (yyvsp[0].ttype)); - else - { - if (is_private (decl)) - yyval.ttype = error_mark_node; - else - yyval.ttype = build_ivar_reference (yyvsp[0].ttype); - } - } - } - else /* we have a message to super */ - yyval.ttype = get_super_receiver (); - } - - if (TREE_CODE (yyval.ttype) == CONST_DECL) - { - yyval.ttype = DECL_INITIAL (yyval.ttype); - /* This is to prevent an enum whose value is 0 - from being considered a null pointer constant. */ - yyval.ttype = build1 (NOP_EXPR, TREE_TYPE (yyval.ttype), yyval.ttype); - TREE_CONSTANT (yyval.ttype) = 1; - } + if (yychar == YYEMPTY) + yychar = YYLEX; + yyval.ttype = build_external_ref (yyvsp[0].ttype, yychar == '('); ; break;} case 92: -#line 768 "objc-parse.y" +#line 613 "objc-parse.y" { yyval.ttype = combine_strings (yyvsp[0].ttype); ; break;} case 93: -#line 770 "objc-parse.y" +#line 615 "objc-parse.y" { char class = TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype)); if (class == 'e' || class == '1' || class == '2' || class == '<') @@ -2892,11 +2737,11 @@ case 93: yyval.ttype = yyvsp[-1].ttype; ; break;} case 94: -#line 776 "objc-parse.y" +#line 621 "objc-parse.y" { yyval.ttype = error_mark_node; ; break;} case 95: -#line 778 "objc-parse.y" +#line 623 "objc-parse.y" { tree rtl_exp; if (pedantic) pedwarn ("ANSI C forbids braced-groups within expressions"); @@ -2921,7 +2766,7 @@ case 95: ; break;} case 96: -#line 801 "objc-parse.y" +#line 646 "objc-parse.y" { /* Make sure we call expand_end_stmt_expr. Otherwise we are likely to lose sequences and crash later. */ @@ -2932,15 +2777,15 @@ case 96: ; break;} case 97: -#line 810 "objc-parse.y" +#line 655 "objc-parse.y" { yyval.ttype = build_function_call (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 98: -#line 812 "objc-parse.y" +#line 657 "objc-parse.y" { yyval.ttype = build_array_ref (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 99: -#line 814 "objc-parse.y" +#line 659 "objc-parse.y" { if (doing_objc_thang) { @@ -2954,7 +2799,7 @@ case 99: ; break;} case 100: -#line 826 "objc-parse.y" +#line 671 "objc-parse.y" { tree expr = build_indirect_ref (yyvsp[-2].ttype, "->"); @@ -2970,79 +2815,79 @@ case 100: ; break;} case 101: -#line 840 "objc-parse.y" +#line 685 "objc-parse.y" { yyval.ttype = build_unary_op (POSTINCREMENT_EXPR, yyvsp[-1].ttype, 0); ; break;} case 102: -#line 842 "objc-parse.y" +#line 687 "objc-parse.y" { yyval.ttype = build_unary_op (POSTDECREMENT_EXPR, yyvsp[-1].ttype, 0); ; break;} case 103: -#line 844 "objc-parse.y" +#line 689 "objc-parse.y" { yyval.ttype = build_message_expr (yyvsp[0].ttype); ; break;} case 104: -#line 846 "objc-parse.y" +#line 691 "objc-parse.y" { yyval.ttype = build_selector_expr (yyvsp[0].ttype); ; break;} case 105: -#line 848 "objc-parse.y" +#line 693 "objc-parse.y" { yyval.ttype = build_protocol_expr (yyvsp[0].ttype); ; break;} case 106: -#line 850 "objc-parse.y" +#line 695 "objc-parse.y" { yyval.ttype = build_encode_expr (yyvsp[0].ttype); ; break;} case 107: -#line 852 "objc-parse.y" +#line 697 "objc-parse.y" { yyval.ttype = build_objc_string_object (yyvsp[0].ttype); ; break;} case 109: -#line 859 "objc-parse.y" +#line 704 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 111: -#line 868 "objc-parse.y" +#line 713 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 114: -#line 876 "objc-parse.y" +#line 721 "objc-parse.y" { c_mark_varargs (); if (pedantic) pedwarn ("ANSI C does not permit use of `varargs.h'"); ; break;} case 115: -#line 886 "objc-parse.y" +#line 731 "objc-parse.y" { ; break;} case 120: -#line 902 "objc-parse.y" +#line 747 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 121: -#line 906 "objc-parse.y" +#line 751 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 122: -#line 910 "objc-parse.y" +#line 755 "objc-parse.y" { shadow_tag_warned (yyvsp[-1].ttype, 1); pedwarn ("empty declaration"); ; break;} case 123: -#line 913 "objc-parse.y" +#line 758 "objc-parse.y" { pedwarn ("empty declaration"); ; break;} case 124: -#line 922 "objc-parse.y" +#line 767 "objc-parse.y" { ; break;} case 129: -#line 937 "objc-parse.y" +#line 782 "objc-parse.y" { pending_xref_error (); declspec_stack = tree_cons (prefix_attributes, current_declspecs, @@ -3051,127 +2896,127 @@ case 129: ¤t_declspecs, &prefix_attributes); ; break;} case 130: -#line 947 "objc-parse.y" +#line 792 "objc-parse.y" { prefix_attributes = chainon (prefix_attributes, yyvsp[0].ttype); ; break;} case 131: -#line 952 "objc-parse.y" +#line 797 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 132: -#line 956 "objc-parse.y" +#line 801 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 133: -#line 960 "objc-parse.y" +#line 805 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 134: -#line 964 "objc-parse.y" +#line 809 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 135: -#line 968 "objc-parse.y" +#line 813 "objc-parse.y" { shadow_tag (yyvsp[-1].ttype); ; break;} case 136: -#line 970 "objc-parse.y" +#line 815 "objc-parse.y" { pedwarn ("empty declaration"); ; break;} case 137: -#line 972 "objc-parse.y" +#line 817 "objc-parse.y" { RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 138: -#line 982 "objc-parse.y" +#line 827 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 139: -#line 984 "objc-parse.y" +#line 829 "objc-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ; break;} case 140: -#line 988 "objc-parse.y" +#line 833 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 141: -#line 990 "objc-parse.y" +#line 835 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 142: -#line 992 "objc-parse.y" +#line 837 "objc-parse.y" { if (extra_warnings) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 143: -#line 997 "objc-parse.y" +#line 842 "objc-parse.y" { yyval.ttype = tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 144: -#line 1002 "objc-parse.y" +#line 847 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 145: -#line 1004 "objc-parse.y" +#line 849 "objc-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ; break;} case 146: -#line 1009 "objc-parse.y" +#line 854 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 147: -#line 1011 "objc-parse.y" +#line 856 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 148: -#line 1013 "objc-parse.y" +#line 858 "objc-parse.y" { if (extra_warnings) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 149: -#line 1026 "objc-parse.y" +#line 871 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 150: -#line 1028 "objc-parse.y" +#line 873 "objc-parse.y" { yyval.ttype = tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ; break;} case 151: -#line 1030 "objc-parse.y" +#line 875 "objc-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 152: -#line 1032 "objc-parse.y" +#line 877 "objc-parse.y" { yyval.ttype = tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ; break;} case 153: -#line 1037 "objc-parse.y" +#line 882 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); TREE_STATIC (yyval.ttype) = 1; ; break;} case 154: -#line 1040 "objc-parse.y" +#line 885 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 155: -#line 1042 "objc-parse.y" +#line 887 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); TREE_STATIC (yyval.ttype) = 1; ; break;} case 156: -#line 1045 "objc-parse.y" +#line 890 "objc-parse.y" { if (extra_warnings && TREE_STATIC (yyvsp[-1].ttype)) warning ("`%s' is not at beginning of declaration", IDENTIFIER_POINTER (yyvsp[0].ttype)); @@ -3179,180 +3024,180 @@ case 156: TREE_STATIC (yyval.ttype) = TREE_STATIC (yyvsp[-1].ttype); ; break;} case 157: -#line 1059 "objc-parse.y" +#line 904 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 158: -#line 1061 "objc-parse.y" +#line 906 "objc-parse.y" { yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ; break;} case 159: -#line 1065 "objc-parse.y" +#line 910 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 160: -#line 1067 "objc-parse.y" +#line 912 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 163: -#line 1077 "objc-parse.y" +#line 922 "objc-parse.y" { /* For a typedef name, record the meaning, not the name. In case of `foo foo, bar;'. */ yyval.ttype = lookup_name (yyvsp[0].ttype); ; break;} case 164: -#line 1081 "objc-parse.y" +#line 926 "objc-parse.y" { yyval.ttype = get_static_reference (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 165: -#line 1083 "objc-parse.y" +#line 928 "objc-parse.y" { yyval.ttype = get_object_reference (yyvsp[0].ttype); ; break;} case 166: -#line 1088 "objc-parse.y" +#line 933 "objc-parse.y" { yyval.ttype = get_object_reference (yyvsp[0].ttype); ; break;} case 167: -#line 1090 "objc-parse.y" +#line 935 "objc-parse.y" { yyval.ttype = TREE_TYPE (yyvsp[-1].ttype); ; break;} case 168: -#line 1092 "objc-parse.y" +#line 937 "objc-parse.y" { yyval.ttype = groktypename (yyvsp[-1].ttype); ; break;} case 176: -#line 1114 "objc-parse.y" +#line 959 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 177: -#line 1116 "objc-parse.y" +#line 961 "objc-parse.y" { if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype); yyval.ttype = yyvsp[-1].ttype; ; break;} case 178: -#line 1123 "objc-parse.y" +#line 968 "objc-parse.y" { yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1, yyvsp[-1].ttype, prefix_attributes); start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ; break;} case 179: -#line 1128 "objc-parse.y" +#line 973 "objc-parse.y" { finish_init (); finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 180: -#line 1131 "objc-parse.y" +#line 976 "objc-parse.y" { tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0, yyvsp[0].ttype, prefix_attributes); finish_decl (d, NULL_TREE, yyvsp[-1].ttype); ; break;} case 181: -#line 1139 "objc-parse.y" +#line 984 "objc-parse.y" { yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1, yyvsp[-1].ttype, prefix_attributes); start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ; break;} case 182: -#line 1144 "objc-parse.y" +#line 989 "objc-parse.y" { finish_init (); decl_attributes (yyvsp[-1].ttype, yyvsp[-3].ttype, prefix_attributes); finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ; break;} case 183: -#line 1148 "objc-parse.y" +#line 993 "objc-parse.y" { tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0, yyvsp[0].ttype, prefix_attributes); finish_decl (d, NULL_TREE, yyvsp[-1].ttype); ; break;} case 184: -#line 1156 "objc-parse.y" +#line 1001 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 185: -#line 1158 "objc-parse.y" +#line 1003 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 186: -#line 1163 "objc-parse.y" +#line 1008 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 187: -#line 1165 "objc-parse.y" +#line 1010 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 188: -#line 1170 "objc-parse.y" +#line 1015 "objc-parse.y" { yyval.ttype = yyvsp[-2].ttype; ; break;} case 189: -#line 1175 "objc-parse.y" +#line 1020 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 190: -#line 1177 "objc-parse.y" +#line 1022 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 191: -#line 1182 "objc-parse.y" +#line 1027 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 192: -#line 1184 "objc-parse.y" +#line 1029 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ; break;} case 193: -#line 1186 "objc-parse.y" +#line 1031 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ; break;} case 194: -#line 1188 "objc-parse.y" +#line 1033 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ; break;} case 195: -#line 1190 "objc-parse.y" +#line 1035 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 201: -#line 1208 "objc-parse.y" +#line 1053 "objc-parse.y" { really_start_incremental_init (NULL_TREE); ; break;} case 202: -#line 1210 "objc-parse.y" +#line 1055 "objc-parse.y" { yyval.ttype = pop_init_level (0); ; break;} case 203: -#line 1212 "objc-parse.y" +#line 1057 "objc-parse.y" { yyval.ttype = error_mark_node; ; break;} case 204: -#line 1218 "objc-parse.y" +#line 1063 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids empty initializer braces"); ; break;} case 210: -#line 1234 "objc-parse.y" +#line 1079 "objc-parse.y" { set_init_label (yyvsp[-1].ttype); ; break;} case 213: -#line 1241 "objc-parse.y" +#line 1086 "objc-parse.y" { push_init_level (0); ; break;} case 214: -#line 1243 "objc-parse.y" +#line 1088 "objc-parse.y" { process_init_element (pop_init_level (0)); ; break;} case 215: -#line 1245 "objc-parse.y" +#line 1090 "objc-parse.y" { process_init_element (yyvsp[0].ttype); ; break;} case 219: -#line 1256 "objc-parse.y" +#line 1101 "objc-parse.y" { set_init_label (yyvsp[0].ttype); ; break;} case 220: -#line 1264 "objc-parse.y" +#line 1109 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids nested functions"); @@ -3366,16 +3211,16 @@ case 220: reinit_parse_for_function (); ; break;} case 221: -#line 1276 "objc-parse.y" +#line 1121 "objc-parse.y" { store_parm_decls (); ; break;} case 222: -#line 1284 "objc-parse.y" +#line 1129 "objc-parse.y" { finish_function (1); pop_function_context (); ; break;} case 223: -#line 1290 "objc-parse.y" +#line 1135 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids nested functions"); @@ -3389,195 +3234,195 @@ case 223: reinit_parse_for_function (); ; break;} case 224: -#line 1302 "objc-parse.y" +#line 1147 "objc-parse.y" { store_parm_decls (); ; break;} case 225: -#line 1310 "objc-parse.y" +#line 1155 "objc-parse.y" { finish_function (1); pop_function_context (); ; break;} case 228: -#line 1326 "objc-parse.y" +#line 1171 "objc-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 229: -#line 1328 "objc-parse.y" +#line 1173 "objc-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 230: -#line 1333 "objc-parse.y" +#line 1178 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 231: -#line 1335 "objc-parse.y" +#line 1180 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 232: -#line 1337 "objc-parse.y" +#line 1182 "objc-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 233: -#line 1344 "objc-parse.y" +#line 1189 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 236: -#line 1356 "objc-parse.y" +#line 1201 "objc-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 237: -#line 1361 "objc-parse.y" +#line 1206 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 238: -#line 1363 "objc-parse.y" +#line 1208 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 239: -#line 1365 "objc-parse.y" +#line 1210 "objc-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 240: -#line 1372 "objc-parse.y" +#line 1217 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 242: -#line 1381 "objc-parse.y" +#line 1226 "objc-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 243: -#line 1386 "objc-parse.y" +#line 1231 "objc-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 244: -#line 1388 "objc-parse.y" +#line 1233 "objc-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 245: -#line 1390 "objc-parse.y" +#line 1235 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 246: -#line 1392 "objc-parse.y" +#line 1237 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 247: -#line 1399 "objc-parse.y" +#line 1244 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 249: -#line 1405 "objc-parse.y" +#line 1250 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 250: -#line 1407 "objc-parse.y" +#line 1252 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 251: -#line 1412 "objc-parse.y" +#line 1257 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 252: -#line 1414 "objc-parse.y" +#line 1259 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 253: -#line 1419 "objc-parse.y" +#line 1264 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 254: -#line 1421 "objc-parse.y" +#line 1266 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 255: -#line 1426 "objc-parse.y" +#line 1271 "objc-parse.y" { yyval.ttype = start_struct (RECORD_TYPE, yyvsp[-1].ttype); /* Start scope of tag before parsing components. */ ; break;} case 256: -#line 1430 "objc-parse.y" +#line 1275 "objc-parse.y" { yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, chainon (yyvsp[-6].ttype, yyvsp[0].ttype)); ; break;} case 257: -#line 1432 "objc-parse.y" +#line 1277 "objc-parse.y" { yyval.ttype = finish_struct (start_struct (RECORD_TYPE, NULL_TREE), yyvsp[-2].ttype, chainon (yyvsp[-4].ttype, yyvsp[0].ttype)); ; break;} case 258: -#line 1436 "objc-parse.y" +#line 1281 "objc-parse.y" { yyval.ttype = xref_tag (RECORD_TYPE, yyvsp[0].ttype); ; break;} case 259: -#line 1438 "objc-parse.y" +#line 1283 "objc-parse.y" { yyval.ttype = start_struct (UNION_TYPE, yyvsp[-1].ttype); ; break;} case 260: -#line 1440 "objc-parse.y" +#line 1285 "objc-parse.y" { yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, chainon (yyvsp[-6].ttype, yyvsp[0].ttype)); ; break;} case 261: -#line 1442 "objc-parse.y" +#line 1287 "objc-parse.y" { yyval.ttype = finish_struct (start_struct (UNION_TYPE, NULL_TREE), yyvsp[-2].ttype, chainon (yyvsp[-4].ttype, yyvsp[0].ttype)); ; break;} case 262: -#line 1446 "objc-parse.y" +#line 1291 "objc-parse.y" { yyval.ttype = xref_tag (UNION_TYPE, yyvsp[0].ttype); ; break;} case 263: -#line 1448 "objc-parse.y" +#line 1293 "objc-parse.y" { yyval.ttype = start_enum (yyvsp[-1].ttype); ; break;} case 264: -#line 1450 "objc-parse.y" +#line 1295 "objc-parse.y" { yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), chainon (yyvsp[-7].ttype, yyvsp[0].ttype)); ; break;} case 265: -#line 1453 "objc-parse.y" +#line 1298 "objc-parse.y" { yyval.ttype = start_enum (NULL_TREE); ; break;} case 266: -#line 1455 "objc-parse.y" +#line 1300 "objc-parse.y" { yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), chainon (yyvsp[-6].ttype, yyvsp[0].ttype)); ; break;} case 267: -#line 1458 "objc-parse.y" +#line 1303 "objc-parse.y" { yyval.ttype = xref_tag (ENUMERAL_TYPE, yyvsp[0].ttype); ; break;} case 271: -#line 1469 "objc-parse.y" +#line 1314 "objc-parse.y" { if (pedantic && ! flag_isoc99) pedwarn ("comma at end of enumerator list"); ; break;} case 272: -#line 1475 "objc-parse.y" +#line 1320 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 273: -#line 1477 "objc-parse.y" +#line 1322 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); pedwarn ("no semicolon at end of struct or union"); ; break;} case 274: -#line 1482 "objc-parse.y" +#line 1327 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 275: -#line 1484 "objc-parse.y" +#line 1329 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 276: -#line 1486 "objc-parse.y" +#line 1331 "objc-parse.y" { if (pedantic) pedwarn ("extra semicolon in struct or union specified"); ; break;} case 277: -#line 1490 "objc-parse.y" +#line 1335 "objc-parse.y" { tree interface = lookup_interface (yyvsp[-1].ttype); @@ -3592,14 +3437,14 @@ case 277: ; break;} case 278: -#line 1515 "objc-parse.y" +#line 1360 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 279: -#line 1520 "objc-parse.y" +#line 1365 "objc-parse.y" { /* Support for unnamed structs or unions as members of structs or unions (which is [a] useful and [b] supports @@ -3614,151 +3459,151 @@ case 279: ; break;} case 280: -#line 1533 "objc-parse.y" +#line 1378 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 281: -#line 1538 "objc-parse.y" +#line 1383 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids member declarations with no members"); shadow_tag(yyvsp[0].ttype); yyval.ttype = NULL_TREE; ; break;} case 282: -#line 1543 "objc-parse.y" +#line 1388 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 283: -#line 1545 "objc-parse.y" +#line 1390 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; RESTORE_WARN_FLAGS (yyvsp[-1].ttype); ; break;} case 285: -#line 1552 "objc-parse.y" +#line 1397 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 286: -#line 1557 "objc-parse.y" +#line 1402 "objc-parse.y" { yyval.ttype = grokfield (yyvsp[-3].filename, yyvsp[-2].lineno, yyvsp[-1].ttype, current_declspecs, NULL_TREE); decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ; break;} case 287: -#line 1561 "objc-parse.y" +#line 1406 "objc-parse.y" { yyval.ttype = grokfield (yyvsp[-5].filename, yyvsp[-4].lineno, yyvsp[-3].ttype, current_declspecs, yyvsp[-1].ttype); decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ; break;} case 288: -#line 1564 "objc-parse.y" +#line 1409 "objc-parse.y" { yyval.ttype = grokfield (yyvsp[-4].filename, yyvsp[-3].lineno, NULL_TREE, current_declspecs, yyvsp[-1].ttype); decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ; break;} case 290: -#line 1576 "objc-parse.y" +#line 1421 "objc-parse.y" { if (yyvsp[-2].ttype == error_mark_node) yyval.ttype = yyvsp[-2].ttype; else yyval.ttype = chainon (yyvsp[0].ttype, yyvsp[-2].ttype); ; break;} case 291: -#line 1581 "objc-parse.y" +#line 1426 "objc-parse.y" { yyval.ttype = error_mark_node; ; break;} case 292: -#line 1587 "objc-parse.y" +#line 1432 "objc-parse.y" { yyval.ttype = build_enumerator (yyvsp[0].ttype, NULL_TREE); ; break;} case 293: -#line 1589 "objc-parse.y" +#line 1434 "objc-parse.y" { yyval.ttype = build_enumerator (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 294: -#line 1594 "objc-parse.y" +#line 1439 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 295: -#line 1596 "objc-parse.y" +#line 1441 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 296: -#line 1601 "objc-parse.y" +#line 1446 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 298: -#line 1607 "objc-parse.y" +#line 1452 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 299: -#line 1609 "objc-parse.y" +#line 1454 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 300: -#line 1614 "objc-parse.y" +#line 1459 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 301: -#line 1616 "objc-parse.y" +#line 1461 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ; break;} case 302: -#line 1621 "objc-parse.y" +#line 1466 "objc-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 303: -#line 1624 "objc-parse.y" +#line 1469 "objc-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 304: -#line 1626 "objc-parse.y" +#line 1471 "objc-parse.y" { yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ; break;} case 305: -#line 1628 "objc-parse.y" +#line 1473 "objc-parse.y" { yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 306: -#line 1630 "objc-parse.y" +#line 1475 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 307: -#line 1632 "objc-parse.y" +#line 1477 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ; break;} case 308: -#line 1634 "objc-parse.y" +#line 1479 "objc-parse.y" { yyval.ttype = build_nt (CALL_EXPR, NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 309: -#line 1636 "objc-parse.y" +#line 1481 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ; break;} case 310: -#line 1638 "objc-parse.y" +#line 1483 "objc-parse.y" { yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, NULL_TREE); ; break;} case 311: -#line 1642 "objc-parse.y" +#line 1487 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 312: -#line 1651 "objc-parse.y" +#line 1496 "objc-parse.y" { if (pedantic && yyvsp[0].ends_in_label) pedwarn ("ANSI C forbids label at end of compound statement"); ; break;} case 314: -#line 1660 "objc-parse.y" +#line 1505 "objc-parse.y" { yyval.ends_in_label = yyvsp[0].ends_in_label; ; break;} case 315: -#line 1662 "objc-parse.y" +#line 1507 "objc-parse.y" { yyval.ends_in_label = 0; ; break;} case 319: -#line 1674 "objc-parse.y" +#line 1519 "objc-parse.y" { emit_line_note (input_filename, lineno); pushlevel (0); clear_last_expr (); @@ -3768,12 +3613,12 @@ case 319: ; break;} case 321: -#line 1688 "objc-parse.y" +#line 1533 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids label declarations"); ; break;} case 324: -#line 1699 "objc-parse.y" +#line 1544 "objc-parse.y" { tree link; for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link)) { @@ -3784,37 +3629,37 @@ case 324: ; break;} case 325: -#line 1713 "objc-parse.y" +#line 1558 "objc-parse.y" {; break;} case 327: -#line 1717 "objc-parse.y" +#line 1562 "objc-parse.y" { compstmt_count++; ; break;} case 328: -#line 1720 "objc-parse.y" +#line 1565 "objc-parse.y" { yyval.ttype = convert (void_type_node, integer_zero_node); ; break;} case 329: -#line 1722 "objc-parse.y" +#line 1567 "objc-parse.y" { emit_line_note (input_filename, lineno); expand_end_bindings (getdecls (), 1, 0); yyval.ttype = poplevel (1, 1, 0); ; break;} case 330: -#line 1726 "objc-parse.y" +#line 1571 "objc-parse.y" { emit_line_note (input_filename, lineno); expand_end_bindings (getdecls (), kept_level_p (), 0); yyval.ttype = poplevel (kept_level_p (), 0, 0); ; break;} case 331: -#line 1730 "objc-parse.y" +#line 1575 "objc-parse.y" { emit_line_note (input_filename, lineno); expand_end_bindings (getdecls (), kept_level_p (), 0); yyval.ttype = poplevel (kept_level_p (), 0, 0); ; break;} case 332: -#line 1737 "objc-parse.y" +#line 1582 "objc-parse.y" { if (current_function_decl == 0) { error ("braced-group within expression allowed only inside a function"); @@ -3832,11 +3677,11 @@ case 332: ; break;} case 333: -#line 1754 "objc-parse.y" +#line 1599 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 336: -#line 1768 "objc-parse.y" +#line 1613 "objc-parse.y" { emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno); c_expand_start_cond (truthvalue_conversion (yyvsp[-1].ttype), 0, compstmt_count); @@ -3846,7 +3691,7 @@ case 336: position_after_white_space (); ; break;} case 337: -#line 1782 "objc-parse.y" +#line 1627 "objc-parse.y" { stmt_count++; compstmt_count++; emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno); @@ -3856,43 +3701,43 @@ case 337: position_after_white_space (); ; break;} case 338: -#line 1790 "objc-parse.y" +#line 1635 "objc-parse.y" { expand_loop_continue_here (); ; break;} case 339: -#line 1794 "objc-parse.y" +#line 1639 "objc-parse.y" { yyval.filename = input_filename; ; break;} case 340: -#line 1798 "objc-parse.y" +#line 1643 "objc-parse.y" { yyval.lineno = lineno; ; break;} case 341: -#line 1803 "objc-parse.y" +#line 1648 "objc-parse.y" { ; break;} case 342: -#line 1808 "objc-parse.y" +#line 1653 "objc-parse.y" { ; break;} case 343: -#line 1813 "objc-parse.y" +#line 1658 "objc-parse.y" { yyval.ends_in_label = yyvsp[0].ends_in_label; ; break;} case 344: -#line 1818 "objc-parse.y" +#line 1663 "objc-parse.y" { yyval.ends_in_label = 0; ; break;} case 345: -#line 1820 "objc-parse.y" +#line 1665 "objc-parse.y" { yyval.ends_in_label = 1; ; break;} case 346: -#line 1826 "objc-parse.y" +#line 1671 "objc-parse.y" { stmt_count++; ; break;} case 348: -#line 1829 "objc-parse.y" +#line 1674 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); /* It appears that this should not be done--that a non-lvalue array @@ -3910,19 +3755,19 @@ case 348: iterator_expand (yyvsp[-1].ttype); ; break;} case 349: -#line 1845 "objc-parse.y" +#line 1690 "objc-parse.y" { c_expand_start_else (); yyvsp[-1].itype = stmt_count; position_after_white_space (); ; break;} case 350: -#line 1849 "objc-parse.y" +#line 1694 "objc-parse.y" { c_expand_end_cond (); if (extra_warnings && stmt_count == yyvsp[-3].itype) warning ("empty body in an else-statement"); ; break;} case 351: -#line 1853 "objc-parse.y" +#line 1698 "objc-parse.y" { c_expand_end_cond (); /* This warning is here instead of in simple_if, because we do not want a warning if an empty if is followed by an @@ -3933,11 +3778,11 @@ case 351: "empty body in an if-statement"); ; break;} case 352: -#line 1865 "objc-parse.y" +#line 1710 "objc-parse.y" { c_expand_end_cond (); ; break;} case 353: -#line 1867 "objc-parse.y" +#line 1712 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno); /* The emit_nop used to come before emit_line_note, @@ -3949,7 +3794,7 @@ case 353: emit_nop (); ; break;} case 354: -#line 1877 "objc-parse.y" +#line 1722 "objc-parse.y" { /* Don't start the loop till we have succeeded in parsing the end test. This is to make sure that we end every loop we start. */ @@ -3960,22 +3805,22 @@ case 354: position_after_white_space (); ; break;} case 355: -#line 1886 "objc-parse.y" +#line 1731 "objc-parse.y" { expand_end_loop (); ; break;} case 356: -#line 1889 "objc-parse.y" +#line 1734 "objc-parse.y" { emit_line_note (input_filename, lineno); expand_exit_loop_if_false (NULL_PTR, truthvalue_conversion (yyvsp[-2].ttype)); expand_end_loop (); ; break;} case 357: -#line 1895 "objc-parse.y" +#line 1740 "objc-parse.y" { expand_end_loop (); ; break;} case 358: -#line 1898 "objc-parse.y" +#line 1743 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno); /* See comment in `while' alternative, above. */ @@ -3988,12 +3833,12 @@ case 358: ; break;} case 359: -#line 1910 "objc-parse.y" +#line 1755 "objc-parse.y" { yyvsp[0].lineno = lineno; yyval.filename = input_filename; ; break;} case 360: -#line 1913 "objc-parse.y" +#line 1758 "objc-parse.y" { /* Start the loop. Doing this after parsing all the expressions ensures we will end the loop. */ @@ -4008,7 +3853,7 @@ case 360: position_after_white_space (); ; break;} case 361: -#line 1926 "objc-parse.y" +#line 1771 "objc-parse.y" { /* Emit the increment expression, with a line number. */ emit_line_note (yyvsp[-4].filename, yyvsp[-5].lineno); expand_loop_continue_here (); @@ -4017,44 +3862,44 @@ case 361: expand_end_loop (); ; break;} case 362: -#line 1933 "objc-parse.y" +#line 1778 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno); c_expand_start_case (yyvsp[-1].ttype); position_after_white_space (); ; break;} case 363: -#line 1938 "objc-parse.y" +#line 1783 "objc-parse.y" { expand_end_case (yyvsp[-3].ttype); ; break;} case 364: -#line 1940 "objc-parse.y" +#line 1785 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); if ( ! expand_exit_something ()) error ("break statement not within loop or switch"); ; break;} case 365: -#line 1945 "objc-parse.y" +#line 1790 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); if (! expand_continue_loop (NULL_PTR)) error ("continue statement not within a loop"); ; break;} case 366: -#line 1950 "objc-parse.y" +#line 1795 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno); c_expand_return (NULL_TREE); ; break;} case 367: -#line 1954 "objc-parse.y" +#line 1799 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno); c_expand_return (yyvsp[-1].ttype); ; break;} case 368: -#line 1958 "objc-parse.y" +#line 1803 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-7].filename, yyvsp[-6].lineno); STRIP_NOPS (yyvsp[-2].ttype); @@ -4066,7 +3911,7 @@ case 368: error ("argument of `asm' is not a constant string"); ; break;} case 369: -#line 1969 "objc-parse.y" +#line 1814 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-9].filename, yyvsp[-8].lineno); c_expand_asm_operands (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE, @@ -4074,7 +3919,7 @@ case 369: input_filename, lineno); ; break;} case 370: -#line 1976 "objc-parse.y" +#line 1821 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-11].filename, yyvsp[-10].lineno); c_expand_asm_operands (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, @@ -4082,7 +3927,7 @@ case 370: input_filename, lineno); ; break;} case 371: -#line 1984 "objc-parse.y" +#line 1829 "objc-parse.y" { stmt_count++; emit_line_note (yyvsp[-13].filename, yyvsp[-12].lineno); c_expand_asm_operands (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, @@ -4090,7 +3935,7 @@ case 371: input_filename, lineno); ; break;} case 372: -#line 1990 "objc-parse.y" +#line 1835 "objc-parse.y" { tree decl; stmt_count++; emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno); @@ -4103,7 +3948,7 @@ case 372: ; break;} case 373: -#line 2001 "objc-parse.y" +#line 1846 "objc-parse.y" { if (pedantic) pedwarn ("ANSI C forbids `goto *expr;'"); stmt_count++; @@ -4111,7 +3956,7 @@ case 373: expand_computed_goto (convert (ptr_type_node, yyvsp[-1].ttype)); ; break;} case 376: -#line 2016 "objc-parse.y" +#line 1861 "objc-parse.y" { /* The value returned by this action is */ /* 1 if everything is OK */ @@ -4134,14 +3979,14 @@ case 376: ; break;} case 377: -#line 2037 "objc-parse.y" +#line 1882 "objc-parse.y" { if (yyvsp[-1].itype) iterator_for_loop_end (yyvsp[-3].ttype); ; break;} case 378: -#line 2068 "objc-parse.y" +#line 1913 "objc-parse.y" { register tree value = check_case_value (yyvsp[-1].ttype); register tree label = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE); @@ -4174,7 +4019,7 @@ case 378: position_after_white_space (); ; break;} case 379: -#line 2099 "objc-parse.y" +#line 1944 "objc-parse.y" { register tree value1 = check_case_value (yyvsp[-3].ttype); register tree value2 = check_case_value (yyvsp[-1].ttype); register tree label @@ -4207,7 +4052,7 @@ case 379: position_after_white_space (); ; break;} case 380: -#line 2130 "objc-parse.y" +#line 1975 "objc-parse.y" { tree duplicate; register tree label @@ -4224,7 +4069,7 @@ case 380: position_after_white_space (); ; break;} case 381: -#line 2145 "objc-parse.y" +#line 1990 "objc-parse.y" { tree label = define_label (input_filename, lineno, yyvsp[-2].ttype); stmt_count++; emit_nop (); @@ -4236,52 +4081,52 @@ case 381: position_after_white_space (); ; break;} case 382: -#line 2160 "objc-parse.y" +#line 2005 "objc-parse.y" { emit_line_note (input_filename, lineno); yyval.ttype = NULL_TREE; ; break;} case 383: -#line 2163 "objc-parse.y" +#line 2008 "objc-parse.y" { emit_line_note (input_filename, lineno); ; break;} case 384: -#line 2168 "objc-parse.y" +#line 2013 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 386: -#line 2175 "objc-parse.y" +#line 2020 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 389: -#line 2182 "objc-parse.y" +#line 2027 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 390: -#line 2187 "objc-parse.y" +#line 2032 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 391: -#line 2192 "objc-parse.y" +#line 2037 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), NULL_TREE); ; break;} case 392: -#line 2194 "objc-parse.y" +#line 2039 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), yyvsp[-2].ttype); ; break;} case 393: -#line 2200 "objc-parse.y" +#line 2045 "objc-parse.y" { pushlevel (0); clear_parm_order (); declare_parm_level (0); ; break;} case 394: -#line 2204 "objc-parse.y" +#line 2049 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; parmlist_tags_warning (); poplevel (0, 0, 0); ; break;} case 396: -#line 2212 "objc-parse.y" +#line 2057 "objc-parse.y" { tree parm; if (pedantic) pedwarn ("ANSI C forbids forward parameter declarations"); @@ -4291,19 +4136,19 @@ case 396: clear_parm_order (); ; break;} case 397: -#line 2220 "objc-parse.y" +#line 2065 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; ; break;} case 398: -#line 2222 "objc-parse.y" +#line 2067 "objc-parse.y" { yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, NULL_TREE); ; break;} case 399: -#line 2228 "objc-parse.y" +#line 2073 "objc-parse.y" { yyval.ttype = get_parm_info (0); ; break;} case 400: -#line 2230 "objc-parse.y" +#line 2075 "objc-parse.y" { yyval.ttype = get_parm_info (0); /* Gcc used to allow this as an extension. However, it does not work for all targets, and thus has been disabled. @@ -4315,23 +4160,23 @@ case 400: ; break;} case 401: -#line 2240 "objc-parse.y" +#line 2085 "objc-parse.y" { yyval.ttype = get_parm_info (1); ; break;} case 402: -#line 2242 "objc-parse.y" +#line 2087 "objc-parse.y" { yyval.ttype = get_parm_info (0); ; break;} case 403: -#line 2247 "objc-parse.y" +#line 2092 "objc-parse.y" { push_parm_decl (yyvsp[0].ttype); ; break;} case 404: -#line 2249 "objc-parse.y" +#line 2094 "objc-parse.y" { push_parm_decl (yyvsp[0].ttype); ; break;} case 405: -#line 2256 "objc-parse.y" +#line 2101 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -4341,7 +4186,7 @@ case 405: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 406: -#line 2264 "objc-parse.y" +#line 2109 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -4351,7 +4196,7 @@ case 406: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 407: -#line 2272 "objc-parse.y" +#line 2117 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -4361,7 +4206,7 @@ case 407: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 408: -#line 2280 "objc-parse.y" +#line 2125 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -4371,7 +4216,7 @@ case 408: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 409: -#line 2289 "objc-parse.y" +#line 2134 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, @@ -4381,19 +4226,19 @@ case 409: declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 410: -#line 2302 "objc-parse.y" +#line 2147 "objc-parse.y" { pushlevel (0); clear_parm_order (); declare_parm_level (1); ; break;} case 411: -#line 2306 "objc-parse.y" +#line 2151 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; parmlist_tags_warning (); poplevel (0, 0, 0); ; break;} case 413: -#line 2314 "objc-parse.y" +#line 2159 "objc-parse.y" { tree t; for (t = yyvsp[-1].ttype; t; t = TREE_CHAIN (t)) if (TREE_VALUE (t) == NULL_TREE) @@ -4401,29 +4246,29 @@ case 413: yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, yyvsp[-1].ttype); ; break;} case 414: -#line 2324 "objc-parse.y" +#line 2169 "objc-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 415: -#line 2326 "objc-parse.y" +#line 2171 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 416: -#line 2332 "objc-parse.y" +#line 2177 "objc-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 417: -#line 2334 "objc-parse.y" +#line 2179 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 418: -#line 2339 "objc-parse.y" +#line 2184 "objc-parse.y" { yyval.ttype = SAVE_WARN_FLAGS(); pedantic = 0; warn_pointer_arith = 0; ; break;} case 424: -#line 2353 "objc-parse.y" +#line 2198 "objc-parse.y" { if (objc_implementation_context) { @@ -4436,27 +4281,27 @@ case 424: ; break;} case 425: -#line 2368 "objc-parse.y" +#line 2213 "objc-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 426: -#line 2370 "objc-parse.y" +#line 2215 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ; break;} case 427: -#line 2375 "objc-parse.y" +#line 2220 "objc-parse.y" { objc_declare_class (yyvsp[-1].ttype); ; break;} case 428: -#line 2381 "objc-parse.y" +#line 2226 "objc-parse.y" { objc_declare_alias (yyvsp[-2].ttype, yyvsp[-1].ttype); ; break;} case 429: -#line 2387 "objc-parse.y" +#line 2232 "objc-parse.y" { objc_interface_context = objc_ivar_context = start_class (CLASS_INTERFACE_TYPE, yyvsp[-2].ttype, NULL_TREE, yyvsp[-1].ttype); @@ -4464,20 +4309,20 @@ case 429: ; break;} case 430: -#line 2393 "objc-parse.y" +#line 2238 "objc-parse.y" { continue_class (objc_interface_context); ; break;} case 431: -#line 2398 "objc-parse.y" +#line 2243 "objc-parse.y" { finish_class (objc_interface_context); objc_interface_context = NULL_TREE; ; break;} case 432: -#line 2404 "objc-parse.y" +#line 2249 "objc-parse.y" { objc_interface_context = start_class (CLASS_INTERFACE_TYPE, yyvsp[-1].ttype, NULL_TREE, yyvsp[0].ttype); @@ -4485,14 +4330,14 @@ case 432: ; break;} case 433: -#line 2411 "objc-parse.y" +#line 2256 "objc-parse.y" { finish_class (objc_interface_context); objc_interface_context = NULL_TREE; ; break;} case 434: -#line 2417 "objc-parse.y" +#line 2262 "objc-parse.y" { objc_interface_context = objc_ivar_context = start_class (CLASS_INTERFACE_TYPE, yyvsp[-4].ttype, yyvsp[-2].ttype, yyvsp[-1].ttype); @@ -4500,20 +4345,20 @@ case 434: ; break;} case 435: -#line 2423 "objc-parse.y" +#line 2268 "objc-parse.y" { continue_class (objc_interface_context); ; break;} case 436: -#line 2428 "objc-parse.y" +#line 2273 "objc-parse.y" { finish_class (objc_interface_context); objc_interface_context = NULL_TREE; ; break;} case 437: -#line 2434 "objc-parse.y" +#line 2279 "objc-parse.y" { objc_interface_context = start_class (CLASS_INTERFACE_TYPE, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); @@ -4521,14 +4366,14 @@ case 437: ; break;} case 438: -#line 2441 "objc-parse.y" +#line 2286 "objc-parse.y" { finish_class (objc_interface_context); objc_interface_context = NULL_TREE; ; break;} case 439: -#line 2447 "objc-parse.y" +#line 2292 "objc-parse.y" { objc_implementation_context = objc_ivar_context = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[-1].ttype, NULL_TREE, NULL_TREE); @@ -4536,14 +4381,14 @@ case 439: ; break;} case 440: -#line 2453 "objc-parse.y" +#line 2298 "objc-parse.y" { objc_ivar_chain = continue_class (objc_implementation_context); ; break;} case 441: -#line 2459 "objc-parse.y" +#line 2304 "objc-parse.y" { objc_implementation_context = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[0].ttype, NULL_TREE, NULL_TREE); @@ -4552,7 +4397,7 @@ case 441: ; break;} case 442: -#line 2467 "objc-parse.y" +#line 2312 "objc-parse.y" { objc_implementation_context = objc_ivar_context = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE); @@ -4560,14 +4405,14 @@ case 442: ; break;} case 443: -#line 2473 "objc-parse.y" +#line 2318 "objc-parse.y" { objc_ivar_chain = continue_class (objc_implementation_context); ; break;} case 444: -#line 2479 "objc-parse.y" +#line 2324 "objc-parse.y" { objc_implementation_context = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); @@ -4576,7 +4421,7 @@ case 444: ; break;} case 445: -#line 2487 "objc-parse.y" +#line 2332 "objc-parse.y" { objc_interface_context = start_class (CATEGORY_INTERFACE_TYPE, yyvsp[-4].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); @@ -4584,14 +4429,14 @@ case 445: ; break;} case 446: -#line 2494 "objc-parse.y" +#line 2339 "objc-parse.y" { finish_class (objc_interface_context); objc_interface_context = NULL_TREE; ; break;} case 447: -#line 2500 "objc-parse.y" +#line 2345 "objc-parse.y" { objc_implementation_context = start_class (CATEGORY_IMPLEMENTATION_TYPE, yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE); @@ -4600,7 +4445,7 @@ case 447: ; break;} case 448: -#line 2510 "objc-parse.y" +#line 2355 "objc-parse.y" { remember_protocol_qualifiers (); objc_interface_context @@ -4608,7 +4453,7 @@ case 448: ; break;} case 449: -#line 2516 "objc-parse.y" +#line 2361 "objc-parse.y" { forget_protocol_qualifiers(); finish_protocol(objc_interface_context); @@ -4616,13 +4461,13 @@ case 449: ; break;} case 450: -#line 2525 "objc-parse.y" +#line 2370 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 452: -#line 2533 "objc-parse.y" +#line 2378 "objc-parse.y" { if (yyvsp[-2].code == LT_EXPR && yyvsp[0].code == GT_EXPR) yyval.ttype = yyvsp[-1].ttype; @@ -4631,54 +4476,54 @@ case 452: ; break;} case 455: -#line 2547 "objc-parse.y" +#line 2392 "objc-parse.y" { objc_public_flag = 2; ; break;} case 456: -#line 2548 "objc-parse.y" +#line 2393 "objc-parse.y" { objc_public_flag = 0; ; break;} case 457: -#line 2549 "objc-parse.y" +#line 2394 "objc-parse.y" { objc_public_flag = 1; ; break;} case 458: -#line 2554 "objc-parse.y" +#line 2399 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 460: -#line 2559 "objc-parse.y" +#line 2404 "objc-parse.y" { if (pedantic) pedwarn ("extra semicolon in struct or union specified"); ; break;} case 461: -#line 2577 "objc-parse.y" +#line 2422 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 462: -#line 2582 "objc-parse.y" +#line 2427 "objc-parse.y" { yyval.ttype = yyvsp[0].ttype; current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 463: -#line 2587 "objc-parse.y" +#line 2432 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 464: -#line 2592 "objc-parse.y" +#line 2437 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 467: -#line 2599 "objc-parse.y" +#line 2444 "objc-parse.y" { yyval.ttype = add_instance_variable (objc_ivar_context, objc_public_flag, @@ -4687,7 +4532,7 @@ case 467: ; break;} case 468: -#line 2606 "objc-parse.y" +#line 2451 "objc-parse.y" { yyval.ttype = add_instance_variable (objc_ivar_context, objc_public_flag, @@ -4695,7 +4540,7 @@ case 468: ; break;} case 469: -#line 2612 "objc-parse.y" +#line 2457 "objc-parse.y" { yyval.ttype = add_instance_variable (objc_ivar_context, objc_public_flag, @@ -4704,7 +4549,7 @@ case 469: ; break;} case 470: -#line 2622 "objc-parse.y" +#line 2467 "objc-parse.y" { remember_protocol_qualifiers (); if (objc_implementation_context) @@ -4714,7 +4559,7 @@ case 470: ; break;} case 471: -#line 2630 "objc-parse.y" +#line 2475 "objc-parse.y" { forget_protocol_qualifiers (); add_class_method (objc_implementation_context, yyvsp[0].ttype); @@ -4723,20 +4568,20 @@ case 471: ; break;} case 472: -#line 2637 "objc-parse.y" +#line 2482 "objc-parse.y" { continue_method_def (); ; break;} case 473: -#line 2641 "objc-parse.y" +#line 2486 "objc-parse.y" { finish_method_def (); objc_method_context = NULL_TREE; ; break;} case 474: -#line 2647 "objc-parse.y" +#line 2492 "objc-parse.y" { remember_protocol_qualifiers (); if (objc_implementation_context) @@ -4746,7 +4591,7 @@ case 474: ; break;} case 475: -#line 2655 "objc-parse.y" +#line 2500 "objc-parse.y" { forget_protocol_qualifiers (); add_instance_method (objc_implementation_context, yyvsp[0].ttype); @@ -4755,28 +4600,28 @@ case 475: ; break;} case 476: -#line 2662 "objc-parse.y" +#line 2507 "objc-parse.y" { continue_method_def (); ; break;} case 477: -#line 2666 "objc-parse.y" +#line 2511 "objc-parse.y" { finish_method_def (); objc_method_context = NULL_TREE; ; break;} case 479: -#line 2678 "objc-parse.y" +#line 2523 "objc-parse.y" {yyval.ttype = NULL_TREE; ; break;} case 484: -#line 2685 "objc-parse.y" +#line 2530 "objc-parse.y" {yyval.ttype = NULL_TREE; ; break;} case 488: -#line 2695 "objc-parse.y" +#line 2540 "objc-parse.y" { /* Remember protocol qualifiers in prototypes. */ remember_protocol_qualifiers (); @@ -4784,7 +4629,7 @@ case 488: ; break;} case 489: -#line 2701 "objc-parse.y" +#line 2546 "objc-parse.y" { /* Forget protocol qualifiers here. */ forget_protocol_qualifiers (); @@ -4792,7 +4637,7 @@ case 489: ; break;} case 491: -#line 2709 "objc-parse.y" +#line 2554 "objc-parse.y" { /* Remember protocol qualifiers in prototypes. */ remember_protocol_qualifiers (); @@ -4800,7 +4645,7 @@ case 491: ; break;} case 492: -#line 2715 "objc-parse.y" +#line 2560 "objc-parse.y" { /* Forget protocol qualifiers here. */ forget_protocol_qualifiers (); @@ -4808,93 +4653,93 @@ case 492: ; break;} case 494: -#line 2725 "objc-parse.y" +#line 2570 "objc-parse.y" { yyval.ttype = build_method_decl (objc_inherit_code, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ; break;} case 495: -#line 2730 "objc-parse.y" +#line 2575 "objc-parse.y" { yyval.ttype = build_method_decl (objc_inherit_code, NULL_TREE, yyvsp[0].ttype, NULL_TREE); ; break;} case 496: -#line 2735 "objc-parse.y" +#line 2580 "objc-parse.y" { yyval.ttype = build_method_decl (objc_inherit_code, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 497: -#line 2740 "objc-parse.y" +#line 2585 "objc-parse.y" { yyval.ttype = build_method_decl (objc_inherit_code, NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 506: -#line 2770 "objc-parse.y" +#line 2615 "objc-parse.y" { current_declspecs = TREE_VALUE (declspec_stack); prefix_attributes = TREE_PURPOSE (declspec_stack); declspec_stack = TREE_CHAIN (declspec_stack); ; break;} case 507: -#line 2774 "objc-parse.y" +#line 2619 "objc-parse.y" { shadow_tag (yyvsp[-1].ttype); ; break;} case 508: -#line 2776 "objc-parse.y" +#line 2621 "objc-parse.y" { pedwarn ("empty declaration"); ; break;} case 509: -#line 2781 "objc-parse.y" +#line 2626 "objc-parse.y" { push_parm_decl (yyvsp[0].ttype); ; break;} case 510: -#line 2783 "objc-parse.y" +#line 2628 "objc-parse.y" { push_parm_decl (yyvsp[0].ttype); ; break;} case 511: -#line 2791 "objc-parse.y" +#line 2636 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, yyvsp[0].ttype)); ; break;} case 512: -#line 2796 "objc-parse.y" +#line 2641 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, yyvsp[0].ttype)); ; break;} case 513: -#line 2801 "objc-parse.y" +#line 2646 "objc-parse.y" { yyval.ttype = build_tree_list (build_tree_list (current_declspecs, yyvsp[-1].ttype), build_tree_list (prefix_attributes, yyvsp[0].ttype)); ; break;} case 514: -#line 2809 "objc-parse.y" +#line 2654 "objc-parse.y" { yyval.ttype = NULL_TREE; ; break;} case 515: -#line 2813 "objc-parse.y" +#line 2658 "objc-parse.y" { /* oh what a kludge! */ yyval.ttype = objc_ellipsis_node; ; break;} case 516: -#line 2818 "objc-parse.y" +#line 2663 "objc-parse.y" { pushlevel (0); ; break;} case 517: -#line 2822 "objc-parse.y" +#line 2667 "objc-parse.y" { /* returns a tree list node generated by get_parm_info */ yyval.ttype = yyvsp[0].ttype; @@ -4902,119 +4747,119 @@ case 517: ; break;} case 520: -#line 2837 "objc-parse.y" +#line 2682 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 525: -#line 2850 "objc-parse.y" +#line 2695 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 526: -#line 2851 "objc-parse.y" +#line 2696 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 527: -#line 2852 "objc-parse.y" +#line 2697 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 528: -#line 2853 "objc-parse.y" +#line 2698 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 529: -#line 2854 "objc-parse.y" +#line 2699 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 530: -#line 2855 "objc-parse.y" +#line 2700 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 531: -#line 2856 "objc-parse.y" +#line 2701 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 532: -#line 2857 "objc-parse.y" +#line 2702 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 533: -#line 2858 "objc-parse.y" +#line 2703 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 534: -#line 2859 "objc-parse.y" +#line 2704 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 535: -#line 2860 "objc-parse.y" +#line 2705 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 536: -#line 2861 "objc-parse.y" +#line 2706 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 537: -#line 2862 "objc-parse.y" +#line 2707 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 538: -#line 2863 "objc-parse.y" +#line 2708 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 539: -#line 2864 "objc-parse.y" +#line 2709 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 540: -#line 2865 "objc-parse.y" +#line 2710 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 541: -#line 2866 "objc-parse.y" +#line 2711 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 542: -#line 2867 "objc-parse.y" +#line 2712 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 543: -#line 2868 "objc-parse.y" +#line 2713 "objc-parse.y" { yyval.ttype = get_identifier (token_buffer); ; break;} case 546: -#line 2874 "objc-parse.y" +#line 2719 "objc-parse.y" { yyval.ttype = build_keyword_decl (yyvsp[-5].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 547: -#line 2879 "objc-parse.y" +#line 2724 "objc-parse.y" { yyval.ttype = build_keyword_decl (yyvsp[-2].ttype, NULL_TREE, yyvsp[0].ttype); ; break;} case 548: -#line 2884 "objc-parse.y" +#line 2729 "objc-parse.y" { yyval.ttype = build_keyword_decl (NULL_TREE, yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 549: -#line 2889 "objc-parse.y" +#line 2734 "objc-parse.y" { yyval.ttype = build_keyword_decl (NULL_TREE, NULL_TREE, yyvsp[0].ttype); ; break;} case 553: -#line 2902 "objc-parse.y" +#line 2747 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 554: -#line 2910 "objc-parse.y" +#line 2755 "objc-parse.y" { if (TREE_CHAIN (yyvsp[0].ttype) == NULL_TREE) /* just return the expr., remove a level of indirection */ @@ -5025,76 +4870,76 @@ case 554: ; break;} case 555: -#line 2922 "objc-parse.y" +#line 2767 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-2].ttype, yyvsp[0].ttype); ; break;} case 556: -#line 2926 "objc-parse.y" +#line 2771 "objc-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ; break;} case 558: -#line 2934 "objc-parse.y" +#line 2779 "objc-parse.y" { yyval.ttype = get_class_reference (yyvsp[0].ttype); ; break;} case 559: -#line 2941 "objc-parse.y" +#line 2786 "objc-parse.y" { objc_receiver_context = 1; ; break;} case 560: -#line 2943 "objc-parse.y" +#line 2788 "objc-parse.y" { objc_receiver_context = 0; ; break;} case 561: -#line 2945 "objc-parse.y" +#line 2790 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ; break;} case 565: -#line 2958 "objc-parse.y" +#line 2803 "objc-parse.y" { yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ; break;} case 566: -#line 2965 "objc-parse.y" +#line 2810 "objc-parse.y" { yyval.ttype = build_tree_list (yyvsp[-1].ttype, NULL_TREE); ; break;} case 567: -#line 2969 "objc-parse.y" +#line 2814 "objc-parse.y" { yyval.ttype = build_tree_list (NULL_TREE, NULL_TREE); ; break;} case 568: -#line 2976 "objc-parse.y" +#line 2821 "objc-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 569: -#line 2983 "objc-parse.y" +#line 2828 "objc-parse.y" { yyval.ttype = yyvsp[-1].ttype; ; break;} case 570: -#line 2992 "objc-parse.y" +#line 2837 "objc-parse.y" { yyval.ttype = groktypename (yyvsp[-1].ttype); ; break;} } /* the action file gets copied in in place of this dollarsign */ -#line 543 "/usr/lib/bison.simple" +#line 543 "/usr/share/misc/bison.simple" yyvsp -= yylen; yyssp -= yylen; @@ -5314,5 +5159,5 @@ yyerrhandle: } return 1; } -#line 2997 "objc-parse.y" +#line 2842 "objc-parse.y" diff --git a/gcc/objc/objc-parse.y b/gcc/objc/objc-parse.y index 7bf9119..b6f15b2 100644 --- a/gcc/objc/objc-parse.y +++ b/gcc/objc/objc-parse.y @@ -213,9 +213,6 @@ static tree prefix_attributes = NULL_TREE; /* Stack of saved values of current_declspecs and prefix_attributes. */ static tree declspec_stack; -/* 1 if we explained undeclared var errors. */ -static int undeclared_variable_notice; - /* For __extension__, save/restore the warning flags which are controlled by __extension__. */ #define SAVE_WARN_FLAGS() \ @@ -607,161 +604,9 @@ expr_no_commas: primary: IDENTIFIER { - $$ = lastiddecl; - if (!$$ || $$ == error_mark_node) - { - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - tree decl; - - if (objc_receiver_context - && ! (objc_receiver_context - && strcmp (IDENTIFIER_POINTER ($1), "super"))) - /* we have a message to super */ - $$ = get_super_receiver (); - else if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, $1))) - { - if (is_private (decl)) - $$ = error_mark_node; - else - $$ = build_ivar_reference ($1); - } - else - { - /* Ordinary implicit function declaration. */ - $$ = implicitly_declare ($1); - assemble_external ($$); - TREE_USED ($$) = 1; - } - } - else if (current_function_decl == 0) - { - error ("`%s' undeclared here (not in a function)", - IDENTIFIER_POINTER ($1)); - $$ = error_mark_node; - } - else - { - tree decl; - - if (objc_receiver_context - && ! strcmp (IDENTIFIER_POINTER ($1), "super")) - /* we have a message to super */ - $$ = get_super_receiver (); - else if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, $1))) - { - if (is_private (decl)) - $$ = error_mark_node; - else - $$ = build_ivar_reference ($1); - } - else - { - if (IDENTIFIER_GLOBAL_VALUE ($1) != error_mark_node - || IDENTIFIER_ERROR_LOCUS ($1) != current_function_decl) - { - error ("`%s' undeclared (first use in this function)", - IDENTIFIER_POINTER ($1)); - - if (! undeclared_variable_notice) - { - error ("(Each undeclared identifier is reported only once"); - error ("for each function it appears in.)"); - undeclared_variable_notice = 1; - } - } - $$ = error_mark_node; - /* Prevent repeated error messages. */ - IDENTIFIER_GLOBAL_VALUE ($1) = error_mark_node; - IDENTIFIER_ERROR_LOCUS ($1) = current_function_decl; - } - } - } - else if (TREE_TYPE ($$) == error_mark_node) - $$ = error_mark_node; - else if (C_DECL_ANTICIPATED ($$)) - { - /* The first time we see a build-in function used, - if it has not been declared. */ - C_DECL_ANTICIPATED ($$) = 0; - if (yychar == YYEMPTY) - yychar = YYLEX; - if (yychar == '(') - { - /* Omit the implicit declaration we - would ordinarily do, so we don't lose - the actual built in type. - But print a diagnostic for the mismatch. */ - if (objc_method_context - && is_ivar (objc_ivar_chain, $1)) - error ("Instance variable `%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME ($$))); - else - if (TREE_CODE ($$) != FUNCTION_DECL) - error ("`%s' implicitly declared as function", - IDENTIFIER_POINTER (DECL_NAME ($$))); - else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE ($$))) - != TYPE_MODE (integer_type_node)) - && !VOID_TYPE_P (TREE_TYPE (TREE_TYPE ($$)))) - pedwarn ("type mismatch in implicit declaration for built-in function `%s'", - IDENTIFIER_POINTER (DECL_NAME ($$))); - /* If it really returns void, change that to int. */ - if (TREE_TYPE (TREE_TYPE ($$)) == void_type_node) - TREE_TYPE ($$) - = build_function_type (integer_type_node, - TYPE_ARG_TYPES (TREE_TYPE ($$))); - } - else - pedwarn ("built-in function `%s' used without declaration", - IDENTIFIER_POINTER (DECL_NAME ($$))); - - /* Do what we would ordinarily do when a fn is used. */ - assemble_external ($$); - TREE_USED ($$) = 1; - } - else - { - assemble_external ($$); - TREE_USED ($$) = 1; - /* we have a definition - still check if iVariable */ - - if (!objc_receiver_context - || (objc_receiver_context - && strcmp (IDENTIFIER_POINTER ($1), "super"))) - { - tree decl; - - if (objc_method_context - && (decl = is_ivar (objc_ivar_chain, $1))) - { - if (IDENTIFIER_LOCAL_VALUE ($1)) - warning ("local declaration of `%s' hides instance variable", - IDENTIFIER_POINTER ($1)); - else - { - if (is_private (decl)) - $$ = error_mark_node; - else - $$ = build_ivar_reference ($1); - } - } - } - else /* we have a message to super */ - $$ = get_super_receiver (); - } - - if (TREE_CODE ($$) == CONST_DECL) - { - $$ = DECL_INITIAL ($$); - /* This is to prevent an enum whose value is 0 - from being considered a null pointer constant. */ - $$ = build1 (NOP_EXPR, TREE_TYPE ($$), $$); - TREE_CONSTANT ($$) = 1; - } + if (yychar == YYEMPTY) + yychar = YYLEX; + $$ = build_external_ref ($1, yychar == '('); } | CONSTANT | string |