This is the mail archive of the gcc-patches@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[PATCH] More location cleanup


Hi,
this patch removes the unused filename and line parameters from grokfield.

booted & tested on i686-pc-linux-gnu, ok?

nathan
--
Nathan Sidwell    ::   http://www.codesourcery.com   ::     CodeSourcery LLC
         The voices in my head said this was stupid too
nathan@codesourcery.com    ::     http://www.planetfall.pwp.blueyonder.co.uk

2003-06-26  Nathan Sidwell  <nathan@codesourcery.com>

	* c-tree.h (grokfield): Remove unused filename and line parameters.
	* c-decl.c (grokfield): Remove unused filename and line	parameters.
	* c-parse.in (component_decl): Adjust field grokking rules, adjust
	grokfield calls.
	(component_declarator): Likewise.
	(component_notype_declarator): Likewise.

	* objc/objc-act.c (build_module_descriptor): Adjust grokfield
	calls.
	(build_protocol_template, build_method_prototype_list_template,
	build_method_prototype_template, build_category_template,
	build_selector_template, build_class_template,
	build_super_template, build_ivar_template,
	build_ivar_list_template, build_method_list_template,
	build_method_template, add_instance_variable): Likewise.

Index: c-decl.c
===================================================================
RCS file: /cvs/gcc/gcc/gcc/c-decl.c,v
retrieving revision 1.397
diff -c -3 -p -r1.397 c-decl.c
*** c-decl.c	20 Jun 2003 22:56:35 -0000	1.397
--- c-decl.c	26 Jun 2003 19:07:35 -0000
*************** start_struct (enum tree_code code, tree 
*** 4811,4818 ****
     are ultimately passed to `build_struct' to make the RECORD_TYPE node.  */
  
  tree
! grokfield (const char *filename ATTRIBUTE_UNUSED, int line ATTRIBUTE_UNUSED,
! 	   tree declarator, tree declspecs, tree width)
  {
    tree value;
  
--- 4811,4817 ----
     are ultimately passed to `build_struct' to make the RECORD_TYPE node.  */
  
  tree
! grokfield (tree declarator, tree declspecs, tree width)
  {
    tree value;
  
Index: c-parse.in
===================================================================
RCS file: /cvs/gcc/gcc/gcc/c-parse.in,v
retrieving revision 1.161
diff -c -3 -p -r1.161 c-parse.in
*** c-parse.in	21 May 2003 14:27:43 -0000	1.161
--- c-parse.in	26 Jun 2003 19:07:43 -0000
*************** component_decl:
*** 1862,1868 ****
  	  declspecs_nosc_ts setspecs components
  		{ $$ = $3;
  		  POP_DECLSPEC_STACK; }
! 	| declspecs_nosc_ts setspecs save_filename save_lineno
  		{
  		  /* Support for unnamed structs or unions as members of
  		     structs or unions (which is [a] useful and [b] supports
--- 1862,1868 ----
  	  declspecs_nosc_ts setspecs components
  		{ $$ = $3;
  		  POP_DECLSPEC_STACK; }
! 	| declspecs_nosc_ts setspecs
  		{
  		  /* Support for unnamed structs or unions as members of
  		     structs or unions (which is [a] useful and [b] supports
*************** component_decl:
*** 1870,1876 ****
  		  if (pedantic)
  		    pedwarn ("ISO C doesn't support unnamed structs/unions");
  
! 		  $$ = grokfield($3, $4, NULL, current_declspecs, NULL_TREE);
  		  POP_DECLSPEC_STACK; }
  	| declspecs_nosc_nots setspecs components_notype
  		{ $$ = $3;
--- 1870,1876 ----
  		  if (pedantic)
  		    pedwarn ("ISO C doesn't support unnamed structs/unions");
  
! 		  $$ = grokfield(NULL, current_declspecs, NULL_TREE);
  		  POP_DECLSPEC_STACK; }
  	| declspecs_nosc_nots setspecs components_notype
  		{ $$ = $3;
*************** components_notype:
*** 1900,1928 ****
  	;
  
  component_declarator:
! 	  save_filename save_lineno declarator maybe_attribute
! 		{ $$ = grokfield ($1, $2, $3, current_declspecs, NULL_TREE);
! 		  decl_attributes (&$$, chainon ($4, all_prefix_attributes), 0); }
! 	| save_filename save_lineno
! 	  declarator ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield ($1, $2, $3, current_declspecs, $5);
! 		  decl_attributes (&$$, chainon ($6, all_prefix_attributes), 0); }
! 	| save_filename save_lineno ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield ($1, $2, NULL_TREE, current_declspecs, $4);
! 		  decl_attributes (&$$, chainon ($5, all_prefix_attributes), 0); }
  	;
  
  component_notype_declarator:
! 	  save_filename save_lineno notype_declarator maybe_attribute
! 		{ $$ = grokfield ($1, $2, $3, current_declspecs, NULL_TREE);
! 		  decl_attributes (&$$, chainon ($4, all_prefix_attributes), 0); }
! 	| save_filename save_lineno
! 	  notype_declarator ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield ($1, $2, $3, current_declspecs, $5);
! 		  decl_attributes (&$$, chainon ($6, all_prefix_attributes), 0); }
! 	| save_filename save_lineno ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield ($1, $2, NULL_TREE, current_declspecs, $4);
! 		  decl_attributes (&$$, chainon ($5, all_prefix_attributes), 0); }
  	;
  
  /* We chain the enumerators in reverse order.
--- 1900,1932 ----
  	;
  
  component_declarator:
! 	  declarator maybe_attribute
! 		{ $$ = grokfield ($1, current_declspecs, NULL_TREE);
! 		  decl_attributes (&$$,
! 				   chainon ($2, all_prefix_attributes), 0); }
! 	| declarator ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield ($1, current_declspecs, $3);
! 		  decl_attributes (&$$,
! 				   chainon ($4, all_prefix_attributes), 0); }
! 	| ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield (NULL_TREE, current_declspecs, $2);
! 		  decl_attributes (&$$,
! 				   chainon ($3, all_prefix_attributes), 0); }
  	;
  
  component_notype_declarator:
! 	  notype_declarator maybe_attribute
! 		{ $$ = grokfield ($1, current_declspecs, NULL_TREE);
! 		  decl_attributes (&$$,
! 				   chainon ($2, all_prefix_attributes), 0); }
! 	| notype_declarator ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield ($1, current_declspecs, $3);
! 		  decl_attributes (&$$,
! 				   chainon ($4, all_prefix_attributes), 0); }
! 	| ':' expr_no_commas maybe_attribute
! 		{ $$ = grokfield (NULL_TREE, current_declspecs, $2);
! 		  decl_attributes (&$$,
! 				   chainon ($3, all_prefix_attributes), 0); }
  	;
  
  /* We chain the enumerators in reverse order.
Index: c-tree.h
===================================================================
RCS file: /cvs/gcc/gcc/gcc/c-tree.h,v
retrieving revision 1.115
diff -c -3 -p -r1.115 c-tree.h
*** c-tree.h	22 Jun 2003 13:41:25 -0000	1.115
--- c-tree.h	26 Jun 2003 19:07:44 -0000
*************** extern tree finish_enum (tree, tree, tre
*** 195,201 ****
  extern void finish_function (int, int);
  extern tree finish_struct (tree, tree, tree);
  extern tree get_parm_info (int);
! extern tree grokfield (const char *, int, tree, tree, tree);
  extern tree groktypename (tree);
  extern tree groktypename_in_parm_context (tree);
  extern tree implicitly_declare (tree);
--- 195,201 ----
  extern void finish_function (int, int);
  extern tree finish_struct (tree, tree, tree);
  extern tree get_parm_info (int);
! extern tree grokfield (tree, tree, tree);
  extern tree groktypename (tree);
  extern tree groktypename_in_parm_context (tree);
  extern tree implicitly_declare (tree);
Index: objc/objc-act.c
===================================================================
RCS file: /cvs/gcc/gcc/gcc/objc/objc-act.c,v
retrieving revision 1.177
diff -c -3 -p -r1.177 objc-act.c
*** objc/objc-act.c	14 Jun 2003 17:33:32 -0000	1.177
--- objc/objc-act.c	26 Jun 2003 19:08:00 -0000
*************** build_module_descriptor ()
*** 1697,1720 ****
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("version");
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* long  size; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("size");
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* char  *name; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("name"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_symtab *symtab; */
--- 1697,1717 ----
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("version");
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* long  size; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("size");
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* char  *name; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("name"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_symtab *symtab; */
*************** build_module_descriptor ()
*** 1722,1729 ****
    decl_specs = get_identifier (UTAG_SYMTAB);
    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE, decl_specs));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("symtab"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_module_template, field_decl_chain, NULL_TREE);
--- 1719,1725 ----
    decl_specs = get_identifier (UTAG_SYMTAB);
    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE, decl_specs));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("symtab"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_module_template, field_decl_chain, NULL_TREE);
