OSDN Git Service

2000-08-08 Alexandre Petit-Bianco <apbianco@cygnus.com>
[pf3gnuchains/gcc-fork.git] / gcc / java / java-tree.h
1 /* Definitions for parsing and type checking for the GNU compiler for
2    the Java(TM) language.
3    Copyright (C) 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
4
5 This file is part of GNU CC.
6
7 GNU CC is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
11
12 GNU CC is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GNU CC; see the file COPYING.  If not, write to
19 the Free Software Foundation, 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA.  
21
22 Java and all Java-based marks are trademarks or registered trademarks
23 of Sun Microsystems, Inc. in the United States and other countries.
24 The Free Software Foundation is independent of Sun Microsystems, Inc.  */
25
26 /* Hacked by Per Bothner <bothner@cygnus.com> February 1996. */
27
28 #include "hash.h"
29
30 /* Java language-specific tree codes.  */
31 #define DEFTREECODE(SYM, NAME, TYPE, LENGTH) SYM,
32 enum java_tree_code {
33   __DUMMY = LAST_AND_UNUSED_TREE_CODE,
34 #include "java-tree.def"
35   LAST_JAVA_TREE_CODE
36 };
37 #undef DEFTREECODE
38
39 struct JCF;
40
41 /* Usage of TREE_LANG_FLAG_?:
42    0: IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P (in IDENTIFIER_NODE)
43       RESOLVE_EXPRESSION_NAME_P (in EXPR_WITH_FILE_LOCATION)
44       FOR_LOOP_P (in LOOP_EXPR)
45       ANONYMOUS_CLASS_P (in RECORD_TYPE)
46       ARG_FINAL_P (in TREE_LIST)
47    1: CLASS_HAS_SUPER_FLAG (in TREE_VEC).
48       IS_A_CLASSFILE_NAME (in IDENTIFIER_NODE)
49       COMPOUND_ASSIGN_P (in EXPR (binop_*))
50       LOCAL_CLASS_P (in RECORD_TYPE)
51    2: RETURN_MAP_ADJUSTED (in TREE_VEC).
52       QUALIFIED_P (in IDENTIFIER_NODE)
53       PRIMARY_P (in EXPR_WITH_FILE_LOCATION)
54       MODIFY_EXPR_FROM_INITIALIZATION_P (in MODIFY_EXPR)
55       CLASS_METHOD_CHECKED_P (in RECORD_TYPE) 
56    3: IS_AN_IMPORT_ON_DEMAND_P (in IDENTIFIER_NODE)
57       RESOLVE_PACKAGE_NAME_P (in EXPR_WITH_FILE_LOCATION)
58       SWITCH_HAS_DEFAULT (in SWITCH_EXPR)
59    4: IS_A_COMMAND_LINE_FILENAME_P (in IDENTIFIER_NODE)
60       RESOLVE_TYPE_NAME_P (in EXPR_WITH_FILE_LOCATION)
61       CALL_USING_SUPER (in CALL_EXPR)
62    5: HAS_BEEN_ALREADY_PARSED_P (in IDENTIFIER_NODE)
63       IS_BREAK_STMT_P (in EXPR_WITH_FILE_LOCATION)
64       IS_CRAFTED_STRING_BUFFER_P (in CALL_EXPR)
65       IS_INIT_CHECKED (in SAVE_EXPR)
66    6: CAN_COMPLETE_NORMALLY (in statement nodes)
67       OUTER_FIELD_ACCESS_IDENTIFIER_P (in IDENTIFIER_NODE)
68
69    Usage of TYPE_LANG_FLAG_?:
70    0: CLASS_ACCESS0_GENERATED_P (in RECORD_TYPE)
71    1: TYPE_ARRAY_P (in RECORD_TYPE).
72    2: CLASS_LOADED_P (in RECORD_TYPE).
73    3: CLASS_FROM_SOURCE_P (in RECORD_TYPE).
74    4: CLASS_P (in RECORD_TYPE).
75    5: CLASS_FROM_CURRENTLY_COMPILED_SOURCE_P (in RECORD_TYPE)
76    6: CLASS_BEING_LAIDOUT (in RECORD_TYPE)
77
78    Usage of DECL_LANG_FLAG_?:
79    0: METHOD_DEPRECATED (in FUNCTION_DECL).
80       FIELD_DEPRECATED (in FIELD_DECL).
81       CLASS_DEPRECATED (in TYPE_DECL).
82    1: METHOD_PUBLIC (in FUNCTION_DECL).
83       FIELD_PUBLIC (in FIELD_DECL).
84       CLASS_PUBLIC (in TYPE_DECL).
85    2: METHOD_STATIC (in FUNCTION_DECL).
86       (But note that FIELD_STATIC uses TREE_STATIC!)
87       CLASS_COMPLETE_P (in TYPE_DECL)
88    3: METHOD_FINAL (in FUNCTION_DECL)
89       FIELD_FINAL (in FIELD_DECL)
90       CLASS_FINAL (in TYPE_DECL)
91       LOCAL_FINAL (in VAR_DECL)
92    4: METHOD_SYNCHRONIZED (in FUNCTION_DECL).
93       LABEL_IN_SUBR (in LABEL_DECL)
94       CLASS_INTERFACE (in TYPE_DECL)
95       FIELD_VOLATILE (int FIELD_DECL)
96    5: METHOD_ABSTRACT (in FUNCTION_DECL).
97       LABEL_IS_SUBR_START (in LABEL_DECL)
98       CLASS_ABSTRACT (in TYPE_DECL)
99       FIELD_TRANSIENT (in FIELD_DECL)
100    6: METHOD_TRANSIENT (in FUNCTION_DECL)
101       LABEL_CHANGED (in LABEL_DECL)
102       CLASS_SUPER (in TYPE_DECL, ACC_SUPER flag)
103       FIELD_LOCAL_ALIAS (in FIELD_DECL)
104    7: DECL_CONSTRUCTOR_P (in FUNCTION_DECL).
105       CLASS_STATIC (in TYPE_DECL)
106       FIELD_LOCAL_ALIAS_USED (in FIELD_DECL)
107       FIELD_THISN (in FIELD_DECL)
108 */
109
110 /* True if the class whose TYPE_BINFO this is has a superclass.
111    (True of all classes except Object.) */
112 #define CLASS_HAS_SUPER_FLAG(BINFO) TREE_LANG_FLAG_1(BINFO)
113 #define CLASS_HAS_SUPER(TYPE) CLASS_HAS_SUPER_FLAG (TYPE_BINFO (TYPE))
114
115 /* Return the supertype of class TYPE, or NULL_TREE is it has none. */
116 #define CLASSTYPE_SUPER(TYPE) (CLASS_HAS_SUPER (TYPE) ? \
117   BINFO_TYPE (TREE_VEC_ELT (TYPE_BINFO_BASETYPES (TYPE), 0)) : NULL_TREE)
118
119 /* True if the class we are compiling is a .java source file;
120    false if it is a .class bytecode file. */
121 extern int compiling_from_source;
122
123 /* The class defined by the actual (main) file we are compiling. */
124 extern tree main_class;
125
126 /* The class we are currently processing. */
127 extern tree current_class;
128
129 /* List of all class DECLs seen so far.  */
130 extern tree all_class_list;
131
132 /* Nonzero if we should make is_compiled_class always return 1 for
133    appropriate classes that we're referencing.  */
134
135 extern int flag_assume_compiled;
136
137 extern int flag_emit_class_files;
138
139 /* When non zero, assume all native functions are implemented with
140    JNI, not CNI.  */
141
142 extern int flag_jni;
143
144 /* When non zero, report the now deprecated empty statements.  */
145
146 extern int flag_extraneous_semicolon;
147
148 /* When non zero, we emit xref strings. Values of the flag for xref
149    backends are defined in xref.h.  */
150
151 extern int flag_emit_xref;
152
153 /* When doing xrefs, tell when not to fold.   */
154 extern int do_not_fold;
155
156 /* Turned to 1 if -Wall was encountered. See lang.c for their meanings.  */
157 extern int flag_wall;
158 extern int flag_redundant;
159 extern int flag_not_overriding;
160 extern int flag_static_local_jdk1_1;
161
162 /* When non zero, call a library routine to do integer divisions. */
163 extern int flag_use_divide_subroutine;
164
165 /* When non zero, generate code for the Boehm GC.  */
166 extern int flag_use_boehm_gc;
167
168 /* When non zero, assume the runtime uses a hash table to map an
169    object to its synchronization structure.  */
170 extern int flag_hash_synchronization;
171
172 /* The Java .class file that provides main_class;  the main input file. */
173 extern struct JCF *current_jcf;
174
175 typedef struct CPool constant_pool;
176
177 #define CONSTANT_ResolvedFlag 16
178
179 /* The cpool->data[i] for a ResolvedString points to a STRING_CST. */
180 #define CONSTANT_ResolvedString    (CONSTANT_String+CONSTANT_ResolvedFlag)
181
182 /* The cpool->data[i] for a ResolvedClass points to a RECORD_TYPE. */
183 #define CONSTANT_ResolvedClass     (CONSTANT_Class+CONSTANT_ResolvedFlag)
184
185 #define CPOOL_UTF(CPOOL, INDEX) ((tree) (CPOOL)->data[INDEX])
186
187 /* A NameAndType constant is represented as a TREE_LIST.
188    The type is the signature string (as an IDENTIFIER_NODE).  */
189
190 #define NAME_AND_TYPE_NAME(CPOOL, IDX) \
191   CPOOL_UTF(CPOOL, CPOOL_USHORT1(CPOOL, IDX))
192 #define NAME_AND_TYPE_SIGNATURE(CPOOL, IDX) \
193   CPOOL_UTF(CPOOL, CPOOL_USHORT2(CPOOL, IDX))
194
195 /* A FieldRef, MethodRef or InterfaceMethodRef constant
196    is represented as a TREE_LIST. */
197
198 #define COMPONENT_REF_CLASS_INDEX(CPOOL, IDX) CPOOL_USHORT1(CPOOL, IDX)
199 #define COMPONENT_REF_NAME_AND_TYPE(CPOOL, IDX) CPOOL_USHORT2(CPOOL, IDX)
200 #define COMPONENT_REF_NAME(CPOOL, IDX) \
201   NAME_AND_TYPE_NAME (CPOOL, COMPONENT_REF_NAME_AND_TYPE(CPOOL, IDX))
202 #define COMPONENT_REF_SIGNATURE(CPOOL, IDX) \
203   NAME_AND_TYPE_SIGNATURE (CPOOL, COMPONENT_REF_NAME_AND_TYPE(CPOOL, IDX))
204
205 /* "Promoted types" that are used for primitive types smaller
206    than int.  We could use int_type_node, but then we would lose
207    type information (such as needed for debugging). */
208 extern tree promoted_byte_type_node;
209 extern tree promoted_short_type_node;
210 extern tree promoted_char_type_node;
211 extern tree promoted_boolean_type_node;
212
213 extern tree byte_type_node;
214 extern tree short_type_node;
215 extern tree int_type_node;
216 extern tree long_type_node;
217
218 extern tree unsigned_byte_type_node;
219 extern tree unsigned_short_type_node;
220 extern tree unsigned_int_type_node;
221 extern tree unsigned_long_type_node;
222
223 extern tree boolean_type_node;
224
225 extern tree object_type_node;
226 extern tree unqualified_object_id_node;
227 extern tree object_ptr_type_node;
228 extern tree string_type_node;
229 extern tree string_ptr_type_node;
230 extern tree throwable_type_node;
231 extern tree runtime_exception_type_node;
232 extern tree error_exception_type_node;
233 extern tree rawdata_ptr_type_node;
234
235 extern tree *predef_filenames;
236 extern int predef_filenames_size;
237
238 extern tree byte_array_type_node;
239 extern tree short_array_type_node;
240 extern tree int_array_type_node;
241 extern tree long_array_type_node;
242 extern tree boolean_array_type_node;
243 extern tree char_array_type_node;
244 extern tree double_array_type_node;
245 extern tree float_array_type_node;
246 extern tree array_array_type_node;
247 extern tree object_array_type_node;
248 extern tree string_array_type_node;
249 extern tree boolean_array_vtable;
250 extern tree byte_array_vtable;
251 extern tree char_array_vtable;
252 extern tree short_array_vtable;
253 extern tree int_array_vtable;
254 extern tree long_array_vtable;
255 extern tree float_array_vtable;
256 extern tree double_array_vtable;
257 extern tree TYPE_identifier_node;      /* "TYPE" */
258 extern tree init_identifier_node;      /* "<init>" */
259 extern tree clinit_identifier_node;      /* "<clinit>" */
260 extern tree finit_identifier_node;      /* "finit$" */
261 extern tree finit_leg_identifier_node;  /* "$finit$" */
262 extern tree void_signature_node;       /* "()V" */
263 extern tree length_identifier_node;  /* "length" */
264 extern tree this_identifier_node;  /* "this" */
265 extern tree super_identifier_node;  /* "super" */
266 extern tree continue_identifier_node;  /* "continue" */
267 extern tree access0_identifier_node; /* "access$0" */
268 extern tree one_elt_array_domain_type;
269 /* The type of the return address of a subroutine. */
270 extern tree return_address_type_node;
271
272 /* Nodes for boolean constants TRUE and FALSE. */
273 extern tree boolean_true_node, boolean_false_node;
274
275 /* Integer constants not declared in tree.h. */
276 extern tree long_zero_node;
277 extern tree float_zero_node;
278 extern tree double_zero_node;
279 extern tree integer_negative_one_node;
280 extern tree integer_two_node;
281 extern tree integer_four_node;
282 extern tree empty_stmt_node;
283
284 /* The type for struct methodtable. */
285 extern tree methodtable_type;
286 extern tree methodtable_ptr_type;
287
288 extern tree utf8const_type;
289 extern tree utf8const_ptr_type;
290
291 extern tree class_type_node;
292 extern tree class_ptr_type;
293 extern tree field_type_node;
294 extern tree constants_type_node;
295 extern tree dtable_type, dtable_ptr_type;
296 extern tree field_ptr_type_node;
297 extern tree field_info_union_node;
298 extern tree method_type_node;
299 extern tree method_ptr_type_node;
300 #define nativecode_ptr_type_node ptr_type_node
301
302 extern tree end_params_node;
303
304 /* References to internal libjava functions we use. */
305 extern tree alloc_object_node;
306 extern tree soft_instanceof_node;
307 extern tree soft_checkcast_node;
308 extern tree soft_initclass_node;
309 extern tree soft_newarray_node;
310 extern tree soft_anewarray_node;
311 extern tree soft_multianewarray_node;
312 extern tree soft_badarrayindex_node;
313 extern tree soft_nullpointer_node;
314 extern tree throw_node[];
315 extern tree soft_checkarraystore_node;
316 extern tree soft_monitorenter_node;
317 extern tree soft_monitorexit_node;
318 extern tree soft_lookupinterfacemethod_node;
319 extern tree soft_lookupjnimethod_node;
320 extern tree soft_getjnienvnewframe_node;
321 extern tree soft_jnipopsystemframe_node;
322 extern tree soft_fmod_node;
323 extern tree soft_exceptioninfo_call_node;
324 extern tree soft_idiv_node;
325 extern tree soft_irem_node;
326 extern tree soft_ldiv_node;
327 extern tree soft_lrem_node;
328
329 extern tree access_flags_type_node;
330
331 extern tree class_dtable_decl;
332
333 /* They need to be reset before processing each class */
334 extern struct CPool *outgoing_cpool; 
335 extern tree current_constant_pool_data_ref;
336
337 extern tree wfl_operator;
338
339 extern char *cyclic_inheritance_report;
340
341 extern char *cyclic_inheritance_report;
342
343 struct lang_identifier
344 {
345   struct tree_identifier ignore;
346   tree global_value, local_value;
347
348   /* If non-NULL:  An ADDR_REF to a VAR_DECL that contains
349    * the Utf8Const representation of the identifier.  */
350   tree utf8_ref;
351 };
352
353 /* Macros for access to language-specific slots in an identifier.  */
354 /* UNless specifide, each of these slots contains a DECL node or null.  */
355
356 /* This represents the value which the identifier has in the
357    file-scope namespace.  */
358 #define IDENTIFIER_GLOBAL_VALUE(NODE)   \
359   (((struct lang_identifier *)(NODE))->global_value)
360 /* This represents the value which the identifier has in the current
361    scope.  */
362 #define IDENTIFIER_LOCAL_VALUE(NODE)    \
363   (((struct lang_identifier *)(NODE))->local_value)
364
365 /* Given an identifier NODE, get the corresponding (non-handle) class.
366    For get_identifier ("java.lang.Number"), the result is
367    the struct whose DECL_ASSEMBLER_NAME is "Classjava_lang_Number". */
368 #define IDENTIFIER_CLASS_VALUE(NODE) IDENTIFIER_GLOBAL_VALUE(NODE)
369
370 /* Given an identifier NODE, get the corresponding handle class.
371    For get_identifier ("java.lang.Number"), the result is
372    the struct whose DECL_ASSEMBLER_NAME is "Hjava_lang_Number". */
373 #define IDENTIFIER_HANDLECLASS_VALUE(NODE) ???
374
375 /* Given a signature of a reference (or array) type, or a method, return the
376    corresponding type (if one has been allocated).
377    Do not use for primitive types, since they may be ambiguous.
378    (E.g. is "I" a signature or a class name?) */
379 #define IDENTIFIER_SIGNATURE_TYPE(NODE) IDENTIFIER_GLOBAL_VALUE(NODE)
380
381 /* If non-NULL:  An ADDR_REF to a VAR_DECL that contains
382    the Utf8Const representation of the identifier.  */
383 #define IDENTIFIER_UTF8_REF(NODE) \
384   (((struct lang_identifier *)(NODE))->utf8_ref)
385
386 #define IDENTIFIER_UTF8_DECL(NODE) \
387   TREE_OPERAND((((struct lang_identifier *)(NODE))->utf8_ref), 0)
388
389 /* For a FUNCTION_DECL, if we are compiling a .class file, then this is
390    the position in the .class file of the method code.
391    Specifically, this is the code itself, not the code attribute. */
392 #define DECL_CODE_OFFSET(DECL) (DECL_LANG_SPECIFIC(DECL)->code_offset)
393 /* Similarly, the length of the bytecode. */
394 #define DECL_CODE_LENGTH(DECL) (DECL_LANG_SPECIFIC(DECL)->code_length)
395 /* Similarly, the position of the LineNumberTable attribute. */
396 #define DECL_LINENUMBERS_OFFSET(DECL) \
397   (DECL_LANG_SPECIFIC(DECL)->linenumbers_offset)
398 /* Similarly, the position of the LocalVariableTable attribute
399    (following the standard attribute header). */
400 #define DECL_LOCALVARIABLES_OFFSET(DECL) \
401   (DECL_LANG_SPECIFIC(DECL)->localvariables_offset)
402
403 #define DECL_MAX_LOCALS(DECL) (DECL_LANG_SPECIFIC(DECL)->max_locals)
404 #define DECL_MAX_STACK(DECL) (DECL_LANG_SPECIFIC(DECL)->max_stack)
405 /* Number of local variable slots needed for the arguments of this function. */
406 #define DECL_ARG_SLOT_COUNT(DECL) (DECL_LANG_SPECIFIC(DECL)->arg_slot_count)
407 /* List of checked thrown exceptions, as specified with the `throws'
408    keyword */
409 #define DECL_FUNCTION_THROWS(DECL) (DECL_LANG_SPECIFIC(DECL)->throws_list)
410 /* List of other constructors of the same class that this constructor
411    calls */
412 #define DECL_CONSTRUCTOR_CALLS(DECL) \
413   (DECL_LANG_SPECIFIC(DECL)->called_constructor)
414 /* When the function is an access function, the DECL it was trying to
415    access */
416 #define DECL_FUNCTION_ACCESS_DECL(DECL) \
417   (DECL_LANG_SPECIFIC(DECL)->called_constructor)
418 /* The identifier of the access method used to invoke this method from
419    an inner class.  */
420 #define DECL_FUNCTION_INNER_ACCESS(DECL) \
421   (DECL_LANG_SPECIFIC(DECL)->inner_access)
422 /* Pointer to the function's current's COMPOUND_EXPR tree (while
423    completing its body) or the function's block */
424 #define DECL_FUNCTION_BODY(DECL) (DECL_LANG_SPECIFIC(DECL)->function_decl_body)
425 /* How specific the function is (for method selection - Java source
426    code front-end */
427 #define DECL_SPECIFIC_COUNT(DECL) DECL_ARG_SLOT_COUNT(DECL)
428 /* For each function decl, init_test_table contains a hash table whose
429    entries are keyed on class names, and whose values are local
430    boolean decls.  The variables are intended to be TRUE when the
431    class has been initialized in this function, and FALSE otherwise.  */
432 #define DECL_FUNCTION_INIT_TEST_TABLE(DECL) \
433   (DECL_LANG_SPECIFIC(DECL)->init_test_table)
434 /* The Number of Artificial Parameters (NAP) DECL contains. this$<n>
435    is excluded, because sometimes created as a parameter before the
436    function decl exists. */
437 #define DECL_FUNCTION_NAP(DECL) (DECL_LANG_SPECIFIC(DECL)->nap)
438
439 /* For a FIELD_DECL, holds the name of the access method used to
440    read/write the content of the field from an inner class. 
441    The cast is ugly. FIXME  */
442 #define FIELD_INNER_ACCESS(DECL)       ((tree)DECL_LANG_SPECIFIC (DECL))
443
444 /* True when DECL aliases an outer context local variable.  */
445 #define FIELD_LOCAL_ALIAS(DECL) DECL_LANG_FLAG_6 (DECL)
446
447 /* True when DECL, which aliases an outer context local variable is
448    used by the inner classe */
449 #define FIELD_LOCAL_ALIAS_USED(DECL) DECL_LANG_FLAG_7 (DECL)
450
451 /* True when DECL is a this$<n> field. Note that
452    FIELD_LOCAL_ALIAS_USED can be differenciated when tested against
453    FIELD_LOCAL_ALIAS.  */
454 #define FIELD_THISN(DECL) DECL_LANG_FLAG_7 (DECL)
455
456 /* In a LABEL_DECL, a TREE_VEC that saves the type_map at that point. */
457 #define LABEL_TYPE_STATE(NODE) (DECL_INITIAL (NODE))
458
459 /* In the label of a subroutine, a dummy label that records the
460    state following a merge of all the ret instructions in this subroutine. */
461 #define LABEL_RETURN_LABEL(DECL) DECL_ARGUMENTS(DECL)
462
463 /* In the label of a sub-routine, records the type state at return.
464  * A local may be TYPE_UNUSED, which means that the local is not
465  * used (stored to or loaded from) in this subroutine - at least for
466  * code that we have verified so far. */
467 #define LABEL_RETURN_TYPE_STATE(NODE) LABEL_TYPE_STATE (LABEL_RETURN_LABEL (NODE))
468
469 /* In a TREE_VEC for a LABEL_RETURN_TYPE_STATE, notes that
470    TREE_VEC_LENGTH has been adjust to the correct stack size. */
471 #define RETURN_MAP_ADJUSTED(NODE) TREE_LANG_FLAG_2(NODE)
472
473 /* In the label of a sub-routine, a chain of the return location labels. */
474 #define LABEL_RETURN_LABELS(node) \
475   (LABEL_DECL_CHECK (LABEL_RETURN_LABEL(node))->decl.result)
476
477 /* In a LABEL_DECL, the next pending label.
478    See pending_blocks in expr.c. */
479 #define LABEL_PENDING_CHAIN(NODE) (LABEL_DECL_CHECK (NODE)->decl.result)
480
481 /* In a LABEL_DECL, the corresponding bytecode program counter. */
482 #define LABEL_PC(NODE) ((NODE)->decl.u2.i)
483
484 /* Used during verification to mark the label has "changed". (See JVM Spec). */
485 #define LABEL_CHANGED(NODE) DECL_LANG_FLAG_6(NODE)
486
487 /* In a LABEL_DECL, true if we have verified instructions starting here. */
488 #define LABEL_VERIFIED(NODE) (instruction_bits[LABEL_PC(NODE)]&BCODE_VERIFIED)
489
490 /* True if this code is within a subroutine (target of a jsr). */
491 #define LABEL_IN_SUBR(NODE) DECL_LANG_FLAG_4(NODE)
492 /* True if this code is the start of a subroutine (target of a jsr). */
493 #define LABEL_IS_SUBR_START(NODE) DECL_LANG_FLAG_5(NODE)
494
495 /* In a LABEL_DECL, if LABEL_IN_SUBR(NODE), points to start of subroutine. */
496 #define LABEL_SUBR_START(NODE) DECL_ABSTRACT_ORIGIN(NODE)
497
498 /* In a LABEL_DECL that has LABEL_IS_SUBR_START, this points to the start
499    of surrounding subroutine in the case of a nested subroutine,
500    and NULL_TREE otherwise. */
501 #define LABEL_SUBR_CONTEXT(NODE) DECL_CONTEXT (LABEL_RETURN_LABEL (NODE))
502
503 /* The slot number for this local variable. */
504 #define DECL_LOCAL_SLOT_NUMBER(NODE) \
505   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->slot_number)
506 /* The start (bytecode) pc for the valid range of this local variable. */
507 #define DECL_LOCAL_START_PC(NODE) \
508   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->start_pc)
509 /* The end (bytecode) pc for the valid range of this local variable. */
510 #define DECL_LOCAL_END_PC(NODE) \
511   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->end_pc)
512 /* For a VAR_DECLor PARM_DECL, used to chain decls with the same
513    slot_number in decl_map. */
514 #define DECL_LOCAL_SLOT_CHAIN(NODE) \
515   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->slot_chain)
516
517 /* For a local VAR_DECL, holds the index into a words bitstring that
518    specifies if this decl is definitively assigned.
519    A DECL_BIT_INDEX of -1 means we no longer care. */
520 #define DECL_BIT_INDEX(DECL) (DECL_CHECK (DECL)->decl.u2.i)
521
522 /* DECL_LANG_SPECIFIC for FUNCTION_DECLs. */
523 struct lang_decl
524 {
525   /*  tree chain; not yet used. */
526   long code_offset;
527   int code_length;
528   long linenumbers_offset;
529   long localvariables_offset;
530   int arg_slots;
531   int max_locals, max_stack, arg_slot_count;
532   tree throws_list;             /* Exception specified by `throws' */
533   tree function_decl_body;      /* Hold all function's statements */
534   tree called_constructor;      /* When decl is a constructor, the
535                                    list of other constructor it calls. */
536   struct hash_table init_test_table;
537                                 /* Class initialization test variables.  */
538   tree inner_access;            /* The identifier of the access method
539                                    used for invocation from inner classes */
540   int nap;                      /* Number of artificial parameters */
541
542   int native : 1;               /* Nonzero if this is a native
543                                    method.  */
544 };
545
546 /* init_test_table hash table entry structure.  */
547 struct init_test_hash_entry
548 {
549   struct hash_entry root;
550   tree init_test_decl;
551 };
552
553 /* DECL_LANG_SPECIFIC for VAR_DECL and PARM_DECL. */
554 struct lang_decl_var
555 {
556   int slot_number;
557   int start_pc;
558   int end_pc;
559   tree slot_chain;
560 };
561
562 /* Macro to access fields in `struct lang_type'.  */
563
564 #define TYPE_SIGNATURE(T) (TYPE_LANG_SPECIFIC(T)->signature)
565 #define TYPE_JCF(T) (TYPE_LANG_SPECIFIC(T)->jcf)
566 #define TYPE_CPOOL(T) (TYPE_LANG_SPECIFIC(T)->cpool)
567 #define TYPE_CPOOL_DATA_REF(T) (TYPE_LANG_SPECIFIC(T)->cpool_data_ref)
568 #define MAYBE_CREATE_TYPE_TYPE_LANG_SPECIFIC(T)                         \
569   if (TYPE_LANG_SPECIFIC ((T)) == NULL)                                 \
570     {                                                                   \
571       TYPE_LANG_SPECIFIC ((T)) =                                        \
572         (struct lang_type *) xmalloc (sizeof (struct lang_type));       \
573                                                                         \
574       bzero ((char *) TYPE_LANG_SPECIFIC ((T)),                         \
575              sizeof (struct lang_type));                                \
576     }
577
578 #define TYPE_FINIT_STMT_LIST(T)  (TYPE_LANG_SPECIFIC(T)->finit_stmt_list)
579 #define TYPE_CLINIT_STMT_LIST(T) (TYPE_LANG_SPECIFIC(T)->clinit_stmt_list)
580 #define TYPE_II_STMT_LIST(T)     (TYPE_LANG_SPECIFIC(T)->ii_block)
581 /* The decl of the synthetic method `class$' used to handle `.class'
582    for non primitive types when compiling to bytecode. */
583 #define TYPE_DOT_CLASS(T)        (TYPE_LANG_SPECIFIC(T)->dot_class)
584 #define TYPE_PRIVATE_INNER_CLASS(T) (TYPE_LANG_SPECIFIC(T)->pic)
585 #define TYPE_PROTECTED_INNER_CLASS(T) (TYPE_LANG_SPECIFIC(T)->poic)
586
587 struct lang_type
588 {
589   tree signature;
590   struct JCF *jcf;
591   struct CPool *cpool;
592   tree cpool_data_ref;          /* Cached */
593   tree finit_stmt_list;         /* List of statements $finit$ will use */
594   tree clinit_stmt_list;        /* List of statements <clinit> will use  */
595   tree ii_block;                /* Instance initializer block */
596   tree dot_class;               /* The decl of the `class$' function that
597                                    needs to be invoked and generated when
598                                    compiling to bytecode to implement
599                                    <non_primitive_type>.class */
600   unsigned pic:1;               /* Private Inner Class. */
601   unsigned poic:1;              /* Protected Inner Class. */
602 };
603
604 #ifdef JAVA_USE_HANDLES
605 /* TYPE_BINFO_HANDLE points from a handle-class to its corresponding
606    non-handle-class, and vice verse. */
607
608 #define BINFO_HANDLE(NODE) TREE_VEC_ELT ((NODE), 6)
609
610 /* Given a RECORD_TYPE for a handle type, return the corresponding class. */
611 #define HANDLE_TO_CLASS_TYPE(HTYPE) BINFO_HANDLE (TYPE_BINFO (HTYPE))
612
613 /* Given a RECORD_TYPE for a class, return the corresponding handle type. */
614 #define CLASS_TO_HANDLE_TYPE(TYPE) BINFO_HANDLE (TYPE_BINFO (TYPE))
615 #else
616 #define HANDLE_TO_CLASS_TYPE(HTYPE) (HTYPE)
617 #define CLASS_TO_HANDLE_TYPE(TYPE) (TYPE)
618 #endif
619
620 #define JCF_u4 unsigned long
621 #define JCF_u2 unsigned short
622
623 extern void add_assume_compiled PARAMS ((const char *, int));
624 extern tree lookup_class PARAMS ((tree));
625 extern tree lookup_java_constructor PARAMS ((tree, tree));
626 extern tree lookup_java_method PARAMS ((tree, tree, tree));
627 extern tree lookup_argument_method PARAMS ((tree, tree, tree));
628 extern tree lookup_argument_method2 PARAMS ((tree, tree, tree));
629 extern tree promote_type PARAMS ((tree));
630 extern tree get_constant PARAMS ((struct JCF*, int));
631 extern tree get_name_constant PARAMS ((struct JCF*, int));
632 extern tree get_class_constant PARAMS ((struct JCF*, int));
633 extern tree parse_signature PARAMS ((struct JCF *jcf, int sig_index));
634 extern void jcf_parse PARAMS ((struct JCF*));
635 extern tree add_field PARAMS ((tree, tree, tree, int));
636 extern tree add_method PARAMS ((tree, int, tree, tree));
637 extern tree add_method_1 PARAMS ((tree, int, tree, tree));
638 extern tree make_class PARAMS ((void));
639 extern tree push_class PARAMS ((tree, tree));
640 extern tree unmangle_classname PARAMS ((const char *name, int name_length));
641 extern tree parse_signature_string PARAMS ((const unsigned char *, int));
642 extern tree get_type_from_signature PARAMS ((tree));
643 extern void layout_class PARAMS ((tree));
644 extern tree layout_class_method PARAMS ((tree, tree, tree, tree));
645 extern void layout_class_methods PARAMS ((tree));
646 extern tree build_class_ref PARAMS ((tree));
647 extern tree build_dtable_decl PARAMS ((tree));
648 extern tree build_internal_class_name PARAMS ((tree));
649 extern tree build_constants_constructor PARAMS ((void));
650 extern tree build_ref_from_constant_pool PARAMS ((int));
651 extern tree build_utf8_ref PARAMS ((tree));
652 extern tree ident_subst PARAMS ((const char*, int,
653                                 const char*, int, int, const char*));
654 extern tree identifier_subst PARAMS ((const tree,
655                                      const char *, int, int, const char *));
656 extern tree build_java_signature PARAMS ((tree));
657 extern tree build_java_argument_signature PARAMS ((tree));
658 extern void set_java_signature PARAMS ((tree, tree));
659 extern tree build_static_field_ref PARAMS ((tree));
660 extern tree build_address_of PARAMS ((tree));
661 extern tree find_local_variable PARAMS ((int index, tree type, int pc));
662 extern tree find_stack_slot PARAMS ((int index, tree type));
663 extern tree build_prim_array_type PARAMS ((tree, HOST_WIDE_INT));
664 extern tree build_java_array_type PARAMS ((tree, HOST_WIDE_INT));
665 extern int is_compiled_class PARAMS ((tree));
666 extern tree mangled_classname PARAMS ((const char*, tree));
667 extern tree lookup_label PARAMS ((int));
668 extern tree pop_type_0 PARAMS ((tree));
669 extern tree pop_type PARAMS ((tree));
670 extern void pop_argument_types PARAMS ((tree));
671 extern tree decode_newarray_type PARAMS ((int));
672 extern tree lookup_field PARAMS ((tree*, tree));
673 extern int is_array_type_p PARAMS ((tree));
674 extern HOST_WIDE_INT java_array_type_length PARAMS ((tree));
675 extern int read_class PARAMS ((tree));
676 extern void load_class PARAMS ((tree, int));
677
678 extern tree lookup_name PARAMS ((tree));
679 extern tree build_known_method_ref PARAMS ((tree, tree, tree, tree, tree));
680 extern tree build_class_init PARAMS ((tree, tree));
681 extern tree build_invokevirtual PARAMS ((tree, tree));
682 extern tree build_invokeinterface PARAMS ((tree, tree));
683 extern tree build_jni_stub PARAMS ((tree));
684 extern tree invoke_build_dtable PARAMS ((int, tree));
685 extern tree build_field_ref PARAMS ((tree, tree, tree));
686 extern void pushdecl_force_head PARAMS ((tree));
687 extern tree build_java_binop PARAMS ((enum tree_code, tree, tree, tree));
688 extern tree build_java_soft_divmod PARAMS ((enum tree_code, tree, tree, tree));
689 extern tree binary_numeric_promotion PARAMS ((tree, tree, tree *, tree *));
690 extern tree build_java_arrayaccess PARAMS ((tree, tree, tree));
691 extern tree build_newarray PARAMS ((int, tree));
692 extern tree build_anewarray PARAMS ((tree, tree));
693 extern tree build_new_array PARAMS ((tree, tree));
694 extern tree build_java_array_length_access PARAMS ((tree));
695 extern tree build_java_arraynull_check PARAMS ((tree, tree, tree));
696 extern tree build_get_class PARAMS ((tree));
697 extern tree build_instanceof PARAMS ((tree, tree));
698 extern tree create_label_decl PARAMS ((tree));
699 extern void push_labeled_block PARAMS ((tree));
700 extern tree prepare_eh_table_type PARAMS ((tree));
701 extern void java_set_exception_lang_code PARAMS ((void));
702 extern tree generate_name PARAMS ((void));
703 extern void pop_labeled_block PARAMS ((void));
704 extern const char *lang_printable_name PARAMS ((tree, int));
705 extern tree maybe_add_interface PARAMS ((tree, tree));
706 extern void set_super_info PARAMS ((int, tree, tree, int));
707 extern int get_access_flags_from_decl PARAMS ((tree));
708 extern int interface_of_p PARAMS ((tree, tree));
709 extern int inherits_from_p PARAMS ((tree, tree));
710 extern int common_enclosing_context_p PARAMS ((tree, tree));
711 extern int enclosing_context_p PARAMS ((tree, tree));
712 extern void complete_start_java_method PARAMS ((tree));
713 extern tree build_result_decl PARAMS ((tree));
714 extern void emit_handlers PARAMS ((void));
715 extern void init_outgoing_cpool PARAMS ((void));
716 extern void make_class_data PARAMS ((tree));
717 extern void register_class PARAMS ((void));
718 extern int alloc_name_constant PARAMS ((int, tree));
719 extern void emit_register_classes PARAMS ((void));
720 extern void lang_init_source PARAMS ((int));
721 extern void write_classfile PARAMS ((tree));
722 extern char *print_int_node PARAMS ((tree));
723 extern void parse_error_context PARAMS ((tree cl, const char *, ...))
724   ATTRIBUTE_PRINTF_2;
725 extern tree build_primtype_type_ref PARAMS ((const char *));
726 extern tree java_get_real_method_name PARAMS ((tree));
727 extern void finish_class PARAMS ((void));
728 extern void java_layout_seen_class_methods PARAMS ((void));
729 extern void check_for_initialization PARAMS ((tree));
730
731 extern tree pushdecl_top_level PARAMS ((tree));
732 extern int alloc_class_constant PARAMS ((tree));
733 extern int unicode_mangling_length PARAMS ((const char *, int));
734 extern void init_expr_processing PARAMS ((void));
735 extern void push_super_field PARAMS ((tree, tree));
736 extern void init_class_processing PARAMS ((void));
737 extern int can_widen_reference_to PARAMS ((tree, tree));
738 extern int class_depth PARAMS ((tree));
739 extern int verify_jvm_instructions PARAMS ((struct JCF *, const unsigned char *, long));
740 extern void maybe_pushlevels PARAMS ((int));
741 extern void maybe_poplevels PARAMS ((int));
742 extern void force_poplevels PARAMS ((int));
743 extern int process_jvm_instruction PARAMS ((int, const unsigned char *, long));
744 extern void set_local_type PARAMS ((int, tree));
745 extern int merge_type_state PARAMS ((tree));
746 extern void push_type PARAMS ((tree));
747 extern void load_type_state PARAMS ((tree));
748 extern void add_interface PARAMS ((tree, tree));
749 extern void append_gpp_mangled_name PARAMS ((struct obstack *, const char *, int));
750 extern void append_gpp_mangled_classtype PARAMS ((struct obstack *, const char *));
751 extern void emit_unicode_mangled_name PARAMS ((struct obstack *, const char *, int));
752 extern tree force_evaluation_order PARAMS ((tree));
753 extern int verify_constant_pool PARAMS ((struct JCF *));
754 extern void start_java_method PARAMS ((tree));
755 extern void end_java_method PARAMS ((void));
756 extern void give_name_to_locals PARAMS ((struct JCF *));
757 extern void expand_byte_code PARAMS ((struct JCF *, tree));
758 extern int open_in_zip PARAMS ((struct JCF *, const char *, const char *, int));
759 extern void set_constant_value PARAMS ((tree, tree));
760 #ifdef jword
761 extern int find_constant1 PARAMS ((struct CPool *, int, jword));
762 extern int find_constant2 PARAMS ((struct CPool *, int, jword, jword));
763 #endif
764 extern int find_utf8_constant PARAMS ((struct CPool *, tree));
765 extern int find_string_constant PARAMS ((struct CPool *, tree));
766 extern int find_class_constant PARAMS ((struct CPool *, tree));
767 extern int find_fieldref_index PARAMS ((struct CPool *, tree));
768 extern int find_methodref_index PARAMS ((struct CPool *, tree));
769 extern void write_constant_pool PARAMS ((struct CPool *, unsigned char *, int));
770 extern int count_constant_pool_bytes PARAMS ((struct CPool *));
771 extern int encode_newarray_type PARAMS ((tree));
772 #ifdef uint64
773 extern void format_int PARAMS ((char *, jlong, int));
774 extern void format_uint PARAMS ((char *, uint64, int));
775 #endif
776 extern void jcf_trim_old_input PARAMS ((struct JCF *));
777 #ifdef BUFSIZ
778 extern void jcf_print_utf8 PARAMS ((FILE *, const unsigned char *, int));
779 extern void jcf_print_char PARAMS ((FILE *, int));
780 extern void jcf_print_utf8_replace PARAMS ((FILE *, const unsigned char *,
781                                            int, int, int));
782 # if JCF_USE_STDIO
783 extern const char* open_class PARAMS ((const char *, struct JCF *,
784                                        FILE *, const char *));
785 # else
786 extern const char* open_class PARAMS ((const char *, struct JCF *,
787                                        int, const char *));
788 # endif /* JCF_USE_STDIO */
789 #endif
790 extern void java_debug_context PARAMS ((void));
791 extern void safe_layout_class PARAMS ((tree));
792
793 extern tree get_boehm_type_descriptor PARAMS ((tree));
794 extern unsigned long java_hash_hash_tree_node PARAMS ((hash_table_key));
795 extern boolean java_hash_compare_tree_node PARAMS ((hash_table_key, 
796                                                     hash_table_key));
797 extern void java_check_methods PARAMS ((tree));
798
799 /* We use ARGS_SIZE_RTX to indicate that gcc/expr.h has been included
800    to declare `enum expand_modifier'. */
801 #if defined (TREE_CODE) && defined(RTX_CODE) && defined (HAVE_MACHINE_MODES) && defined (ARGS_SIZE_RTX)
802 struct rtx_def * java_lang_expand_expr PARAMS ((tree, rtx, enum machine_mode,
803                                                enum expand_modifier)); 
804 #endif /* TREE_CODE && RTX_CODE && HAVE_MACHINE_MODES && ARGS_SIZE_RTX */
805
806 /* Access flags etc for a method (a FUNCTION_DECL): */
807
808 #define METHOD_PUBLIC(DECL) DECL_LANG_FLAG_1 (DECL)
809 #define METHOD_PRIVATE(DECL) TREE_PRIVATE (DECL)
810 #define METHOD_PROTECTED(DECL) TREE_PROTECTED (DECL)
811 #define METHOD_STATIC(DECL) DECL_LANG_FLAG_2 (DECL)
812 #define METHOD_FINAL(DECL) DECL_LANG_FLAG_3 (DECL)
813 #define METHOD_SYNCHRONIZED(DECL) DECL_LANG_FLAG_4 (DECL)
814 #define METHOD_NATIVE(DECL) (DECL_LANG_SPECIFIC(DECL)->native)
815 #define METHOD_ABSTRACT(DECL) DECL_LANG_FLAG_5 (DECL)
816 #define METHOD_TRANSIENT(DECL) DECL_LANG_FLAG_6 (DECL)
817
818 /* Other predicates on method decls  */
819
820 #define DECL_CONSTRUCTOR_P(DECL) DECL_LANG_FLAG_7(DECL)
821
822 #define DECL_INIT_P(DECL)   (ID_INIT_P (DECL_NAME (DECL)))
823 #define DECL_FINIT_P(DECL)  (ID_FINIT_P (DECL_NAME (DECL)))
824 #define DECL_CLINIT_P(DECL) (ID_CLINIT_P (DECL_NAME (DECL)))
825
826 /* Predicates on method identifiers. Kept close to other macros using
827    them  */
828 #define ID_INIT_P(ID)   ((ID) == init_identifier_node)
829 /* Match ID to either `$finit$' or `finit$', so that `$finit$'
830    continues to be recognized as an equivalent to `finit$' which is
831    now the prefered name used for the field initialization special
832    method.  */
833 #define ID_FINIT_P(ID)  ((ID) == finit_identifier_node \
834                          || (ID) == finit_leg_identifier_node)
835 #define ID_CLINIT_P(ID) ((ID) == clinit_identifier_node)
836
837 /* Access flags etc for a variable/field (a FIELD_DECL): */
838
839 #define FIELD_PRIVATE(DECL) TREE_PRIVATE (DECL)
840 #define FIELD_PROTECTED(DECL) TREE_PROTECTED (DECL)
841 #define FIELD_PUBLIC(DECL) DECL_LANG_FLAG_1 (DECL)
842 #define FIELD_STATIC(DECL) TREE_STATIC (DECL)
843 #define FIELD_FINAL(DECL) DECL_LANG_FLAG_3 (DECL)
844 #define FIELD_VOLATILE(DECL) DECL_LANG_FLAG_4 (DECL)
845 #define FIELD_TRANSIENT(DECL) DECL_LANG_FLAG_5 (DECL)
846 #define LOCAL_FINAL(DECL) FIELD_FINAL(DECL)
847
848 /* Access flags etc for a class (a TYPE_DECL): */
849
850 #define CLASS_PUBLIC(DECL) DECL_LANG_FLAG_1 (DECL)
851 #define CLASS_FINAL(DECL) DECL_LANG_FLAG_3 (DECL)
852 #define CLASS_INTERFACE(DECL) DECL_LANG_FLAG_4 (DECL)
853 #define CLASS_ABSTRACT(DECL) DECL_LANG_FLAG_5 (DECL)
854 #define CLASS_SUPER(DECL) DECL_LANG_FLAG_6 (DECL)
855 #define CLASS_STATIC(DECL) DECL_LANG_FLAG_7 (DECL)
856 #define CLASS_PRIVATE(DECL) (TYPE_PRIVATE_INNER_CLASS (TREE_TYPE (DECL)))
857 #define CLASS_PROTECTED(DECL) (TYPE_PROTECTED_INNER_CLASS (TREE_TYPE (DECL)))
858
859 /* @deprecated marker flag on methods, fields and classes */
860
861 #define METHOD_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
862 #define FIELD_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
863 #define CLASS_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
864 #define DECL_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
865
866 /* The number of virtual methods in this class's dispatch table.
867  Does not include initial two dummy entries (one points to the
868  Class object, and the other is for G++ -fvtable-thunks compatibility). */
869 #define TYPE_NVIRTUALS(TYPE) TYPE_BINFO_VIRTUALS (TYPE)
870
871 /* A TREE_VEC (indexed by DECL_VINDEX) containing this class's
872    virtual methods. */
873 #define TYPE_VTABLE(TYPE) TYPE_BINFO_VTABLE(TYPE)
874
875 /* Use CLASS_LOADED_P? FIXME */
876 #define CLASS_COMPLETE_P(DECL) DECL_LANG_FLAG_2 (DECL) 
877
878 /* This maps a bytecode offset (PC) to various flags,
879    listed below (starting with BCODE_). */
880 extern char *instruction_bits;
881
882 /* True iff the byte is the start of an instruction. */
883 #define BCODE_INSTRUCTION_START 1
884
885 /* True iff there is a jump to this location. */
886 #define BCODE_JUMP_TARGET 2
887
888 /* True iff there is a return to this location.
889    (I.e. the preceedng instruction was a call.) */
890 #define BCODE_RETURN_TARGET 4
891
892 /* True iff this is the start of an exception handler. */
893 #define BCODE_EXCEPTION_TARGET 16
894
895 /* True iff there is a jump to this location (and it needs a label). */
896 #define BCODE_TARGET \
897   (BCODE_JUMP_TARGET|BCODE_RETURN_TARGET \
898    | BCODE_EXCEPTION_TARGET)
899
900 /* True iff there is an entry in the linenumber table for this location. */
901 #define BCODE_HAS_LINENUMBER 32
902
903 /* True iff there is more than one entry in the linenumber table for
904    this location.  (This probably does not make much sense.)  */
905 #define BCODE_HAS_MULTI_LINENUMBERS 64
906
907 /* True if this instruction has been verified. */
908 #define BCODE_VERIFIED 8
909
910 /* A pointer to the line number table of the current method. */
911 extern const unsigned char *linenumber_table;
912 /* The length (in items) of the line number table. */
913 extern int linenumber_count;
914
915 /* In type_map, means that slot is uninitialized or otherwise unusable. */
916 #define TYPE_UNKNOWN NULL_TREE
917
918 /* In type_map, means the second half of a 64-bit double or long. */
919 #define TYPE_SECOND void_type_node
920
921 /* In type_map, means the null type (i.e. type of a null reference). */ 
922 #define TYPE_NULL ptr_type_node
923
924 /* In a type map means the type the address subroutine return address. */
925 #define TYPE_RETURN_ADDR return_address_type_node
926
927 /* In a subroutine's return type map, indicates that the slot was neither
928    used nor set in the subroutine. */
929 #define TYPE_UNUSED error_mark_node
930
931 /* A array mapping variable/stack slot index to the type current
932    in that variable/stack slot.
933    TYPE_UNKNOWN, TYPE_SECOND, and TYPE_NULL are special cases. */
934 extern tree *type_map;
935
936 /* Map a stack index to the type currently in that slot. */
937 #define stack_type_map (type_map+DECL_MAX_LOCALS(current_function_decl))
938
939 /* True iff TYPE takes two variable/stack slots. */
940 #define TYPE_IS_WIDE(TYPE) \
941   ((TYPE) == double_type_node || (TYPE) == long_type_node)
942
943 /* True iif CLASS has it's access$0 method generated.  */
944 #define CLASS_ACCESS0_GENERATED_P(CLASS) TYPE_LANG_FLAG_0 (CLASS)
945
946 /* True iff TYPE is a Java array type. */
947 #define TYPE_ARRAY_P(TYPE) TYPE_LANG_FLAG_1 (TYPE)
948
949 /* If FUNCTION_TYPE or METHOD_TYPE: cache for build_java_argument_signature. */
950 #define TYPE_ARGUMENT_SIGNATURE(TYPE) TYPE_VFIELD(TYPE)
951
952 /* Given an array type, give the type of the elements. */
953 /* FIXME this use of TREE_TYPE conflicts with something or other. */
954 #define TYPE_ARRAY_ELEMENT(ATYPE) TREE_TYPE(ATYPE)
955
956 /* True if class TYPE has been loaded. */
957 #define CLASS_LOADED_P(TYPE) TYPE_LANG_FLAG_2 (TYPE)
958
959 /* True if class TYPE was defined in Java source code. */
960 #define CLASS_FROM_SOURCE_P(TYPE) TYPE_LANG_FLAG_3 (TYPE)
961
962 /* True of a RECORD_TYPE of a class/interface type (not array type) */
963 #define CLASS_P(TYPE) TYPE_LANG_FLAG_4 (TYPE)
964
965 /* True if class TYPE was defined in a Java source file compiled. */
966 #define CLASS_FROM_CURRENTLY_COMPILED_SOURCE_P(TYPE) \
967   TYPE_LANG_FLAG_5 (TYPE)
968
969 /* True if class TYPE is currently being laid out. Helps in detection
970    of inheritance cycle occuring as a side effect of performing the
971    layout of a class.  */
972 #define CLASS_BEING_LAIDOUT(TYPE) TYPE_LANG_FLAG_6 (TYPE)
973
974 /* True if class TYPE is currently being laid out. Helps in detection
975    of inheritance cycle occuring as a side effect of performing the
976    layout of a class.  */
977 #define CLASS_BEING_LAIDOUT(TYPE) TYPE_LANG_FLAG_6 (TYPE)
978
979 /* True if class TYPE has a field initializer $finit$ function */
980 #define CLASS_HAS_FINIT_P(TYPE) TYPE_FINIT_STMT_LIST (TYPE)
981
982 /* True if identifier ID was seen while processing a single type import stmt */
983 #define IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P(ID) TREE_LANG_FLAG_0 (ID)
984
985 /* True if identifier ID was seen while processing an import statement */
986 #define IS_A_CLASSFILE_NAME(ID) TREE_LANG_FLAG_1 (ID)
987
988 /* True if ID is a qualified named (contains . or /) */
989 #define QUALIFIED_P(ID) TREE_LANG_FLAG_2 (ID)
990
991 /* True if ID is an already processed import on demand */
992 #define IS_AN_IMPORT_ON_DEMAND_P(ID) TREE_LANG_FLAG_3 (ID)
993
994 /* True if ID is a command-line specified filename */
995 #define IS_A_COMMAND_LINE_FILENAME_P(ID) TREE_LANG_FLAG_4 (ID)
996
997 /* True if filename ID has already been parsed */
998 #define HAS_BEEN_ALREADY_PARSED_P(ID) TREE_LANG_FLAG_5 (ID)
999
1000 /* True if EXPR is RHS sub-tree of a compound assign expression */
1001 #define COMPOUND_ASSIGN_P(EXPR) TREE_LANG_FLAG_1 (EXPR)
1002
1003 /* True if a SWITCH_EXPR has a DEFAULT_EXPR. */
1004 #define SWITCH_HAS_DEFAULT(NODE) TREE_LANG_FLAG_3 (NODE)
1005
1006 /* True if EXPR (a WFL in that case) was created after the
1007    reduction of PRIMARY . XXX */
1008 #define PRIMARY_P(EXPR) TREE_LANG_FLAG_2 (EXPR)
1009
1010 /* True if EXPR (a MODIFY_EXPR in that case) is the result of variable
1011    initialization during its declaration */
1012 #define MODIFY_EXPR_FROM_INITIALIZATION_P(EXPR) TREE_LANG_FLAG_2 (EXPR)
1013
1014 #define CLASS_METHOD_CHECKED_P(EXPR) TREE_LANG_FLAG_2 (EXPR)
1015
1016 /* True if EXPR (a WFL in that case) resolves into an expression name */
1017 #define RESOLVE_EXPRESSION_NAME_P(WFL) TREE_LANG_FLAG_0 (WFL)
1018
1019 /* True if EXPR (a LOOP_EXPR in that case) is part of a for statement */
1020 #define FOR_LOOP_P(EXPR) TREE_LANG_FLAG_0 (EXPR)
1021
1022 /* True if NODE (a RECORD_TYPE in that case) is an anonymous class.  */
1023 #define ANONYMOUS_CLASS_P(NODE) TREE_LANG_FLAG_0 (NODE)
1024
1025 /* True if NODE (a RECORD_TYPE in that case) is a block local class.  */
1026 #define LOCAL_CLASS_P(NODE) TREE_LANG_FLAG_1 (NODE)
1027
1028 /* True if NODE (a TREE_LIST) hold a pair of argument name/type
1029    declared with the final modifier */
1030 #define ARG_FINAL_P(NODE) TREE_LANG_FLAG_0 (NODE)
1031
1032 /* True if EXPR (a WFL in that case) resolves into a package name */
1033 #define RESOLVE_PACKAGE_NAME_P(WFL) TREE_LANG_FLAG_3 (WFL)
1034
1035 /* True if EXPR (a WFL in that case) resolves into a type name */
1036 #define RESOLVE_TYPE_NAME_P(WFL) TREE_LANG_FLAG_4 (WFL)
1037
1038 /* True if STMT (a WFL in that case) holds a BREAK statement */
1039 #define IS_BREAK_STMT_P(WFL) TREE_LANG_FLAG_5 (WFL)
1040
1041 /* True if EXPR (a CALL_EXPR in that case) is a crafted StringBuffer */
1042 #define IS_CRAFTED_STRING_BUFFER_P(EXPR) TREE_LANG_FLAG_5 (EXPR)
1043
1044 /* True if EXPR (a SAVE_EXPR in that case) had its content already
1045    checked for (un)initialized local variables.  */
1046 #define IS_INIT_CHECKED(EXPR) TREE_LANG_FLAG_5 (EXPR)
1047
1048 /* If set in CALL_EXPR, the receiver is 'super'. */
1049 #define CALL_USING_SUPER(EXPR) TREE_LANG_FLAG_4 (EXPR)
1050
1051 /* True if NODE (a statement) can complete normally. */
1052 #define CAN_COMPLETE_NORMALLY(NODE) TREE_LANG_FLAG_6(NODE)
1053
1054 /* True if NODE (an IDENTIFIER) bears the name of a outer field from
1055    inner class access function.  */
1056 #define OUTER_FIELD_ACCESS_IDENTIFIER_P(NODE) TREE_LANG_FLAG_6(NODE)
1057
1058 /* Non null if NODE belongs to an inner class TYPE_DECL node.
1059    Verifies that NODE as the attributes of a decl.  */
1060 #define INNER_CLASS_DECL_P(NODE) (TYPE_NAME (TREE_TYPE (NODE)) == NODE  \
1061                                   && DECL_CONTEXT (NODE))
1062
1063 /* Non null if NODE is an top level class TYPE_DECL node: NODE isn't
1064    an inner class or NODE is a static class.  */
1065 #define TOPLEVEL_CLASS_DECL_P(NODE) (!INNER_CLASS_DECL_P (NODE)         \
1066                                      || CLASS_STATIC (NODE))
1067
1068 /* True if the class decl NODE was declared in a inner scope and is
1069    not a toplevel class */
1070 #define PURE_INNER_CLASS_DECL_P(NODE) \
1071   (INNER_CLASS_DECL_P (NODE) && !CLASS_STATIC (NODE))
1072
1073 /* Non null if NODE belongs to an inner class RECORD_TYPE node. Checks
1074    that TYPE_NAME bears a decl. An array type wouldn't.  */
1075 #define INNER_CLASS_TYPE_P(NODE) (TREE_CODE (TYPE_NAME (NODE)) == TYPE_DECL \
1076                                   && DECL_CONTEXT (TYPE_NAME (NODE)))
1077
1078 #define TOPLEVEL_CLASS_TYPE_P(NODE) (!INNER_CLASS_TYPE_P (NODE)         \
1079                                      || CLASS_STATIC (TYPE_NAME (NODE)))
1080
1081 /* True if the class type NODE was declared in a inner scope and is
1082    not a toplevel class */
1083 #define PURE_INNER_CLASS_TYPE_P(NODE) \
1084   (INNER_CLASS_TYPE_P (NODE) && !CLASS_STATIC (TYPE_NAME (NODE)))
1085
1086 /* Non null if NODE (a TYPE_DECL or a RECORD_TYPE) is an inner class.  */
1087 #define INNER_CLASS_P(NODE) (TREE_CODE (NODE) == TYPE_DECL ?                  \
1088                              INNER_CLASS_DECL_P (NODE) :                      \
1089                              (TREE_CODE (NODE) == RECORD_TYPE ?               \
1090                               INNER_CLASS_TYPE_P (NODE) :                     \
1091                               (fatal ("INNER_CLASS_P: Wrong node type"), 0)))
1092
1093 /* On a TYPE_DECL, hold the list of inner classes defined within the
1094    scope of TYPE_DECL.  */
1095 #define DECL_INNER_CLASS_LIST(NODE) DECL_INITIAL (NODE)
1096
1097 /* Add a FIELD_DECL to RECORD_TYPE RTYPE.
1098    The field has name NAME (a char*), and type FTYPE.
1099    Unless this is the first field, FIELD most hold the previous field.
1100    FIELD is set to the newly created FIELD_DECL.
1101
1102    We set DECL_ARTIFICIAL so these fields get skipped by make_class_data
1103    if compiling java.lang.Object or java.lang.Class. */
1104
1105 #define PUSH_FIELD(RTYPE, FIELD, NAME, FTYPE) \
1106 { tree tmp_field = build_decl (FIELD_DECL, get_identifier(NAME), FTYPE); \
1107   if (TYPE_FIELDS (RTYPE) == NULL_TREE) TYPE_FIELDS (RTYPE) = tmp_field; \
1108   else TREE_CHAIN(FIELD) = tmp_field; \
1109   DECL_CONTEXT (tmp_field) = RTYPE; \
1110   DECL_ARTIFICIAL (tmp_field) = 1; \
1111   FIELD = tmp_field; }
1112
1113 #define FINISH_RECORD(RTYPE) layout_type (RTYPE)
1114
1115 /* Start building a RECORD_TYPE constructor with a given TYPE in CONS. */
1116 #define START_RECORD_CONSTRUCTOR(CONS, CTYPE) { \
1117   CONS = build (CONSTRUCTOR, CTYPE, NULL_TREE, NULL_TREE);\
1118   TREE_CHAIN(CONS) = TYPE_FIELDS (CTYPE); }
1119
1120 /* Append a field initializer to CONS for the dummy field for the inherited
1121    fields.  The dummy field has the given VALUE, and the same type as the
1122    super-class.   Must be specified before calls to PUSH_FIELD_VALUE. */
1123
1124 #define PUSH_SUPER_VALUE(CONS, VALUE) {\
1125   tree field = TREE_CHAIN(CONS);\
1126   if (DECL_NAME (field) != NULL_TREE) abort();\
1127   CONSTRUCTOR_ELTS(CONS) = tree_cons (field, VALUE, CONSTRUCTOR_ELTS(CONS));\
1128   TREE_CHAIN(CONS) = TREE_CHAIN (field); }
1129
1130 /* Append a field initializer to CONS for a field with the given VALUE.
1131    NAME is a char* string used for error checking;
1132    the initializer must be specified in order. */
1133 #define PUSH_FIELD_VALUE(CONS, NAME, VALUE) {\
1134   tree field = TREE_CHAIN(CONS);\
1135   if (strcmp (IDENTIFIER_POINTER (DECL_NAME (field)), NAME) != 0) abort();\
1136   CONSTRUCTOR_ELTS(CONS) = tree_cons (field, VALUE, CONSTRUCTOR_ELTS(CONS));\
1137   TREE_CHAIN(CONS) = TREE_CHAIN (field); }
1138
1139 /* Finish creating a record CONSTRUCTOR CONS. */
1140 #define FINISH_RECORD_CONSTRUCTOR(CONS) \
1141   CONSTRUCTOR_ELTS(CONS) = nreverse (CONSTRUCTOR_ELTS(CONS))
1142
1143 /* Macros on constructors invocations.  */
1144 #define CALL_CONSTRUCTOR_P(NODE)                \
1145   (TREE_CODE (NODE) == NEW_CLASS_EXPR || CALL_EXPLICIT_CONSTRUCTOR_P (NODE))
1146
1147 #define CALL_EXPLICIT_CONSTRUCTOR_P(NODE)                               \
1148   (CALL_THIS_CONSTRUCTOR_P (NODE) || CALL_SUPER_CONSTRUCTOR_P (NODE))
1149
1150 #define CALL_THIS_CONSTRUCTOR_P(NODE)                                   \
1151   (TREE_CODE (NODE) == CALL_EXPR                                        \
1152    && EXPR_WFL_NODE (TREE_OPERAND (NODE, 0)) == this_identifier_node)
1153
1154 #define CALL_SUPER_CONSTRUCTOR_P(NODE)                                  \
1155   (TREE_CODE (NODE) == CALL_EXPR                                        \
1156    && EXPR_WFL_NODE (TREE_OPERAND (NODE, 0)) == super_identifier_node)
1157
1158 /* Using a FINALLY_EXPR node */
1159 #define FINALLY_EXPR_LABEL(NODE) TREE_OPERAND ((NODE), 0)
1160 #define FINALLY_EXPR_BLOCK(NODE) TREE_OPERAND ((NODE), 1)
1161
1162 #define BLOCK_EXPR_DECLS(NODE)  BLOCK_VARS(NODE)
1163 #define BLOCK_EXPR_BODY(NODE)   BLOCK_SUBBLOCKS(NODE)
1164
1165 #define BUILD_MONITOR_ENTER(WHERE, ARG)                         \
1166   {                                                             \
1167     (WHERE) = build (CALL_EXPR, int_type_node,                  \
1168                      build_address_of (soft_monitorenter_node), \
1169                      build_tree_list (NULL_TREE, (ARG)),        \
1170                      NULL_TREE);                                \
1171     TREE_SIDE_EFFECTS (WHERE) = 1;                              \
1172   }
1173
1174 #define BUILD_MONITOR_EXIT(WHERE, ARG)                          \
1175   {                                                             \
1176     (WHERE) = build (CALL_EXPR, int_type_node,                  \
1177                      build_address_of (soft_monitorexit_node),  \
1178                      build_tree_list (NULL_TREE, (ARG)),        \
1179                      NULL_TREE);                                \
1180     TREE_SIDE_EFFECTS (WHERE) = 1;                              \
1181   }
1182
1183 /* Non zero if TYPE is an unchecked exception */
1184 #define IS_UNCHECKED_EXCEPTION_P(TYPE)                          \
1185   (inherits_from_p ((TYPE), runtime_exception_type_node)        \
1186    || inherits_from_p ((TYPE), error_exception_type_node))
1187
1188 extern int java_error_count;                                    \
1189
1190 /* Make the current function where this macro is invoked report error
1191    messages and and return, if any */
1192 #define java_parse_abort_on_error()                                     \
1193   {                                                                     \
1194      if (java_error_count > save_error_count)                           \
1195        return;                                                          \
1196    }
1197
1198 /* These are the possible values for the `state' field of the class
1199    structure.  This must be kept in sync with libgcj.  */
1200 enum
1201 {
1202   JV_STATE_NOTHING = 0,         /* Set by compiler.  */
1203
1204   JV_STATE_PRELOADING = 1,      /* Can do _Jv_FindClass.  */
1205   JV_STATE_LOADING = 3,         /* Has super installed.  */
1206   JV_STATE_LOADED = 5,          /* Is complete.  */
1207
1208   JV_STATE_COMPILED = 6,        /* This was a compiled class.  */
1209
1210   JV_STATE_PREPARED = 7,        /* Layout & static init done.  */
1211   JV_STATE_LINKED = 9,          /* Strings interned.  */
1212
1213   JV_STATE_IN_PROGRESS = 10,    /* <Clinit> running.  */
1214   JV_STATE_DONE = 12,
1215
1216   JV_STATE_ERROR = 14           /* must be last.  */
1217 };
1218
1219 #undef DEBUG_JAVA_BINDING_LEVELS