OSDN Git Service

[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 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 /* Java language-specific tree codes.  */
29 #define DEFTREECODE(SYM, NAME, TYPE, LENGTH) SYM,
30 enum java_tree_code {
31   __DUMMY = LAST_AND_UNUSED_TREE_CODE,
32 #include "java-tree.def"
33   LAST_JAVA_TREE_CODE
34 };
35 #undef DEFTREECODE
36
37 struct JCF;
38
39 /* Usage of TREE_LANG_FLAG_?:
40    0: IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P (in IDENTIFIER_NODE)
41       RESOLVE_EXPRESSION_NAME_P (in EXPR_WITH_FILE_LOCATION)
42       IS_FOR_LOOP_P (in LOOP_EXPR)
43    1: CLASS_HAS_SUPER_FLAG (in TREE_VEC).
44       IS_A_CLASSFILE_NAME (in IDENTIFIER_NODE)
45       COMPOUND_ASSIGN_P (in EXPR (binop_*))
46    2: RETURN_MAP_ADJUSTED (in TREE_VEC).
47       QUALIFIED_P (in IDENTIFIER_NODE)
48       PRIMARY_P (in EXPR_WITH_FILE_LOCATION)
49       MODIFY_EXPR_FROM_INITIALIZATION_P (in MODIFY_EXPR)
50    3: IS_AN_IMPORT_ON_DEMAND_P (in IDENTIFIER_NODE)
51       RESOLVE_PACKAGE_NAME_P (in EXPR_WITH_FILE_LOCATION)
52       SWITCH_HAS_DEFAULT (in SWITCH_EXPR)
53    4: IS_A_COMMAND_LINE_FILENAME_P (in IDENTIFIER_NODE)
54       RESOLVE_TYPE_NAME_P (in EXPR_WITH_FILE_LOCATION)
55       CALL_USING_SUPER (in CALL_EXPR)
56    5: HAS_BEEN_ALREADY_PARSED_P (in IDENTIFIER_NODE)
57       IS_BREAK_STMT_P (in EXPR_WITH_FILE_LOCATION)
58       IS_CRAFTED_STRING_BUFFER_P (in CALL_EXPR)
59    6: CAN_COMPLETE_NORMALLY (in statement nodes).
60
61    Usage of TYPE_LANG_FLAG_?:
62    1: TYPE_ARRAY_P (in RECORD_TYPE).
63    2: CLASS_LOADED_P (in RECORD_TYPE).
64    3: CLASS_FROM_SOURCE_P (in RECORD_TYPE).
65    4: CLASS_P (in RECORD_TYPE).
66    5: CLASS_FROM_CURRENTLY_COMPILED_SOURCE_P (in RECORD_TYPE)
67    6: CLASS_HAS_FINIT_P (in RECORD_TYPE)
68
69    Usage of DECL_LANG_FLAG_?:
70    0: METHOD_DEPRECATED (in FUNCTION_DECL).
71       FIELD_DEPRECATED (in FIELD_DECL).
72       CLASS_DEPRECATED (in TYPE_DECL).
73    1: METHOD_PUBLIC (in FUNCTION_DECL).
74       FIELD_PUBLIC (in FIELD_DECL).
75       CLASS_PUBLIC (in TYPE_DECL).
76    2: METHOD_STATIC (in FUNCTION_DECL).
77       (But note that FIELD_STATIC uses TREE_STATIC!)
78       CLASS_COMPLETE_P (in TYPE_DECL)
79    3: METHOD_FINAL (in FUNCTION_DECL)
80       FIELD_FINAL (in FIELD_DECL)
81       CLASS_FINAL (in TYPE_DECL)
82    4: METHOD_SYNCHRONIZED (in FUNCTION_DECL).
83       LABEL_IN_SUBR (in LABEL_DECL)
84       CLASS_INTERFACE (in TYPE_DECL)
85       FIELD_VOLATILE (int FIELD_DECL)
86    5: METHOD_ABSTRACT (in FUNCTION_DECL).
87       LABEL_IS_SUBR_START (in LABEL_DECL)
88       CLASS_ABSTRACT (in TYPE_DECL)
89       FIELD_TRANSIENT (in FIELD_DECL)
90    6: METHOD_TRANSIENT (in FUNCTION_DECL)
91       LABEL_CHANGED (in LABEL_DECL)
92       CLASS_SUPER (in TYPE_DECL, ACC_SUPER flag)
93    7: DECL_CONSTRUCTOR_P (in FUNCTION_DECL).
94 */
95
96 /* True if the class whose TYPE_BINFO this is has a superclass.
97    (True of all classes except Object.) */
98 #define CLASS_HAS_SUPER_FLAG(BINFO) TREE_LANG_FLAG_1(BINFO)
99 #define CLASS_HAS_SUPER(TYPE) CLASS_HAS_SUPER_FLAG (TYPE_BINFO (TYPE))
100
101 /* Return the supertype of class TYPE, or NULL_TREE is it has none. */
102 #define CLASSTYPE_SUPER(TYPE) (CLASS_HAS_SUPER (TYPE) ? \
103   BINFO_TYPE (TREE_VEC_ELT (TYPE_BINFO_BASETYPES (TYPE), 0)) : NULL_TREE)
104
105 /* True if the class we are compiling is a .java source file;
106    false if it is a .class bytecode file. */
107 extern int compiling_from_source;
108
109 /* The class defined by the actual (main) file we are compiling. */
110 extern tree main_class;
111
112 /* The class we are currently processing. */
113 extern tree current_class;
114
115 /* List of all class DECLs seen so far.  */
116 extern tree all_class_list;
117
118 /* Nonzero if we want to automatically do array bounds checking;
119    on by default.  Use -fno-bounds-check to disable.  */
120
121 extern int flag_bounds_check;
122
123 /* Nonzero if we should make is_compiled_class always return 1 for
124    appropriate classes that we're referencing.  */
125
126 extern int flag_assume_compiled;
127
128 extern int flag_emit_class_files;
129
130 /* Turned to 1 if -Wall was encountered. See lang.c for their meanings.  */
131 extern int flag_wall;
132 extern int flag_redundant;
133 extern int flag_not_overriding;
134 extern int flag_static_local_jdk1_1;
135
136 /* The Java .class file that provides main_class;  the main input file. */
137 extern struct JCF main_jcf[1], *current_jcf;
138
139 typedef struct CPool constant_pool;
140
141 #define CONSTANT_ResolvedFlag 16
142
143 /* The cpool->data[i] for a ResolvedString points to a STRING_CST. */
144 #define CONSTANT_ResolvedString    (CONSTANT_String+CONSTANT_ResolvedFlag)
145
146 /* The cpool->data[i] for a ResolvedClass points to a RECORD_TYPE. */
147 #define CONSTANT_ResolvedClass     (CONSTANT_Class+CONSTANT_ResolvedFlag)
148
149 #define CPOOL_UTF(CPOOL, INDEX) ((tree) (CPOOL)->data[INDEX])
150
151 /* A NameAndType constant is represented as a TREE_LIST.
152    The type is the signature string (as an IDENTIFIER_NODE).  */
153
154 #define NAME_AND_TYPE_NAME(CPOOL, IDX) \
155   CPOOL_UTF(CPOOL, CPOOL_USHORT1(CPOOL, IDX))
156 #define NAME_AND_TYPE_SIGNATURE(CPOOL, IDX) \
157   CPOOL_UTF(CPOOL, CPOOL_USHORT2(CPOOL, IDX))
158
159 /* A FieldRef, MethodRef or InterfaceMethodRef constant
160    is represented as a TREE_LIST. */
161
162 #define COMPONENT_REF_CLASS_INDEX(CPOOL, IDX) CPOOL_USHORT1(CPOOL, IDX)
163 #define COMPONENT_REF_NAME_AND_TYPE(CPOOL, IDX) CPOOL_USHORT2(CPOOL, IDX)
164 #define COMPONENT_REF_NAME(CPOOL, IDX) \
165   NAME_AND_TYPE_NAME (CPOOL, COMPONENT_REF_NAME_AND_TYPE(CPOOL, IDX))
166 #define COMPONENT_REF_SIGNATURE(CPOOL, IDX) \
167   NAME_AND_TYPE_SIGNATURE (CPOOL, COMPONENT_REF_NAME_AND_TYPE(CPOOL, IDX))
168
169 /* "Promoted types" that are used for primitive types smaller
170    than int.  We could use int_type_node, but then we would lose
171    type information (such as needed for debugging). */
172 extern tree promoted_byte_type_node;
173 extern tree promoted_short_type_node;
174 extern tree promoted_char_type_node;
175 extern tree promoted_boolean_type_node;
176
177 extern tree byte_type_node;
178 extern tree short_type_node;
179 extern tree int_type_node;
180 extern tree long_type_node;
181
182 extern tree unsigned_byte_type_node;
183 extern tree unsigned_short_type_node;
184 extern tree unsigned_int_type_node;
185 extern tree unsigned_long_type_node;
186
187 extern tree boolean_type_node;
188 extern tree char_type_node;
189 extern tree float_type_node;
190 extern tree double_type_node;
191
192 extern tree object_type_node;
193 extern tree unqualified_object_id_node;
194 extern tree object_ptr_type_node;
195 extern tree string_type_node;
196 extern tree throwable_type_node;
197 extern tree runtime_exception_type_node;
198 extern tree error_exception_type_node;
199
200 extern tree byte_array_type_node;
201 extern tree short_array_type_node;
202 extern tree int_array_type_node;
203 extern tree long_array_type_node;
204 extern tree boolean_array_type_node;
205 extern tree char_array_type_node;
206 extern tree double_array_type_node;
207 extern tree float_array_type_node;
208 extern tree array_array_type_node;
209 extern tree object_array_type_node;
210 extern tree string_array_type_node;
211 extern tree TYPE_identifier_node;      /* "TYPE" */
212 extern tree init_identifier_node;      /* "<init>" */
213 extern tree clinit_identifier_node;      /* "<clinit>" */
214 extern tree finit_identifier_node;      /* "$finit$" */
215 extern tree void_signature_node;       /* "()V" */
216 extern tree length_identifier_node;  /* "length" */
217 extern tree this_identifier_node;  /* "this" */
218 extern tree super_identifier_node;  /* "super" */
219 extern tree one_elt_array_domain_type;
220 extern tree void_type_node;
221 extern tree ptr_type_node;
222 /* The type of the return address of a subroutine. */
223 extern tree return_address_type_node;
224
225 /* Nodes for boolean constants TRUE and FALSE. */
226 extern tree boolean_true_node, boolean_false_node;
227
228 /* Integer constants not declared in tree.h. */
229 extern tree long_zero_node;
230 extern tree float_zero_node;
231 extern tree double_zero_node;
232 extern tree integer_negative_one_node;
233 extern tree integer_two_node;
234 extern tree integer_four_node;
235 extern tree empty_stmt_node;
236
237 /* The type for struct methodtable. */
238 extern tree methodtable_type;
239 extern tree methodtable_ptr_type;
240
241 extern tree utf8const_type;
242 extern tree utf8const_ptr_type;
243
244 extern tree class_type_node;
245 extern tree class_ptr_type;
246 extern tree field_type_node;
247 extern tree constants_type_node;
248 extern tree dtable_type, dtable_ptr_type;
249 extern tree field_ptr_type_node;
250 extern tree field_info_union_node;
251 extern tree method_type_node;
252 extern tree method_ptr_type_node;
253 #define nativecode_ptr_type_node ptr_type_node
254
255 extern tree end_params_node;
256
257 /* References to internal libjava functions we use. */
258 extern tree alloc_object_node;
259 extern tree soft_instanceof_node;
260 extern tree soft_checkcast_node;
261 extern tree soft_initclass_node;
262 extern tree soft_newarray_node;
263 extern tree soft_anewarray_node;
264 extern tree soft_multianewarray_node;
265 extern tree soft_badarrayindex_node;
266 extern tree throw_node;
267 extern tree soft_checkarraystore_node;
268 extern tree soft_monitorenter_node;
269 extern tree soft_monitorexit_node;
270 extern tree soft_lookupinterfacemethod_node;
271 extern tree soft_fmod_node;
272 extern tree soft_exceptioninfo_call_node;
273
274 extern tree access_flags_type_node;
275
276 extern tree class_dtable_decl;
277
278 /* They need to be reset before processing each class */
279 extern struct CPool *outgoing_cpool; 
280 extern tree current_constant_pool_data_ref;
281
282 extern tree wfl_operator;
283
284 struct lang_identifier
285 {
286   struct tree_identifier ignore;
287   tree global_value, local_value;
288
289   /* If non-NULL:  An ADDR_REF to a VAR_DECL that contains
290    * the Utf8Const representation of the identifier.  */
291   tree utf8_ref;
292 };
293
294 /* Macros for access to language-specific slots in an identifier.  */
295 /* UNless specifide, each of these slots contains a DECL node or null.  */
296
297 /* This represents the value which the identifier has in the
298    file-scope namespace.  */
299 #define IDENTIFIER_GLOBAL_VALUE(NODE)   \
300   (((struct lang_identifier *)(NODE))->global_value)
301 /* This represents the value which the identifier has in the current
302    scope.  */
303 #define IDENTIFIER_LOCAL_VALUE(NODE)    \
304   (((struct lang_identifier *)(NODE))->local_value)
305
306 /* Given an identifier NODE, get the corresponding (non-handle) class.
307    For get_identifier ("java.lang.Number"), the result is
308    the struct whose DECL_ASSEMBLER_NAME is "Classjava_lang_Number". */
309 #define IDENTIFIER_CLASS_VALUE(NODE) IDENTIFIER_GLOBAL_VALUE(NODE)
310
311 /* Given an identifier NODE, get the corresponding handle class.
312    For get_identifier ("java.lang.Number"), the result is
313    the struct whose DECL_ASSEMBLER_NAME is "Hjava_lang_Number". */
314 #define IDENTIFIER_HANDLECLASS_VALUE(NODE) ???
315
316 /* Given a signature of a reference (or array) type, or a method, return the
317    corresponding type (if one has been allocated).
318    Do not use for primitive types, since they may be ambiguous.
319    (E.g. is "I" a signature or a class name?) */
320 #define IDENTIFIER_SIGNATURE_TYPE(NODE) IDENTIFIER_GLOBAL_VALUE(NODE)
321
322 /* If non-NULL:  An ADDR_REF to a VAR_DECL that contains
323    the Utf8Const representation of the identifier.  */
324 #define IDENTIFIER_UTF8_REF(NODE) \
325   (((struct lang_identifier *)(NODE))->utf8_ref)
326
327 #define IDENTIFIER_UTF8_DECL(NODE) \
328   TREE_OPERAND((((struct lang_identifier *)(NODE))->utf8_ref), 0)
329
330 /* For a FUNCTION_DECL, if we are compiling a .class file, then this is
331    the position in the .class file of the method code.
332    Specifically, this is the code itself, not the code attribute. */
333 #define DECL_CODE_OFFSET(DECL) (DECL_LANG_SPECIFIC(DECL)->code_offset)
334 /* Similarly, the length of the bytecode. */
335 #define DECL_CODE_LENGTH(DECL) (DECL_LANG_SPECIFIC(DECL)->code_length)
336 /* Similarly, the position of the LineNumberTable attribute. */
337 #define DECL_LINENUMBERS_OFFSET(DECL) \
338   (DECL_LANG_SPECIFIC(DECL)->linenumbers_offset)
339 /* Similarly, the position of the LocalVariableTable attribute
340    (following the standard attribute header). */
341 #define DECL_LOCALVARIABLES_OFFSET(DECL) \
342   (DECL_LANG_SPECIFIC(DECL)->localvariables_offset)
343
344 #define DECL_MAX_LOCALS(DECL) (DECL_LANG_SPECIFIC(DECL)->max_locals)
345 #define DECL_MAX_STACK(DECL) (DECL_LANG_SPECIFIC(DECL)->max_stack)
346 /* Number of local variable slots needed for the arguments of this function. */
347 #define DECL_ARG_SLOT_COUNT(DECL) (DECL_LANG_SPECIFIC(DECL)->arg_slot_count)
348 /* List of checked thrown exceptions, as specified with the `throws'
349    keyword */
350 #define DECL_FUNCTION_THROWS(DECL) (DECL_LANG_SPECIFIC(DECL)->throws_list)
351 /* List of other constructors of the same class that this constructor
352    calls */
353 #define DECL_CONSTRUCTOR_CALLS(DECL) \
354   (DECL_LANG_SPECIFIC(DECL)->called_constructor)
355 /* Pointer to the function's current's COMPOUND_EXPR tree (while
356    completing its body) or the function's block */
357 #define DECL_FUNCTION_BODY(DECL) (DECL_LANG_SPECIFIC(DECL)->function_decl_body)
358 /* How specific the function is (for method selection - Java source
359    code front-end */
360 #define DECL_SPECIFIC_COUNT(DECL) DECL_ARG_SLOT_COUNT(DECL)
361
362 /* In a LABEL_DECL, a TREE_VEC that saves the type_map at that point. */
363 #define LABEL_TYPE_STATE(NODE) (DECL_INITIAL (NODE))
364
365 /* In the label of a subroutine, a dummy label that records the
366    state following a merge of all the ret instructions in this subroutine. */
367 #define LABEL_RETURN_LABEL(DECL) DECL_ARGUMENTS(DECL)
368
369 /* In the label of a sub-routine, records the type state at return.
370  * A local may be TYPE_UNUSED, which means that the local is not
371  * used (stored to or loaded from) in this subroutine - at least for
372  * code that we have verified so far. */
373 #define LABEL_RETURN_TYPE_STATE(NODE) LABEL_TYPE_STATE (LABEL_RETURN_LABEL (NODE))
374
375 /* In a TREE_VEC for a LABEL_RETURN_TYPE_STATE, notes that
376    TREE_VEC_LENGTH has been adjust to the correct stack size. */
377 #define RETURN_MAP_ADJUSTED(NODE) TREE_LANG_FLAG_2(NODE)
378
379 /* In the label of a sub-routine, a chain of the return location labels. */
380 #define LABEL_RETURN_LABELS(node) DECL_RESULT (LABEL_RETURN_LABEL(node))
381
382 /* In a LABEL_DECL, the next pending label.
383    See pending_blocks in expr.c. */
384 #define LABEL_PENDING_CHAIN(NODE) DECL_RESULT(NODE)
385
386 /* In a LABEL_DECL, the corresponding bytecode program counter. */
387 #define LABEL_PC(NODE) ((NODE)->decl.saved_insns.i)
388
389 /* Used during verification to mark the label has "changed". (See JVM Spec). */
390 #define LABEL_CHANGED(NODE) DECL_LANG_FLAG_6(NODE)
391
392 /* In a LABEL_DECL, true if we have verified instructions starting here. */
393 #define LABEL_VERIFIED(NODE) (instruction_bits[LABEL_PC(NODE)]&BCODE_VERIFIED)
394
395 /* True if this code is within a subroutine (target of a jsr). */
396 #define LABEL_IN_SUBR(NODE) DECL_LANG_FLAG_4(NODE)
397 /* True if this code is the start of a subroutine (target of a jsr). */
398 #define LABEL_IS_SUBR_START(NODE) DECL_LANG_FLAG_5(NODE)
399
400 /* In a LABEL_DECL, if LABEL_IN_SUBR(NODE), points to start of subroutine. */
401 #define LABEL_SUBR_START(NODE) DECL_ABSTRACT_ORIGIN(NODE)
402
403 /* In a LABEL_DECL that has LABEL_IS_SUBR_START, this points to the start
404    of surrounding subroutine in the case of a nested subroutine,
405    and NULL_TREE otherwise. */
406 #define LABEL_SUBR_CONTEXT(NODE) DECL_CONTEXT (LABEL_RETURN_LABEL (NODE))
407
408 /* The slot number for this local variable. */
409 #define DECL_LOCAL_SLOT_NUMBER(NODE) \
410   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->slot_number)
411 /* The start (bytecode) pc for the valid range of this local variable. */
412 #define DECL_LOCAL_START_PC(NODE) \
413   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->start_pc)
414 /* The end (bytecode) pc for the valid range of this local variable. */
415 #define DECL_LOCAL_END_PC(NODE) \
416   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->end_pc)
417 /* For a VAR_DECLor PARM_DECL, used to chain decls with the same
418    slot_number in decl_map. */
419 #define DECL_LOCAL_SLOT_CHAIN(NODE) \
420   (((struct lang_decl_var*)DECL_LANG_SPECIFIC(NODE))->slot_chain)
421
422 /* DECL_LANG_SPECIFIC for FUNCTION_DECLs. */
423 struct lang_decl
424 {
425   /*  tree chain; not yet used. */
426   long code_offset;
427   int code_length;
428   long linenumbers_offset;
429   long localvariables_offset;
430   int arg_slots;
431   int max_locals, max_stack, arg_slot_count;
432   tree throws_list;             /* Exception specified by `throws' */
433   tree function_decl_body;      /* Hold all function's statements */
434   tree called_constructor;      /* When decl is a constructor, the
435                                    list of other constructor it calls. */
436 };
437
438 /* DECL_LANG_SPECIFIC for VAR_DECL and PARM_DECL. */
439 struct lang_decl_var
440 {
441   int slot_number;
442   int start_pc;
443   int end_pc;
444   tree slot_chain;
445 };
446
447 struct lang_type
448 {
449   tree signature;
450   struct JCF *jcf;
451 };
452
453 #ifdef JAVA_USE_HANDLES
454 /* TYPE_BINFO_HANDLE points from a handle-class to its corresponding
455    non-handle-class, and vice verse. */
456
457 #define BINFO_HANDLE(NODE) TREE_VEC_ELT ((NODE), 6)
458
459 /* Given a RECORD_TYPE for a handle type, return the corresponding class. */
460 #define HANDLE_TO_CLASS_TYPE(HTYPE) BINFO_HANDLE (TYPE_BINFO (HTYPE))
461
462 /* Given a RECORD_TYPE for a class, return the corresponding handle type. */
463 #define CLASS_TO_HANDLE_TYPE(TYPE) BINFO_HANDLE (TYPE_BINFO (TYPE))
464 #else
465 #define HANDLE_TO_CLASS_TYPE(HTYPE) (HTYPE)
466 #define CLASS_TO_HANDLE_TYPE(TYPE) (TYPE)
467 #endif
468
469 #define JCF_u4 unsigned long
470 #define JCF_u2 unsigned short
471
472 extern tree lookup_class PROTO ((tree));
473 extern tree lookup_java_constructor PROTO ((tree, tree));
474 extern tree lookup_java_method PROTO ((tree, tree, tree));
475 extern tree lookup_argument_method PROTO ((tree, tree, tree));
476 extern tree promote_type PROTO ((tree));
477 extern tree get_constant PROTO ((struct JCF*, int));
478 extern tree get_name_constant PROTO ((struct JCF*, int));
479 extern tree get_class_constant PROTO ((struct JCF*, int));
480 extern tree parse_signature PROTO ((struct JCF *jcf, int sig_index));
481 extern void jcf_parse PROTO ((struct JCF*));
482 extern tree add_field PROTO ((tree, tree, tree, int));
483 extern tree add_method PROTO ((tree, int, tree, tree));
484 extern tree add_method_1 PROTO ((tree, int, tree, tree));
485 extern tree make_class ();
486 extern tree push_class PROTO ((tree, tree));
487 extern tree unmangle_classname PROTO ((const char *name, int name_length));
488 extern tree parse_signature_string PROTO ((const unsigned char *, int));
489 extern tree get_type_from_signature PROTO ((tree));
490 extern void layout_class PROTO ((tree));
491 extern tree layout_class_method PROTO ((tree, tree, tree, tree));
492 extern void layout_class_methods PROTO ((tree));
493 extern tree make_class ();
494 extern tree build_class_ref PROTO ((tree));
495 extern tree build_dtable_decl PROTO ((tree));
496 extern tree build_internal_class_name PROTO ((tree));
497 extern tree build_constants_constructor ();
498 extern tree build_ref_from_constant_pool PROTO ((int));
499 extern tree build_utf8_ref PROTO ((tree));
500 extern tree ident_subst PROTO ((const char*, int,
501                                 const char*, int, int, const char*));
502 extern tree identifier_subst PROTO ((const tree,
503                                      const char *, int, int, const char *));
504 extern tree build_java_signature PROTO ((tree));
505 extern tree build_java_argument_signature PROTO ((tree));
506 extern void set_java_signature PROTO ((tree, tree));
507 extern tree build_static_field_ref PROTO ((tree));
508 extern tree build_address_of PROTO ((tree));
509 extern tree find_local_variable PROTO ((int index, tree type, int pc));
510 extern tree find_stack_slot PROTO ((int index, tree type));
511 extern tree build_prim_array_type PROTO ((tree, HOST_WIDE_INT));
512 extern tree build_java_array_type PROTO ((tree, HOST_WIDE_INT));
513 extern int is_compiled_class PROTO ((tree));
514 extern tree mangled_classname PROTO ((const char*, tree));
515 extern tree lookup_label PROTO ((int));
516 extern tree pop_type PROTO ((tree));
517 extern void pop_argument_types PROTO ((tree));
518 extern tree decode_newarray_type PROTO ((int));
519 extern tree lookup_field PROTO ((tree*, tree));
520 extern int is_array_type_p PROTO ((tree));
521 extern HOST_WIDE_INT java_array_type_length PROTO ((tree));
522 extern int read_class PROTO ((tree));
523 extern void load_class PROTO ((tree, int));
524
525 extern tree lookup_name PROTO ((tree));
526 extern tree build_known_method_ref PROTO ((tree, tree, tree, tree, tree));
527 extern tree build_class_init PROTO ((tree, tree));
528 extern tree build_invokevirtual PROTO ((tree, tree));
529 extern tree build_invokeinterface PROTO ((tree, tree, tree));
530 extern tree invoke_build_dtable PROTO ((int, tree));
531 extern tree build_field_ref PROTO ((tree, tree, tree));
532 extern void pushdecl_force_head PROTO ((tree));
533 extern tree build_java_binop PROTO ((enum tree_code, tree, tree, tree));
534 extern tree binary_numeric_promotion PROTO ((tree, tree, tree *, tree *));
535 extern tree build_java_arrayaccess PROTO ((tree, tree, tree));
536 extern tree build_newarray PROTO ((int, tree));
537 extern tree build_anewarray PROTO ((tree, tree));
538 extern tree build_new_array PROTO ((tree, tree));
539 extern tree build_java_array_length_access PROTO ((tree));
540 extern tree build_java_arraynull_check PROTO ((tree, tree, tree));
541 extern tree create_label_decl PROTO ((tree));
542 extern void push_labeled_block PROTO ((tree));
543 extern tree prepare_eh_table_type PROTO ((tree));
544 extern void java_set_exception_lang_code PROTO (());
545 extern tree generate_name PROTO ((void));
546 extern void pop_labeled_block PROTO (());
547 extern char *lang_printable_name PROTO ((tree, int));
548 extern tree maybe_add_interface PROTO ((tree, tree));
549 extern void set_super_info PROTO ((int, tree, tree, int));
550 extern int get_access_flags_from_decl PROTO ((tree));
551 extern int interface_of_p PROTO ((tree, tree));
552 extern int inherits_from_p PROTO ((tree, tree));
553 extern void complete_start_java_method PROTO ((tree));
554 extern tree build_result_decl PROTO ((tree));
555 extern void emit_handlers PROTO (());
556 extern void init_outgoing_cpool PROTO (());
557 extern void make_class_data PROTO ((tree));
558 extern void register_class PROTO (());
559 extern int alloc_name_constant PROTO ((int, tree));
560 extern void emit_register_classes PROTO (());
561 extern void lang_init_source PROTO ((int));
562 extern void write_classfile PROTO ((tree));
563 extern char *print_int_node PROTO ((tree));
564 extern void parse_error_context PVPROTO ((tree cl, const char *, ...))
565   ATTRIBUTE_PRINTF_2;
566 extern tree build_primtype_type_ref PROTO ((char *));
567 extern tree java_get_real_method_name PROTO ((tree));
568 extern void finish_class PROTO ((tree));
569 extern void java_layout_seen_class_methods PROTO (());
570 extern void check_for_initialization PROTO ((tree));
571
572 extern tree pushdecl_top_level PROTO ((tree));
573 extern int alloc_class_constant PROTO ((tree));
574 extern int unicode_mangling_length PROTO ((char *, int));
575 extern void init_expr_processing PROTO ((void));
576 extern void push_super_field PROTO ((tree, tree));
577 extern void init_class_processing PROTO ((void));
578 extern int can_widen_reference_to PROTO ((tree, tree));
579 extern int class_depth PROTO ((tree));
580 extern int verify_jvm_instructions PROTO ((struct JCF *, unsigned char *, long));
581 extern void maybe_pushlevels PROTO ((int));
582 extern void maybe_poplevels PROTO ((int));
583 extern int process_jvm_instruction PROTO ((int, unsigned char *, long));
584 extern void set_local_type PROTO ((int, tree));
585 extern int merge_type_state PROTO ((tree));
586 extern void push_type PROTO ((tree));
587 extern void load_type_state PROTO ((tree));
588 extern void add_interface PROTO ((tree, tree));
589 extern void append_gpp_mangled_classtype PROTO ((struct obstack *, char *));
590 extern void emit_unicode_mangled_name PROTO ((struct obstack *, char *, int));
591 extern tree force_evaluation_order PROTO ((tree));
592 extern int verify_constant_pool PROTO ((struct JCF *));
593 extern void start_java_method PROTO ((tree));
594 extern void end_java_method PROTO ((void));
595 extern void give_name_to_locals PROTO ((struct JCF *));
596 extern void expand_byte_code PROTO ((struct JCF *, tree));
597 extern int open_in_zip PROTO ((struct JCF *, const char *, const char *, int));
598 extern void set_constant_value PROTO ((tree, tree));
599 #ifdef jword
600 extern int find_constant1 PROTO ((struct CPool *, int, jword));
601 extern int find_constant2 PROTO ((struct CPool *, int, jword, jword));
602 #endif
603 extern int find_utf8_constant PROTO ((struct CPool *, tree));
604 extern int find_string_constant PROTO ((struct CPool *, tree));
605 extern int find_class_constant PROTO ((struct CPool *, tree));
606 extern int find_fieldref_index PROTO ((struct CPool *, tree));
607 extern int find_methodref_index PROTO ((struct CPool *, tree));
608 extern void write_constant_pool PROTO ((struct CPool *, unsigned char *, int));
609 extern int count_constant_pool_bytes PROTO ((struct CPool *));
610 extern int encode_newarray_type PROTO ((tree));
611
612 /* Access flags etc for a method (a FUNCTION_DECL): */
613
614 #define METHOD_PUBLIC(DECL) DECL_LANG_FLAG_1 (DECL)
615 #define METHOD_PRIVATE(DECL) TREE_PRIVATE (DECL)
616 #define METHOD_PROTECTED(DECL) TREE_PROTECTED (DECL)
617 #define METHOD_STATIC(DECL) DECL_LANG_FLAG_2 (DECL)
618 #define METHOD_FINAL(DECL) DECL_LANG_FLAG_3 (DECL)
619 #define METHOD_SYNCHRONIZED(DECL) DECL_LANG_FLAG_4 (DECL)
620 #define METHOD_NATIVE(DECL) DECL_EXTERNAL(DECL)
621 #define METHOD_ABSTRACT(DECL) DECL_LANG_FLAG_5 (DECL)
622 #define METHOD_TRANSIENT(DECL) DECL_LANG_FLAG_6 (DECL)
623
624 #define DECL_CONSTRUCTOR_P(DECL) DECL_LANG_FLAG_7(DECL)
625
626 /* Access flags etc for a variable/field (a FIELD_DECL): */
627
628 #define FIELD_PRIVATE(DECL) TREE_PRIVATE (DECL)
629 #define FIELD_PROTECTED(DECL) TREE_PROTECTED (DECL)
630 #define FIELD_PUBLIC(DECL) DECL_LANG_FLAG_1 (DECL)
631 #define FIELD_STATIC(DECL) TREE_STATIC (DECL)
632 #define FIELD_FINAL(DECL) DECL_LANG_FLAG_3 (DECL)
633 #define FIELD_VOLATILE(DECL) DECL_LANG_FLAG_4 (DECL)
634 #define FIELD_TRANSIENT(DECL) DECL_LANG_FLAG_5 (DECL)
635
636 /* Access flags etc for a class (a TYPE_DECL): */
637
638 #define CLASS_PUBLIC(DECL) DECL_LANG_FLAG_1 (DECL)
639 #define CLASS_FINAL(DECL) DECL_LANG_FLAG_3 (DECL)
640 #define CLASS_INTERFACE(DECL) DECL_LANG_FLAG_4 (DECL)
641 #define CLASS_ABSTRACT(DECL) DECL_LANG_FLAG_5 (DECL)
642 #define CLASS_SUPER(DECL) DECL_LANG_FLAG_6 (DECL)
643
644 /* @deprecated marker flag on methods, fields and classes */
645
646 #define METHOD_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
647 #define FIELD_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
648 #define CLASS_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
649 #define DECL_DEPRECATED(DECL) DECL_LANG_FLAG_0 (DECL)
650
651 /* The number of virtual methods in this class's dispatch table.
652  Does not include initial two dummy entries (one points to the
653  Class object, and the other is for G++ -fvtable-thunks compatibility). */
654 #define TYPE_NVIRTUALS(TYPE) TYPE_BINFO_VIRTUALS (TYPE)
655
656 /* A TREE_VEC (indexed by DECL_VINDEX) containing this class's
657    virtual methods. */
658 #define TYPE_VTABLE(TYPE) TYPE_BINFO_VTABLE(TYPE)
659
660 /* Use CLASS_LOADED_P? FIXME */
661 #define CLASS_COMPLETE_P(DECL) DECL_LANG_FLAG_2 (DECL) 
662
663 /* This maps a bytecode offset (PC) to various flags,
664    listed below (starting with BCODE_). */
665 extern char *instruction_bits;
666
667 /* True iff the byte is the start of an instruction. */
668 #define BCODE_INSTRUCTION_START 1
669
670 /* True iff there is a jump to this location. */
671 #define BCODE_JUMP_TARGET 2
672
673 /* True iff there is a return to this location.
674    (I.e. the preceedng instruction was a call.) */
675 #define BCODE_RETURN_TARGET 4
676
677 /* True iff this is the start of an exception handler. */
678 #define BCODE_EXCEPTION_TARGET 16
679
680 /* True iff there is a jump to this location (and it needs a label). */
681 #define BCODE_TARGET \
682   (BCODE_JUMP_TARGET|BCODE_RETURN_TARGET \
683    | BCODE_EXCEPTION_TARGET)
684
685 /* True iff there is an entry in the linenumber table for this location. */
686 #define BCODE_HAS_LINENUMBER 32
687
688 /* True iff there is more than one entry in the linenumber table for
689    this location.  (This probably does not make much sense.)  */
690 #define BCODE_HAS_MULTI_LINENUMBERS 64
691
692 /* True if this instruction has been verified. */
693 #define BCODE_VERIFIED 8
694
695 /* A pointer to the line number table of the current method. */
696 extern unsigned char *linenumber_table;
697 /* The length (in items) of the line number table. */
698 extern int linenumber_count;
699
700 /* In type_map, means that slot is uninitialized or otherwise unusable. */
701 #define TYPE_UNKNOWN NULL_TREE
702
703 /* In type_map, means the second half of a 64-bit double or long. */
704 #define TYPE_SECOND void_type_node
705
706 /* In type_map, means the null type (i.e. type of a null reference). */ 
707 #define TYPE_NULL ptr_type_node
708
709 /* In a type map means the type the address subroutine return address. */
710 #define TYPE_RETURN_ADDR return_address_type_node
711
712 /* In a subroutine's return type map, indicates that the slot was neither
713    used nor set in the subroutine. */
714 #define TYPE_UNUSED error_mark_node
715
716 /* A array mapping variable/stack slot index to the type current
717    in that variable/stack slot.
718    TYPE_UNKNOWN, TYPE_SECOND, and TYPE_NULL are special cases. */
719 extern tree *type_map;
720
721 /* Map a stack index to the type currently in that slot. */
722 #define stack_type_map (type_map+DECL_MAX_LOCALS(current_function_decl))
723
724 /* True iff TYPE takes two variable/stack slots. */
725 #define TYPE_IS_WIDE(TYPE) \
726   ((TYPE) == double_type_node || (TYPE) == long_type_node)
727
728 /* True iff TYPE is a Java array type. */
729 #define TYPE_ARRAY_P(TYPE) TYPE_LANG_FLAG_1 (TYPE)
730
731 /* If FUNCTION_TYPE or METHOD_TYPE: cache for build_java_argument_signature. */
732 #define TYPE_ARGUMENT_SIGNATURE(TYPE) TYPE_VFIELD(TYPE)
733
734 /* Given an array type, give the type of the elements. */
735 /* FIXME this use of TREE_TYPE conflicts with something or other. */
736 #define TYPE_ARRAY_ELEMENT(ATYPE) TREE_TYPE(ATYPE)
737
738 /* True if class TYPE has been loaded. */
739 #define CLASS_LOADED_P(TYPE) TYPE_LANG_FLAG_2 (TYPE)
740
741 /* True if class TYPE was defined in Java source code. */
742 #define CLASS_FROM_SOURCE_P(TYPE) TYPE_LANG_FLAG_3 (TYPE)
743
744 /* True of a RECORD_TYPE of a class/interface type (not array type) */
745 #define CLASS_P(TYPE) TYPE_LANG_FLAG_4 (TYPE)
746
747 /* True if class TYPE was defined in a Java source file compiled. */
748 #define CLASS_FROM_CURRENTLY_COMPILED_SOURCE_P(TYPE) \
749   TYPE_LANG_FLAG_5 (TYPE)
750
751 /* True if class TYPE has a field initializer $finit$ function */
752 #define CLASS_HAS_FINIT_P(TYPE) TYPE_LANG_FLAG_6 (TYPE)
753
754 /* True if identifier ID was seen while processing a single type import stmt */
755 #define IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P(ID) TREE_LANG_FLAG_0 (ID)
756
757 /* True if identifier ID was seen while processing an import statement */
758 #define IS_A_CLASSFILE_NAME(ID) TREE_LANG_FLAG_1 (ID)
759
760 /* True if ID is a qualified named (contains . or /) */
761 #define QUALIFIED_P(ID) TREE_LANG_FLAG_2 (ID)
762
763 /* True if ID is an already processed import on demand */
764 #define IS_AN_IMPORT_ON_DEMAND_P(ID) TREE_LANG_FLAG_3 (ID)
765
766 /* True if ID is a command-line specified filename */
767 #define IS_A_COMMAND_LINE_FILENAME_P(ID) TREE_LANG_FLAG_4 (ID)
768
769 /* True if filename ID has already been parsed */
770 #define HAS_BEEN_ALREADY_PARSED_P(ID) TREE_LANG_FLAG_5 (ID)
771
772 /* True if EXPR is RHS sub-tree of a compound assign expression */
773 #define COMPOUND_ASSIGN_P(EXPR) TREE_LANG_FLAG_1 (EXPR)
774
775 /* True if a SWITCH_EXPR has a DEFAULT_EXPR. */
776 #define SWITCH_HAS_DEFAULT(NODE) TREE_LANG_FLAG_3 (NODE)
777
778 /* True if EXPR (a WFL in that case) was created after the
779    reduction of PRIMARY . XXX */
780 #define PRIMARY_P(EXPR) TREE_LANG_FLAG_2 (EXPR)
781
782 /* True if EXPR (a MODIFY_EXPR in that case) is the result of variable
783    initialization during its declaration */
784 #define MODIFY_EXPR_FROM_INITIALIZATION_P(EXPR) TREE_LANG_FLAG_2 (EXPR)
785
786 /* True if EXPR (a WFL in that case) resolves into an expression name */
787 #define RESOLVE_EXPRESSION_NAME_P(WFL) TREE_LANG_FLAG_0 (WFL)
788
789 /* True if EXPR (a LOOP_EXPR in that case) is part of a for statement */
790 #define IS_FOR_LOOP_P(EXPR) TREE_LANG_FLAG_0 (EXPR)
791
792 /* True if EXPR (a WFL in that case) resolves into a package name */
793 #define RESOLVE_PACKAGE_NAME_P(WFL) TREE_LANG_FLAG_3 (WFL)
794
795 /* True if EXPR (a WFL in that case) resolves into a type name */
796 #define RESOLVE_TYPE_NAME_P(WFL) TREE_LANG_FLAG_4 (WFL)
797
798 /* True if STMT (a WFL in that case) holds a BREAK statement */
799 #define IS_BREAK_STMT_P(WFL) TREE_LANG_FLAG_5 (WFL)
800
801 /* True if EXPR (a CALL_EXPR in that case) is a crafted StringBuffer */
802 #define IS_CRAFTED_STRING_BUFFER_P(EXPR) TREE_LANG_FLAG_5 (EXPR)
803
804 /* If set in CALL_EXPR, the receiver is 'super'. */
805 #define CALL_USING_SUPER(EXPR) TREE_LANG_FLAG_4 (EXPR)
806
807 /* True if NODE (a statement) can complete normally. */
808 #define CAN_COMPLETE_NORMALLY(NODE) TREE_LANG_FLAG_6(NODE)
809
810 /* Add a FIELD_DECL to RECORD_TYPE RTYPE.
811    The field has name NAME (a char*), and type FTYPE.
812    Unless this is the first field, FIELD most hold the previous field.
813    FIELD is set to the newly created FIELD_DECL.
814
815    We set DECL_ARTIFICIAL so these fields get skipped by make_class_data
816    if compiling java.lang.Object or java.lang.Class. */
817
818 #define PUSH_FIELD(RTYPE, FIELD, NAME, FTYPE) \
819 { tree tmp_field = build_decl (FIELD_DECL, get_identifier(NAME), FTYPE); \
820   if (TYPE_FIELDS (RTYPE) == NULL_TREE) TYPE_FIELDS (RTYPE) = tmp_field; \
821   else TREE_CHAIN(FIELD) = tmp_field; \
822   DECL_CONTEXT (tmp_field) = RTYPE; \
823   DECL_ARTIFICIAL (tmp_field) = 1; \
824   FIELD = tmp_field; }
825
826 #define FINISH_RECORD(RTYPE) layout_type (RTYPE)
827
828 /* Start building a RECORD_TYPE constructor with a given TYPE in CONS. */
829 #define START_RECORD_CONSTRUCTOR(CONS, CTYPE) { \
830   CONS = build (CONSTRUCTOR, CTYPE, NULL_TREE, NULL_TREE);\
831   TREE_CHAIN(CONS) = TYPE_FIELDS (CTYPE); }
832
833 /* Append a field initializer to CONS for the dummy field for the inherited
834    fields.  The dummy field has the given VALUE, and the same type as the
835    super-class.   Must be specified before calls to PUSH_FIELD_VALUE. */
836
837 #define PUSH_SUPER_VALUE(CONS, VALUE) {\
838   tree field = TREE_CHAIN(CONS);\
839   if (DECL_NAME (field) != NULL_TREE) abort();\
840   CONSTRUCTOR_ELTS(CONS) = tree_cons (field, VALUE, CONSTRUCTOR_ELTS(CONS));\
841   TREE_CHAIN(CONS) = TREE_CHAIN (field); }
842
843 /* Append a field initializer to CONS for a field with the given VALUE.
844    NAME is a char* string used for error checking;
845    the initializer must be specified in order. */
846 #define PUSH_FIELD_VALUE(CONS, NAME, VALUE) {\
847   tree field = TREE_CHAIN(CONS);\
848   if (strcmp (IDENTIFIER_POINTER (DECL_NAME (field)), NAME) != 0) abort();\
849   CONSTRUCTOR_ELTS(CONS) = tree_cons (field, VALUE, CONSTRUCTOR_ELTS(CONS));\
850   TREE_CHAIN(CONS) = TREE_CHAIN (field); }
851
852 /* Finish creating a record CONSTRUCTOR CONS. */
853 #define FINISH_RECORD_CONSTRUCTOR(CONS) \
854   CONSTRUCTOR_ELTS(CONS) = nreverse (CONSTRUCTOR_ELTS(CONS))
855
856 /* Macros on constructors invocations.  */
857 #define CALL_CONSTRUCTOR_P(NODE)                \
858   (TREE_CODE (NODE) == NEW_CLASS_EXPR || CALL_EXPLICIT_CONSTRUCTOR_P (NODE))
859
860 #define CALL_EXPLICIT_CONSTRUCTOR_P(NODE)                               \
861   (CALL_THIS_CONSTRUCTOR_P (NODE) || CALL_SUPER_CONSTRUCTOR_P (NODE))
862
863 #define CALL_THIS_CONSTRUCTOR_P(NODE)                                   \
864   (TREE_CODE (NODE) == CALL_EXPR                                        \
865    && EXPR_WFL_NODE (TREE_OPERAND (NODE, 0)) == this_identifier_node)
866
867 #define CALL_SUPER_CONSTRUCTOR_P(NODE)                                  \
868   (TREE_CODE (NODE) == CALL_EXPR                                        \
869    && EXPR_WFL_NODE (TREE_OPERAND (NODE, 0)) == super_identifier_node)
870
871 /* Using a FINALLY_EXPR node */
872 #define FINALLY_EXPR_LABEL(NODE) TREE_OPERAND ((NODE), 0)
873 #define FINALLY_EXPR_BLOCK(NODE) TREE_OPERAND ((NODE), 1)
874
875 #define BLOCK_EXPR_DECLS(NODE)  BLOCK_VARS(NODE)
876 #define BLOCK_EXPR_BODY(NODE)   BLOCK_SUBBLOCKS(NODE)
877
878 #define BUILD_MONITOR_ENTER(WHERE, ARG)                         \
879   {                                                             \
880     (WHERE) = build (CALL_EXPR, int_type_node,                  \
881                      build_address_of (soft_monitorenter_node), \
882                      build_tree_list (NULL_TREE, (ARG)),        \
883                      NULL_TREE);                                \
884     TREE_SIDE_EFFECTS (WHERE) = 1;                              \
885   }
886
887 #define BUILD_MONITOR_EXIT(WHERE, ARG)                          \
888   {                                                             \
889     (WHERE) = build (CALL_EXPR, int_type_node,                  \
890                      build_address_of (soft_monitorexit_node),  \
891                      build_tree_list (NULL_TREE, (ARG)),        \
892                      NULL_TREE);                                \
893     TREE_SIDE_EFFECTS (WHERE) = 1;                              \
894   }
895
896 /* Non zero if TYPE is an unchecked exception */
897 #define IS_UNCHECKED_EXCEPTION_P(TYPE)                          \
898   (inherits_from_p ((TYPE), runtime_exception_type_node)        \
899    || inherits_from_p ((TYPE), error_exception_type_node))
900
901 extern int java_error_count;                                    \
902
903 /* Make the current function where this macro is invoked report error
904    messages and and return, if any */
905 #define java_parse_abort_on_error()                                     \
906   {                                                                     \
907      if (java_error_count > save_error_count)                           \
908        return;                                                          \
909    }