*************** build_protocol_template ()
*** 2565,2572 ****
    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE,
  					get_identifier (UTAG_CLASS)));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("isa"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *protocol_name; */
--- 2561,2567 ----
    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE,
  					get_identifier (UTAG_CLASS)));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("isa"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *protocol_name; */
*************** build_protocol_template ()
*** 2574,2581 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_name"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_protocol **protocol_list; */
--- 2569,2575 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_name"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_protocol **protocol_list; */
*************** build_protocol_template ()
*** 2584,2591 ****
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_list"));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *instance_methods; */
--- 2578,2584 ----
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_list"));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *instance_methods; */
*************** build_protocol_template ()
*** 2596,2603 ****
  				 get_identifier (UTAG_METHOD_PROTOTYPE_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("instance_methods"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *class_methods; */
--- 2589,2595 ----
  				 get_identifier (UTAG_METHOD_PROTOTYPE_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("instance_methods"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *class_methods; */
*************** build_protocol_template ()
*** 2608,2615 ****
  				 get_identifier (UTAG_METHOD_PROTOTYPE_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class_methods"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    return finish_struct (template, field_decl_chain, NULL_TREE);
--- 2600,2606 ----
  				 get_identifier (UTAG_METHOD_PROTOTYPE_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class_methods"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    return finish_struct (template, field_decl_chain, NULL_TREE);
*************** build_method_prototype_list_template (li
*** 2672,2679 ****
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("method_count");
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_method method_list[]; */
--- 2663,2669 ----
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("method_count");
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_method method_list[]; */
*************** build_method_prototype_list_template (li
*** 2681,2688 ****
    decl_specs = build_tree_list (NULL_TREE, list_type);
    field_decl = build_nt (ARRAY_REF, get_identifier ("method_list"),
  			 build_int_2 (size, 0));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_list_record, field_decl_chain, NULL_TREE);
--- 2671,2677 ----
    decl_specs = build_tree_list (NULL_TREE, list_type);
    field_decl = build_nt (ARRAY_REF, get_identifier ("method_list"),
  			 build_int_2 (size, 0));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_list_record, field_decl_chain, NULL_TREE);
*************** build_method_prototype_template ()
*** 2703,2717 ****
    decl_specs = tree_cons (NULL_TREE, xref_tag (RECORD_TYPE,
  		          get_identifier (TAG_SELECTOR)), NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("_cmd"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_CHAR], NULL_TREE);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("method_types"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (proto_record, field_decl_chain, NULL_TREE);
--- 2692,2704 ----
    decl_specs = tree_cons (NULL_TREE, xref_tag (RECORD_TYPE,
  		          get_identifier (TAG_SELECTOR)), NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("_cmd"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_CHAR], NULL_TREE);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("method_types"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (proto_record, field_decl_chain, NULL_TREE);
*************** build_category_template ()
*** 3250,3265 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("category_name"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *class_name; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class_name"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *instance_methods; */
--- 3237,3250 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("category_name"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *class_name; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class_name"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *instance_methods; */
*************** build_category_template ()
*** 3269,3276 ****
  					  get_identifier (UTAG_METHOD_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("instance_methods"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *class_methods; */
--- 3254,3260 ----
  					  get_identifier (UTAG_METHOD_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("instance_methods"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *class_methods; */
*************** build_category_template ()
*** 3280,3287 ****
  					  get_identifier (UTAG_METHOD_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class_methods"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_protocol **protocol_list; */
--- 3264,3270 ----
  					  get_identifier (UTAG_METHOD_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class_methods"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_protocol **protocol_list; */
*************** build_category_template ()
*** 3292,3299 ****
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_list"));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_category_template, field_decl_chain, NULL_TREE);
--- 3275,3281 ----
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_list"));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_category_template, field_decl_chain, NULL_TREE);
*************** build_selector_template ()
*** 3317,3332 ****
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_VOID]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sel_id"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *sel_type; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sel_type"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_selector_template, field_decl_chain, NULL_TREE);
--- 3299,3312 ----
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_VOID]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sel_id"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *sel_type; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sel_type"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_selector_template, field_decl_chain, NULL_TREE);
*************** build_class_template ()
*** 3364,3371 ****
  
    decl_specs = build_tree_list (NULL_TREE, objc_class_template);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("isa"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_class *super_class; */
--- 3344,3350 ----
  
    decl_specs = build_tree_list (NULL_TREE, objc_class_template);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("isa"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_class *super_class; */
*************** build_class_template ()
*** 3373,3412 ****
    decl_specs = build_tree_list (NULL_TREE, objc_class_template);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("super_class"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* char *name; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("name"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* long version; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("version");
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* long info; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("info");
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* long instance_size; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("instance_size");
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_ivar_list *ivars; */
--- 3352,3386 ----
    decl_specs = build_tree_list (NULL_TREE, objc_class_template);
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("super_class"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* char *name; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("name"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* long version; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("version");
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* long info; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("info");
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* long instance_size; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);
    field_decl = get_identifier ("instance_size");
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_ivar_list *ivars; */
*************** build_class_template ()
*** 3415,3422 ****
  				xref_tag (RECORD_TYPE,
  					  get_identifier (UTAG_IVAR_LIST)));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("ivars"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *methods; */
--- 3389,3395 ----
  				xref_tag (RECORD_TYPE,
  					  get_identifier (UTAG_IVAR_LIST)));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("ivars"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method_list *methods; */
*************** build_class_template ()
*** 3425,3432 ****
  				xref_tag (RECORD_TYPE,
  					  get_identifier (UTAG_METHOD_LIST)));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("methods"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    if (flag_next_runtime)
--- 3398,3404 ----
  				xref_tag (RECORD_TYPE,
  					  get_identifier (UTAG_METHOD_LIST)));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("methods"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    if (flag_next_runtime)
*************** build_class_template ()
*** 3437,3444 ****
  				    xref_tag (RECORD_TYPE,
  					      get_identifier ("objc_cache")));
        field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("cache"));
!       field_decl = grokfield (input_filename, input_line, field_decl,
! 			      decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
      }
    else
--- 3409,3415 ----
  				    xref_tag (RECORD_TYPE,
  					      get_identifier ("objc_cache")));
        field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("cache"));
!       field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
      }
    else
*************** build_class_template ()
*** 3449,3456 ****
  				    xref_tag (RECORD_TYPE,
  					      get_identifier ("sarray")));
        field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("dtable"));
!       field_decl = grokfield (input_filename, input_line, field_decl,
! 			      decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
  
        /* struct objc_class *subclass_list; */
--- 3420,3426 ----
  				    xref_tag (RECORD_TYPE,
  					      get_identifier ("sarray")));
        field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("dtable"));
!       field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
  
        /* struct objc_class *subclass_list; */
*************** build_class_template ()
*** 3458,3465 ****
        decl_specs = build_tree_list (NULL_TREE, objc_class_template);
        field_decl
  	= build1 (INDIRECT_REF, NULL_TREE, get_identifier ("subclass_list"));
!       field_decl = grokfield (input_filename, input_line, field_decl,
! 			      decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
  
        /* struct objc_class *sibling_class; */
--- 3428,3434 ----
        decl_specs = build_tree_list (NULL_TREE, objc_class_template);
        field_decl
  	= build1 (INDIRECT_REF, NULL_TREE, get_identifier ("subclass_list"));
!       field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
  
        /* struct objc_class *sibling_class; */
*************** build_class_template ()
*** 3467,3474 ****
        decl_specs = build_tree_list (NULL_TREE, objc_class_template);
        field_decl
  	= build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sibling_class"));
!       field_decl = grokfield (input_filename, input_line, field_decl,
! 			      decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
      }
  
--- 3436,3442 ----
        decl_specs = build_tree_list (NULL_TREE, objc_class_template);
        field_decl
  	= build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sibling_class"));
!       field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
        chainon (field_decl_chain, field_decl);
      }
  
*************** build_class_template ()
*** 3481,3504 ****
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_list"));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* void *sel_id; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_VOID]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sel_id"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* void *gc_object_type; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_VOID]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("gc_object_type"));
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_class_template, field_decl_chain, NULL_TREE);
--- 3449,3469 ----
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("protocol_list"));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* void *sel_id; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_VOID]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("sel_id"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* void *gc_object_type; */
  
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_VOID]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("gc_object_type"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_class_template, field_decl_chain, NULL_TREE);
*************** build_super_template ()
*** 3619,3626 ****
    decl_specs = build_tree_list (NULL_TREE, objc_object_reference);
    field_decl = get_identifier ("self");
    field_decl = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_class *class; */
--- 3584,3590 ----
    decl_specs = build_tree_list (NULL_TREE, objc_object_reference);
    field_decl = get_identifier ("self");
    field_decl = build1 (INDIRECT_REF, NULL_TREE, field_decl);
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_class *class; */
*************** build_super_template ()
*** 3629,3636 ****
    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE, decl_specs));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class"));
  
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (record, field_decl_chain, NULL_TREE);
--- 3593,3599 ----
    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE, decl_specs));
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("class"));
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (record, field_decl_chain, NULL_TREE);
*************** build_ivar_template ()
*** 3663,3670 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("ivar_name"));
  
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *ivar_type; */
--- 3626,3632 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("ivar_name"));
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* char *ivar_type; */
*************** build_ivar_template ()
*** 3672,3679 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("ivar_type"));
  
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* int ivar_offset; */
--- 3634,3640 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("ivar_type"));
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* int ivar_offset; */
*************** build_ivar_template ()
*** 3681,3688 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("ivar_offset");
  
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_record, field_decl_chain, NULL_TREE);
--- 3642,3648 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("ivar_offset");
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_record, field_decl_chain, NULL_TREE);
*************** build_ivar_list_template (list_type, siz
*** 3710,3717 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("ivar_count");
  
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_ivar ivar_list[]; */
--- 3670,3676 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("ivar_count");
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* struct objc_ivar ivar_list[]; */
*************** build_ivar_list_template (list_type, siz
*** 3720,3727 ****
    field_decl = build_nt (ARRAY_REF, get_identifier ("ivar_list"),
  			 build_int_2 (size, 0));
  
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_list_record, field_decl_chain, NULL_TREE);
--- 3679,3685 ----
    field_decl = build_nt (ARRAY_REF, get_identifier ("ivar_list"),
  			 build_int_2 (size, 0));
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_list_record, field_decl_chain, NULL_TREE);
*************** build_method_list_template (list_type, s
*** 3754,3761 ****
  		 get_identifier (UTAG_METHOD_PROTOTYPE_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("method_next"));
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* int method_count; */
--- 3712,3718 ----
  		 get_identifier (UTAG_METHOD_PROTOTYPE_LIST)));
    field_decl
      = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("method_next"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    /* int method_count; */
*************** build_method_list_template (list_type, s
*** 3763,3770 ****
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("method_count");
  
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method method_list[]; */
--- 3720,3726 ----
    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_INT]);
    field_decl = get_identifier ("method_count");
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* struct objc_method method_list[]; */
*************** build_method_list_template (list_type, s
*** 3773,3780 ****
    field_decl = build_nt (ARRAY_REF, get_identifier ("method_list"),
  			 build_int_2 (size, 0));
  
!   field_decl = grokfield (input_filename, input_line,
! 			  field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_list_record, field_decl_chain, NULL_TREE);
--- 3729,3735 ----
    field_decl = build_nt (ARRAY_REF, get_identifier ("method_list"),
  			 build_int_2 (size, 0));
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (objc_ivar_list_record, field_decl_chain, NULL_TREE);
*************** build_method_template ()
*** 3978,4000 ****
  			  NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("_cmd"));
  
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_CHAR], NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE,
  		       get_identifier ("method_types"));
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* void *_imp; */
  
    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_VOID], NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("_imp"));
!   field_decl = grokfield (input_filename, input_line, field_decl,
! 			  decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (_SLT_record, field_decl_chain, NULL_TREE);
--- 3933,3952 ----
  			  NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("_cmd"));
  
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    field_decl_chain = field_decl;
  
    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_CHAR], NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE,
  		       get_identifier ("method_types"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    /* void *_imp; */
  
    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_VOID], NULL_TREE);
    field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("_imp"));
!   field_decl = grokfield (field_decl, decl_specs, NULL_TREE);
    chainon (field_decl_chain, field_decl);
  
    finish_struct (_SLT_record, field_decl_chain, NULL_TREE);
*************** add_instance_variable (class, public, de
*** 5823,5830 ****
    else
      CLASS_RAW_IVARS (class) = raw_decl;
  
!   field_decl = grokfield (input_filename, input_line,
! 			  declarator, declspecs, width);
  
    /* Overload the public attribute, it is not used for FIELD_DECLs.  */
    switch (public)
--- 5775,5781 ----
    else
      CLASS_RAW_IVARS (class) = raw_decl;
  
!   field_decl = grokfield (declarator, declspecs, width);
  
    /* Overload the public attribute, it is not used for FIELD_DECLs.  */
    switch (public)

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]