gcj.texi (Input and output files): Mention non-class entries.
[gcc.git] / gcc / java / decl.c
1 /* Process declarations and variables for the GNU compiler for the
2 Java(TM) language.
3 Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003
4 Free Software Foundation, Inc.
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2, or (at your option)
11 any later version.
12
13 GCC is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING. If not, write to
20 the Free Software Foundation, 59 Temple Place - Suite 330,
21 Boston, MA 02111-1307, USA.
22
23 Java and all Java-based marks are trademarks or registered trademarks
24 of Sun Microsystems, Inc. in the United States and other countries.
25 The Free Software Foundation is independent of Sun Microsystems, Inc. */
26
27 /* Hacked by Per Bothner <bothner@cygnus.com> February 1996. */
28
29 #include "config.h"
30 #include "system.h"
31 #include "coretypes.h"
32 #include "tm.h"
33 #include "tree.h"
34 #include "rtl.h"
35 #include "real.h"
36 #include "toplev.h"
37 #include "flags.h"
38 #include "java-tree.h"
39 #include "jcf.h"
40 #include "function.h"
41 #include "expr.h"
42 #include "libfuncs.h"
43 #include "except.h"
44 #include "java-except.h"
45 #include "ggc.h"
46 #include "timevar.h"
47 #include "tree-inline.h"
48
49 #if defined (DEBUG_JAVA_BINDING_LEVELS)
50 extern void indent (void);
51 #endif
52
53 static tree push_jvm_slot (int, tree);
54 static tree lookup_name_current_level (tree);
55 static tree push_promoted_type (const char *, tree);
56 static struct binding_level *make_binding_level (void);
57 static tree create_primitive_vtable (const char *);
58 static tree check_local_named_variable (tree, tree, int, int *);
59 static tree check_local_unnamed_variable (tree, tree, tree);
60 static void dump_function (enum tree_dump_index, tree);
61
62 /* Name of the Cloneable class. */
63 tree java_lang_cloneable_identifier_node;
64
65 /* Name of the Serializable class. */
66 tree java_io_serializable_identifier_node;
67
68 /* Set to nonzero value in order to emit class initialization code
69 before static field references. */
70 extern int always_initialize_class_p;
71
72 /* The DECL_MAP is a mapping from (index, type) to a decl node.
73 If index < max_locals, it is the index of a local variable.
74 if index >= max_locals, then index-max_locals is a stack slot.
75 The DECL_MAP mapping is represented as a TREE_VEC whose elements
76 are a list of decls (VAR_DECL or PARM_DECL) chained by
77 DECL_LOCAL_SLOT_CHAIN; the index finds the TREE_VEC element, and then
78 we search the chain for a decl with a matching TREE_TYPE. */
79
80 static GTY(()) tree decl_map;
81
82 /* A list of local variables VAR_DECLs for this method that we have seen
83 debug information, but we have not reached their starting (byte) PC yet. */
84
85 static GTY(()) tree pending_local_decls;
86
87 /* Push a local variable or stack slot into the decl_map,
88 and assign it an rtl. */
89
90 #if defined(DEBUG_JAVA_BINDING_LEVELS)
91 int binding_depth = 0;
92 int is_class_level = 0;
93 int current_pc;
94
95 void
96 indent (void)
97 {
98 register unsigned i;
99
100 for (i = 0; i < binding_depth*2; i++)
101 putc (' ', stderr);
102 }
103 #endif /* defined(DEBUG_JAVA_BINDING_LEVELS) */
104
105 static tree
106 push_jvm_slot (int index, tree decl)
107 {
108 struct rtx_def *rtl = NULL;
109 tree type = TREE_TYPE (decl);
110 tree tmp;
111
112 DECL_CONTEXT (decl) = current_function_decl;
113 layout_decl (decl, 0);
114
115 /* See if we have an appropriate rtl (i.e. same mode) at this index.
116 If so, we must use it. */
117 tmp = TREE_VEC_ELT (decl_map, index);
118 while (tmp != NULL_TREE)
119 {
120 if (TYPE_MODE (type) == TYPE_MODE (TREE_TYPE (tmp)))
121 rtl = DECL_RTL_IF_SET (tmp);
122 if (rtl != NULL)
123 break;
124 tmp = DECL_LOCAL_SLOT_CHAIN (tmp);
125 }
126 if (rtl != NULL)
127 SET_DECL_RTL (decl, rtl);
128 else
129 {
130 if (index >= DECL_MAX_LOCALS (current_function_decl))
131 DECL_REGISTER (decl) = 1;
132 expand_decl (decl);
133 }
134
135 /* Now link the decl into the decl_map. */
136 if (DECL_LANG_SPECIFIC (decl) == NULL)
137 {
138 MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (decl);
139 DECL_LOCAL_START_PC (decl) = 0;
140 DECL_LOCAL_END_PC (decl) = DECL_CODE_LENGTH (current_function_decl);
141 DECL_LOCAL_SLOT_NUMBER (decl) = index;
142 }
143 DECL_LOCAL_SLOT_CHAIN (decl) = TREE_VEC_ELT (decl_map, index);
144 TREE_VEC_ELT (decl_map, index) = decl;
145 return decl;
146 }
147
148 /* Find out if 'decl' passed in fits the defined PC location better than
149 'best'. Return decl if it does, return best if it doesn't. If decl
150 is returned, then updated is set to true. */
151
152 static tree
153 check_local_named_variable (tree best, tree decl, int pc, int *updated)
154 {
155 if (pc >= DECL_LOCAL_START_PC (decl)
156 && pc < DECL_LOCAL_END_PC (decl))
157 {
158 if (best == NULL_TREE
159 || (DECL_LOCAL_START_PC (decl) > DECL_LOCAL_START_PC (best)
160 && DECL_LOCAL_END_PC (decl) < DECL_LOCAL_END_PC (best)))
161 {
162 *updated = 1;
163 return decl;
164 }
165 }
166
167 return best;
168 }
169
170 /* Find the best declaration based upon type. If 'decl' fits 'type' better
171 than 'best', return 'decl'. Otherwise return 'best'. */
172
173 static tree
174 check_local_unnamed_variable (tree best, tree decl, tree type)
175 {
176 if (TREE_TYPE (decl) == type
177 || (TREE_CODE (TREE_TYPE (decl)) == TREE_CODE (type)
178 && TYPE_PRECISION (TREE_TYPE (decl)) <= 32
179 && TYPE_PRECISION (type) <= 32
180 && TREE_CODE (type) != POINTER_TYPE)
181 || (TREE_CODE (TREE_TYPE (decl)) == POINTER_TYPE
182 && type == ptr_type_node))
183 {
184 if (best == NULL_TREE
185 || (TREE_TYPE (decl) == type && TREE_TYPE (best) != type))
186 return decl;
187 }
188
189 return best;
190 }
191
192
193 /* Find a VAR_DECL (or PARM_DECL) at local index INDEX that has type TYPE,
194 that is valid at PC (or -1 if any pc).
195 If there is no existing matching decl, allocate one. */
196
197 tree
198 find_local_variable (int index, tree type, int pc)
199 {
200 tree decl = TREE_VEC_ELT (decl_map, index);
201 tree best = NULL_TREE;
202 int found_scoped_var = 0;
203
204 /* Scan through every declaration that has been created in this slot. */
205 while (decl != NULL_TREE)
206 {
207 /* Variables created in give_name_to_locals() have a name and have
208 a specified scope, so we can handle them specifically. We want
209 to use the specific decls created for those so they are assigned
210 the right variables in the debugging information. */
211 if (DECL_NAME (decl) != NULL_TREE)
212 {
213 /* This is a variable we have a name for, so it has a scope
214 supplied in the class file. But it only matters when we
215 actually have a PC to use. If pc<0, then we are asking
216 for a stack slot and this decl won't be one of those. */
217 if (pc >= 0)
218 best = check_local_named_variable (best, decl, pc,
219 &found_scoped_var);
220 }
221 /* We scan for type information unless we found a variable in the
222 proper scope already. */
223 else if (!found_scoped_var)
224 {
225 /* If we don't have scoping information for a variable, we use
226 a different method to look it up. */
227 best = check_local_unnamed_variable (best, decl, type);
228 }
229
230 decl = DECL_LOCAL_SLOT_CHAIN (decl);
231 }
232
233 if (best != NULL_TREE)
234 return best;
235
236 /* If we don't find a match, create one with the type passed in. */
237 return push_jvm_slot (index, build_decl (VAR_DECL, NULL_TREE, type));
238 }
239
240
241 /* Same as find_local_index, except that INDEX is a stack index. */
242
243 tree
244 find_stack_slot (int index, tree type)
245 {
246 return find_local_variable (index + DECL_MAX_LOCALS (current_function_decl),
247 type, -1);
248 }
249
250 struct binding_level
251 {
252 /* A chain of _DECL nodes for all variables, constants, functions,
253 * and typedef types. These are in the reverse of the order supplied.
254 */
255 tree names;
256
257 /* For each level, a list of shadowed outer-level local definitions
258 to be restored when this level is popped.
259 Each link is a TREE_LIST whose TREE_PURPOSE is an identifier and
260 whose TREE_VALUE is its old definition (a kind of ..._DECL node). */
261 tree shadowed;
262
263 /* For each level (except not the global one),
264 a chain of BLOCK nodes for all the levels
265 that were entered and exited one level down. */
266 tree blocks;
267
268 /* The BLOCK node for this level, if one has been preallocated.
269 If 0, the BLOCK is allocated (if needed) when the level is popped. */
270 tree this_block;
271
272 /* The binding level which this one is contained in (inherits from). */
273 struct binding_level *level_chain;
274
275 /* The bytecode PC that marks the end of this level. */
276 int end_pc;
277 /* The bytecode PC that marks the start of this level. */
278 int start_pc;
279
280 #if defined(DEBUG_JAVA_BINDING_LEVELS)
281 /* Binding depth at which this level began. */
282 unsigned binding_depth;
283 #endif /* defined(DEBUG_JAVA_BINDING_LEVELS) */
284 };
285
286 #define NULL_BINDING_LEVEL (struct binding_level *) NULL
287
288 /* The binding level currently in effect. */
289
290 static struct binding_level *current_binding_level;
291
292 /* A chain of binding_level structures awaiting reuse. */
293
294 static struct binding_level *free_binding_level;
295
296 /* The outermost binding level, for names of file scope.
297 This is created when the compiler is started and exists
298 through the entire run. */
299
300 static struct binding_level *global_binding_level;
301
302 /* A PC value bigger than any PC value we may ever may encounter. */
303
304 #define LARGEST_PC (( (unsigned int)1 << (HOST_BITS_PER_INT - 1)) - 1)
305
306 /* Binding level structures are initialized by copying this one. */
307
308 static const struct binding_level clear_binding_level
309 = {NULL_TREE, NULL_TREE, NULL_TREE, NULL_TREE,
310 NULL_BINDING_LEVEL, LARGEST_PC, 0};
311
312 #if 0
313 /* A list (chain of TREE_LIST nodes) of all LABEL_DECLs in the function
314 that have names. Here so we can clear out their names' definitions
315 at the end of the function. */
316
317 static tree named_labels;
318
319 /* A list of LABEL_DECLs from outer contexts that are currently shadowed. */
320
321 static tree shadowed_labels;
322 #endif
323
324 tree java_global_trees[JTI_MAX];
325
326 /* Build (and pushdecl) a "promoted type" for all standard
327 types shorter than int. */
328
329 static tree
330 push_promoted_type (const char *name, tree actual_type)
331 {
332 tree type = make_node (TREE_CODE (actual_type));
333 #if 1
334 tree in_min = TYPE_MIN_VALUE (int_type_node);
335 tree in_max = TYPE_MAX_VALUE (int_type_node);
336 #else
337 tree in_min = TYPE_MIN_VALUE (actual_type);
338 tree in_max = TYPE_MAX_VALUE (actual_type);
339 #endif
340 TYPE_MIN_VALUE (type) = copy_node (in_min);
341 TREE_TYPE (TYPE_MIN_VALUE (type)) = type;
342 TYPE_MAX_VALUE (type) = copy_node (in_max);
343 TREE_TYPE (TYPE_MAX_VALUE (type)) = type;
344 TYPE_PRECISION (type) = TYPE_PRECISION (int_type_node);
345 layout_type (type);
346 pushdecl (build_decl (TYPE_DECL, get_identifier (name), type));
347 return type;
348 }
349
350 /* Return a definition for a builtin function named NAME and whose data type
351 is TYPE. TYPE should be a function type with argument types.
352 FUNCTION_CODE tells later passes how to compile calls to this function.
353 See tree.h for its possible values.
354
355 If LIBRARY_NAME is nonzero, use that for DECL_ASSEMBLER_NAME,
356 the name to be called if we can't opencode the function. If
357 ATTRS is nonzero, use that for the function's attribute list. */
358
359 tree
360 builtin_function (const char *name,
361 tree type,
362 int function_code,
363 enum built_in_class class,
364 const char *library_name,
365 tree attrs ATTRIBUTE_UNUSED)
366 {
367 tree decl = build_decl (FUNCTION_DECL, get_identifier (name), type);
368 DECL_EXTERNAL (decl) = 1;
369 TREE_PUBLIC (decl) = 1;
370 if (library_name)
371 SET_DECL_ASSEMBLER_NAME (decl, get_identifier (library_name));
372 make_decl_rtl (decl, NULL);
373 pushdecl (decl);
374 DECL_BUILT_IN_CLASS (decl) = class;
375 DECL_FUNCTION_CODE (decl) = function_code;
376 return decl;
377 }
378
379 /* Return tree that represents a vtable for a primitive array. */
380 static tree
381 create_primitive_vtable (const char *name)
382 {
383 tree r;
384 char buf[50];
385
386 sprintf (buf, "_Jv_%sVTable", name);
387 r = build_decl (VAR_DECL, get_identifier (buf), ptr_type_node);
388 DECL_EXTERNAL (r) = 1;
389 return r;
390 }
391
392 void
393 java_init_decl_processing (void)
394 {
395 register tree endlink;
396 tree field = NULL_TREE;
397 tree t;
398
399 init_class_processing ();
400 init_resource_processing ();
401
402 current_function_decl = NULL;
403 current_binding_level = NULL_BINDING_LEVEL;
404 free_binding_level = NULL_BINDING_LEVEL;
405 pushlevel (0); /* make the binding_level structure for global names */
406 global_binding_level = current_binding_level;
407
408 /* The code here must be similar to build_common_tree_nodes{,_2} in
409 tree.c, especially as to the order of initializing common nodes. */
410 error_mark_node = make_node (ERROR_MARK);
411 TREE_TYPE (error_mark_node) = error_mark_node;
412
413 /* Create sizetype first - needed for other types. */
414 initialize_sizetypes ();
415
416 byte_type_node = make_signed_type (8);
417 pushdecl (build_decl (TYPE_DECL, get_identifier ("byte"), byte_type_node));
418 short_type_node = make_signed_type (16);
419 pushdecl (build_decl (TYPE_DECL, get_identifier ("short"), short_type_node));
420 int_type_node = make_signed_type (32);
421 pushdecl (build_decl (TYPE_DECL, get_identifier ("int"), int_type_node));
422 long_type_node = make_signed_type (64);
423 pushdecl (build_decl (TYPE_DECL, get_identifier ("long"), long_type_node));
424
425 unsigned_byte_type_node = make_unsigned_type (8);
426 pushdecl (build_decl (TYPE_DECL, get_identifier ("unsigned byte"),
427 unsigned_byte_type_node));
428 unsigned_short_type_node = make_unsigned_type (16);
429 pushdecl (build_decl (TYPE_DECL, get_identifier ("unsigned short"),
430 unsigned_short_type_node));
431 unsigned_int_type_node = make_unsigned_type (32);
432 pushdecl (build_decl (TYPE_DECL, get_identifier ("unsigned int"),
433 unsigned_int_type_node));
434 unsigned_long_type_node = make_unsigned_type (64);
435 pushdecl (build_decl (TYPE_DECL, get_identifier ("unsigned long"),
436 unsigned_long_type_node));
437
438 set_sizetype (make_unsigned_type (POINTER_SIZE));
439
440 /* Define these next since types below may used them. */
441 integer_type_node = java_type_for_size (INT_TYPE_SIZE, 0);
442 integer_zero_node = build_int_2 (0, 0);
443 integer_one_node = build_int_2 (1, 0);
444 integer_two_node = build_int_2 (2, 0);
445 integer_four_node = build_int_2 (4, 0);
446 integer_minus_one_node = build_int_2 (-1, -1);
447
448 /* A few values used for range checking in the lexer. */
449 decimal_int_max = build_int_2 (0x80000000, 0);
450 TREE_TYPE (decimal_int_max) = unsigned_int_type_node;
451 #if HOST_BITS_PER_WIDE_INT == 64
452 decimal_long_max = build_int_2 (0x8000000000000000LL, 0);
453 #else
454 #if HOST_BITS_PER_WIDE_INT == 32
455 decimal_long_max = build_int_2 (0, 0x80000000);
456 #else
457 #error "unsupported size"
458 #endif
459 #endif
460 TREE_TYPE (decimal_long_max) = unsigned_long_type_node;
461
462 size_zero_node = size_int (0);
463 size_one_node = size_int (1);
464 bitsize_zero_node = bitsize_int (0);
465 bitsize_one_node = bitsize_int (1);
466 bitsize_unit_node = bitsize_int (BITS_PER_UNIT);
467
468 long_zero_node = build_int_2 (0, 0);
469 TREE_TYPE (long_zero_node) = long_type_node;
470
471 void_type_node = make_node (VOID_TYPE);
472 pushdecl (build_decl (TYPE_DECL, get_identifier ("void"), void_type_node));
473 layout_type (void_type_node); /* Uses size_zero_node */
474 ptr_type_node = build_pointer_type (void_type_node);
475 t = make_node (VOID_TYPE);
476 layout_type (t); /* Uses size_zero_node */
477 return_address_type_node = build_pointer_type (t);
478
479 null_pointer_node = build_int_2 (0, 0);
480 TREE_TYPE (null_pointer_node) = ptr_type_node;
481
482 /* Used by the parser to represent empty statements and blocks. */
483 empty_stmt_node = build1 (NOP_EXPR, void_type_node, size_zero_node);
484 CAN_COMPLETE_NORMALLY (empty_stmt_node) = 1;
485
486 #if 0
487 /* Make a type to be the domain of a few array types
488 whose domains don't really matter.
489 200 is small enough that it always fits in size_t
490 and large enough that it can hold most function names for the
491 initializations of __FUNCTION__ and __PRETTY_FUNCTION__. */
492 short_array_type_node = build_prim_array_type (short_type_node, 200);
493 #endif
494 char_type_node = make_node (CHAR_TYPE);
495 TYPE_PRECISION (char_type_node) = 16;
496 fixup_unsigned_type (char_type_node);
497 pushdecl (build_decl (TYPE_DECL, get_identifier ("char"), char_type_node));
498
499 boolean_type_node = make_node (BOOLEAN_TYPE);
500 TYPE_PRECISION (boolean_type_node) = 1;
501 fixup_unsigned_type (boolean_type_node);
502 pushdecl (build_decl (TYPE_DECL, get_identifier ("boolean"),
503 boolean_type_node));
504 boolean_false_node = TYPE_MIN_VALUE (boolean_type_node);
505 boolean_true_node = TYPE_MAX_VALUE (boolean_type_node);
506
507 promoted_byte_type_node
508 = push_promoted_type ("promoted_byte", byte_type_node);
509 promoted_short_type_node
510 = push_promoted_type ("promoted_short", short_type_node);
511 promoted_char_type_node
512 = push_promoted_type ("promoted_char", char_type_node);
513 promoted_boolean_type_node
514 = push_promoted_type ("promoted_boolean", boolean_type_node);
515
516 float_type_node = make_node (REAL_TYPE);
517 TYPE_PRECISION (float_type_node) = 32;
518 pushdecl (build_decl (TYPE_DECL, get_identifier ("float"),
519 float_type_node));
520 layout_type (float_type_node);
521
522 double_type_node = make_node (REAL_TYPE);
523 TYPE_PRECISION (double_type_node) = 64;
524 pushdecl (build_decl (TYPE_DECL, get_identifier ("double"),
525 double_type_node));
526 layout_type (double_type_node);
527
528 float_zero_node = build_real (float_type_node, dconst0);
529 double_zero_node = build_real (double_type_node, dconst0);
530
531 /* These are the vtables for arrays of primitives. */
532 boolean_array_vtable = create_primitive_vtable ("boolean");
533 byte_array_vtable = create_primitive_vtable ("byte");
534 char_array_vtable = create_primitive_vtable ("char");
535 short_array_vtable = create_primitive_vtable ("short");
536 int_array_vtable = create_primitive_vtable ("int");
537 long_array_vtable = create_primitive_vtable ("long");
538 float_array_vtable = create_primitive_vtable ("float");
539 double_array_vtable = create_primitive_vtable ("double");
540
541 /* As you're adding items here, please update the code right after
542 this section, so that the filename containing the source code of
543 the pre-defined class gets registered correctly. */
544 unqualified_object_id_node = get_identifier ("Object");
545 object_type_node = lookup_class (get_identifier ("java.lang.Object"));
546 object_ptr_type_node = promote_type (object_type_node);
547 string_type_node = lookup_class (get_identifier ("java.lang.String"));
548 string_ptr_type_node = promote_type (string_type_node);
549 class_type_node = lookup_class (get_identifier ("java.lang.Class"));
550 throwable_type_node = lookup_class (get_identifier ("java.lang.Throwable"));
551 exception_type_node = lookup_class (get_identifier ("java.lang.Exception"));
552 runtime_exception_type_node =
553 lookup_class (get_identifier ("java.lang.RuntimeException"));
554 error_exception_type_node =
555 lookup_class (get_identifier ("java.lang.Error"));
556 class_not_found_type_node =
557 lookup_class (get_identifier ("java.lang.ClassNotFoundException"));
558 no_class_def_found_type_node =
559 lookup_class (get_identifier ("java.lang.NoClassDefFoundError"));
560
561 rawdata_ptr_type_node
562 = promote_type (lookup_class (get_identifier ("gnu.gcj.RawData")));
563
564 add_predefined_file (get_identifier ("java/lang/Class.java"));
565 add_predefined_file (get_identifier ("java/lang/Error.java"));
566 add_predefined_file (get_identifier ("java/lang/Object.java"));
567 add_predefined_file (get_identifier ("java/lang/RuntimeException.java"));
568 add_predefined_file (get_identifier ("java/lang/String.java"));
569 add_predefined_file (get_identifier ("java/lang/Throwable.java"));
570 add_predefined_file (get_identifier ("gnu/gcj/RawData.java"));
571 add_predefined_file (get_identifier ("java/lang/Exception.java"));
572 add_predefined_file (get_identifier ("java/lang/ClassNotFoundException.java"));
573 add_predefined_file (get_identifier ("java/lang/NoClassDefFoundError.java"));
574 add_predefined_file (get_identifier ("gnu/gcj/RawData.java"));
575
576 methodtable_type = make_node (RECORD_TYPE);
577 layout_type (methodtable_type);
578 build_decl (TYPE_DECL, get_identifier ("methodtable"), methodtable_type);
579 methodtable_ptr_type = build_pointer_type (methodtable_type);
580
581 TYPE_identifier_node = get_identifier ("TYPE");
582 init_identifier_node = get_identifier ("<init>");
583 clinit_identifier_node = get_identifier ("<clinit>");
584 finit_identifier_node = get_identifier ("finit$");
585 instinit_identifier_node = get_identifier ("instinit$");
586 void_signature_node = get_identifier ("()V");
587 length_identifier_node = get_identifier ("length");
588 finalize_identifier_node = get_identifier ("finalize");
589 this_identifier_node = get_identifier ("this");
590 super_identifier_node = get_identifier ("super");
591 continue_identifier_node = get_identifier ("continue");
592 access0_identifier_node = get_identifier ("access$0");
593 classdollar_identifier_node = get_identifier ("class$");
594
595 java_lang_cloneable_identifier_node = get_identifier ("java.lang.Cloneable");
596 java_io_serializable_identifier_node =
597 get_identifier ("java.io.Serializable");
598
599 /* for lack of a better place to put this stub call */
600 init_expr_processing();
601
602 utf8const_type = make_node (RECORD_TYPE);
603 PUSH_FIELD (utf8const_type, field, "hash", unsigned_short_type_node);
604 PUSH_FIELD (utf8const_type, field, "length", unsigned_short_type_node);
605 FINISH_RECORD (utf8const_type);
606 utf8const_ptr_type = build_pointer_type (utf8const_type);
607
608 constants_type_node = make_node (RECORD_TYPE);
609 PUSH_FIELD (constants_type_node, field, "size", unsigned_int_type_node);
610 PUSH_FIELD (constants_type_node, field, "tags", ptr_type_node);
611 PUSH_FIELD (constants_type_node, field, "data", ptr_type_node);
612 FINISH_RECORD (constants_type_node);
613 build_decl (TYPE_DECL, get_identifier ("constants"), constants_type_node);
614
615 access_flags_type_node = unsigned_short_type_node;
616
617 dtable_type = make_node (RECORD_TYPE);
618 dtable_ptr_type = build_pointer_type (dtable_type);
619
620 one_elt_array_domain_type = build_index_type (integer_one_node);
621 otable_type = build_array_type (integer_type_node,
622 one_elt_array_domain_type);
623 TYPE_NONALIASED_COMPONENT (otable_type) = 1;
624 otable_ptr_type = build_pointer_type (otable_type);
625
626 method_symbol_type = make_node (RECORD_TYPE);
627 PUSH_FIELD (method_symbol_type, field, "clname", utf8const_ptr_type);
628 PUSH_FIELD (method_symbol_type, field, "name", utf8const_ptr_type);
629 PUSH_FIELD (method_symbol_type, field, "signature", utf8const_ptr_type);
630 FINISH_RECORD (method_symbol_type);
631
632 method_symbols_array_type = build_array_type (method_symbol_type,
633 one_elt_array_domain_type);
634 method_symbols_array_ptr_type = build_pointer_type
635 (method_symbols_array_type);
636
637 otable_decl = build_decl (VAR_DECL, get_identifier ("otable"), otable_type);
638 DECL_EXTERNAL (otable_decl) = 1;
639 TREE_STATIC (otable_decl) = 1;
640 TREE_READONLY (otable_decl) = 1;
641 pushdecl (otable_decl);
642
643 otable_syms_decl = build_decl (VAR_DECL, get_identifier ("otable_syms"),
644 method_symbols_array_type);
645 TREE_STATIC (otable_syms_decl) = 1;
646 TREE_CONSTANT (otable_syms_decl) = 1;
647 pushdecl (otable_syms_decl);
648
649 PUSH_FIELD (object_type_node, field, "vtable", dtable_ptr_type);
650 /* This isn't exactly true, but it is what we have in the source.
651 There is an unresolved issue here, which is whether the vtable
652 should be marked by the GC. */
653 if (! flag_hash_synchronization)
654 PUSH_FIELD (object_type_node, field, "sync_info",
655 build_pointer_type (object_type_node));
656 for (t = TYPE_FIELDS (object_type_node); t != NULL_TREE; t = TREE_CHAIN (t))
657 FIELD_PRIVATE (t) = 1;
658 FINISH_RECORD (object_type_node);
659
660 field_type_node = make_node (RECORD_TYPE);
661 field_ptr_type_node = build_pointer_type (field_type_node);
662 method_type_node = make_node (RECORD_TYPE);
663 method_ptr_type_node = build_pointer_type (method_type_node);
664
665 set_super_info (0, class_type_node, object_type_node, 0);
666 set_super_info (0, string_type_node, object_type_node, 0);
667 class_ptr_type = build_pointer_type (class_type_node);
668
669 PUSH_FIELD (class_type_node, field, "next", class_ptr_type);
670 PUSH_FIELD (class_type_node, field, "name", utf8const_ptr_type);
671 PUSH_FIELD (class_type_node, field, "accflags", access_flags_type_node);
672 PUSH_FIELD (class_type_node, field, "superclass", class_ptr_type);
673 PUSH_FIELD (class_type_node, field, "constants", constants_type_node);
674 PUSH_FIELD (class_type_node, field, "methods", method_ptr_type_node);
675 PUSH_FIELD (class_type_node, field, "method_count", short_type_node);
676 PUSH_FIELD (class_type_node, field, "vtable_method_count", short_type_node);
677 PUSH_FIELD (class_type_node, field, "fields", field_ptr_type_node);
678 PUSH_FIELD (class_type_node, field, "size_in_bytes", int_type_node);
679 PUSH_FIELD (class_type_node, field, "field_count", short_type_node);
680 PUSH_FIELD (class_type_node, field, "static_field_count", short_type_node);
681 PUSH_FIELD (class_type_node, field, "vtable", dtable_ptr_type);
682 PUSH_FIELD (class_type_node, field, "otable", otable_ptr_type);
683 PUSH_FIELD (class_type_node, field, "otable_syms",
684 method_symbols_array_ptr_type);
685 PUSH_FIELD (class_type_node, field, "interfaces",
686 build_pointer_type (class_ptr_type));
687 PUSH_FIELD (class_type_node, field, "loader", ptr_type_node);
688 PUSH_FIELD (class_type_node, field, "interface_count", short_type_node);
689 PUSH_FIELD (class_type_node, field, "state", byte_type_node);
690 PUSH_FIELD (class_type_node, field, "thread", ptr_type_node);
691 PUSH_FIELD (class_type_node, field, "depth", short_type_node);
692 PUSH_FIELD (class_type_node, field, "ancestors", ptr_type_node);
693 PUSH_FIELD (class_type_node, field, "idt", ptr_type_node);
694 PUSH_FIELD (class_type_node, field, "arrayclass", ptr_type_node);
695 PUSH_FIELD (class_type_node, field, "protectionDomain", ptr_type_node);
696 PUSH_FIELD (class_type_node, field, "chain", ptr_type_node);
697 for (t = TYPE_FIELDS (class_type_node); t != NULL_TREE; t = TREE_CHAIN (t))
698 FIELD_PRIVATE (t) = 1;
699 push_super_field (class_type_node, object_type_node);
700
701 FINISH_RECORD (class_type_node);
702 build_decl (TYPE_DECL, get_identifier ("Class"), class_type_node);
703
704 field_info_union_node = make_node (UNION_TYPE);
705 PUSH_FIELD (field_info_union_node, field, "boffset", int_type_node);
706 PUSH_FIELD (field_info_union_node, field, "addr", ptr_type_node);
707 #if 0
708 PUSH_FIELD (field_info_union_node, field, "idx", unsigned_short_type_node);
709 #endif
710 layout_type (field_info_union_node);
711
712 PUSH_FIELD (field_type_node, field, "name", utf8const_ptr_type);
713 PUSH_FIELD (field_type_node, field, "type", class_ptr_type);
714 PUSH_FIELD (field_type_node, field, "accflags", access_flags_type_node);
715 PUSH_FIELD (field_type_node, field, "bsize", unsigned_short_type_node);
716 PUSH_FIELD (field_type_node, field, "info", field_info_union_node);
717 FINISH_RECORD (field_type_node);
718 build_decl (TYPE_DECL, get_identifier ("Field"), field_type_node);
719
720 nativecode_ptr_array_type_node
721 = build_array_type (nativecode_ptr_type_node, one_elt_array_domain_type);
722
723 PUSH_FIELD (dtable_type, field, "class", class_ptr_type);
724 PUSH_FIELD (dtable_type, field, "methods", nativecode_ptr_array_type_node);
725 FINISH_RECORD (dtable_type);
726 build_decl (TYPE_DECL, get_identifier ("dispatchTable"), dtable_type);
727
728 #define jint_type int_type_node
729 #define jint_ptr_type ptr_type_node
730
731 jexception_type = make_node (RECORD_TYPE);
732 PUSH_FIELD (jexception_type, field, "start_pc", ptr_type_node);
733 PUSH_FIELD (jexception_type, field, "end_pc", ptr_type_node);
734 PUSH_FIELD (jexception_type, field, "handler_pc", ptr_type_node);
735 PUSH_FIELD (jexception_type, field, "catch_type", class_ptr_type);
736 FINISH_RECORD (jexception_type);
737 build_decl (TYPE_DECL, get_identifier ("jexception"), field_type_node);
738 jexception_ptr_type = build_pointer_type (jexception_type);
739
740 lineNumberEntry_type = make_node (RECORD_TYPE);
741 PUSH_FIELD (lineNumberEntry_type, field, "line_nr", unsigned_short_type_node);
742 PUSH_FIELD (lineNumberEntry_type, field, "start_pc", ptr_type_node);
743 FINISH_RECORD (lineNumberEntry_type);
744
745 lineNumbers_type = make_node (RECORD_TYPE);
746 PUSH_FIELD (lineNumbers_type, field, "length", unsigned_int_type_node);
747 FINISH_RECORD (lineNumbers_type);
748
749 #define instn_ptr_type_node ptr_type_node /* XXX JH */
750
751 #define lineNumbers_ptr_type_node build_pointer_type(lineNumbers_type)
752
753 PUSH_FIELD (method_type_node, field, "name", utf8const_ptr_type);
754 PUSH_FIELD (method_type_node, field, "signature", utf8const_ptr_type);
755 PUSH_FIELD (method_type_node, field, "accflags", access_flags_type_node);
756 PUSH_FIELD (method_type_node, field, "index", unsigned_short_type_node);
757 PUSH_FIELD (method_type_node, field, "ncode", nativecode_ptr_type_node);
758 PUSH_FIELD (method_type_node, field, "throws", ptr_type_node);
759 FINISH_RECORD (method_type_node);
760 build_decl (TYPE_DECL, get_identifier ("Method"), method_type_node);
761
762 endlink = end_params_node = tree_cons (NULL_TREE, void_type_node, NULL_TREE);
763
764 t = tree_cons (NULL_TREE, class_ptr_type,
765 tree_cons (NULL_TREE, int_type_node, endlink));
766 alloc_object_node = builtin_function ("_Jv_AllocObject",
767 build_function_type (ptr_type_node, t),
768 0, NOT_BUILT_IN, NULL, NULL_TREE);
769 DECL_IS_MALLOC (alloc_object_node) = 1;
770 alloc_no_finalizer_node =
771 builtin_function ("_Jv_AllocObjectNoFinalizer",
772 build_function_type (ptr_type_node, t),
773 0, NOT_BUILT_IN, NULL, NULL_TREE);
774 DECL_IS_MALLOC (alloc_no_finalizer_node) = 1;
775
776 t = tree_cons (NULL_TREE, ptr_type_node, endlink);
777 soft_initclass_node = builtin_function ("_Jv_InitClass",
778 build_function_type (void_type_node,
779 t),
780 0, NOT_BUILT_IN, NULL, NULL_TREE);
781
782 throw_node = builtin_function ("_Jv_Throw",
783 build_function_type (ptr_type_node, t),
784 0, NOT_BUILT_IN, NULL, NULL_TREE);
785 /* Mark throw_nodes as `noreturn' functions with side effects. */
786 TREE_THIS_VOLATILE (throw_node) = 1;
787 TREE_SIDE_EFFECTS (throw_node) = 1;
788
789 t = build_function_type (int_type_node, endlink);
790 soft_monitorenter_node
791 = builtin_function ("_Jv_MonitorEnter", t, 0, NOT_BUILT_IN,
792 NULL, NULL_TREE);
793 soft_monitorexit_node
794 = builtin_function ("_Jv_MonitorExit", t, 0, NOT_BUILT_IN,
795 NULL, NULL_TREE);
796
797 t = tree_cons (NULL_TREE, int_type_node,
798 tree_cons (NULL_TREE, int_type_node, endlink));
799 soft_newarray_node
800 = builtin_function ("_Jv_NewPrimArray",
801 build_function_type(ptr_type_node, t),
802 0, NOT_BUILT_IN, NULL, NULL_TREE);
803 DECL_IS_MALLOC (soft_newarray_node) = 1;
804
805 t = tree_cons (NULL_TREE, int_type_node,
806 tree_cons (NULL_TREE, class_ptr_type,
807 tree_cons (NULL_TREE, object_ptr_type_node, endlink)));
808 soft_anewarray_node
809 = builtin_function ("_Jv_NewObjectArray",
810 build_function_type (ptr_type_node, t),
811 0, NOT_BUILT_IN, NULL, NULL_TREE);
812 DECL_IS_MALLOC (soft_anewarray_node) = 1;
813
814 /* There is no endlink here because _Jv_NewMultiArray is a varargs
815 function. */
816 t = tree_cons (NULL_TREE, ptr_type_node,
817 tree_cons (NULL_TREE, int_type_node, NULL_TREE));
818 soft_multianewarray_node
819 = builtin_function ("_Jv_NewMultiArray",
820 build_function_type (ptr_type_node, t),
821 0, NOT_BUILT_IN, NULL, NULL_TREE);
822 DECL_IS_MALLOC (soft_multianewarray_node) = 1;
823
824 t = build_function_type (void_type_node,
825 tree_cons (NULL_TREE, int_type_node, endlink));
826 soft_badarrayindex_node
827 = builtin_function ("_Jv_ThrowBadArrayIndex", t,
828 0, NOT_BUILT_IN, NULL, NULL_TREE);
829 /* Mark soft_badarrayindex_node as a `noreturn' function with side
830 effects. */
831 TREE_THIS_VOLATILE (soft_badarrayindex_node) = 1;
832 TREE_SIDE_EFFECTS (soft_badarrayindex_node) = 1;
833
834 soft_nullpointer_node
835 = builtin_function ("_Jv_ThrowNullPointerException",
836 build_function_type (void_type_node, endlink),
837 0, NOT_BUILT_IN, NULL, NULL_TREE);
838 /* Mark soft_nullpointer_node as a `noreturn' function with side
839 effects. */
840 TREE_THIS_VOLATILE (soft_nullpointer_node) = 1;
841 TREE_SIDE_EFFECTS (soft_nullpointer_node) = 1;
842
843 t = tree_cons (NULL_TREE, class_ptr_type,
844 tree_cons (NULL_TREE, object_ptr_type_node, endlink));
845 soft_checkcast_node
846 = builtin_function ("_Jv_CheckCast",
847 build_function_type (ptr_type_node, t),
848 0, NOT_BUILT_IN, NULL, NULL_TREE);
849 t = tree_cons (NULL_TREE, object_ptr_type_node,
850 tree_cons (NULL_TREE, class_ptr_type, endlink));
851 soft_instanceof_node
852 = builtin_function ("_Jv_IsInstanceOf",
853 build_function_type (boolean_type_node, t),
854 0, NOT_BUILT_IN, NULL, NULL_TREE);
855 t = tree_cons (NULL_TREE, object_ptr_type_node,
856 tree_cons (NULL_TREE, object_ptr_type_node, endlink));
857 soft_checkarraystore_node
858 = builtin_function ("_Jv_CheckArrayStore",
859 build_function_type (void_type_node, t),
860 0, NOT_BUILT_IN, NULL, NULL_TREE);
861 t = tree_cons (NULL_TREE, ptr_type_node,
862 tree_cons (NULL_TREE, ptr_type_node,
863 tree_cons (NULL_TREE, int_type_node, endlink)));
864 soft_lookupinterfacemethod_node
865 = builtin_function ("_Jv_LookupInterfaceMethodIdx",
866 build_function_type (ptr_type_node, t),
867 0, NOT_BUILT_IN, NULL, NULL_TREE);
868
869 t = tree_cons (NULL_TREE, object_ptr_type_node,
870 tree_cons (NULL_TREE, ptr_type_node,
871 tree_cons (NULL_TREE, ptr_type_node, endlink)));
872 soft_lookupjnimethod_node
873 = builtin_function ("_Jv_LookupJNIMethod",
874 build_function_type (ptr_type_node, t),
875 0, NOT_BUILT_IN, NULL, NULL_TREE);
876 t = tree_cons (NULL_TREE, ptr_type_node, endlink);
877 soft_getjnienvnewframe_node
878 = builtin_function ("_Jv_GetJNIEnvNewFrame",
879 build_function_type (ptr_type_node, t),
880 0, NOT_BUILT_IN, NULL, NULL_TREE);
881 soft_jnipopsystemframe_node
882 = builtin_function ("_Jv_JNI_PopSystemFrame",
883 build_function_type (ptr_type_node, t),
884 0, NOT_BUILT_IN, NULL, NULL_TREE);
885
886 t = tree_cons (NULL_TREE, double_type_node,
887 tree_cons (NULL_TREE, double_type_node, endlink));
888 soft_fmod_node
889 = builtin_function ("__builtin_fmod",
890 build_function_type (double_type_node, t),
891 BUILT_IN_FMOD, BUILT_IN_NORMAL, "fmod", NULL_TREE);
892
893 #if 0
894 t = tree_cons (NULL_TREE, float_type_node,
895 tree_cons (NULL_TREE, float_type_node, endlink));
896 soft_fmodf_node
897 = builtin_function ("__builtin_fmodf",
898 build_function_type (float_type_node, t),
899 BUILT_IN_FMOD, BUILT_IN_NORMAL, "fmodf", NULL_TREE);
900 #endif
901
902 soft_idiv_node
903 = builtin_function ("_Jv_divI",
904 build_function_type (int_type_node, t),
905 0, NOT_BUILT_IN, NULL, NULL_TREE);
906
907 soft_irem_node
908 = builtin_function ("_Jv_remI",
909 build_function_type (int_type_node, t),
910 0, NOT_BUILT_IN, NULL, NULL_TREE);
911
912 soft_ldiv_node
913 = builtin_function ("_Jv_divJ",
914 build_function_type (long_type_node, t),
915 0, NOT_BUILT_IN, NULL, NULL_TREE);
916
917 soft_lrem_node
918 = builtin_function ("_Jv_remJ",
919 build_function_type (long_type_node, t),
920 0, NOT_BUILT_IN, NULL, NULL_TREE);
921
922 /* Initialize variables for except.c. */
923 eh_personality_libfunc = init_one_libfunc (USING_SJLJ_EXCEPTIONS
924 ? "__gcj_personality_sj0"
925 : "__gcj_personality_v0");
926 lang_eh_runtime_type = prepare_eh_table_type;
927
928 init_jcf_parse ();
929
930 initialize_builtins ();
931 }
932
933
934 /* Look up NAME in the current binding level and its superiors
935 in the namespace of variables, functions and typedefs.
936 Return a ..._DECL node of some kind representing its definition,
937 or return 0 if it is undefined. */
938
939 tree
940 lookup_name (tree name)
941 {
942 register tree val;
943 if (current_binding_level != global_binding_level
944 && IDENTIFIER_LOCAL_VALUE (name))
945 val = IDENTIFIER_LOCAL_VALUE (name);
946 else
947 val = IDENTIFIER_GLOBAL_VALUE (name);
948 return val;
949 }
950
951 /* Similar to `lookup_name' but look only at current binding level and
952 the previous one if its the parameter level. */
953
954 static tree
955 lookup_name_current_level (tree name)
956 {
957 register tree t;
958
959 if (current_binding_level == global_binding_level)
960 return IDENTIFIER_GLOBAL_VALUE (name);
961
962 if (IDENTIFIER_LOCAL_VALUE (name) == 0)
963 return 0;
964
965 for (t = current_binding_level->names; t; t = TREE_CHAIN (t))
966 if (DECL_NAME (t) == name)
967 break;
968
969 return t;
970 }
971
972 /* Use a binding level to record a labeled block declaration */
973
974 void
975 push_labeled_block (tree lb)
976 {
977 register tree name = DECL_NAME (LABELED_BLOCK_LABEL (lb));
978 register struct binding_level *b = current_binding_level;
979 tree oldlocal = IDENTIFIER_LOCAL_VALUE (name);
980 if (oldlocal != 0)
981 b->shadowed = tree_cons (name, oldlocal, b->shadowed);
982 TREE_CHAIN (lb) = b->names;
983 b->names = lb;
984 IDENTIFIER_LOCAL_VALUE (name) = lb;
985 }
986
987 /* Pop the current binding level, reinstalling values for the previous
988 labeled block */
989
990 void
991 pop_labeled_block (void)
992 {
993 struct binding_level *b = current_binding_level;
994 tree label = b->names;
995 IDENTIFIER_LOCAL_VALUE (DECL_NAME (LABELED_BLOCK_LABEL (label))) =
996 NULL_TREE;
997 if (b->shadowed)
998 IDENTIFIER_LOCAL_VALUE (TREE_PURPOSE (b->shadowed)) =
999 TREE_VALUE (b->shadowed);
1000
1001 /* Pop the current level, and free the structure for reuse. */
1002 current_binding_level = current_binding_level->level_chain;
1003 b->level_chain = free_binding_level;
1004 free_binding_level = b;
1005 }
1006
1007 /* Record a decl-node X as belonging to the current lexical scope.
1008 Check for errors (such as an incompatible declaration for the same
1009 name already seen in the same scope).
1010
1011 Returns either X or an old decl for the same name.
1012 If an old decl is returned, it may have been smashed
1013 to agree with what X says. */
1014
1015 tree
1016 pushdecl (tree x)
1017 {
1018 register tree t;
1019 register tree name = DECL_NAME (x);
1020 register struct binding_level *b = current_binding_level;
1021
1022 if (TREE_CODE (x) != TYPE_DECL)
1023 DECL_CONTEXT (x) = current_function_decl;
1024 if (name)
1025 {
1026 const char *file;
1027 int line;
1028
1029 t = lookup_name_current_level (name);
1030 if (t != 0 && t == error_mark_node)
1031 /* error_mark_node is 0 for a while during initialization! */
1032 {
1033 t = 0;
1034 error_with_decl (x, "`%s' used prior to declaration");
1035 }
1036
1037 if (t != 0)
1038 {
1039 file = DECL_SOURCE_FILE (t);
1040 line = DECL_SOURCE_LINE (t);
1041 }
1042
1043 /* If we're naming a hitherto-unnamed type, set its TYPE_NAME
1044 to point to the TYPE_DECL.
1045 Since Java does not have typedefs, a type can only have
1046 one (true) name, given by a class, interface, or builtin. */
1047 if (TREE_CODE (x) == TYPE_DECL
1048 && TYPE_NAME (TREE_TYPE (x)) == 0
1049 && TREE_TYPE (x) != error_mark_node)
1050 {
1051 TYPE_NAME (TREE_TYPE (x)) = x;
1052 TYPE_STUB_DECL (TREE_TYPE (x)) = x;
1053 }
1054
1055 /* This name is new in its binding level.
1056 Install the new declaration and return it. */
1057 if (b == global_binding_level)
1058 {
1059 /* Install a global value. */
1060
1061 IDENTIFIER_GLOBAL_VALUE (name) = x;
1062 }
1063 else
1064 {
1065 /* Here to install a non-global value. */
1066 tree oldlocal = IDENTIFIER_LOCAL_VALUE (name);
1067 IDENTIFIER_LOCAL_VALUE (name) = x;
1068
1069 #if 0
1070 /* Warn if shadowing an argument at the top level of the body. */
1071 if (oldlocal != 0 && !DECL_EXTERNAL (x)
1072 /* This warning doesn't apply to the parms of a nested fcn. */
1073 && ! current_binding_level->parm_flag
1074 /* Check that this is one level down from the parms. */
1075 && current_binding_level->level_chain->parm_flag
1076 /* Check that the decl being shadowed
1077 comes from the parm level, one level up. */
1078 && chain_member (oldlocal, current_binding_level->level_chain->names))
1079 {
1080 if (TREE_CODE (oldlocal) == PARM_DECL)
1081 pedwarn ("declaration of `%s' shadows a parameter",
1082 IDENTIFIER_POINTER (name));
1083 else
1084 pedwarn ("declaration of `%s' shadows a symbol from the parameter list",
1085 IDENTIFIER_POINTER (name));
1086 }
1087
1088 /* Maybe warn if shadowing something else. */
1089 else if (warn_shadow && !DECL_EXTERNAL (x)
1090 /* No shadow warnings for internally generated vars. */
1091 && DECL_SOURCE_LINE (x) != 0
1092 /* No shadow warnings for vars made for inlining. */
1093 && ! DECL_FROM_INLINE (x))
1094 {
1095 const char *warnstring = 0;
1096
1097 if (TREE_CODE (x) == PARM_DECL
1098 && current_binding_level->level_chain->parm_flag)
1099 /* Don't warn about the parm names in function declarator
1100 within a function declarator.
1101 It would be nice to avoid warning in any function
1102 declarator in a declaration, as opposed to a definition,
1103 but there is no way to tell it's not a definition. */
1104 ;
1105 else if (oldlocal != 0 && TREE_CODE (oldlocal) == PARM_DECL)
1106 warnstring = "declaration of `%s' shadows a parameter";
1107 else if (oldlocal != 0)
1108 warnstring = "declaration of `%s' shadows previous local";
1109 else if (IDENTIFIER_GLOBAL_VALUE (name) != 0
1110 && IDENTIFIER_GLOBAL_VALUE (name) != error_mark_node)
1111 warnstring = "declaration of `%s' shadows global declaration";
1112
1113 if (warnstring)
1114 warning (warnstring, IDENTIFIER_POINTER (name));
1115 }
1116 #endif
1117
1118 /* If storing a local value, there may already be one (inherited).
1119 If so, record it for restoration when this binding level ends. */
1120 if (oldlocal != 0)
1121 b->shadowed = tree_cons (name, oldlocal, b->shadowed);
1122 }
1123 }
1124
1125 /* Put decls on list in reverse order.
1126 We will reverse them later if necessary. */
1127 TREE_CHAIN (x) = b->names;
1128 b->names = x;
1129
1130 return x;
1131 }
1132
1133 void
1134 pushdecl_force_head (tree x)
1135 {
1136 current_binding_level->names = x;
1137 }
1138
1139 /* Like pushdecl, only it places X in GLOBAL_BINDING_LEVEL, if appropriate. */
1140
1141 tree
1142 pushdecl_top_level (tree x)
1143 {
1144 register tree t;
1145 register struct binding_level *b = current_binding_level;
1146
1147 current_binding_level = global_binding_level;
1148 t = pushdecl (x);
1149 current_binding_level = b;
1150 return t;
1151 }
1152
1153 /* Nonzero if we are currently in the global binding level. */
1154
1155 int
1156 global_bindings_p (void)
1157 {
1158 return current_binding_level == global_binding_level;
1159 }
1160
1161 /* Return the list of declarations of the current level.
1162 Note that this list is in reverse order unless/until
1163 you nreverse it; and when you do nreverse it, you must
1164 store the result back using `storedecls' or you will lose. */
1165
1166 tree
1167 getdecls (void)
1168 {
1169 return current_binding_level->names;
1170 }
1171
1172 /* Create a new `struct binding_level'. */
1173
1174 static struct binding_level *
1175 make_binding_level (void)
1176 {
1177 /* NOSTRICT */
1178 return xmalloc (sizeof (struct binding_level));
1179 }
1180
1181 void
1182 pushlevel (int unused ATTRIBUTE_UNUSED)
1183 {
1184 register struct binding_level *newlevel = NULL_BINDING_LEVEL;
1185
1186 #if 0
1187 /* If this is the top level of a function,
1188 just make sure that NAMED_LABELS is 0. */
1189
1190 if (current_binding_level == global_binding_level)
1191 named_labels = 0;
1192 #endif
1193
1194 /* Reuse or create a struct for this binding level. */
1195
1196 if (free_binding_level)
1197 {
1198 newlevel = free_binding_level;
1199 free_binding_level = free_binding_level->level_chain;
1200 }
1201 else
1202 {
1203 newlevel = make_binding_level ();
1204 }
1205
1206 /* Add this level to the front of the chain (stack) of levels that
1207 are active. */
1208
1209 *newlevel = clear_binding_level;
1210 newlevel->level_chain = current_binding_level;
1211 current_binding_level = newlevel;
1212 #if defined(DEBUG_JAVA_BINDING_LEVELS)
1213 newlevel->binding_depth = binding_depth;
1214 indent ();
1215 fprintf (stderr, "push %s level 0x%08x pc %d\n",
1216 (is_class_level) ? "class" : "block", newlevel, current_pc);
1217 is_class_level = 0;
1218 binding_depth++;
1219 #endif /* defined(DEBUG_JAVA_BINDING_LEVELS) */
1220 }
1221
1222 /* Exit a binding level.
1223 Pop the level off, and restore the state of the identifier-decl mappings
1224 that were in effect when this level was entered.
1225
1226 If KEEP is nonzero, this level had explicit declarations, so
1227 and create a "block" (a BLOCK node) for the level
1228 to record its declarations and subblocks for symbol table output.
1229
1230 If FUNCTIONBODY is nonzero, this level is the body of a function,
1231 so create a block as if KEEP were set and also clear out all
1232 label names.
1233
1234 If REVERSE is nonzero, reverse the order of decls before putting
1235 them into the BLOCK. */
1236
1237 tree
1238 poplevel (int keep, int reverse, int functionbody)
1239 {
1240 register tree link;
1241 /* The chain of decls was accumulated in reverse order.
1242 Put it into forward order, just for cleanliness. */
1243 tree decls;
1244 tree subblocks = current_binding_level->blocks;
1245 tree block = 0;
1246 tree decl;
1247 int block_previously_created;
1248
1249 #if defined(DEBUG_JAVA_BINDING_LEVELS)
1250 binding_depth--;
1251 indent ();
1252 if (current_binding_level->end_pc != LARGEST_PC)
1253 fprintf (stderr, "pop %s level 0x%08x pc %d (end pc %d)\n",
1254 (is_class_level) ? "class" : "block", current_binding_level, current_pc,
1255 current_binding_level->end_pc);
1256 else
1257 fprintf (stderr, "pop %s level 0x%08x pc %d\n",
1258 (is_class_level) ? "class" : "block", current_binding_level, current_pc);
1259 #if 0
1260 if (is_class_level != (current_binding_level == class_binding_level))
1261 {
1262 indent ();
1263 fprintf (stderr, "XXX is_class_level != (current_binding_level == class_binding_level)\n");
1264 }
1265 is_class_level = 0;
1266 #endif
1267 #endif /* defined(DEBUG_JAVA_BINDING_LEVELS) */
1268
1269 /* Get the decls in the order they were written.
1270 Usually current_binding_level->names is in reverse order.
1271 But parameter decls were previously put in forward order. */
1272
1273 if (reverse)
1274 current_binding_level->names
1275 = decls = nreverse (current_binding_level->names);
1276 else
1277 decls = current_binding_level->names;
1278
1279 /* Output any nested inline functions within this block
1280 if they weren't already output. */
1281
1282 for (decl = decls; decl; decl = TREE_CHAIN (decl))
1283 if (TREE_CODE (decl) == FUNCTION_DECL
1284 && ! TREE_ASM_WRITTEN (decl)
1285 && DECL_INITIAL (decl) != 0
1286 && TREE_ADDRESSABLE (decl))
1287 {
1288 /* If this decl was copied from a file-scope decl
1289 on account of a block-scope extern decl,
1290 propagate TREE_ADDRESSABLE to the file-scope decl.
1291
1292 DECL_ABSTRACT_ORIGIN can be set to itself if warn_return_type is
1293 true, since then the decl goes through save_for_inline_copying. */
1294 if (DECL_ABSTRACT_ORIGIN (decl) != 0
1295 && DECL_ABSTRACT_ORIGIN (decl) != decl)
1296 TREE_ADDRESSABLE (DECL_ABSTRACT_ORIGIN (decl)) = 1;
1297 else
1298 {
1299 push_function_context ();
1300 output_inline_function (decl);
1301 pop_function_context ();
1302 }
1303 }
1304
1305 /* If there were any declarations in that level,
1306 or if this level is a function body,
1307 create a BLOCK to record them for the life of this function. */
1308
1309 block = 0;
1310 block_previously_created = (current_binding_level->this_block != 0);
1311 if (block_previously_created)
1312 block = current_binding_level->this_block;
1313 else if (keep || functionbody)
1314 block = make_node (BLOCK);
1315 if (block != 0)
1316 {
1317 BLOCK_VARS (block) = decls;
1318 BLOCK_SUBBLOCKS (block) = subblocks;
1319 }
1320
1321 /* In each subblock, record that this is its superior. */
1322
1323 for (link = subblocks; link; link = TREE_CHAIN (link))
1324 BLOCK_SUPERCONTEXT (link) = block;
1325
1326 /* Clear out the meanings of the local variables of this level. */
1327
1328 for (link = decls; link; link = TREE_CHAIN (link))
1329 {
1330 tree name = DECL_NAME (link);
1331 if (name != 0 && IDENTIFIER_LOCAL_VALUE (name) == link)
1332 {
1333 /* If the ident. was used or addressed via a local extern decl,
1334 don't forget that fact. */
1335 if (DECL_EXTERNAL (link))
1336 {
1337 if (TREE_USED (link))
1338 TREE_USED (name) = 1;
1339 if (TREE_ADDRESSABLE (link))
1340 TREE_ADDRESSABLE (DECL_ASSEMBLER_NAME (link)) = 1;
1341 }
1342 IDENTIFIER_LOCAL_VALUE (name) = 0;
1343 }
1344 }
1345
1346 /* Restore all name-meanings of the outer levels
1347 that were shadowed by this level. */
1348
1349 for (link = current_binding_level->shadowed; link; link = TREE_CHAIN (link))
1350 IDENTIFIER_LOCAL_VALUE (TREE_PURPOSE (link)) = TREE_VALUE (link);
1351
1352 /* If the level being exited is the top level of a function,
1353 check over all the labels, and clear out the current
1354 (function local) meanings of their names. */
1355
1356 if (functionbody)
1357 {
1358 /* If this is the top level block of a function,
1359 the vars are the function's parameters.
1360 Don't leave them in the BLOCK because they are
1361 found in the FUNCTION_DECL instead. */
1362
1363 BLOCK_VARS (block) = 0;
1364
1365 /* Clear out the definitions of all label names,
1366 since their scopes end here,
1367 and add them to BLOCK_VARS. */
1368
1369 #if 0
1370 for (link = named_labels; link; link = TREE_CHAIN (link))
1371 {
1372 register tree label = TREE_VALUE (link);
1373
1374 if (DECL_INITIAL (label) == 0)
1375 {
1376 error_with_decl (label, "label `%s' used but not defined");
1377 /* Avoid crashing later. */
1378 define_label (input_filename, lineno,
1379 DECL_NAME (label));
1380 }
1381 else if (warn_unused[UNUSED_LABEL] && !TREE_USED (label))
1382 warning_with_decl (label, "label `%s' defined but not used");
1383 IDENTIFIER_LABEL_VALUE (DECL_NAME (label)) = 0;
1384
1385 /* Put the labels into the "variables" of the
1386 top-level block, so debugger can see them. */
1387 TREE_CHAIN (label) = BLOCK_VARS (block);
1388 BLOCK_VARS (block) = label;
1389 }
1390 #endif
1391 }
1392
1393 /* Pop the current level, and free the structure for reuse. */
1394
1395 {
1396 register struct binding_level *level = current_binding_level;
1397 current_binding_level = current_binding_level->level_chain;
1398
1399 level->level_chain = free_binding_level;
1400 free_binding_level = level;
1401 }
1402
1403 /* Dispose of the block that we just made inside some higher level. */
1404 if (functionbody)
1405 DECL_INITIAL (current_function_decl) = block;
1406 else if (block)
1407 {
1408 if (!block_previously_created)
1409 current_binding_level->blocks
1410 = chainon (current_binding_level->blocks, block);
1411 }
1412 /* If we did not make a block for the level just exited,
1413 any blocks made for inner levels
1414 (since they cannot be recorded as subblocks in that level)
1415 must be carried forward so they will later become subblocks
1416 of something else. */
1417 else if (subblocks)
1418 current_binding_level->blocks
1419 = chainon (current_binding_level->blocks, subblocks);
1420
1421 /* Set the TYPE_CONTEXTs for all of the tagged types belonging to this
1422 binding contour so that they point to the appropriate construct, i.e.
1423 either to the current FUNCTION_DECL node, or else to the BLOCK node
1424 we just constructed.
1425
1426 Note that for tagged types whose scope is just the formal parameter
1427 list for some function type specification, we can't properly set
1428 their TYPE_CONTEXTs here, because we don't have a pointer to the
1429 appropriate FUNCTION_TYPE node readily available to us. For those
1430 cases, the TYPE_CONTEXTs of the relevant tagged type nodes get set
1431 in `grokdeclarator' as soon as we have created the FUNCTION_TYPE
1432 node which will represent the "scope" for these "parameter list local"
1433 tagged types.
1434 */
1435
1436 if (block)
1437 TREE_USED (block) = 1;
1438 return block;
1439 }
1440
1441 void
1442 maybe_pushlevels (int pc)
1443 {
1444 #if defined(DEBUG_JAVA_BINDING_LEVELS)
1445 current_pc = pc;
1446 #endif
1447
1448 while (pending_local_decls != NULL_TREE &&
1449 DECL_LOCAL_START_PC (pending_local_decls) <= pc)
1450 {
1451 tree *ptr = &pending_local_decls;
1452 tree decl = *ptr;
1453 int end_pc = DECL_LOCAL_END_PC (decl);
1454
1455 while (*ptr != NULL_TREE
1456 && DECL_LOCAL_START_PC (*ptr) <= pc
1457 && DECL_LOCAL_END_PC (*ptr) == end_pc)
1458 ptr = &TREE_CHAIN (*ptr);
1459 pending_local_decls = *ptr;
1460 *ptr = NULL_TREE;
1461
1462 /* Force non-nested range to be nested in current range. */
1463 if (end_pc > current_binding_level->end_pc)
1464 end_pc = current_binding_level->end_pc;
1465
1466 maybe_start_try (pc, end_pc);
1467
1468 pushlevel (1);
1469 expand_start_bindings (0);
1470
1471 current_binding_level->end_pc = end_pc;
1472 current_binding_level->start_pc = pc;
1473 current_binding_level->names = decl;
1474 for ( ; decl != NULL_TREE; decl = TREE_CHAIN (decl))
1475 {
1476 push_jvm_slot (DECL_LOCAL_SLOT_NUMBER (decl), decl);
1477 }
1478 }
1479
1480 maybe_start_try (pc, 0);
1481 }
1482
1483 void
1484 maybe_poplevels (int pc)
1485 {
1486 #if defined(DEBUG_JAVA_BINDING_LEVELS)
1487 current_pc = pc;
1488 #endif
1489
1490 while (current_binding_level->end_pc <= pc)
1491 {
1492 expand_end_bindings (getdecls (), 1, 0);
1493 maybe_end_try (current_binding_level->start_pc, pc);
1494 poplevel (1, 0, 0);
1495 }
1496 maybe_end_try (0, pc);
1497 }
1498
1499 /* Terminate any binding which began during the range beginning at
1500 start_pc. This tidies up improperly nested local variable ranges
1501 and exception handlers; a variable declared within an exception
1502 range is forcibly terminated when that exception ends. */
1503
1504 void
1505 force_poplevels (int start_pc)
1506 {
1507 while (current_binding_level->start_pc > start_pc)
1508 {
1509 if (pedantic && current_binding_level->start_pc > start_pc)
1510 warning_with_decl (current_function_decl,
1511 "In %s: overlapped variable and exception ranges at %d",
1512 current_binding_level->start_pc);
1513 expand_end_bindings (getdecls (), 1, 0);
1514 poplevel (1, 0, 0);
1515 }
1516 }
1517
1518 /* Insert BLOCK at the end of the list of subblocks of the
1519 current binding level. This is used when a BIND_EXPR is expanded,
1520 to handle the BLOCK node inside the BIND_EXPR. */
1521
1522 void
1523 insert_block (tree block)
1524 {
1525 TREE_USED (block) = 1;
1526 current_binding_level->blocks
1527 = chainon (current_binding_level->blocks, block);
1528 }
1529
1530 /* Set the BLOCK node for the innermost scope
1531 (the one we are currently in). */
1532
1533 void
1534 set_block (tree block)
1535 {
1536 current_binding_level->this_block = block;
1537 current_binding_level->names = chainon (current_binding_level->names,
1538 BLOCK_VARS (block));
1539 current_binding_level->blocks = chainon (current_binding_level->blocks,
1540 BLOCK_SUBBLOCKS (block));
1541 }
1542
1543 /* integrate_decl_tree calls this function. */
1544
1545 void
1546 java_dup_lang_specific_decl (tree node)
1547 {
1548 int lang_decl_size;
1549 struct lang_decl *x;
1550
1551 if (!DECL_LANG_SPECIFIC (node))
1552 return;
1553
1554 lang_decl_size = sizeof (struct lang_decl);
1555 x = ggc_alloc (lang_decl_size);
1556 memcpy (x, DECL_LANG_SPECIFIC (node), lang_decl_size);
1557 DECL_LANG_SPECIFIC (node) = x;
1558 }
1559
1560 void
1561 give_name_to_locals (JCF *jcf)
1562 {
1563 int i, n = DECL_LOCALVARIABLES_OFFSET (current_function_decl);
1564 int code_offset = DECL_CODE_OFFSET (current_function_decl);
1565 tree parm;
1566 pending_local_decls = NULL_TREE;
1567 if (n == 0)
1568 return;
1569 JCF_SEEK (jcf, n);
1570 n = JCF_readu2 (jcf);
1571 for (i = 0; i < n; i++)
1572 {
1573 int start_pc = JCF_readu2 (jcf);
1574 int length = JCF_readu2 (jcf);
1575 int name_index = JCF_readu2 (jcf);
1576 int signature_index = JCF_readu2 (jcf);
1577 int slot = JCF_readu2 (jcf);
1578 tree name = get_name_constant (jcf, name_index);
1579 tree type = parse_signature (jcf, signature_index);
1580 if (slot < DECL_ARG_SLOT_COUNT (current_function_decl)
1581 && start_pc == 0
1582 && length == DECL_CODE_LENGTH (current_function_decl))
1583 {
1584 tree decl = TREE_VEC_ELT (decl_map, slot);
1585 DECL_NAME (decl) = name;
1586 SET_DECL_ASSEMBLER_NAME (decl, name);
1587 if (TREE_CODE (decl) != PARM_DECL || TREE_TYPE (decl) != type)
1588 warning ("bad type in parameter debug info");
1589 }
1590 else
1591 {
1592 tree *ptr;
1593 int end_pc = start_pc + length;
1594 tree decl = build_decl (VAR_DECL, name, type);
1595 if (end_pc > DECL_CODE_LENGTH (current_function_decl))
1596 {
1597 warning_with_decl (decl,
1598 "bad PC range for debug info for local `%s'");
1599 end_pc = DECL_CODE_LENGTH (current_function_decl);
1600 }
1601
1602 /* Adjust start_pc if necessary so that the local's first
1603 store operation will use the relevant DECL as a
1604 destination. Fore more information, read the leading
1605 comments for expr.c:maybe_adjust_start_pc. */
1606 start_pc = maybe_adjust_start_pc (jcf, code_offset, start_pc, slot);
1607
1608 MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (decl);
1609 DECL_LOCAL_SLOT_NUMBER (decl) = slot;
1610 DECL_LOCAL_START_PC (decl) = start_pc;
1611 #if 0
1612 /* FIXME: The range used internally for exceptions and local
1613 variable ranges, is a half-open interval:
1614 start_pc <= pc < end_pc. However, the range used in the
1615 Java VM spec is inclusive at both ends:
1616 start_pc <= pc <= end_pc. */
1617 end_pc++;
1618 #endif
1619 DECL_LOCAL_END_PC (decl) = end_pc;
1620
1621 /* Now insert the new decl in the proper place in
1622 pending_local_decls. We are essentially doing an insertion sort,
1623 which works fine, since the list input will normally already
1624 be sorted. */
1625 ptr = &pending_local_decls;
1626 while (*ptr != NULL_TREE
1627 && (DECL_LOCAL_START_PC (*ptr) > start_pc
1628 || (DECL_LOCAL_START_PC (*ptr) == start_pc
1629 && DECL_LOCAL_END_PC (*ptr) < end_pc)))
1630 ptr = &TREE_CHAIN (*ptr);
1631 TREE_CHAIN (decl) = *ptr;
1632 *ptr = decl;
1633 }
1634 }
1635
1636 pending_local_decls = nreverse (pending_local_decls);
1637
1638 /* Fill in default names for the parameters. */
1639 for (parm = DECL_ARGUMENTS (current_function_decl), i = 0;
1640 parm != NULL_TREE; parm = TREE_CHAIN (parm), i++)
1641 {
1642 if (DECL_NAME (parm) == NULL_TREE)
1643 {
1644 int arg_i = METHOD_STATIC (current_function_decl) ? i+1 : i;
1645 if (arg_i == 0)
1646 DECL_NAME (parm) = get_identifier ("this");
1647 else
1648 {
1649 char buffer[12];
1650 sprintf (buffer, "ARG_%d", arg_i);
1651 DECL_NAME (parm) = get_identifier (buffer);
1652 }
1653 SET_DECL_ASSEMBLER_NAME (parm, DECL_NAME (parm));
1654 }
1655 }
1656 }
1657
1658 tree
1659 build_result_decl (tree fndecl)
1660 {
1661 tree restype = TREE_TYPE (TREE_TYPE (fndecl));
1662 tree result = DECL_RESULT (fndecl);
1663 if (! result)
1664 {
1665 /* To be compatible with C_PROMOTING_INTEGER_TYPE_P in cc1/cc1plus. */
1666 if (INTEGRAL_TYPE_P (restype)
1667 && TYPE_PRECISION (restype) < TYPE_PRECISION (integer_type_node))
1668 restype = integer_type_node;
1669 result = build_decl (RESULT_DECL, NULL_TREE, restype);
1670 DECL_CONTEXT (result) = fndecl;
1671 DECL_RESULT (fndecl) = result;
1672 }
1673 return result;
1674 }
1675
1676 void
1677 complete_start_java_method (tree fndecl)
1678 {
1679 if (! flag_emit_class_files)
1680 {
1681 /* Initialize the RTL code for the function. */
1682 init_function_start (fndecl, input_filename, lineno);
1683
1684 /* Set up parameters and prepare for return, for the function. */
1685 expand_function_start (fndecl, 0);
1686 }
1687
1688 #if 0
1689 /* If this fcn was already referenced via a block-scope `extern' decl (or
1690 an implicit decl), propagate certain information about the usage. */
1691 if (TREE_ADDRESSABLE (DECL_ASSEMBLER_NAME (current_function_decl)))
1692 TREE_ADDRESSABLE (current_function_decl) = 1;
1693
1694 #endif
1695
1696 if (METHOD_STATIC (fndecl) && ! METHOD_PRIVATE (fndecl)
1697 && ! flag_emit_class_files
1698 && ! DECL_CLINIT_P (fndecl)
1699 && ! CLASS_INTERFACE (TYPE_NAME (current_class)))
1700 {
1701 tree clas = DECL_CONTEXT (fndecl);
1702 tree init = build (CALL_EXPR, void_type_node,
1703 build_address_of (soft_initclass_node),
1704 build_tree_list (NULL_TREE, build_class_ref (clas)),
1705 NULL_TREE);
1706 TREE_SIDE_EFFECTS (init) = 1;
1707 expand_expr_stmt (init);
1708 }
1709
1710 /* Push local variables. Function compiled from source code are
1711 using a different local variables management, and for them,
1712 pushlevel shouldn't be called from here. */
1713 if (!CLASS_FROM_SOURCE_P (DECL_CONTEXT (fndecl)))
1714 {
1715 pushlevel (2);
1716 if (! flag_emit_class_files)
1717 expand_start_bindings (1);
1718 }
1719
1720 if (METHOD_SYNCHRONIZED (fndecl) && ! flag_emit_class_files)
1721 {
1722 /* Wrap function body with a monitorenter plus monitorexit cleanup. */
1723 tree enter, exit, lock;
1724 if (METHOD_STATIC (fndecl))
1725 lock = build_class_ref (DECL_CONTEXT (fndecl));
1726 else
1727 lock = DECL_ARGUMENTS (fndecl);
1728 BUILD_MONITOR_ENTER (enter, lock);
1729 BUILD_MONITOR_EXIT (exit, lock);
1730 if (!CLASS_FROM_SOURCE_P (DECL_CONTEXT (fndecl)))
1731 {
1732 expand_expr_stmt (enter);
1733 expand_decl_cleanup (NULL_TREE, exit);
1734 }
1735 else
1736 {
1737 tree function_body = DECL_FUNCTION_BODY (fndecl);
1738 tree body = BLOCK_EXPR_BODY (function_body);
1739 lock = build (COMPOUND_EXPR, void_type_node,
1740 enter,
1741 build (TRY_FINALLY_EXPR, void_type_node, body, exit));
1742 TREE_SIDE_EFFECTS (lock) = 1;
1743 BLOCK_EXPR_BODY (function_body) = lock;
1744 }
1745 }
1746 }
1747
1748 void
1749 start_java_method (tree fndecl)
1750 {
1751 tree tem, *ptr;
1752 int i;
1753
1754 current_function_decl = fndecl;
1755 announce_function (fndecl);
1756
1757 i = DECL_MAX_LOCALS(fndecl) + DECL_MAX_STACK(fndecl);
1758 decl_map = make_tree_vec (i);
1759 type_map = xrealloc (type_map, i * sizeof (tree));
1760
1761 #if defined(DEBUG_JAVA_BINDING_LEVELS)
1762 fprintf (stderr, "%s:\n", lang_printable_name (fndecl, 2));
1763 current_pc = 0;
1764 #endif /* defined(DEBUG_JAVA_BINDING_LEVELS) */
1765 pushlevel (1); /* Push parameters. */
1766
1767 ptr = &DECL_ARGUMENTS (fndecl);
1768 for (tem = TYPE_ARG_TYPES (TREE_TYPE (fndecl)), i = 0;
1769 tem != end_params_node; tem = TREE_CHAIN (tem), i++)
1770 {
1771 tree parm_name = NULL_TREE, parm_decl;
1772 tree parm_type = TREE_VALUE (tem);
1773 if (i >= DECL_MAX_LOCALS (fndecl))
1774 abort ();
1775
1776 parm_decl = build_decl (PARM_DECL, parm_name, parm_type);
1777 DECL_CONTEXT (parm_decl) = fndecl;
1778 if (PROMOTE_PROTOTYPES
1779 && TYPE_PRECISION (parm_type) < TYPE_PRECISION (integer_type_node)
1780 && INTEGRAL_TYPE_P (parm_type))
1781 parm_type = integer_type_node;
1782 DECL_ARG_TYPE (parm_decl) = parm_type;
1783
1784 *ptr = parm_decl;
1785 ptr = &TREE_CHAIN (parm_decl);
1786
1787 /* Add parm_decl to the decl_map. */
1788 push_jvm_slot (i, parm_decl);
1789
1790 type_map[i] = TREE_TYPE (parm_decl);
1791 if (TYPE_IS_WIDE (TREE_TYPE (parm_decl)))
1792 {
1793 i++;
1794 type_map[i] = void_type_node;
1795 }
1796 }
1797 *ptr = NULL_TREE;
1798 DECL_ARG_SLOT_COUNT (current_function_decl) = i;
1799
1800 while (i < DECL_MAX_LOCALS(fndecl))
1801 type_map[i++] = NULL_TREE;
1802
1803 build_result_decl (fndecl);
1804 complete_start_java_method (fndecl);
1805 }
1806
1807 void
1808 end_java_method (void)
1809 {
1810 tree fndecl = current_function_decl;
1811
1812 expand_end_bindings (getdecls (), 1, 0);
1813 /* pop out of function */
1814 poplevel (1, 1, 0);
1815
1816 /* pop out of its parameters */
1817 poplevel (1, 0, 1);
1818
1819 BLOCK_SUPERCONTEXT (DECL_INITIAL (fndecl)) = fndecl;
1820
1821 /* Generate rtl for function exit. */
1822 expand_function_end (input_filename, lineno, 0);
1823
1824 /* Run the optimizers and output assembler code for this function. */
1825 rest_of_compilation (fndecl);
1826
1827 current_function_decl = NULL_TREE;
1828 }
1829
1830 /* Dump FUNCTION_DECL FN as tree dump PHASE. */
1831
1832 static void
1833 dump_function (enum tree_dump_index phase, tree fn)
1834 {
1835 FILE *stream;
1836 int flags;
1837
1838 stream = dump_begin (phase, &flags);
1839 if (stream)
1840 {
1841 dump_node (fn, TDF_SLIM | flags, stream);
1842 dump_end (phase, stream);
1843 }
1844 }
1845
1846 void java_optimize_inline (tree fndecl)
1847 {
1848 if (flag_inline_trees)
1849 {
1850 timevar_push (TV_INTEGRATION);
1851 optimize_inline_calls (fndecl);
1852 timevar_pop (TV_INTEGRATION);
1853 dump_function (TDI_inlined, fndecl);
1854 }
1855 }
1856
1857 #include "gt-java-decl.h"