]> oss.titaniummirror.com Git - msp430-gcc.git/blobdiff - gcc/java/parse.c
Imported gcc-4.4.3
[msp430-gcc.git] / gcc / java / parse.c
diff --git a/gcc/java/parse.c b/gcc/java/parse.c
deleted file mode 100644 (file)
index e283bac..0000000
+++ /dev/null
@@ -1,19632 +0,0 @@
-/* A Bison parser, made by GNU Bison 1.875.  */
-
-/* Skeleton parser for Yacc-like parsing with Bison,
-   Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002 Free Software Foundation, Inc.
-
-   This program is free software; you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 2, or (at your option)
-   any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-
-   You should have received a copy of the GNU General Public License
-   along with this program; if not, write to the Free Software
-   Foundation, Inc., 59 Temple Place - Suite 330,
-   Boston, MA 02111-1307, USA.  */
-
-/* As a special exception, when this file is copied by Bison into a
-   Bison output file, you may use that output file without restriction.
-   This special exception was added by the Free Software Foundation
-   in version 1.24 of Bison.  */
-
-/* Written by Richard Stallman by simplifying the original so called
-   ``semantic'' parser.  */
-
-/* All symbols defined below should begin with yy or YY, to avoid
-   infringing on user name space.  This should be done even for local
-   variables, as they might otherwise be expanded by user macros.
-   There are some unavoidable exceptions within include files to
-   define necessary library symbols; they are noted "INFRINGES ON
-   USER NAME SPACE" below.  */
-
-/* Identify Bison output.  */
-#define YYBISON 1
-
-/* Skeleton name.  */
-#define YYSKELETON_NAME "yacc.c"
-
-/* Pure parsers.  */
-#define YYPURE 1
-
-/* Using locations.  */
-#define YYLSP_NEEDED 0
-
-/* If NAME_PREFIX is specified substitute the variables and functions
-   names.  */
-#define yyparse java_parse
-#define yylex   java_lex
-#define yyerror java_error
-#define yylval  java_lval
-#define yychar  java_char
-#define yydebug java_debug
-#define yynerrs java_nerrs
-
-
-/* Tokens.  */
-#ifndef YYTOKENTYPE
-# define YYTOKENTYPE
-   /* Put the tokens into the symbol table, so that GDB and other debuggers
-      know about them.  */
-   enum yytokentype {
-     PLUS_TK = 258,
-     MINUS_TK = 259,
-     MULT_TK = 260,
-     DIV_TK = 261,
-     REM_TK = 262,
-     LS_TK = 263,
-     SRS_TK = 264,
-     ZRS_TK = 265,
-     AND_TK = 266,
-     XOR_TK = 267,
-     OR_TK = 268,
-     BOOL_AND_TK = 269,
-     BOOL_OR_TK = 270,
-     EQ_TK = 271,
-     NEQ_TK = 272,
-     GT_TK = 273,
-     GTE_TK = 274,
-     LT_TK = 275,
-     LTE_TK = 276,
-     PLUS_ASSIGN_TK = 277,
-     MINUS_ASSIGN_TK = 278,
-     MULT_ASSIGN_TK = 279,
-     DIV_ASSIGN_TK = 280,
-     REM_ASSIGN_TK = 281,
-     LS_ASSIGN_TK = 282,
-     SRS_ASSIGN_TK = 283,
-     ZRS_ASSIGN_TK = 284,
-     AND_ASSIGN_TK = 285,
-     XOR_ASSIGN_TK = 286,
-     OR_ASSIGN_TK = 287,
-     PUBLIC_TK = 288,
-     PRIVATE_TK = 289,
-     PROTECTED_TK = 290,
-     STATIC_TK = 291,
-     FINAL_TK = 292,
-     SYNCHRONIZED_TK = 293,
-     VOLATILE_TK = 294,
-     TRANSIENT_TK = 295,
-     NATIVE_TK = 296,
-     PAD_TK = 297,
-     ABSTRACT_TK = 298,
-     STRICT_TK = 299,
-     MODIFIER_TK = 300,
-     DECR_TK = 301,
-     INCR_TK = 302,
-     DEFAULT_TK = 303,
-     IF_TK = 304,
-     THROW_TK = 305,
-     BOOLEAN_TK = 306,
-     DO_TK = 307,
-     IMPLEMENTS_TK = 308,
-     THROWS_TK = 309,
-     BREAK_TK = 310,
-     IMPORT_TK = 311,
-     ELSE_TK = 312,
-     INSTANCEOF_TK = 313,
-     RETURN_TK = 314,
-     VOID_TK = 315,
-     CATCH_TK = 316,
-     INTERFACE_TK = 317,
-     CASE_TK = 318,
-     EXTENDS_TK = 319,
-     FINALLY_TK = 320,
-     SUPER_TK = 321,
-     WHILE_TK = 322,
-     CLASS_TK = 323,
-     SWITCH_TK = 324,
-     CONST_TK = 325,
-     TRY_TK = 326,
-     FOR_TK = 327,
-     NEW_TK = 328,
-     CONTINUE_TK = 329,
-     GOTO_TK = 330,
-     PACKAGE_TK = 331,
-     THIS_TK = 332,
-     BYTE_TK = 333,
-     SHORT_TK = 334,
-     INT_TK = 335,
-     LONG_TK = 336,
-     CHAR_TK = 337,
-     INTEGRAL_TK = 338,
-     FLOAT_TK = 339,
-     DOUBLE_TK = 340,
-     FP_TK = 341,
-     ID_TK = 342,
-     REL_QM_TK = 343,
-     REL_CL_TK = 344,
-     NOT_TK = 345,
-     NEG_TK = 346,
-     ASSIGN_ANY_TK = 347,
-     ASSIGN_TK = 348,
-     OP_TK = 349,
-     CP_TK = 350,
-     OCB_TK = 351,
-     CCB_TK = 352,
-     OSB_TK = 353,
-     CSB_TK = 354,
-     SC_TK = 355,
-     C_TK = 356,
-     DOT_TK = 357,
-     STRING_LIT_TK = 358,
-     CHAR_LIT_TK = 359,
-     INT_LIT_TK = 360,
-     FP_LIT_TK = 361,
-     TRUE_TK = 362,
-     FALSE_TK = 363,
-     BOOL_LIT_TK = 364,
-     NULL_TK = 365
-   };
-#endif
-#define PLUS_TK 258
-#define MINUS_TK 259
-#define MULT_TK 260
-#define DIV_TK 261
-#define REM_TK 262
-#define LS_TK 263
-#define SRS_TK 264
-#define ZRS_TK 265
-#define AND_TK 266
-#define XOR_TK 267
-#define OR_TK 268
-#define BOOL_AND_TK 269
-#define BOOL_OR_TK 270
-#define EQ_TK 271
-#define NEQ_TK 272
-#define GT_TK 273
-#define GTE_TK 274
-#define LT_TK 275
-#define LTE_TK 276
-#define PLUS_ASSIGN_TK 277
-#define MINUS_ASSIGN_TK 278
-#define MULT_ASSIGN_TK 279
-#define DIV_ASSIGN_TK 280
-#define REM_ASSIGN_TK 281
-#define LS_ASSIGN_TK 282
-#define SRS_ASSIGN_TK 283
-#define ZRS_ASSIGN_TK 284
-#define AND_ASSIGN_TK 285
-#define XOR_ASSIGN_TK 286
-#define OR_ASSIGN_TK 287
-#define PUBLIC_TK 288
-#define PRIVATE_TK 289
-#define PROTECTED_TK 290
-#define STATIC_TK 291
-#define FINAL_TK 292
-#define SYNCHRONIZED_TK 293
-#define VOLATILE_TK 294
-#define TRANSIENT_TK 295
-#define NATIVE_TK 296
-#define PAD_TK 297
-#define ABSTRACT_TK 298
-#define STRICT_TK 299
-#define MODIFIER_TK 300
-#define DECR_TK 301
-#define INCR_TK 302
-#define DEFAULT_TK 303
-#define IF_TK 304
-#define THROW_TK 305
-#define BOOLEAN_TK 306
-#define DO_TK 307
-#define IMPLEMENTS_TK 308
-#define THROWS_TK 309
-#define BREAK_TK 310
-#define IMPORT_TK 311
-#define ELSE_TK 312
-#define INSTANCEOF_TK 313
-#define RETURN_TK 314
-#define VOID_TK 315
-#define CATCH_TK 316
-#define INTERFACE_TK 317
-#define CASE_TK 318
-#define EXTENDS_TK 319
-#define FINALLY_TK 320
-#define SUPER_TK 321
-#define WHILE_TK 322
-#define CLASS_TK 323
-#define SWITCH_TK 324
-#define CONST_TK 325
-#define TRY_TK 326
-#define FOR_TK 327
-#define NEW_TK 328
-#define CONTINUE_TK 329
-#define GOTO_TK 330
-#define PACKAGE_TK 331
-#define THIS_TK 332
-#define BYTE_TK 333
-#define SHORT_TK 334
-#define INT_TK 335
-#define LONG_TK 336
-#define CHAR_TK 337
-#define INTEGRAL_TK 338
-#define FLOAT_TK 339
-#define DOUBLE_TK 340
-#define FP_TK 341
-#define ID_TK 342
-#define REL_QM_TK 343
-#define REL_CL_TK 344
-#define NOT_TK 345
-#define NEG_TK 346
-#define ASSIGN_ANY_TK 347
-#define ASSIGN_TK 348
-#define OP_TK 349
-#define CP_TK 350
-#define OCB_TK 351
-#define CCB_TK 352
-#define OSB_TK 353
-#define CSB_TK 354
-#define SC_TK 355
-#define C_TK 356
-#define DOT_TK 357
-#define STRING_LIT_TK 358
-#define CHAR_LIT_TK 359
-#define INT_LIT_TK 360
-#define FP_LIT_TK 361
-#define TRUE_TK 362
-#define FALSE_TK 363
-#define BOOL_LIT_TK 364
-#define NULL_TK 365
-
-
-
-
-/* Copy the first part of user declarations.  */
-#line 48 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-
-#include "config.h"
-#include "system.h"
-#include <dirent.h>
-#include "tree.h"
-#include "rtl.h"
-#include "obstack.h"
-#include "toplev.h"
-#include "flags.h"
-#include "java-tree.h"
-#include "jcf.h"
-#include "lex.h"
-#include "parse.h"
-#include "zipfile.h"
-#include "convert.h"
-#include "buffer.h"
-#include "xref.h"
-#include "function.h"
-#include "except.h"
-#include "ggc.h"
-
-#ifndef DIR_SEPARATOR
-#define DIR_SEPARATOR '/'
-#endif
-
-/* Local function prototypes */
-static char *java_accstring_lookup PARAMS ((int));
-static void  classitf_redefinition_error PARAMS ((const char *,tree, tree, tree));
-static void  variable_redefinition_error PARAMS ((tree, tree, tree, int));
-static tree  create_class PARAMS ((int, tree, tree, tree));
-static tree  create_interface PARAMS ((int, tree, tree));
-static void  end_class_declaration PARAMS ((int));
-static tree  find_field PARAMS ((tree, tree));
-static tree lookup_field_wrapper PARAMS ((tree, tree));
-static int   duplicate_declaration_error_p PARAMS ((tree, tree, tree));
-static void  register_fields PARAMS ((int, tree, tree));
-static tree parser_qualified_classname PARAMS ((tree));
-static int  parser_check_super PARAMS ((tree, tree, tree));
-static int  parser_check_super_interface PARAMS ((tree, tree, tree));
-static void check_modifiers_consistency PARAMS ((int));
-static tree lookup_cl PARAMS ((tree));
-static tree lookup_java_method2 PARAMS ((tree, tree, int));
-static tree method_header PARAMS ((int, tree, tree, tree));
-static void fix_method_argument_names PARAMS ((tree ,tree));
-static tree method_declarator PARAMS ((tree, tree));
-static void parse_warning_context PARAMS ((tree cl, const char *msg, ...))
-  ATTRIBUTE_PRINTF_2;
-static void issue_warning_error_from_context PARAMS ((tree, const char *msg, va_list))
-  ATTRIBUTE_PRINTF (2, 0);
-static void parse_ctor_invocation_error PARAMS ((void));
-static tree parse_jdk1_1_error PARAMS ((const char *));
-static void complete_class_report_errors PARAMS ((jdep *));
-static int process_imports PARAMS ((void));
-static void read_import_dir PARAMS ((tree));
-static int find_in_imports_on_demand PARAMS ((tree, tree));
-static void find_in_imports PARAMS ((tree, tree));
-static void check_inner_class_access PARAMS ((tree, tree, tree));
-static int check_pkg_class_access PARAMS ((tree, tree, bool));
-static void register_package PARAMS ((tree));
-static tree resolve_package PARAMS ((tree, tree *, tree *));
-static tree resolve_class PARAMS ((tree, tree, tree, tree));
-static void declare_local_variables PARAMS ((int, tree, tree));
-static void dump_java_tree PARAMS ((enum tree_dump_index, tree));
-static void source_start_java_method PARAMS ((tree));
-static void source_end_java_method PARAMS ((void));
-static tree find_name_in_single_imports PARAMS ((tree));
-static void check_abstract_method_header PARAMS ((tree));
-static tree lookup_java_interface_method2 PARAMS ((tree, tree));
-static tree resolve_expression_name PARAMS ((tree, tree *));
-static tree maybe_create_class_interface_decl PARAMS ((tree, tree, tree, tree));
-static int check_class_interface_creation PARAMS ((int, int, tree, 
-                                                 tree, tree, tree));
-static tree patch_method_invocation PARAMS ((tree, tree, tree, int,
-                                           int *, tree *));
-static int breakdown_qualified PARAMS ((tree *, tree *, tree));
-static int in_same_package PARAMS ((tree, tree));
-static tree resolve_and_layout PARAMS ((tree, tree));
-static tree qualify_and_find PARAMS ((tree, tree, tree));
-static tree resolve_no_layout PARAMS ((tree, tree));
-static int invocation_mode PARAMS ((tree, int));
-static tree find_applicable_accessible_methods_list PARAMS ((int, tree, 
-                                                           tree, tree));
-static void search_applicable_methods_list PARAMS ((int, tree, tree, tree, 
-                                                  tree *, tree *));
-static tree find_most_specific_methods_list PARAMS ((tree));
-static int argument_types_convertible PARAMS ((tree, tree));
-static tree patch_invoke PARAMS ((tree, tree, tree));
-static int maybe_use_access_method PARAMS ((int, tree *, tree *));
-static tree lookup_method_invoke PARAMS ((int, tree, tree, tree, tree));
-static tree register_incomplete_type PARAMS ((int, tree, tree, tree));
-static tree check_inner_circular_reference PARAMS ((tree, tree));
-static tree check_circular_reference PARAMS ((tree));
-static tree obtain_incomplete_type PARAMS ((tree));
-static tree java_complete_lhs PARAMS ((tree));
-static tree java_complete_tree PARAMS ((tree));
-static tree maybe_generate_pre_expand_clinit PARAMS ((tree));
-static int analyze_clinit_body PARAMS ((tree, tree));
-static int maybe_yank_clinit PARAMS ((tree));
-static void start_complete_expand_method PARAMS ((tree));
-static void java_complete_expand_method PARAMS ((tree));
-static void java_expand_method_bodies PARAMS ((tree));
-static int  unresolved_type_p PARAMS ((tree, tree *));
-static void create_jdep_list PARAMS ((struct parser_ctxt *));
-static tree build_expr_block PARAMS ((tree, tree));
-static tree enter_block PARAMS ((void));
-static tree exit_block PARAMS ((void));
-static tree lookup_name_in_blocks PARAMS ((tree));
-static void maybe_absorb_scoping_blocks PARAMS ((void));
-static tree build_method_invocation PARAMS ((tree, tree));
-static tree build_new_invocation PARAMS ((tree, tree));
-static tree build_assignment PARAMS ((int, int, tree, tree));
-static tree build_binop PARAMS ((enum tree_code, int, tree, tree));
-static tree patch_assignment PARAMS ((tree, tree));
-static tree patch_binop PARAMS ((tree, tree, tree));
-static tree build_unaryop PARAMS ((int, int, tree));
-static tree build_incdec PARAMS ((int, int, tree, int));
-static tree patch_unaryop PARAMS ((tree, tree));
-static tree build_cast PARAMS ((int, tree, tree));
-static tree build_null_of_type PARAMS ((tree));
-static tree patch_cast PARAMS ((tree, tree));
-static int valid_ref_assignconv_cast_p PARAMS ((tree, tree, int));
-static int valid_builtin_assignconv_identity_widening_p PARAMS ((tree, tree));
-static int valid_cast_to_p PARAMS ((tree, tree));
-static int valid_method_invocation_conversion_p PARAMS ((tree, tree));
-static tree try_builtin_assignconv PARAMS ((tree, tree, tree));
-static tree try_reference_assignconv PARAMS ((tree, tree));
-static tree build_unresolved_array_type PARAMS ((tree));
-static int build_type_name_from_array_name PARAMS ((tree, tree *));
-static tree build_array_from_name PARAMS ((tree, tree, tree, tree *));
-static tree build_array_ref PARAMS ((int, tree, tree));
-static tree patch_array_ref PARAMS ((tree));
-static tree make_qualified_name PARAMS ((tree, tree, int));
-static tree merge_qualified_name PARAMS ((tree, tree));
-static tree make_qualified_primary PARAMS ((tree, tree, int));
-static int resolve_qualified_expression_name PARAMS ((tree, tree *, 
-                                                    tree *, tree *));
-static void qualify_ambiguous_name PARAMS ((tree));
-static tree resolve_field_access PARAMS ((tree, tree *, tree *));
-static tree build_newarray_node PARAMS ((tree, tree, int));
-static tree patch_newarray PARAMS ((tree));
-static tree resolve_type_during_patch PARAMS ((tree));
-static tree build_this PARAMS ((int));
-static tree build_wfl_wrap PARAMS ((tree, int));
-static tree build_return PARAMS ((int, tree));
-static tree patch_return PARAMS ((tree));
-static tree maybe_access_field PARAMS ((tree, tree, tree));
-static int complete_function_arguments PARAMS ((tree));
-static int check_for_static_method_reference PARAMS ((tree, tree, tree, 
-                                                     tree, tree));
-static int not_accessible_p PARAMS ((tree, tree, tree, int));
-static void check_deprecation PARAMS ((tree, tree));
-static int class_in_current_package PARAMS ((tree));
-static tree build_if_else_statement PARAMS ((int, tree, tree, tree));
-static tree patch_if_else_statement PARAMS ((tree));
-static tree add_stmt_to_compound PARAMS ((tree, tree, tree));
-static tree add_stmt_to_block PARAMS ((tree, tree, tree));
-static tree patch_exit_expr PARAMS ((tree));
-static tree build_labeled_block PARAMS ((int, tree));
-static tree finish_labeled_statement PARAMS ((tree, tree));
-static tree build_bc_statement PARAMS ((int, int, tree));
-static tree patch_bc_statement PARAMS ((tree));
-static tree patch_loop_statement PARAMS ((tree));
-static tree build_new_loop PARAMS ((tree));
-static tree build_loop_body PARAMS ((int, tree, int));
-static tree finish_loop_body PARAMS ((int, tree, tree, int));
-static tree build_debugable_stmt PARAMS ((int, tree));
-static tree finish_for_loop PARAMS ((int, tree, tree, tree));
-static tree patch_switch_statement PARAMS ((tree));
-static tree string_constant_concatenation PARAMS ((tree, tree));
-static tree build_string_concatenation PARAMS ((tree, tree));
-static tree patch_string_cst PARAMS ((tree));
-static tree patch_string PARAMS ((tree));
-static tree encapsulate_with_try_catch PARAMS ((int, tree, tree, tree));
-static tree build_try_statement PARAMS ((int, tree, tree));
-static tree build_try_finally_statement PARAMS ((int, tree, tree));
-static tree patch_try_statement PARAMS ((tree));
-static tree patch_synchronized_statement PARAMS ((tree, tree));
-static tree patch_throw_statement PARAMS ((tree, tree));
-static void check_thrown_exceptions PARAMS ((int, tree));
-static int check_thrown_exceptions_do PARAMS ((tree));
-static void purge_unchecked_exceptions PARAMS ((tree));
-static bool ctors_unchecked_throws_clause_p PARAMS ((tree));
-static void check_throws_clauses PARAMS ((tree, tree, tree));
-static void finish_method_declaration PARAMS ((tree));
-static tree build_super_invocation PARAMS ((tree));
-static int verify_constructor_circularity PARAMS ((tree, tree));
-static char *constructor_circularity_msg PARAMS ((tree, tree));
-static tree build_this_super_qualified_invocation PARAMS ((int, tree, tree,
-                                                         int, int));
-static const char *get_printable_method_name PARAMS ((tree));
-static tree patch_conditional_expr PARAMS ((tree, tree, tree));
-static tree generate_finit PARAMS ((tree));
-static tree generate_instinit PARAMS ((tree));
-static tree build_instinit_invocation PARAMS ((tree));
-static void fix_constructors PARAMS ((tree));
-static tree build_alias_initializer_parameter_list PARAMS ((int, tree,
-                                                           tree, int *));
-static tree craft_constructor PARAMS ((tree, tree));
-static int verify_constructor_super PARAMS ((tree));
-static tree create_artificial_method PARAMS ((tree, int, tree, tree, tree));
-static void start_artificial_method_body PARAMS ((tree));
-static void end_artificial_method_body PARAMS ((tree));
-static int check_method_redefinition PARAMS ((tree, tree));
-static int check_method_types_complete PARAMS ((tree));
-static void java_check_regular_methods PARAMS ((tree));
-static void java_check_abstract_methods PARAMS ((tree));
-static void unreachable_stmt_error PARAMS ((tree));
-static tree find_expr_with_wfl PARAMS ((tree));
-static void missing_return_error PARAMS ((tree));
-static tree build_new_array_init PARAMS ((int, tree));
-static tree patch_new_array_init PARAMS ((tree, tree));
-static tree maybe_build_array_element_wfl PARAMS ((tree));
-static int array_constructor_check_entry PARAMS ((tree, tree));
-static const char *purify_type_name PARAMS ((const char *));
-static tree fold_constant_for_init PARAMS ((tree, tree));
-static tree strip_out_static_field_access_decl PARAMS ((tree));
-static jdeplist *reverse_jdep_list PARAMS ((struct parser_ctxt *));
-static void static_ref_err PARAMS ((tree, tree, tree));
-static void parser_add_interface PARAMS ((tree, tree, tree));
-static void add_superinterfaces PARAMS ((tree, tree));
-static tree jdep_resolve_class PARAMS ((jdep *));
-static int note_possible_classname PARAMS ((const char *, int));
-static void java_complete_expand_classes PARAMS ((void));
-static void java_complete_expand_class PARAMS ((tree));
-static void java_complete_expand_methods PARAMS ((tree));
-static tree cut_identifier_in_qualified PARAMS ((tree));
-static tree java_stabilize_reference PARAMS ((tree));
-static tree do_unary_numeric_promotion PARAMS ((tree));
-static char * operator_string PARAMS ((tree));
-static tree do_merge_string_cste PARAMS ((tree, const char *, int, int));
-static tree merge_string_cste PARAMS ((tree, tree, int));
-static tree java_refold PARAMS ((tree));
-static int java_decl_equiv PARAMS ((tree, tree));
-static int binop_compound_p PARAMS ((enum tree_code));
-static tree search_loop PARAMS ((tree));
-static int labeled_block_contains_loop_p PARAMS ((tree, tree));
-static int check_abstract_method_definitions PARAMS ((int, tree, tree));
-static void java_check_abstract_method_definitions PARAMS ((tree));
-static void java_debug_context_do PARAMS ((int));
-static void java_parser_context_push_initialized_field PARAMS ((void));
-static void java_parser_context_pop_initialized_field PARAMS ((void));
-static tree reorder_static_initialized PARAMS ((tree));
-static void java_parser_context_suspend PARAMS ((void));
-static void java_parser_context_resume PARAMS ((void));
-static int pop_current_osb PARAMS ((struct parser_ctxt *));
-
-/* JDK 1.1 work. FIXME */
-
-static tree maybe_make_nested_class_name PARAMS ((tree));
-static void make_nested_class_name PARAMS ((tree));
-static void set_nested_class_simple_name_value PARAMS ((tree, int));
-static void link_nested_class_to_enclosing PARAMS ((void));
-static tree resolve_inner_class PARAMS ((struct hash_table *, tree, tree *,
-                                        tree *, tree));
-static tree find_as_inner_class PARAMS ((tree, tree, tree));
-static tree find_as_inner_class_do PARAMS ((tree, tree));
-static int check_inner_class_redefinition PARAMS ((tree, tree));
-
-static tree build_thisn_assign PARAMS ((void));
-static tree build_current_thisn PARAMS ((tree));
-static tree build_access_to_thisn PARAMS ((tree, tree, int));
-static tree maybe_build_thisn_access_method PARAMS ((tree));
-
-static tree build_outer_field_access PARAMS ((tree, tree));
-static tree build_outer_field_access_methods PARAMS ((tree));
-static tree build_outer_field_access_expr PARAMS ((int, tree, tree, 
-                                                 tree, tree));
-static tree build_outer_method_access_method PARAMS ((tree));
-static tree build_new_access_id PARAMS ((void));
-static tree build_outer_field_access_method PARAMS ((tree, tree, tree,
-                                                   tree, tree));
-
-static int outer_field_access_p PARAMS ((tree, tree));
-static int outer_field_expanded_access_p PARAMS ((tree, tree *, 
-                                                tree *, tree *));
-static tree outer_field_access_fix PARAMS ((tree, tree, tree));
-static tree build_incomplete_class_ref PARAMS ((int, tree));
-static tree patch_incomplete_class_ref PARAMS ((tree));
-static tree create_anonymous_class PARAMS ((int, tree));
-static void patch_anonymous_class PARAMS ((tree, tree, tree));
-static void add_inner_class_fields PARAMS ((tree, tree));
-
-static tree build_dot_class_method PARAMS ((tree));
-static tree build_dot_class_method_invocation PARAMS ((tree));
-static void create_new_parser_context PARAMS ((int));
-static void mark_parser_ctxt PARAMS ((void *));
-static tree maybe_build_class_init_for_field PARAMS ((tree, tree));
-
-static bool attach_init_test_initialization_flags PARAMS ((struct hash_entry *,
-                                                         PTR));
-static bool emit_test_initialization PARAMS ((struct hash_entry *, PTR));
-
-/* Number of error found so far. */
-int java_error_count; 
-/* Number of warning found so far. */
-int java_warning_count;
-/* Tell when not to fold, when doing xrefs */
-int do_not_fold;
-/* Cyclic inheritance report, as it can be set by layout_class */
-const char *cyclic_inheritance_report;
-/* The current parser context */
-struct parser_ctxt *ctxp;
-
-/* List of things that were analyzed for which code will be generated */
-struct parser_ctxt *ctxp_for_generation = NULL;
-
-/* binop_lookup maps token to tree_code. It is used where binary
-   operations are involved and required by the parser. RDIV_EXPR
-   covers both integral/floating point division. The code is changed
-   once the type of both operator is worked out.  */
-
-static const enum tree_code binop_lookup[19] = 
-  { 
-    PLUS_EXPR, MINUS_EXPR, MULT_EXPR, RDIV_EXPR, TRUNC_MOD_EXPR,
-    LSHIFT_EXPR, RSHIFT_EXPR, URSHIFT_EXPR, 
-    BIT_AND_EXPR, BIT_XOR_EXPR, BIT_IOR_EXPR,
-    TRUTH_ANDIF_EXPR, TRUTH_ORIF_EXPR,
-    EQ_EXPR, NE_EXPR, GT_EXPR, GE_EXPR, LT_EXPR, LE_EXPR,
-   };
-#define BINOP_LOOKUP(VALUE)                                            \
-  binop_lookup [((VALUE) - PLUS_TK) % ARRAY_SIZE (binop_lookup)]
-
-/* This is the end index for binary operators that can also be used
-   in compound assignements. */
-#define BINOP_COMPOUND_CANDIDATES 11
-
-/* The "$L" identifier we use to create labels.  */
-static tree label_id = NULL_TREE;
-
-/* The "StringBuffer" identifier used for the String `+' operator. */
-static tree wfl_string_buffer = NULL_TREE; 
-
-/* The "append" identifier used for String `+' operator.  */
-static tree wfl_append = NULL_TREE;
-
-/* The "toString" identifier used for String `+' operator. */
-static tree wfl_to_string = NULL_TREE;
-
-/* The "java.lang" import qualified name.  */
-static tree java_lang_id = NULL_TREE;
-
-/* The generated `inst$' identifier used for generated enclosing
-   instance/field access functions.  */
-static tree inst_id = NULL_TREE;
-
-/* The "java.lang.Cloneable" qualified name.  */
-static tree java_lang_cloneable = NULL_TREE;
-
-/* The "java.io.Serializable" qualified name.  */
-static tree java_io_serializable = NULL_TREE; 
-
-/* Context and flag for static blocks */
-static tree current_static_block = NULL_TREE;
-
-/* The generated `write_parm_value$' identifier.  */
-static tree wpv_id;
-
-/* The list of all packages we've seen so far */
-static tree package_list = NULL_TREE;
-/* Hold THIS for the scope of the current method decl.  */
-static tree current_this;
-
-/* Hold a list of catch clauses list. The first element of this list is
-   the list of the catch clauses of the currently analysed try block. */
-static tree currently_caught_type_list;
-
-/* This holds a linked list of all the case labels for the current
-   switch statement.  It is only used when checking to see if there
-   are duplicate labels.  FIXME: probably this should just be attached
-   to the switch itself; then it could be referenced via
-   `ctxp->current_loop'.  */
-static tree case_label_list; 
-
-static tree src_parse_roots[1];
-
-/* All classes seen from source code */
-#define gclass_list src_parse_roots[0]
-
-/* Check modifiers. If one doesn't fit, retrieve it in its declaration
-   line and point it out.  */
-/* Should point out the one that don't fit. ASCII/unicode, going
-   backward. FIXME */
-
-#define check_modifiers(__message, __value, __mask) do {       \
-  if ((__value) & ~(__mask))                                   \
-    {                                                          \
-      int i, remainder = (__value) & ~(__mask);                        \
-      for (i = 0; i <= 10; i++)                                        \
-        if ((1 << i) & remainder)                              \
-         parse_error_context (ctxp->modifier_ctx [i], (__message), \
-                              java_accstring_lookup (1 << i)); \
-    }                                                          \
-} while (0)
-
-
-
-/* Enabling traces.  */
-#ifndef YYDEBUG
-# define YYDEBUG 1
-#endif
-
-/* Enabling verbose error messages.  */
-#ifdef YYERROR_VERBOSE
-# undef YYERROR_VERBOSE
-# define YYERROR_VERBOSE 1
-#else
-# define YYERROR_VERBOSE 0
-#endif
-
-#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
-#line 446 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-typedef union YYSTYPE {
-  tree node;
-  int sub_token;
-  struct {
-    int token;
-    int location;
-  } operator;
-  int value;
-} YYSTYPE;
-/* Line 191 of yacc.c.  */
-#line 712 "p2378.c"
-# define yystype YYSTYPE /* obsolescent; will be withdrawn */
-# define YYSTYPE_IS_DECLARED 1
-# define YYSTYPE_IS_TRIVIAL 1
-#endif
-
-
-
-/* Copy the second part of user declarations.  */
-#line 456 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-
-#include "lex.c"
-
-
-/* Line 214 of yacc.c.  */
-#line 727 "p2378.c"
-
-#if ! defined (yyoverflow) || YYERROR_VERBOSE
-
-/* The parser invokes alloca or malloc; define the necessary symbols.  */
-
-# if YYSTACK_USE_ALLOCA
-#  define YYSTACK_ALLOC alloca
-# else
-#  ifndef YYSTACK_USE_ALLOCA
-#   if defined (alloca) || defined (_ALLOCA_H)
-#    define YYSTACK_ALLOC alloca
-#   else
-#    ifdef __GNUC__
-#     define YYSTACK_ALLOC __builtin_alloca
-#    endif
-#   endif
-#  endif
-# endif
-
-# ifdef YYSTACK_ALLOC
-   /* Pacify GCC's `empty if-body' warning. */
-#  define YYSTACK_FREE(Ptr) do { /* empty */; } while (0)
-# else
-#  if defined (__STDC__) || defined (__cplusplus)
-#   include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
-#   define YYSIZE_T size_t
-#  endif
-#  define YYSTACK_ALLOC malloc
-#  define YYSTACK_FREE free
-# endif
-#endif /* ! defined (yyoverflow) || YYERROR_VERBOSE */
-
-
-#if (! defined (yyoverflow) \
-     && (! defined (__cplusplus) \
-        || (YYSTYPE_IS_TRIVIAL)))
-
-/* A type that is properly aligned for any stack member.  */
-union yyalloc
-{
-  short yyss;
-  YYSTYPE yyvs;
-  };
-
-/* The size of the maximum gap between one aligned stack and the next.  */
-# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
-
-/* The size of an array large to enough to hold all stacks, each with
-   N elements.  */
-# define YYSTACK_BYTES(N) \
-     ((N) * (sizeof (short) + sizeof (YYSTYPE))                                \
-      + YYSTACK_GAP_MAXIMUM)
-
-/* Copy COUNT objects from FROM to TO.  The source and destination do
-   not overlap.  */
-# ifndef YYCOPY
-#  if 1 < __GNUC__
-#   define YYCOPY(To, From, Count) \
-      __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
-#  else
-#   define YYCOPY(To, From, Count)             \
-      do                                       \
-       {                                       \
-         register YYSIZE_T yyi;                \
-         for (yyi = 0; yyi < (Count); yyi++)   \
-           (To)[yyi] = (From)[yyi];            \
-       }                                       \
-      while (0)
-#  endif
-# endif
-
-/* Relocate STACK from its old location to the new one.  The
-   local variables YYSIZE and YYSTACKSIZE give the old and new number of
-   elements in the stack, and YYPTR gives the new location of the
-   stack.  Advance YYPTR to a properly aligned location for the next
-   stack.  */
-# define YYSTACK_RELOCATE(Stack)                                       \
-    do                                                                 \
-      {                                                                        \
-       YYSIZE_T yynewbytes;                                            \
-       YYCOPY (&yyptr->Stack, Stack, yysize);                          \
-       Stack = &yyptr->Stack;                                          \
-       yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
-       yyptr += yynewbytes / sizeof (*yyptr);                          \
-      }                                                                        \
-    while (0)
-
-#endif
-
-#if defined (__STDC__) || defined (__cplusplus)
-   typedef signed char yysigned_char;
-#else
-   typedef short yysigned_char;
-#endif
-
-/* YYFINAL -- State number of the termination state. */
-#define YYFINAL  3
-/* YYLAST -- Last index in YYTABLE.  */
-#define YYLAST   5469
-
-/* YYNTOKENS -- Number of terminals. */
-#define YYNTOKENS  111
-/* YYNNTS -- Number of nonterminals. */
-#define YYNNTS  164
-/* YYNRULES -- Number of rules. */
-#define YYNRULES  506
-/* YYNRULES -- Number of states. */
-#define YYNSTATES  778
-
-/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX.  */
-#define YYUNDEFTOK  2
-#define YYMAXUTOK   365
-
-#define YYTRANSLATE(YYX)                                               \
-  ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
-
-/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX.  */
-static const unsigned char yytranslate[] =
-{
-       0,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
-       2,     2,     2,     2,     2,     2,     1,     2,     3,     4,
-       5,     6,     7,     8,     9,    10,    11,    12,    13,    14,
-      15,    16,    17,    18,    19,    20,    21,    22,    23,    24,
-      25,    26,    27,    28,    29,    30,    31,    32,    33,    34,
-      35,    36,    37,    38,    39,    40,    41,    42,    43,    44,
-      45,    46,    47,    48,    49,    50,    51,    52,    53,    54,
-      55,    56,    57,    58,    59,    60,    61,    62,    63,    64,
-      65,    66,    67,    68,    69,    70,    71,    72,    73,    74,
-      75,    76,    77,    78,    79,    80,    81,    82,    83,    84,
-      85,    86,    87,    88,    89,    90,    91,    92,    93,    94,
-      95,    96,    97,    98,    99,   100,   101,   102,   103,   104,
-     105,   106,   107,   108,   109,   110
-};
-
-#if YYDEBUG
-/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
-   YYRHS.  */
-static const unsigned short yyprhs[] =
-{
-       0,     0,     3,     4,     7,     9,    11,    13,    15,    17,
-      19,    21,    23,    25,    27,    29,    31,    33,    35,    37,
-      39,    42,    45,    47,    49,    51,    55,    57,    58,    60,
-      62,    64,    67,    70,    73,    77,    79,    82,    84,    87,
-      91,    94,    98,   100,   102,   106,   109,   113,   119,   124,
-     130,   132,   134,   136,   138,   140,   143,   144,   152,   153,
-     160,   164,   167,   171,   176,   177,   180,   184,   187,   188,
-     191,   194,   196,   200,   204,   207,   211,   213,   216,   218,
-     220,   222,   224,   226,   228,   230,   232,   234,   238,   243,
-     245,   249,   253,   255,   259,   263,   268,   270,   274,   277,
-     281,   285,   287,   289,   290,   294,   297,   301,   305,   310,
-     315,   318,   322,   325,   329,   332,   336,   341,   345,   349,
-     353,   355,   359,   363,   366,   370,   373,   377,   379,   380,
-     383,   386,   388,   392,   396,   398,   400,   403,   405,   406,
-     410,   413,   417,   421,   426,   429,   433,   437,   442,   444,
-     449,   455,   463,   470,   472,   474,   475,   480,   481,   487,
-     488,   494,   495,   502,   506,   511,   514,   518,   521,   525,
-     528,   532,   534,   537,   539,   541,   543,   545,   547,   550,
-     553,   556,   560,   564,   569,   571,   575,   579,   582,   586,
-     588,   590,   592,   595,   597,   599,   601,   604,   607,   611,
-     613,   615,   617,   619,   621,   623,   625,   627,   629,   631,
-     633,   635,   637,   639,   641,   643,   645,   647,   649,   651,
-     653,   655,   657,   660,   663,   666,   669,   672,   675,   678,
-     681,   685,   690,   695,   701,   706,   712,   719,   727,   734,
-     736,   738,   740,   742,   744,   746,   748,   754,   757,   761,
-     766,   774,   782,   783,   787,   792,   795,   799,   805,   808,
-     812,   816,   821,   823,   826,   829,   831,   834,   838,   841,
-     844,   848,   851,   856,   859,   862,   866,   871,   874,   876,
-     884,   892,   899,   903,   909,   914,   922,   929,   932,   935,
-     939,   942,   943,   945,   947,   950,   951,   953,   955,   959,
-     963,   966,   970,   973,   977,   980,   984,   987,   991,   994,
-     998,  1001,  1005,  1009,  1012,  1016,  1022,  1028,  1031,  1036,
-    1040,  1042,  1046,  1050,  1055,  1058,  1060,  1063,  1066,  1071,
-    1074,  1078,  1083,  1086,  1089,  1091,  1093,  1095,  1097,  1101,
-    1103,  1105,  1107,  1109,  1111,  1115,  1119,  1123,  1127,  1131,
-    1135,  1139,  1143,  1147,  1153,  1158,  1160,  1165,  1171,  1177,
-    1184,  1188,  1192,  1197,  1203,  1206,  1210,  1211,  1219,  1220,
-    1227,  1231,  1235,  1237,  1241,  1245,  1249,  1253,  1258,  1263,
-    1268,  1273,  1277,  1281,  1283,  1286,  1290,  1294,  1297,  1300,
-    1304,  1308,  1312,  1316,  1319,  1323,  1328,  1334,  1341,  1347,
-    1354,  1359,  1364,  1369,  1374,  1378,  1383,  1387,  1392,  1394,
-    1396,  1398,  1400,  1403,  1406,  1408,  1410,  1413,  1415,  1418,
-    1420,  1423,  1426,  1429,  1432,  1435,  1438,  1440,  1443,  1446,
-    1448,  1451,  1454,  1460,  1465,  1470,  1476,  1481,  1484,  1490,
-    1495,  1501,  1503,  1507,  1511,  1515,  1519,  1523,  1527,  1529,
-    1533,  1537,  1541,  1545,  1547,  1551,  1555,  1559,  1563,  1567,
-    1571,  1573,  1577,  1581,  1585,  1589,  1593,  1597,  1601,  1605,
-    1609,  1613,  1615,  1619,  1623,  1627,  1631,  1633,  1637,  1641,
-    1643,  1647,  1651,  1653,  1657,  1661,  1663,  1667,  1671,  1673,
-    1677,  1681,  1683,  1689,  1694,  1698,  1704,  1706,  1708,  1712,
-    1716,  1718,  1720,  1722,  1724,  1726,  1728
-};
-
-/* YYRHS -- A `-1'-separated list of the rules' RHS. */
-static const short yyrhs[] =
-{
-     112,     0,    -1,    -1,   113,   126,    -1,   105,    -1,   106,
-      -1,   109,    -1,   104,    -1,   103,    -1,   110,    -1,   116,
-      -1,   117,    -1,    83,    -1,    86,    -1,    51,    -1,   118,
-      -1,   121,    -1,   122,    -1,   118,    -1,   118,    -1,   116,
-     245,    -1,   122,   245,    -1,   123,    -1,   124,    -1,   125,
-      -1,   122,   102,   125,    -1,    87,    -1,    -1,   129,    -1,
-     127,    -1,   128,    -1,   129,   127,    -1,   129,   128,    -1,
-     127,   128,    -1,   129,   127,   128,    -1,   130,    -1,   127,
-     130,    -1,   133,    -1,   128,   133,    -1,    76,   122,   100,
-      -1,    76,     1,    -1,    76,   122,     1,    -1,   131,    -1,
-     132,    -1,    56,   122,   100,    -1,    56,     1,    -1,    56,
-     122,     1,    -1,    56,   122,   102,     5,   100,    -1,    56,
-     122,   102,     1,    -1,    56,   122,   102,     5,     1,    -1,
-     135,    -1,   170,    -1,   193,    -1,     1,    -1,    45,    -1,
-     134,    45,    -1,    -1,   134,    68,   125,   138,   139,   136,
-     141,    -1,    -1,    68,   125,   138,   139,   137,   141,    -1,
-     134,    68,     1,    -1,    68,     1,    -1,    68,   125,     1,
-      -1,   134,    68,   125,     1,    -1,    -1,    64,   119,    -1,
-      64,   119,     1,    -1,    64,     1,    -1,    -1,    53,   140,
-      -1,    53,     1,    -1,   120,    -1,   140,   101,   120,    -1,
-     140,   101,     1,    -1,    96,    97,    -1,    96,   142,    97,
-      -1,   143,    -1,   142,   143,    -1,   144,    -1,   160,    -1,
-     162,    -1,   183,    -1,   145,    -1,   150,    -1,   135,    -1,
-     170,    -1,   193,    -1,   115,   146,   100,    -1,   134,   115,
-     146,   100,    -1,   147,    -1,   146,   101,   147,    -1,   146,
-     101,     1,    -1,   148,    -1,   148,    93,   149,    -1,   148,
-      93,     1,    -1,   148,    93,   149,     1,    -1,   125,    -1,
-     148,    98,    99,    -1,   125,     1,    -1,   148,    98,     1,
-      -1,   148,    99,     1,    -1,   273,    -1,   181,    -1,    -1,
-     152,   151,   159,    -1,   152,     1,    -1,   115,   153,   157,
-      -1,    60,   153,   157,    -1,   134,   115,   153,   157,    -1,
-     134,    60,   153,   157,    -1,   115,     1,    -1,   134,   115,
-       1,    -1,    60,     1,    -1,   134,    60,     1,    -1,   134,
-       1,    -1,   125,    94,    95,    -1,   125,    94,   154,    95,
-      -1,   153,    98,    99,    -1,   125,    94,     1,    -1,   153,
-      98,     1,    -1,   155,    -1,   154,   101,   155,    -1,   154,
-     101,     1,    -1,   115,   148,    -1,   156,   115,   148,    -1,
-     115,     1,    -1,   156,   115,     1,    -1,   134,    -1,    -1,
-      54,   158,    -1,    54,     1,    -1,   119,    -1,   158,   101,
-     119,    -1,   158,   101,     1,    -1,   183,    -1,   100,    -1,
-     161,   183,    -1,   134,    -1,    -1,   164,   163,   166,    -1,
-     165,   157,    -1,   134,   165,   157,    -1,   123,    94,    95,
-      -1,   123,    94,   154,    95,    -1,   184,   167,    -1,   184,
-     168,   167,    -1,   184,   186,   167,    -1,   184,   168,   186,
-     167,    -1,   185,    -1,   169,    94,    95,   100,    -1,   169,
-      94,   241,    95,   100,    -1,   122,   102,    66,    94,   241,
-      95,   100,    -1,   122,   102,    66,    94,    95,   100,    -1,
-      77,    -1,    66,    -1,    -1,    62,   125,   171,   176,    -1,
-      -1,   134,    62,   125,   172,   176,    -1,    -1,    62,   125,
-     175,   173,   176,    -1,    -1,   134,    62,   125,   175,   174,
-     176,    -1,    62,   125,     1,    -1,   134,    62,   125,     1,
-      -1,    64,   120,    -1,   175,   101,   120,    -1,    64,     1,
-      -1,   175,   101,     1,    -1,    96,    97,    -1,    96,   177,
-      97,    -1,   178,    -1,   177,   178,    -1,   179,    -1,   180,
-      -1,   135,    -1,   170,    -1,   145,    -1,   152,   100,    -1,
-     152,     1,    -1,    96,    97,    -1,    96,   101,    97,    -1,
-      96,   182,    97,    -1,    96,   182,   101,    97,    -1,   149,
-      -1,   182,   101,   149,    -1,   182,   101,     1,    -1,    96,
-      97,    -1,   184,   186,   185,    -1,    96,    -1,    97,    -1,
-     187,    -1,   186,   187,    -1,   188,    -1,   190,    -1,   135,
-      -1,   189,   100,    -1,   115,   146,    -1,   156,   115,   146,
-      -1,   192,    -1,   195,    -1,   199,    -1,   200,    -1,   211,
-      -1,   215,    -1,   192,    -1,   196,    -1,   201,    -1,   212,
-      -1,   216,    -1,   183,    -1,   193,    -1,   197,    -1,   202,
-      -1,   214,    -1,   222,    -1,   223,    -1,   224,    -1,   226,
-      -1,   225,    -1,   228,    -1,   100,    -1,   125,    89,    -1,
-     194,   190,    -1,   125,     1,    -1,   194,   191,    -1,   198,
-     100,    -1,     1,   100,    -1,     1,    96,    -1,     1,    97,
-      -1,   169,    94,     1,    -1,   169,    94,    95,     1,    -1,
-     169,    94,   241,     1,    -1,   169,    94,   241,    95,     1,
-      -1,   122,   102,    66,     1,    -1,   122,   102,    66,    94,
-       1,    -1,   122,   102,    66,    94,   241,     1,    -1,   122,
-     102,    66,    94,   241,    95,     1,    -1,   122,   102,    66,
-      94,    95,     1,    -1,   270,    -1,   254,    -1,   255,    -1,
-     250,    -1,   251,    -1,   247,    -1,   236,    -1,    49,    94,
-     273,    95,   190,    -1,    49,     1,    -1,    49,    94,     1,
-      -1,    49,    94,   273,     1,    -1,    49,    94,   273,    95,
-     191,    57,   190,    -1,    49,    94,   273,    95,   191,    57,
-     191,    -1,    -1,   204,   203,   205,    -1,    69,    94,   273,
-      95,    -1,    69,     1,    -1,    69,    94,     1,    -1,    69,
-      94,   273,    95,     1,    -1,    96,    97,    -1,    96,   208,
-      97,    -1,    96,   206,    97,    -1,    96,   206,   208,    97,
-      -1,   207,    -1,   206,   207,    -1,   208,   186,    -1,   209,
-      -1,   208,   209,    -1,    63,   274,    89,    -1,    48,    89,
-      -1,    63,     1,    -1,    63,   274,     1,    -1,    48,     1,
-      -1,    67,    94,   273,    95,    -1,   210,   190,    -1,    67,
-       1,    -1,    67,    94,     1,    -1,    67,    94,   273,     1,
-      -1,   210,   191,    -1,    52,    -1,   213,   190,    67,    94,
-     273,    95,   100,    -1,   218,   100,   273,   100,   220,    95,
-     190,    -1,   218,   100,   100,   220,    95,   190,    -1,   218,
-     100,     1,    -1,   218,   100,   273,   100,     1,    -1,   218,
-     100,   100,     1,    -1,   218,   100,   273,   100,   220,    95,
-     191,    -1,   218,   100,   100,   220,    95,   191,    -1,    72,
-      94,    -1,    72,     1,    -1,    72,    94,     1,    -1,   217,
-     219,    -1,    -1,   221,    -1,   189,    -1,   221,     1,    -1,
-      -1,   221,    -1,   198,    -1,   221,   101,   198,    -1,   221,
-     101,     1,    -1,    55,   100,    -1,    55,   125,   100,    -1,
-      55,     1,    -1,    55,   125,     1,    -1,    74,   100,    -1,
-      74,   125,   100,    -1,    74,     1,    -1,    74,   125,     1,
-      -1,    59,   100,    -1,    59,   273,   100,    -1,    59,     1,
-      -1,    59,   273,     1,    -1,    50,   273,   100,    -1,    50,
-       1,    -1,    50,   273,     1,    -1,   227,    94,   273,    95,
-     183,    -1,   227,    94,   273,    95,     1,    -1,   227,     1,
-      -1,   227,    94,     1,    95,    -1,   227,    94,     1,    -1,
-     134,    -1,    71,   183,   229,    -1,    71,   183,   232,    -1,
-      71,   183,   229,   232,    -1,    71,     1,    -1,   230,    -1,
-     229,   230,    -1,   231,   183,    -1,    61,    94,   155,    95,
-      -1,    61,     1,    -1,    61,    94,     1,    -1,    61,    94,
-       1,    95,    -1,    65,   183,    -1,    65,     1,    -1,   234,
-      -1,   242,    -1,   114,    -1,    77,    -1,    94,   273,    95,
-      -1,   236,    -1,   246,    -1,   247,    -1,   248,    -1,   235,
-      -1,   122,   102,    77,    -1,    94,   273,     1,    -1,   122,
-     102,     1,    -1,   116,   102,     1,    -1,    60,   102,     1,
-      -1,   122,   102,    68,    -1,   121,   102,    68,    -1,   116,
-     102,    68,    -1,    60,   102,    68,    -1,    73,   119,    94,
-     241,    95,    -1,    73,   119,    94,    95,    -1,   237,    -1,
-     240,   125,    94,    95,    -1,   240,   125,    94,    95,   141,
-      -1,   240,   125,    94,   241,    95,    -1,   240,   125,    94,
-     241,    95,   141,    -1,    73,     1,   100,    -1,    73,   119,
-       1,    -1,    73,   119,    94,     1,    -1,    73,   119,    94,
-     241,     1,    -1,   240,     1,    -1,   240,   125,     1,    -1,
-      -1,    73,   119,    94,   241,    95,   238,   141,    -1,    -1,
-      73,   119,    94,    95,   239,   141,    -1,   122,   102,    73,
-      -1,   233,   102,    73,    -1,   273,    -1,   241,   101,   273,
-      -1,   241,   101,     1,    -1,    73,   116,   243,    -1,    73,
-     118,   243,    -1,    73,   116,   243,   245,    -1,    73,   118,
-     243,   245,    -1,    73,   118,   245,   181,    -1,    73,   116,
-     245,   181,    -1,    73,     1,    99,    -1,    73,     1,    98,
-      -1,   244,    -1,   243,   244,    -1,    98,   273,    99,    -1,
-      98,   273,     1,    -1,    98,     1,    -1,    98,    99,    -1,
-     245,    98,    99,    -1,   245,    98,     1,    -1,   233,   102,
-     125,    -1,    66,   102,   125,    -1,    66,     1,    -1,   122,
-      94,    95,    -1,   122,    94,   241,    95,    -1,   233,   102,
-     125,    94,    95,    -1,   233,   102,   125,    94,   241,    95,
-      -1,    66,   102,   125,    94,    95,    -1,    66,   102,   125,
-      94,   241,    95,    -1,    66,   102,     1,    95,    -1,    66,
-     102,     1,   102,    -1,   122,    98,   273,    99,    -1,   234,
-      98,   273,    99,    -1,   122,    98,     1,    -1,   122,    98,
-     273,     1,    -1,   234,    98,     1,    -1,   234,    98,   273,
-       1,    -1,   233,    -1,   122,    -1,   250,    -1,   251,    -1,
-     249,    47,    -1,   249,    46,    -1,   254,    -1,   255,    -1,
-       3,   253,    -1,   256,    -1,     3,     1,    -1,   252,    -1,
-       4,   252,    -1,     4,     1,    -1,    47,   253,    -1,    47,
-       1,    -1,    46,   253,    -1,    46,     1,    -1,   249,    -1,
-      90,   253,    -1,    91,   253,    -1,   257,    -1,    90,     1,
-      -1,    91,     1,    -1,    94,   116,   245,    95,   253,    -1,
-      94,   116,    95,   253,    -1,    94,   273,    95,   256,    -1,
-      94,   122,   245,    95,   256,    -1,    94,   116,    98,     1,
-      -1,    94,     1,    -1,    94,   116,   245,    95,     1,    -1,
-      94,   116,    95,     1,    -1,    94,   122,   245,    95,     1,
-      -1,   253,    -1,   258,     5,   253,    -1,   258,     6,   253,
-      -1,   258,     7,   253,    -1,   258,     5,     1,    -1,   258,
-       6,     1,    -1,   258,     7,     1,    -1,   258,    -1,   259,
-       3,   258,    -1,   259,     4,   258,    -1,   259,     3,     1,
-      -1,   259,     4,     1,    -1,   259,    -1,   260,     8,   259,
-      -1,   260,     9,   259,    -1,   260,    10,   259,    -1,   260,
-       8,     1,    -1,   260,     9,     1,    -1,   260,    10,     1,
-      -1,   260,    -1,   261,    20,   260,    -1,   261,    18,   260,
-      -1,   261,    21,   260,    -1,   261,    19,   260,    -1,   261,
-      58,   117,    -1,   261,    20,     1,    -1,   261,    18,     1,
-      -1,   261,    21,     1,    -1,   261,    19,     1,    -1,   261,
-      58,     1,    -1,   261,    -1,   262,    16,   261,    -1,   262,
-      17,   261,    -1,   262,    16,     1,    -1,   262,    17,     1,
-      -1,   262,    -1,   263,    11,   262,    -1,   263,    11,     1,
-      -1,   263,    -1,   264,    12,   263,    -1,   264,    12,     1,
-      -1,   264,    -1,   265,    13,   264,    -1,   265,    13,     1,
-      -1,   265,    -1,   266,    14,   265,    -1,   266,    14,     1,
-      -1,   266,    -1,   267,    15,   266,    -1,   267,    15,     1,
-      -1,   267,    -1,   267,    88,   273,    89,   268,    -1,   267,
-      88,    89,     1,    -1,   267,    88,     1,    -1,   267,    88,
-     273,    89,     1,    -1,   268,    -1,   270,    -1,   271,   272,
-     269,    -1,   271,   272,     1,    -1,   122,    -1,   246,    -1,
-     248,    -1,    92,    -1,    93,    -1,   269,    -1,   273,    -1
-};
-
-/* YYRLINE[YYN] -- source line where rule number YYN was defined.  */
-static const unsigned short yyrline[] =
-{
-       0,   606,   606,   606,   636,   637,   638,   639,   640,   641,
-     646,   647,   651,   652,   653,   657,   658,   662,   666,   670,
-     674,   682,   694,   695,   699,   703,   708,   713,   714,   715,
-     716,   717,   718,   719,   720,   724,   728,   735,   736,   740,
-     745,   747,   752,   753,   757,   783,   785,   790,   808,   810,
-     815,   817,   819,   820,   831,   835,   852,   851,   856,   855,
-     859,   861,   863,   868,   873,   874,   876,   878,   883,   884,
-     886,   894,   899,   904,   909,   917,   928,   929,   933,   934,
-     935,   936,   947,   948,   949,   951,   953,   958,   960,   972,
-     973,   975,   980,   982,   989,   995,  1004,  1005,  1007,  1009,
-    1019,  1024,  1025,  1031,  1030,  1041,  1046,  1048,  1050,  1052,
-    1054,  1059,  1061,  1063,  1065,  1073,  1078,  1080,  1089,  1091,
-    1096,  1100,  1105,  1110,  1114,  1119,  1124,  1132,  1142,  1143,
-    1145,  1150,  1152,  1154,  1159,  1160,  1165,  1174,  1191,  1190,
-    1200,  1202,  1207,  1212,  1220,  1225,  1227,  1229,  1234,  1239,
-    1245,  1253,  1255,  1260,  1266,  1278,  1277,  1282,  1281,  1286,
-    1285,  1290,  1289,  1293,  1295,  1300,  1305,  1310,  1312,  1317,
-    1319,  1324,  1325,  1329,  1330,  1331,  1333,  1338,  1342,  1347,
-    1353,  1355,  1357,  1359,  1364,  1369,  1373,  1379,  1387,  1392,
-    1397,  1411,  1412,  1416,  1417,  1419,  1427,  1431,  1433,  1438,
-    1439,  1440,  1441,  1442,  1443,  1448,  1449,  1450,  1451,  1452,
-    1457,  1458,  1459,  1460,  1461,  1462,  1463,  1464,  1465,  1466,
-    1467,  1471,  1489,  1500,  1502,  1507,  1514,  1523,  1528,  1533,
-    1538,  1540,  1545,  1547,  1552,  1554,  1556,  1558,  1560,  1565,
-    1566,  1567,  1568,  1569,  1570,  1571,  1575,  1580,  1582,  1584,
-    1589,  1594,  1600,  1599,  1615,  1620,  1622,  1624,  1632,  1634,
-    1636,  1638,  1643,  1644,  1648,  1652,  1653,  1657,  1663,  1669,
-    1671,  1673,  1678,  1686,  1688,  1690,  1692,  1697,  1702,  1711,
-    1716,  1722,  1729,  1731,  1733,  1738,  1740,  1750,  1756,  1758,
-    1763,  1776,  1777,  1783,  1789,  1794,  1795,  1800,  1802,  1804,
-    1809,  1811,  1813,  1815,  1820,  1822,  1824,  1826,  1831,  1833,
-    1835,  1837,  1842,  1847,  1849,  1854,  1860,  1862,  1864,  1866,
-    1871,  1883,  1885,  1887,  1892,  1897,  1898,  1906,  1915,  1931,
-    1933,  1938,  1943,  1945,  1951,  1952,  1956,  1957,  1959,  1961,
-    1962,  1963,  1964,  1965,  1969,  1974,  1976,  1978,  1980,  1985,
-    1987,  1989,  1991,  1999,  2001,  2003,  2007,  2013,  2014,  2020,
-    2021,  2023,  2025,  2027,  2029,  2031,  2042,  2041,  2075,  2074,
-    2092,  2094,  2099,  2104,  2109,  2114,  2116,  2118,  2120,  2124,
-    2135,  2144,  2146,  2151,  2153,  2158,  2168,  2170,  2179,  2205,
-    2207,  2212,  2216,  2222,  2227,  2229,  2231,  2242,  2253,  2258,
-    2267,  2269,  2274,  2276,  2278,  2283,  2288,  2293,  2301,  2302,
-    2303,  2304,  2308,  2313,  2318,  2319,  2320,  2322,  2323,  2328,
-    2333,  2335,  2340,  2342,  2347,  2349,  2354,  2355,  2357,  2359,
-    2360,  2362,  2367,  2375,  2377,  2379,  2393,  2395,  2400,  2402,
-    2404,  2409,  2410,  2415,  2420,  2425,  2427,  2429,  2434,  2435,
-    2440,  2445,  2447,  2452,  2453,  2458,  2463,  2468,  2470,  2472,
-    2477,  2478,  2483,  2488,  2493,  2498,  2500,  2502,  2504,  2506,
-    2508,  2513,  2514,  2519,  2524,  2526,  2531,  2532,  2537,  2542,
-    2543,  2548,  2553,  2554,  2559,  2564,  2565,  2570,  2575,  2576,
-    2581,  2586,  2587,  2592,  2598,  2600,  2605,  2606,  2610,  2612,
-    2620,  2621,  2622,  2626,  2627,  2631,  2635
-};
-#endif
-
-#if YYDEBUG || YYERROR_VERBOSE
-/* YYTNME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
-   First, the terminals, then, starting at YYNTOKENS, nonterminals. */
-static const char *const yytname[] =
-{
-  "$end", "error", "$undefined", "PLUS_TK", "MINUS_TK", "MULT_TK", "DIV_TK", 
-  "REM_TK", "LS_TK", "SRS_TK", "ZRS_TK", "AND_TK", "XOR_TK", "OR_TK", 
-  "BOOL_AND_TK", "BOOL_OR_TK", "EQ_TK", "NEQ_TK", "GT_TK", "GTE_TK", 
-  "LT_TK", "LTE_TK", "PLUS_ASSIGN_TK", "MINUS_ASSIGN_TK", 
-  "MULT_ASSIGN_TK", "DIV_ASSIGN_TK", "REM_ASSIGN_TK", "LS_ASSIGN_TK", 
-  "SRS_ASSIGN_TK", "ZRS_ASSIGN_TK", "AND_ASSIGN_TK", "XOR_ASSIGN_TK", 
-  "OR_ASSIGN_TK", "PUBLIC_TK", "PRIVATE_TK", "PROTECTED_TK", "STATIC_TK", 
-  "FINAL_TK", "SYNCHRONIZED_TK", "VOLATILE_TK", "TRANSIENT_TK", 
-  "NATIVE_TK", "PAD_TK", "ABSTRACT_TK", "STRICT_TK", "MODIFIER_TK", 
-  "DECR_TK", "INCR_TK", "DEFAULT_TK", "IF_TK", "THROW_TK", "BOOLEAN_TK", 
-  "DO_TK", "IMPLEMENTS_TK", "THROWS_TK", "BREAK_TK", "IMPORT_TK", 
-  "ELSE_TK", "INSTANCEOF_TK", "RETURN_TK", "VOID_TK", "CATCH_TK", 
-  "INTERFACE_TK", "CASE_TK", "EXTENDS_TK", "FINALLY_TK", "SUPER_TK", 
-  "WHILE_TK", "CLASS_TK", "SWITCH_TK", "CONST_TK", "TRY_TK", "FOR_TK", 
-  "NEW_TK", "CONTINUE_TK", "GOTO_TK", "PACKAGE_TK", "THIS_TK", "BYTE_TK", 
-  "SHORT_TK", "INT_TK", "LONG_TK", "CHAR_TK", "INTEGRAL_TK", "FLOAT_TK", 
-  "DOUBLE_TK", "FP_TK", "ID_TK", "REL_QM_TK", "REL_CL_TK", "NOT_TK", 
-  "NEG_TK", "ASSIGN_ANY_TK", "ASSIGN_TK", "OP_TK", "CP_TK", "OCB_TK", 
-  "CCB_TK", "OSB_TK", "CSB_TK", "SC_TK", "C_TK", "DOT_TK", 
-  "STRING_LIT_TK", "CHAR_LIT_TK", "INT_LIT_TK", "FP_LIT_TK", "TRUE_TK", 
-  "FALSE_TK", "BOOL_LIT_TK", "NULL_TK", "$accept", "goal", "@1", 
-  "literal", "type", "primitive_type", "reference_type", 
-  "class_or_interface_type", "class_type", "interface_type", "array_type", 
-  "name", "simple_name", "qualified_name", "identifier", 
-  "compilation_unit", "import_declarations", "type_declarations", 
-  "package_declaration", "import_declaration", 
-  "single_type_import_declaration", "type_import_on_demand_declaration", 
-  "type_declaration", "modifiers", "class_declaration", "@2", "@3", 
-  "super", "interfaces", "interface_type_list", "class_body", 
-  "class_body_declarations", "class_body_declaration", 
-  "class_member_declaration", "field_declaration", "variable_declarators", 
-  "variable_declarator", "variable_declarator_id", "variable_initializer", 
-  "method_declaration", "@4", "method_header", "method_declarator", 
-  "formal_parameter_list", "formal_parameter", "final", "throws", 
-  "class_type_list", "method_body", "static_initializer", "static", 
-  "constructor_declaration", "@5", "constructor_header", 
-  "constructor_declarator", "constructor_body", "constructor_block_end", 
-  "explicit_constructor_invocation", "this_or_super", 
-  "interface_declaration", "@6", "@7", "@8", "@9", "extends_interfaces", 
-  "interface_body", "interface_member_declarations", 
-  "interface_member_declaration", "constant_declaration", 
-  "abstract_method_declaration", "array_initializer", 
-  "variable_initializers", "block", "block_begin", "block_end", 
-  "block_statements", "block_statement", 
-  "local_variable_declaration_statement", "local_variable_declaration", 
-  "statement", "statement_nsi", "statement_without_trailing_substatement", 
-  "empty_statement", "label_decl", "labeled_statement", 
-  "labeled_statement_nsi", "expression_statement", "statement_expression", 
-  "if_then_statement", "if_then_else_statement", 
-  "if_then_else_statement_nsi", "switch_statement", "@10", 
-  "switch_expression", "switch_block", "switch_block_statement_groups", 
-  "switch_block_statement_group", "switch_labels", "switch_label", 
-  "while_expression", "while_statement", "while_statement_nsi", 
-  "do_statement_begin", "do_statement", "for_statement", 
-  "for_statement_nsi", "for_header", "for_begin", "for_init", 
-  "for_update", "statement_expression_list", "break_statement", 
-  "continue_statement", "return_statement", "throw_statement", 
-  "synchronized_statement", "synchronized", "try_statement", "catches", 
-  "catch_clause", "catch_clause_parameter", "finally", "primary", 
-  "primary_no_new_array", "type_literals", 
-  "class_instance_creation_expression", "anonymous_class_creation", "@11", 
-  "@12", "something_dot_new", "argument_list", 
-  "array_creation_expression", "dim_exprs", "dim_expr", "dims", 
-  "field_access", "method_invocation", "array_access", 
-  "postfix_expression", "post_increment_expression", 
-  "post_decrement_expression", "trap_overflow_corner_case", 
-  "unary_expression", "pre_increment_expression", 
-  "pre_decrement_expression", "unary_expression_not_plus_minus", 
-  "cast_expression", "multiplicative_expression", "additive_expression", 
-  "shift_expression", "relational_expression", "equality_expression", 
-  "and_expression", "exclusive_or_expression", "inclusive_or_expression", 
-  "conditional_and_expression", "conditional_or_expression", 
-  "conditional_expression", "assignment_expression", "assignment", 
-  "left_hand_side", "assignment_operator", "expression", 
-  "constant_expression", 0
-};
-#endif
-
-# ifdef YYPRINT
-/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
-   token YYLEX-NUM.  */
-static const unsigned short yytoknum[] =
-{
-       0,   256,   257,   258,   259,   260,   261,   262,   263,   264,
-     265,   266,   267,   268,   269,   270,   271,   272,   273,   274,
-     275,   276,   277,   278,   279,   280,   281,   282,   283,   284,
-     285,   286,   287,   288,   289,   290,   291,   292,   293,   294,
-     295,   296,   297,   298,   299,   300,   301,   302,   303,   304,
-     305,   306,   307,   308,   309,   310,   311,   312,   313,   314,
-     315,   316,   317,   318,   319,   320,   321,   322,   323,   324,
-     325,   326,   327,   328,   329,   330,   331,   332,   333,   334,
-     335,   336,   337,   338,   339,   340,   341,   342,   343,   344,
-     345,   346,   347,   348,   349,   350,   351,   352,   353,   354,
-     355,   356,   357,   358,   359,   360,   361,   362,   363,   364,
-     365
-};
-# endif
-
-/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives.  */
-static const unsigned short yyr1[] =
-{
-       0,   111,   113,   112,   114,   114,   114,   114,   114,   114,
-     115,   115,   116,   116,   116,   117,   117,   118,   119,   120,
-     121,   121,   122,   122,   123,   124,   125,   126,   126,   126,
-     126,   126,   126,   126,   126,   127,   127,   128,   128,   129,
-     129,   129,   130,   130,   131,   131,   131,   132,   132,   132,
-     133,   133,   133,   133,   134,   134,   136,   135,   137,   135,
-     135,   135,   135,   135,   138,   138,   138,   138,   139,   139,
-     139,   140,   140,   140,   141,   141,   142,   142,   143,   143,
-     143,   143,   144,   144,   144,   144,   144,   145,   145,   146,
-     146,   146,   147,   147,   147,   147,   148,   148,   148,   148,
-     148,   149,   149,   151,   150,   150,   152,   152,   152,   152,
-     152,   152,   152,   152,   152,   153,   153,   153,   153,   153,
-     154,   154,   154,   155,   155,   155,   155,   156,   157,   157,
-     157,   158,   158,   158,   159,   159,   160,   161,   163,   162,
-     164,   164,   165,   165,   166,   166,   166,   166,   167,   168,
-     168,   168,   168,   169,   169,   171,   170,   172,   170,   173,
-     170,   174,   170,   170,   170,   175,   175,   175,   175,   176,
-     176,   177,   177,   178,   178,   178,   178,   179,   180,   180,
-     181,   181,   181,   181,   182,   182,   182,   183,   183,   184,
-     185,   186,   186,   187,   187,   187,   188,   189,   189,   190,
-     190,   190,   190,   190,   190,   191,   191,   191,   191,   191,
-     192,   192,   192,   192,   192,   192,   192,   192,   192,   192,
-     192,   193,   194,   195,   195,   196,   197,   197,   197,   197,
-     197,   197,   197,   197,   197,   197,   197,   197,   197,   198,
-     198,   198,   198,   198,   198,   198,   199,   199,   199,   199,
-     200,   201,   203,   202,   204,   204,   204,   204,   205,   205,
-     205,   205,   206,   206,   207,   208,   208,   209,   209,   209,
-     209,   209,   210,   211,   211,   211,   211,   212,   213,   214,
-     215,   215,   215,   215,   215,   216,   216,   217,   217,   217,
-     218,   219,   219,   219,   219,   220,   220,   221,   221,   221,
-     222,   222,   222,   222,   223,   223,   223,   223,   224,   224,
-     224,   224,   225,   225,   225,   226,   226,   226,   226,   226,
-     227,   228,   228,   228,   228,   229,   229,   230,   231,   231,
-     231,   231,   232,   232,   233,   233,   234,   234,   234,   234,
-     234,   234,   234,   234,   234,   234,   234,   234,   234,   235,
-     235,   235,   235,   236,   236,   236,   236,   236,   236,   236,
-     236,   236,   236,   236,   236,   236,   238,   237,   239,   237,
-     240,   240,   241,   241,   241,   242,   242,   242,   242,   242,
-     242,   242,   242,   243,   243,   244,   244,   244,   245,   245,
-     245,   246,   246,   246,   247,   247,   247,   247,   247,   247,
-     247,   247,   248,   248,   248,   248,   248,   248,   249,   249,
-     249,   249,   250,   251,   252,   252,   252,   252,   252,   253,
-     253,   253,   254,   254,   255,   255,   256,   256,   256,   256,
-     256,   256,   257,   257,   257,   257,   257,   257,   257,   257,
-     257,   258,   258,   258,   258,   258,   258,   258,   259,   259,
-     259,   259,   259,   260,   260,   260,   260,   260,   260,   260,
-     261,   261,   261,   261,   261,   261,   261,   261,   261,   261,
-     261,   262,   262,   262,   262,   262,   263,   263,   263,   264,
-     264,   264,   265,   265,   265,   266,   266,   266,   267,   267,
-     267,   268,   268,   268,   268,   268,   269,   269,   270,   270,
-     271,   271,   271,   272,   272,   273,   274
-};
-
-/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN.  */
-static const unsigned char yyr2[] =
-{
-       0,     2,     0,     2,     1,     1,     1,     1,     1,     1,
-       1,     1,     1,     1,     1,     1,     1,     1,     1,     1,
-       2,     2,     1,     1,     1,     3,     1,     0,     1,     1,
-       1,     2,     2,     2,     3,     1,     2,     1,     2,     3,
-       2,     3,     1,     1,     3,     2,     3,     5,     4,     5,
-       1,     1,     1,     1,     1,     2,     0,     7,     0,     6,
-       3,     2,     3,     4,     0,     2,     3,     2,     0,     2,
-       2,     1,     3,     3,     2,     3,     1,     2,     1,     1,
-       1,     1,     1,     1,     1,     1,     1,     3,     4,     1,
-       3,     3,     1,     3,     3,     4,     1,     3,     2,     3,
-       3,     1,     1,     0,     3,     2,     3,     3,     4,     4,
-       2,     3,     2,     3,     2,     3,     4,     3,     3,     3,
-       1,     3,     3,     2,     3,     2,     3,     1,     0,     2,
-       2,     1,     3,     3,     1,     1,     2,     1,     0,     3,
-       2,     3,     3,     4,     2,     3,     3,     4,     1,     4,
-       5,     7,     6,     1,     1,     0,     4,     0,     5,     0,
-       5,     0,     6,     3,     4,     2,     3,     2,     3,     2,
-       3,     1,     2,     1,     1,     1,     1,     1,     2,     2,
-       2,     3,     3,     4,     1,     3,     3,     2,     3,     1,
-       1,     1,     2,     1,     1,     1,     2,     2,     3,     1,
-       1,     1,     1,     1,     1,     1,     1,     1,     1,     1,
-       1,     1,     1,     1,     1,     1,     1,     1,     1,     1,
-       1,     1,     2,     2,     2,     2,     2,     2,     2,     2,
-       3,     4,     4,     5,     4,     5,     6,     7,     6,     1,
-       1,     1,     1,     1,     1,     1,     5,     2,     3,     4,
-       7,     7,     0,     3,     4,     2,     3,     5,     2,     3,
-       3,     4,     1,     2,     2,     1,     2,     3,     2,     2,
-       3,     2,     4,     2,     2,     3,     4,     2,     1,     7,
-       7,     6,     3,     5,     4,     7,     6,     2,     2,     3,
-       2,     0,     1,     1,     2,     0,     1,     1,     3,     3,
-       2,     3,     2,     3,     2,     3,     2,     3,     2,     3,
-       2,     3,     3,     2,     3,     5,     5,     2,     4,     3,
-       1,     3,     3,     4,     2,     1,     2,     2,     4,     2,
-       3,     4,     2,     2,     1,     1,     1,     1,     3,     1,
-       1,     1,     1,     1,     3,     3,     3,     3,     3,     3,
-       3,     3,     3,     5,     4,     1,     4,     5,     5,     6,
-       3,     3,     4,     5,     2,     3,     0,     7,     0,     6,
-       3,     3,     1,     3,     3,     3,     3,     4,     4,     4,
-       4,     3,     3,     1,     2,     3,     3,     2,     2,     3,
-       3,     3,     3,     2,     3,     4,     5,     6,     5,     6,
-       4,     4,     4,     4,     3,     4,     3,     4,     1,     1,
-       1,     1,     2,     2,     1,     1,     2,     1,     2,     1,
-       2,     2,     2,     2,     2,     2,     1,     2,     2,     1,
-       2,     2,     5,     4,     4,     5,     4,     2,     5,     4,
-       5,     1,     3,     3,     3,     3,     3,     3,     1,     3,
-       3,     3,     3,     1,     3,     3,     3,     3,     3,     3,
-       1,     3,     3,     3,     3,     3,     3,     3,     3,     3,
-       3,     1,     3,     3,     3,     3,     1,     3,     3,     1,
-       3,     3,     1,     3,     3,     1,     3,     3,     1,     3,
-       3,     1,     5,     4,     3,     5,     1,     1,     3,     3,
-       1,     1,     1,     1,     1,     1,     1
-};
-
-/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
-   STATE-NUM when YYTABLE doesn't specify something else to do.  Zero
-   means the default is an error.  */
-static const unsigned short yydefact[] =
-{
-       2,     0,     0,     1,    53,    54,     0,     0,     0,     0,
-     221,     3,     0,     0,     0,    35,    42,    43,    37,     0,
-      50,    51,    52,    45,    26,     0,    22,    23,    24,     0,
-      61,     0,    40,     0,     0,    36,    38,     0,     0,    55,
-       0,     0,    46,    44,     0,   163,     0,     0,   159,    62,
-       0,    68,    41,    39,     0,     0,     0,    60,     0,    48,
-       0,    25,   167,    19,   165,    17,     0,   156,     0,     0,
-      67,    18,     0,     0,    58,   164,     0,   161,    63,    68,
-      49,    47,    14,     0,    12,    13,   169,     0,    10,    11,
-      15,    16,    17,     0,   175,   177,     0,   176,     0,   171,
-     173,   174,   168,   166,   160,    66,    70,    71,    69,     0,
-     158,     0,    56,   112,     0,   128,   110,     0,     0,    89,
-      92,   128,     0,    20,    21,   114,     0,     0,   179,   178,
-     170,   172,     0,     0,    59,   162,     0,     0,     0,     0,
-     107,    98,    87,     0,     0,     0,     0,   106,   388,     0,
-     113,   128,   111,     0,   128,    73,    72,   189,    74,    22,
-       0,    84,     0,    76,    78,    82,    83,     0,    79,     0,
-      80,   138,   128,    85,    81,     0,    86,    57,   118,   115,
-       0,   127,     0,   120,     0,   130,   131,   129,   119,   117,
-      91,     0,    90,    94,     0,     0,     0,     0,     0,     0,
-       0,   337,     0,     0,     0,     0,     8,     7,     4,     5,
-       6,     9,   336,     0,     0,   409,     0,   102,   408,   334,
-     343,   339,   355,     0,   335,   340,   341,   342,   426,   410,
-     411,   419,   441,   414,   415,   417,   429,   448,   453,   460,
-     471,   476,   479,   482,   485,   488,   491,   496,   505,   497,
-       0,   101,    99,    97,   100,   390,   389,   109,    88,   108,
-     187,     0,   128,    75,    77,   105,     0,   136,     0,   140,
-       0,     0,     0,   278,     0,     0,     0,     0,     0,     0,
-       0,     0,   337,     0,     0,    10,    16,   409,     0,   127,
-     195,     0,     0,   210,     0,   191,   193,     0,   194,   199,
-     211,     0,   200,   212,     0,   201,   202,   213,   252,     0,
-     203,     0,   214,   204,   291,     0,   215,   216,   217,   219,
-     218,     0,   220,   245,   244,     0,   242,   243,   240,   241,
-     239,   125,   123,   116,     0,     0,     0,   418,   409,   340,
-     342,   416,   421,   420,   425,   424,   423,   422,     0,   393,
-       0,     0,     0,    18,     0,   430,   427,   431,   428,   437,
-       0,   409,     0,   180,     0,   184,     0,     0,     0,     0,
-       0,     0,    95,     0,     0,   364,     0,   413,   412,     0,
-       0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
-       0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
-     503,   504,     0,   142,     0,   141,   135,   104,   134,   189,
-     139,     0,   228,   229,   227,   247,     0,   313,     0,   302,
-     300,     0,   310,   308,     0,   274,     0,   255,     0,   324,
-       0,   288,     0,   306,   304,     0,     0,   197,     0,   224,
-     222,     0,     0,   190,   188,   192,   196,   409,   320,   223,
-     226,     0,   273,     0,   409,   293,   297,   290,     0,     0,
-     317,     0,   122,   121,   126,   124,   133,   132,   348,   352,
-       0,   392,   382,   381,   360,     0,   375,   383,     0,   376,
-       0,   361,     0,     0,     0,    20,    21,   345,   338,   181,
-     182,     0,   347,   351,   350,   394,     0,   372,   404,     0,
-     346,   349,   370,   344,   371,   391,   406,     0,   365,     0,
-     445,   442,   446,   443,   447,   444,   451,   449,   452,   450,
-     457,   454,   458,   455,   459,   456,   467,   462,   469,   464,
-     466,   461,   468,   463,   470,     0,   465,   474,   472,   475,
-     473,   478,   477,   481,   480,   484,   483,   487,   486,   490,
-     489,   494,     0,     0,   499,   498,   143,   409,   144,     0,
-       0,   148,     0,   248,     0,   314,   312,   303,   301,   311,
-     309,   275,     0,   256,     0,     0,     0,   321,   325,     0,
-     322,   289,   307,   305,   338,     0,   198,   230,     0,     0,
-       0,   253,     0,   294,     0,   282,     0,     0,   319,     0,
-     400,   401,     0,   387,     0,   384,   377,   380,   378,   379,
-     362,   354,     0,   439,   433,   436,     0,     0,   434,   186,
-     183,   185,   395,     0,   405,   402,     0,   407,   403,   356,
-       0,   493,     0,     0,   145,     0,     0,   146,   249,     0,
-     276,   272,     0,   329,     0,   333,   332,   326,   323,   327,
-     234,     0,   231,   232,     0,     0,     0,   258,     0,   262,
-       0,   265,     0,   299,   298,   284,     0,   296,     0,   318,
-       0,   398,     0,   386,   385,     0,   363,   353,   438,   432,
-     440,   435,   374,   373,   396,     0,   357,   358,   495,   492,
-       0,   147,     0,     0,     0,   246,     0,   199,     0,   206,
-     207,     0,   208,   209,     0,   257,   330,     0,   235,     0,
-       0,   233,   271,   268,   269,   506,     0,   260,   263,     0,
-     259,     0,   266,     0,     0,   283,     0,   316,   315,   399,
-     369,     0,   397,   359,     0,   149,     0,     0,     0,   225,
-     277,     0,   331,   328,   238,   236,     0,   270,   267,   261,
-       0,   281,     0,   367,     0,     0,   150,     0,   250,     0,
-       0,   237,   279,   280,   152,     0,     0,     0,     0,   151,
-       0,     0,     0,     0,   286,     0,   251,   285
-};
-
-/* YYDEFGOTO[NTERM-NUM]. */
-static const short yydefgoto[] =
-{
-      -1,     1,     2,   212,   284,   213,    89,    90,    72,    64,
-     214,   215,    26,    27,    28,    11,    12,    13,    14,    15,
-      16,    17,    18,   448,   290,   136,   109,    51,    74,   108,
-     134,   162,   163,   164,    95,   118,   119,   120,   216,   166,
-     266,    96,   115,   182,   183,   291,   140,   187,   407,   168,
-     169,   170,   268,   171,   172,   410,   558,   559,   292,    21,
-      47,    76,    69,   111,    48,    67,    98,    99,   100,   101,
-     217,   366,   293,   175,   561,   721,   295,   296,   297,   298,
-     696,   299,   300,   301,   302,   699,   303,   304,   305,   306,
-     700,   307,   451,   308,   591,   658,   659,   660,   661,   309,
-     310,   702,   311,   312,   313,   703,   314,   315,   457,   666,
-     667,   316,   317,   318,   319,   320,   321,   322,   577,   578,
-     579,   580,   218,   219,   220,   221,   222,   731,   675,   223,
-     496,   224,   476,   477,   124,   225,   226,   227,   228,   229,
-     230,   231,   232,   233,   234,   235,   236,   237,   238,   239,
-     240,   241,   242,   243,   244,   245,   246,   247,   248,   249,
-     250,   402,   497,   716
-};
-
-/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
-   STATE-NUM.  */
-#define YYPACT_NINF -650
-static const short yypact[] =
-{
-    -650,    33,   200,  -650,  -650,  -650,   353,   -42,   478,   491,
-    -650,  -650,   224,   349,   407,  -650,  -650,  -650,  -650,   601,
-    -650,  -650,  -650,  -650,  -650,    15,  -650,  -650,  -650,   358,
-    -650,   214,  -650,    21,   459,  -650,  -650,   444,   513,  -650,
-     -42,   502,  -650,  -650,   460,  -650,   531,   -27,   170,  -650,
-     540,   283,  -650,  -650,   -42,   590,   424,  -650,   420,  -650,
-      36,  -650,  -650,  -650,  -650,   300,   901,  -650,   541,   -27,
-    -650,  -650,   414,   549,  -650,  -650,   -27,   170,  -650,   283,
-    -650,  -650,  -650,   585,  -650,  -650,  -650,   586,   322,  -650,
-    -650,  -650,   400,  1120,  -650,  -650,    71,  -650,  1586,  -650,
-    -650,  -650,  -650,  -650,  -650,  -650,  -650,  -650,   370,   330,
-    -650,   -27,  -650,  -650,   382,   -28,  -650,   137,   -11,  -650,
-     425,   -28,   426,   438,   438,  -650,   620,   633,  -650,  -650,
-    -650,  -650,   655,  1277,  -650,  -650,   330,   616,   684,    60,
-    -650,  -650,  -650,   687,  1530,    87,   575,  -650,  -650,    93,
-    -650,   -28,  -650,   243,   -28,  -650,  -650,   495,  -650,   510,
-     821,  -650,  1355,  -650,  -650,  -650,  -650,    50,  -650,   545,
-    -650,  -650,   632,  -650,  -650,  1976,  -650,  -650,  -650,  -650,
-     693,   612,   473,  -650,   776,  -650,  -650,   609,  -650,  -650,
-    -650,    84,  -650,  -650,  2784,  1188,  2845,  2896,   651,    35,
-     556,  -650,  2957,  3008,  3069,  4998,  -650,  -650,  -650,  -650,
-    -650,  -650,  -650,   573,   668,   921,    67,  -650,   717,   624,
-    -650,  -650,  -650,   697,  -650,   756,  -650,   867,   755,  -650,
-    -650,  -650,  -650,  -650,  -650,  -650,  -650,   942,   964,   970,
-     797,   966,   767,   801,   811,   812,    10,  -650,  -650,  -650,
-     919,  -650,  -650,  -650,  -650,  -650,  -650,  -650,  -650,  -650,
-    -650,   959,   632,  -650,  -650,  -650,   654,  -650,   740,  -650,
-     819,   180,  3120,  -650,   121,  2173,    26,   226,   303,   316,
-     341,   141,   762,  5283,   -42,   573,   668,   883,   636,   537,
-    -650,   776,   783,  -650,  1907,  -650,  -650,   761,  -650,  -650,
-    -650,  2045,  -650,  -650,   780,  -650,  -650,  -650,  -650,  2045,
-    -650,  2045,  -650,  -650,  5334,   791,  -650,  -650,  -650,  -650,
-    -650,   445,  -650,   372,   832,   755,   985,   991,  -650,  -650,
-    -650,  -650,   960,  -650,   676,   700,   711,  -650,   646,  -650,
-    -650,  -650,  -650,  -650,  -650,  -650,  -650,  -650,    13,  -650,
-     718,   949,   798,   798,   452,  -650,  -650,  -650,  -650,  -650,
-     709,   921,    53,  -650,   816,  -650,   823,    23,   830,  5059,
-    2224,   587,  -650,    -8,  3181,  -650,   485,  -650,  -650,  3232,
-    3293,  3344,  3405,  3456,  3517,  3568,  3629,  3680,  3741,  3792,
-    3853,   690,  3904,  3965,  4016,  4077,  4128,  4189,  4240,  2285,
-    -650,  -650,  4301,  -650,   592,  -650,  -650,  -650,  -650,  -650,
-    -650,  1907,  -650,  -650,  -650,  -650,  4352,  -650,   172,  -650,
-    -650,   211,  -650,  -650,   219,  -650,  4413,  -650,  4464,  -650,
-     860,  -650,  1469,  -650,  -650,   225,   212,   822,   658,  -650,
-    -650,   -42,  2336,  -650,  -650,  -650,  -650,   958,   612,  -650,
-    -650,   831,  -650,   866,   990,  -650,  -650,  -650,   117,  2397,
-    -650,  4525,  -650,  -650,  -650,   960,  -650,  -650,  -650,  -650,
-     204,   842,  -650,  -650,  -650,  2448,   798,  -650,   660,   798,
-     660,  -650,  2509,  4576,   107,   203,   439,  -650,  5359,  -650,
-    -650,   748,  -650,  -650,  -650,  -650,   775,  -650,  -650,   222,
-    -650,  -650,  -650,  -650,  -650,   844,  -650,   249,  -650,  5110,
-    -650,  -650,  -650,  -650,  -650,  -650,  -650,   942,  -650,   942,
-    -650,   964,  -650,   964,  -650,   964,  -650,   970,  -650,   970,
-    -650,   970,  -650,   970,  -650,   322,  -650,  -650,   797,  -650,
-     797,  -650,   966,  -650,   767,  -650,   801,  -650,   811,  -650,
-     812,  -650,   944,   854,  -650,  -650,  -650,  1008,  -650,  1907,
-     857,  -650,  1907,  -650,   276,  -650,  -650,  -650,  -650,  -650,
-    -650,  -650,   333,  -650,   861,   500,   328,   860,  -650,   545,
-    -650,  -650,  -650,  -650,  -650,   504,   822,  -650,   961,   138,
-     -20,  -650,   870,  -650,  4973,  -650,  4861,   871,   879,   895,
-    -650,  -650,  5171,  -650,   265,  -650,   438,  -650,   438,  -650,
-    -650,   896,   151,  -650,  -650,  -650,  4637,  1021,  -650,  -650,
-    -650,  -650,  -650,  4688,  -650,  -650,  5222,  -650,  -650,   330,
-     789,  -650,  4749,   713,  -650,  1907,  2560,  -650,  -650,  2112,
-    -650,  -650,   346,  -650,   746,  -650,  -650,  -650,  -650,  -650,
-    -650,  2621,  -650,  -650,   998,    58,  4800,  -650,   603,  -650,
-    1684,  -650,  5283,  -650,  -650,  -650,   922,   934,  4912,  -650,
-     352,  -650,   805,  -650,  -650,   330,  -650,   924,  -650,  -650,
-    -650,  -650,  -650,  -650,  -650,   808,  -650,   330,  -650,  -650,
-     508,  -650,   241,   156,   514,  -650,   987,   996,  2112,  -650,
-    -650,  2112,  -650,  -650,   965,  -650,   972,   974,  -650,  1073,
-     159,  -650,  -650,  -650,  -650,  -650,   433,  -650,  -650,  1759,
-    -650,  1833,  -650,   980,  2045,  -650,   984,  -650,  -650,  -650,
-    -650,   330,  -650,  -650,  2672,  -650,   258,  4352,  2045,  -650,
-    -650,  2733,  -650,  -650,  -650,  -650,  1084,  -650,  -650,  -650,
-     986,  -650,  2045,  -650,   263,   186,  -650,   356,  -650,  4861,
-     997,  -650,  -650,  -650,  -650,   269,  2112,  1004,  4912,  -650,
-    1046,  2112,  1010,  2112,  -650,  2112,  -650,  -650
-};
-
-/* YYPGOTO[NTERM-NUM].  */
-static const short yypgoto[] =
-{
-    -650,  -650,  -650,  -650,   -59,   -51,   726,     3,  -120,   493,
-     306,    -6,   470,  -650,   122,  -650,  1106,   752,  -650,   325,
-    -650,  -650,   837,    18,   517,  -650,  -650,  1064,  1044,  -650,
-    -135,  -650,   967,  -650,  -104,  -123,   989,  -171,  -197,  -650,
-    -650,   -67,   760,   874,  -328,  -127,   -58,  -650,  -650,  -650,
-    -650,  -650,  -650,  -650,   968,  -650,   174,  -650,   725,   329,
-    -650,  -650,  -650,  -650,  1081,   -12,  -650,  1040,  -650,  -650,
-     332,  -650,  -121,   872,   845,  -158,  -289,  -650,   827,  -288,
-     139,  -601,   610,  -440,  -650,  -650,  -650,  -312,  -650,  -650,
-    -650,  -650,  -650,  -650,  -650,  -650,   486,   487,  -614,  -405,
-    -650,  -650,  -650,  -650,  -650,  -650,  -650,  -202,  -650,  -649,
-     829,  -650,  -650,  -650,  -650,  -650,  -650,  -650,  -650,   569,
-    -650,   571,  -650,  -650,  -650,   234,  -650,  -650,  -650,  -650,
-    -407,  -650,   796,   229,   -38,  1110,   305,  1315,   395,   474,
-     617,   955,   -90,   628,   707,  -477,  -650,   679,   705,   607,
-     648,   757,   758,   759,   763,   754,  -650,   524,   765,   891,
-    -650,  -650,   -61,  -650
-};
-
-/* YYTABLE[YYPACT[STATE-NUM]].  What to do in state STATE-NUM.  If
-   positive, shift that token.  If negative, reduce the rule which
-   number is the opposite.  If zero, do what YYDEFACT says.
-   If YYTABLE_NINF, syntax error.  */
-#define YYTABLE_NINF -503
-static const short yytable[] =
-{
-      25,   177,   456,    33,   153,   445,   463,    87,   365,   332,
-     184,   618,   174,   449,   468,    88,    42,   294,   186,   726,
-      19,   452,    52,   453,   492,   398,   138,   349,   655,   165,
-      19,    19,    19,     3,   127,   589,   349,    80,   697,    87,
-      65,   174,    88,   656,    65,    24,   722,    88,   267,    63,
-     123,   265,    19,    71,   487,    19,    19,   104,   165,   712,
-      92,   188,    65,   147,   110,   504,   167,    65,   372,    66,
-     139,    63,   128,    19,    87,   612,    63,   657,   180,    24,
-     354,   469,    88,   251,    93,   141,    88,    92,   252,   142,
-     143,   493,    92,   257,   255,   167,   259,   697,   399,   135,
-     697,   127,   630,    87,   341,   722,   345,   347,   615,    88,
-     767,    88,   356,   358,   269,    43,    93,    44,   593,   772,
-    -154,    53,   419,    54,   285,   335,    65,    92,   350,    29,
-      31,    92,    65,    88,   184,    63,    81,   350,   141,   653,
-     681,    71,   433,   362,   251,   408,  -103,   713,   488,   352,
-    -103,   160,   676,   360,    92,   181,    92,   653,   430,   189,
-     745,   437,    56,    58,   465,   697,    61,   -93,   -93,   287,
-     697,   129,   697,   565,   697,   123,    61,   -96,    92,   -96,
-     160,   415,   -96,   -96,   -96,   -96,   253,   745,   338,   338,
-     338,   338,   256,   289,    65,   672,   338,   338,   361,   698,
-     -27,     4,   180,   353,   405,   114,   148,   184,    24,   117,
-      88,   418,   567,   487,   424,    49,   467,  -292,   594,   685,
-     569,   420,   436,   624,   -29,     4,   582,   425,    24,   693,
-     -96,   137,   441,   654,   701,   -96,   -96,   -96,   -96,   623,
-      88,   434,   652,   285,   710,     5,   677,   123,   114,   117,
-     627,   736,   623,   562,   746,    92,     6,   623,   698,   711,
-     623,   698,     7,   285,   744,   191,   673,   -64,     8,     5,
-     761,    68,   566,   445,   416,   180,     9,   638,    50,   181,
-       6,   765,   664,    88,   456,    92,     7,   623,   287,   511,
-     513,   515,     8,   701,   621,   447,   701,   288,   616,   600,
-      10,   149,   191,   447,   427,   447,   601,   584,   454,   499,
-     -64,   568,   289,   507,   478,   480,   707,   429,   586,   570,
-     426,   625,   485,   486,    10,   583,   698,   755,    92,   645,
-      65,   698,   181,   698,   640,   698,    73,    35,   553,    71,
-     535,   735,   431,   258,   143,   376,   445,   705,   628,   -30,
-       4,   695,   181,   727,    23,   564,   456,   638,   756,    45,
-     285,   701,    35,   764,   674,   572,   701,   574,   701,   769,
-     701,   639,    91,   338,   338,   338,   338,   338,   338,   338,
-     338,   338,   338,   338,   338,    92,   338,   338,   338,   338,
-     338,   338,   338,   614,     5,    97,   421,   428,   597,    91,
-     599,   635,    54,   435,    91,   557,   191,   -28,     4,   323,
-     449,     7,   157,   452,   604,   105,   288,     8,  -339,  -339,
-     122,    78,    46,   288,   157,    75,   133,    97,   641,   289,
-     251,   288,   445,   288,   747,   432,   751,   704,   606,    91,
-      24,   608,  -254,    91,   -31,     4,   460,   456,   157,    10,
-     758,   766,     5,   481,  -155,   646,   456,   191,   649,   -33,
-       4,    59,   173,     6,   763,    60,    91,   -65,    91,     7,
-    -339,   132,   471,   -64,  -339,     8,   137,   338,   695,    30,
-     324,   286,   338,   751,    50,   758,   508,   763,    46,     5,
-      91,   173,    32,    61,   686,   505,   704,   123,   122,   704,
-       6,   643,    54,    57,     5,   650,     7,    10,   285,   650,
-     -65,   285,     8,   -32,     4,   415,   -64,   184,   144,    20,
-    -157,     7,   748,   145,   146,   148,   679,     8,   323,    20,
-      20,    20,    62,   288,   617,   323,   149,   149,  -320,   461,
-     730,    70,   102,   323,    10,   323,   482,    24,   323,   728,
-     106,    20,   733,   287,    20,    20,   287,   351,     5,    10,
-      61,   103,   683,   191,   704,    24,   107,    91,   333,   704,
-     325,   704,    20,   704,   334,     7,   254,   289,    24,   509,
-     289,     8,    39,    94,   285,   180,   113,   116,   500,    24,
-     -34,     4,   260,    88,   644,   715,   753,    91,   651,   324,
-     286,   723,   734,   159,   261,    41,   324,    82,   737,   285,
-     338,   338,    22,    10,   324,    94,   324,   178,    24,   324,
-     286,   150,    22,    22,    22,   156,   338,    24,    24,   287,
-     159,  -320,   159,   447,   152,     5,    24,   439,    92,    84,
-      91,   157,    85,    24,    22,   323,    39,    22,    22,   326,
-     161,   655,     7,   289,   287,   501,   155,    39,     8,   500,
-     502,     5,   181,    40,   503,    22,   656,    82,   285,    41,
-     285,   122,    24,    24,    24,   367,   757,   462,   289,   161,
-     760,   288,   -24,   -24,   288,   185,   138,   556,   190,   325,
-      10,   534,   447,   334,   331,   447,   325,    91,   375,    84,
-     717,   464,    85,    24,   325,   605,   325,    24,   605,   325,
-     336,   179,   466,   287,   500,   287,   324,   286,   447,   470,
-      24,     5,   374,   -24,   585,   440,   501,    82,   -24,   -24,
-     -24,   502,   447,   634,   -24,   503,   637,   289,   -24,   289,
-     369,    82,    24,   176,   370,    24,   447,   706,   371,   619,
-     157,   194,   195,   348,   406,    61,   205,   288,   149,    84,
-     447,   288,    85,    24,    34,   447,    38,   447,   326,   447,
-     368,    24,   176,    84,    24,   326,    85,    24,   394,   690,
-      24,   501,   288,   326,    24,   326,   502,    24,   326,    55,
-     503,     5,   327,   323,   196,   197,   323,    82,    24,    82,
-      24,   377,   378,   328,   483,    24,   325,   484,   198,   691,
-     607,   367,   609,   395,   199,   387,   388,   389,   390,   373,
-     288,   200,   125,   288,   396,   201,   397,    82,   323,    84,
-     323,    84,    85,    24,    85,    24,   409,   739,   202,   203,
-     740,   288,   204,   288,   205,   620,   288,   121,  -501,  -501,
-      36,   206,   207,   208,   209,   391,  -153,   210,   211,    84,
-     288,   446,    85,    24,   324,   286,    39,   324,   286,   323,
-     622,    36,    82,   323,   288,    36,   623,   442,  -341,  -341,
-     450,   126,   329,    40,   687,   326,   151,   154,   288,    41,
-     623,   459,    36,   288,   323,   288,   475,   288,   494,   324,
-     729,   324,   323,   732,    84,   770,   623,    85,    24,   623,
-     774,   327,   776,   489,   777,   412,   413,  -137,   327,   414,
-     490,   575,   328,   143,   491,   576,   327,   590,   327,   328,
-    -341,   327,   323,   592,  -341,   323,   602,   328,   626,   328,
-     324,   286,   328,   632,   324,   631,     5,   379,   380,   381,
-      91,   636,    82,   323,   325,   323,   642,   325,   323,  -502,
-    -502,    83,   652,     7,   662,   324,   286,   382,   383,     8,
-     -17,   668,   323,   324,   669,  -500,  -500,   369,   384,   385,
-     386,   370,   392,   393,    84,   438,   323,    85,    24,   325,
-     670,   325,  -368,   323,   527,   529,   531,   533,    86,   711,
-     323,   329,   323,   324,     5,   323,   324,   323,   329,   323,
-      82,   400,   401,  -500,  -500,   369,   329,   724,   329,   370,
-    -366,   329,   680,   371,   324,   286,   324,   286,   327,   324,
-     325,  -410,  -410,   326,   325,   594,   326,  -411,  -411,   328,
-     538,   540,    84,   324,   738,    85,    24,   472,   473,   474,
-    -500,  -500,   369,  -205,   403,   325,   370,   324,   145,   146,
-     438,   517,   519,   325,   324,   741,   330,   742,   326,   743,
-     326,   324,    82,   324,   744,   750,   324,   -17,   324,   752,
-     324,   198,  -500,  -500,   369,   761,   762,   199,   370,   521,
-     523,   525,   371,   325,   200,   -17,   325,   768,   201,   771,
-    -500,  -500,   369,   773,    84,   775,   370,    85,    24,   326,
-     633,   202,   203,   326,   325,   204,   325,   536,   329,   325,
-      37,   125,    79,   112,   206,   207,   208,   209,   262,   264,
-     210,   211,   192,   325,   326,   404,   560,    77,   131,   444,
-     411,   455,   326,   458,   718,   719,   647,   325,   648,   479,
-     343,   542,   550,   544,   325,   546,   689,     0,     0,     0,
-     548,   325,     0,   325,     0,    39,   325,   555,   325,     0,
-     325,    82,   326,     0,     0,   326,   327,     0,     0,   327,
-     126,     0,    40,     0,     0,   330,     0,   328,    41,   342,
-     328,   194,   330,   326,     0,   326,     0,     0,   326,     0,
-     330,     0,   330,    84,     0,   330,    85,    24,     0,     0,
-       0,   327,   326,   327,     0,     0,     0,     0,     0,     0,
-       0,     0,   328,     0,   328,     0,   326,     0,     0,     0,
-       0,     0,     0,   326,   196,   197,     0,     0,     0,    82,
-     326,     0,   326,     0,     0,   326,     0,   326,   198,   326,
-       0,     0,   327,     0,   199,     0,   327,     0,     0,     0,
-       0,   200,     0,   328,     0,   201,   329,   328,     0,   329,
-       0,    84,     0,     0,    85,    24,     0,   327,   202,   203,
-       0,     0,   204,     0,     0,   327,     0,     0,   328,     0,
-       0,   206,   207,   208,   209,     0,   328,   210,   211,     0,
-       0,   329,   330,   329,   339,   339,   339,   339,     0,     0,
-       0,     0,   339,   339,     0,   327,     0,     0,   327,     0,
-       0,     0,     5,     0,     0,     0,   328,     0,    82,   328,
-       0,     0,     0,     0,     0,     0,   327,    83,   327,     7,
-       0,   327,   329,     0,     0,     8,   329,   328,     0,   328,
-       0,     0,   328,     0,     0,   327,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,   328,   329,     0,   327,
-       0,     0,     0,   157,   158,   329,   327,    10,     0,     0,
-     328,     0,     0,   327,     0,   327,     0,   328,   327,     0,
-     327,     0,   327,     0,   328,     0,   328,     0,     0,   328,
-       5,   328,     0,   328,     0,   329,    82,     0,   329,     0,
-       0,     0,     0,     0,     0,    83,     0,     7,     0,     0,
-       0,     0,     0,     8,     0,     0,   329,     0,   329,     0,
-       0,   329,     0,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,     0,   329,     0,     0,     0,     0,
-     330,   157,   263,   330,     0,    10,     0,     0,     0,   329,
-       0,     0,     0,     0,     0,     0,   329,     0,     0,     0,
-     581,     0,     0,   329,     0,   329,     0,     0,   329,     0,
-     329,     0,   329,     0,     0,   330,     0,   330,     0,   339,
-     339,   339,   339,   339,   339,   339,   339,   339,   339,   339,
-     339,     0,   339,   339,   339,   339,   339,   339,   339,   340,
-     340,   340,   340,     0,  -287,  -287,  -287,   340,   340,     0,
-    -287,     0,     0,     0,     0,     0,   330,     0,     0,  -287,
-     330,   193,     0,   194,   195,  -287,     0,     0,     0,     0,
-       0,     0,  -287,     0,     0,     0,  -287,     0,     0,     0,
-       0,   330,  -287,     0,     0,  -287,  -287,     0,     0,   330,
-       0,     0,     0,  -287,     0,     0,     0,     0,     0,  -287,
-       0,     0,  -287,  -287,  -287,  -287,   196,   197,  -287,  -287,
-       0,    82,     0,     0,     0,     0,     0,     0,     0,   330,
-     198,     0,   330,   339,     0,     0,   199,     0,   339,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-     330,     0,   330,    84,     0,   330,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,     0,   205,     0,     0,   330,
-       0,     5,     0,   206,   207,   208,   209,    82,     0,   210,
-     211,     0,     0,   330,     0,     0,    83,     0,     7,     0,
-     330,     0,     0,     0,     8,     0,     0,   330,     0,   330,
-       0,     0,   330,     0,   330,     0,   330,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,     0,     0,     0,     0,
-       0,     0,     0,   130,     0,   270,     0,     0,     0,     0,
-       0,     0,     0,     0,   340,   340,   340,   340,   340,   340,
-     340,   340,   340,   340,   340,   340,     0,   340,   340,   340,
-     340,   340,   340,   340,     0,     0,     0,     0,     0,     0,
-       0,     0,     0,     0,     0,     0,   339,   339,     0,     5,
-     196,   197,   655,   271,   272,    82,   273,     0,     0,   274,
-       0,     0,   339,   275,   198,     0,     0,   656,     0,     0,
-     276,   277,     8,   278,     0,   279,   280,   200,   281,     0,
-     270,   282,     0,     0,     0,     0,     0,    84,     0,     0,
-      85,    24,     0,     0,     0,     0,     0,     0,   283,     0,
-     157,   720,     0,     0,    10,     0,     0,   206,   207,   208,
-     209,     0,     0,   210,   211,     0,     0,     0,   340,     0,
-       0,     0,     0,   340,     5,   196,   197,   655,   271,   272,
-      82,   273,     0,     0,   274,     0,     0,     0,   275,   198,
-       0,     0,   656,     0,     0,   276,   277,     8,   278,     0,
-     279,   280,   200,   281,   270,     0,   282,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,     0,
-       0,     0,     0,   283,     0,   157,   749,     0,     0,    10,
-       0,     0,   206,   207,   208,   209,     0,     0,   210,   211,
-       0,     0,     0,     0,     0,     0,     0,     0,     5,   196,
-     197,  -264,   271,   272,    82,   273,     0,     0,   274,     0,
-       0,     0,   275,   198,     0,     0,  -264,     0,     0,   276,
-     277,     8,   278,     0,   279,   280,   200,   281,   270,     0,
-     282,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,     0,     0,     0,     0,   283,     0,   157,
-    -264,   340,   340,    10,     0,     0,   206,   207,   208,   209,
-       0,     0,   210,   211,     0,     0,     0,   340,     0,     0,
-       0,     0,     5,   196,   197,     0,   271,   272,    82,   273,
-       0,     0,   274,     0,     0,     0,   275,   198,     0,     0,
-       0,     0,     0,   276,   277,     8,   278,   270,   279,   280,
-     200,   281,     0,     0,   282,     0,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,     0,     0,     0,     0,
-       0,   283,     0,   157,   443,     0,     0,    10,     0,     0,
-     206,   207,   208,   209,     0,     0,   210,   211,     0,     0,
-       0,     5,   196,   197,     0,   271,   272,    82,   273,     0,
-       0,   274,     0,     0,     0,   275,   198,     0,     0,     0,
-       0,     0,   276,   277,     8,   278,   270,   279,   280,   200,
-     281,     0,     0,   282,     0,     0,     0,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,     0,     0,     0,     0,
-     283,     0,   157,     0,     0,     0,    10,     0,     0,   206,
-     207,   208,   209,     0,     0,   210,   211,     0,     0,     0,
-       5,   196,   197,     0,   271,   272,    82,   273,     0,     0,
-     274,     0,     0,     0,   275,   198,     0,     0,     0,     0,
-       0,   276,   277,   270,   278,     0,   279,   280,   200,   281,
-       0,     0,   282,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,     0,     0,     0,     0,     0,   283,
-       0,   157,     0,     0,     0,    10,     0,     0,   206,   207,
-     208,   209,     0,     0,   210,   211,     0,     5,   196,   197,
-       0,   694,   272,    82,   273,     0,     0,   274,     0,     0,
-       0,   275,   198,     0,   422,     0,   194,   195,   276,   277,
-       0,   278,     0,   279,   280,   200,   281,     0,     0,   282,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,     0,     0,     0,     0,     0,   283,     0,   157,     0,
-       0,     0,    10,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,   498,     0,   194,   195,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,     0,     0,   200,     0,     0,     0,
-     201,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,   202,   203,     0,     0,   204,     0,     0,
-     196,   197,     0,   423,     0,    82,   206,   207,   208,   209,
-       0,     0,   210,   211,   198,     0,   551,     0,   194,   195,
-     199,     0,     0,     0,     0,     0,     0,   200,     0,     0,
-       0,   201,     0,     0,     0,     0,     0,    84,     0,     0,
-      85,    24,     0,     0,   202,   203,     0,     0,   204,     0,
-       0,     0,     0,   148,     0,     0,     0,   206,   207,   208,
-     209,   196,   197,   210,   211,     0,    82,   587,     0,   194,
-     195,     0,     0,     0,     0,   198,     0,     0,     0,     0,
-       0,   199,     0,     0,     0,     0,     0,     0,   200,     0,
-       0,     0,   201,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,   552,   202,   203,     0,     0,   204,
-       0,     0,   196,   197,     0,     0,     0,    82,   206,   207,
-     208,   209,     0,     0,   210,   211,   198,     0,   595,     0,
-     194,   195,   199,     0,     0,     0,     0,     0,     0,   200,
-       0,     0,     0,   201,     0,     0,     0,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,   202,   203,     0,     0,
-     204,   588,     0,     0,     0,     0,     0,     0,     0,   206,
-     207,   208,   209,   196,   197,   210,   211,     0,    82,   603,
-       0,   194,   195,     0,     0,     0,     0,   198,     0,     0,
-       0,     0,     0,   199,     0,     0,     0,     0,     0,     0,
-     200,     0,     0,     0,   201,     0,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,     0,   202,   203,     0,
-       0,   204,     0,     0,   196,   197,     0,   596,     0,    82,
-     206,   207,   208,   209,     0,     0,   210,   211,   198,     0,
-     610,     0,   194,   195,   199,     0,     0,     0,     0,     0,
-       0,   200,     0,     0,     0,   201,     0,     0,     0,     0,
-       0,    84,     0,     0,    85,    24,     0,     0,   202,   203,
-       0,     0,   204,     0,     0,     0,     0,   148,     0,     0,
-       0,   206,   207,   208,   209,   196,   197,   210,   211,     0,
-      82,   587,     0,   194,   195,     0,     0,     0,     0,   198,
-       0,     0,     0,     0,     0,   199,     0,     0,     0,     0,
-       0,     0,   200,     0,     0,     0,   201,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,   611,     0,   196,   197,     0,     0,
-       0,    82,   206,   207,   208,   209,     0,     0,   210,   211,
-     198,     0,   708,     0,   194,   195,   199,     0,     0,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-       0,     0,     0,    84,     0,     0,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,   692,     0,     0,     0,     0,
-       0,     0,     0,   206,   207,   208,   209,   196,   197,   210,
-     211,     0,    82,   708,     0,   194,   195,     0,     0,     0,
-       0,   198,     0,     0,     0,     0,     0,   199,     0,     0,
-       0,     0,     0,     0,   200,     0,     0,     0,   201,     0,
-       0,     0,     0,     0,    84,     0,     0,    85,    24,     0,
-       0,   202,   203,     0,     0,   204,   709,     0,   196,   197,
-       0,     0,     0,    82,   206,   207,   208,   209,     0,     0,
-     210,   211,   198,     0,   595,     0,   194,   195,   199,     0,
-       0,     0,     0,     0,     0,   200,     0,     0,     0,   201,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,     0,   202,   203,     0,     0,   204,   754,     0,     0,
-       0,     0,     0,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,   337,     0,   194,   195,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,     0,     0,   200,     0,     0,     0,
-     201,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,   202,   203,     0,     0,   204,     0,     0,
-     196,   197,     0,   759,     0,    82,   206,   207,   208,   209,
-       0,     0,   210,   211,   198,     0,   344,     0,   194,   195,
-     199,     0,     0,     0,     0,     0,     0,   200,     0,     0,
-       0,   201,     0,     0,     0,     0,     0,    84,     0,     0,
-      85,    24,     0,     0,   202,   203,     0,     0,   204,     0,
-       0,     0,     0,     0,     0,     0,     0,   206,   207,   208,
-     209,   196,   197,   210,   211,     0,    82,   346,     0,   194,
-     195,     0,     0,     0,     0,   198,     0,     0,     0,     0,
-       0,   199,     0,     0,     0,     0,     0,     0,   200,     0,
-       0,     0,   201,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,     0,   202,   203,     0,     0,   204,
-       0,     0,   196,   197,     0,     0,     0,    82,   206,   207,
-     208,   209,     0,     0,   210,   211,   198,     0,   355,     0,
-     194,   195,   199,     0,     0,     0,     0,     0,     0,   200,
-       0,     0,     0,   201,     0,     0,     0,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,   202,   203,     0,     0,
-     204,     0,     0,     0,     0,     0,     0,     0,     0,   206,
-     207,   208,   209,   196,   197,   210,   211,     0,    82,   357,
-       0,   194,   195,     0,     0,     0,     0,   198,     0,     0,
-       0,     0,     0,   199,     0,     0,     0,     0,     0,     0,
-     200,     0,     0,     0,   201,     0,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,     0,   202,   203,     0,
-       0,   204,     0,     0,   196,   197,     0,     0,     0,    82,
-     206,   207,   208,   209,     0,     0,   210,   211,   198,     0,
-     359,     0,   194,   195,   199,     0,     0,     0,     0,     0,
-       0,   200,     0,     0,     0,   201,     0,     0,     0,     0,
-       0,    84,     0,     0,    85,    24,     0,     0,   202,   203,
-       0,     0,   204,     0,     0,     0,     0,     0,     0,     0,
-       0,   206,   207,   208,   209,   196,   197,   210,   211,     0,
-      82,   417,     0,   194,   195,     0,     0,     0,     0,   198,
-       0,     0,     0,     0,     0,   199,     0,     0,     0,     0,
-       0,     0,   200,     0,     0,     0,   201,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,     0,     0,   196,   197,     0,     0,
-       0,    82,   206,   207,   208,   209,     0,     0,   210,   211,
-     198,     0,   506,     0,   194,   195,   199,     0,     0,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-       0,     0,     0,    84,     0,     0,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,     0,     0,     0,     0,     0,
-       0,     0,     0,   206,   207,   208,   209,   196,   197,   210,
-     211,     0,    82,   510,     0,   194,   195,     0,     0,     0,
-       0,   198,     0,     0,     0,     0,     0,   199,     0,     0,
-       0,     0,     0,     0,   200,     0,     0,     0,   201,     0,
-       0,     0,     0,     0,    84,     0,     0,    85,    24,     0,
-       0,   202,   203,     0,     0,   204,     0,     0,   196,   197,
-       0,     0,     0,    82,   206,   207,   208,   209,     0,     0,
-     210,   211,   198,     0,   512,     0,   194,   195,   199,     0,
-       0,     0,     0,     0,     0,   200,     0,     0,     0,   201,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,     0,   202,   203,     0,     0,   204,     0,     0,     0,
-       0,     0,     0,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,   514,     0,   194,   195,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,     0,     0,   200,     0,     0,     0,
-     201,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,   202,   203,     0,     0,   204,     0,     0,
-     196,   197,     0,     0,     0,    82,   206,   207,   208,   209,
-       0,     0,   210,   211,   198,     0,   516,     0,   194,   195,
-     199,     0,     0,     0,     0,     0,     0,   200,     0,     0,
-       0,   201,     0,     0,     0,     0,     0,    84,     0,     0,
-      85,    24,     0,     0,   202,   203,     0,     0,   204,     0,
-       0,     0,     0,     0,     0,     0,     0,   206,   207,   208,
-     209,   196,   197,   210,   211,     0,    82,   518,     0,   194,
-     195,     0,     0,     0,     0,   198,     0,     0,     0,     0,
-       0,   199,     0,     0,     0,     0,     0,     0,   200,     0,
-       0,     0,   201,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,     0,   202,   203,     0,     0,   204,
-       0,     0,   196,   197,     0,     0,     0,    82,   206,   207,
-     208,   209,     0,     0,   210,   211,   198,     0,   520,     0,
-     194,   195,   199,     0,     0,     0,     0,     0,     0,   200,
-       0,     0,     0,   201,     0,     0,     0,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,   202,   203,     0,     0,
-     204,     0,     0,     0,     0,     0,     0,     0,     0,   206,
-     207,   208,   209,   196,   197,   210,   211,     0,    82,   522,
-       0,   194,   195,     0,     0,     0,     0,   198,     0,     0,
-       0,     0,     0,   199,     0,     0,     0,     0,     0,     0,
-     200,     0,     0,     0,   201,     0,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,     0,   202,   203,     0,
-       0,   204,     0,     0,   196,   197,     0,     0,     0,    82,
-     206,   207,   208,   209,     0,     0,   210,   211,   198,     0,
-     524,     0,   194,   195,   199,     0,     0,     0,     0,     0,
-       0,   200,     0,     0,     0,   201,     0,     0,     0,     0,
-       0,    84,     0,     0,    85,    24,     0,     0,   202,   203,
-       0,     0,   204,     0,     0,     0,     0,     0,     0,     0,
-       0,   206,   207,   208,   209,   196,   197,   210,   211,     0,
-      82,   526,     0,   194,   195,     0,     0,     0,     0,   198,
-       0,     0,     0,     0,     0,   199,     0,     0,     0,     0,
-       0,     0,   200,     0,     0,     0,   201,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,     0,     0,   196,   197,     0,     0,
-       0,    82,   206,   207,   208,   209,     0,     0,   210,   211,
-     198,     0,   528,     0,   194,   195,   199,     0,     0,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-       0,     0,     0,    84,     0,     0,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,     0,     0,     0,     0,     0,
-       0,     0,     0,   206,   207,   208,   209,   196,   197,   210,
-     211,     0,    82,   530,     0,   194,   195,     0,     0,     0,
-       0,   198,     0,     0,     0,     0,     0,   199,     0,     0,
-       0,     0,     0,     0,   200,     0,     0,     0,   201,     0,
-       0,     0,     0,     0,    84,     0,     0,    85,    24,     0,
-       0,   202,   203,     0,     0,   204,     0,     0,   196,   197,
-       0,     0,     0,    82,   206,   207,   208,   209,     0,     0,
-     210,   211,   198,     0,   532,     0,   194,   195,   199,     0,
-       0,     0,     0,     0,     0,   200,     0,     0,     0,   201,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,     0,   202,   203,     0,     0,   204,     0,     0,     0,
-       0,     0,     0,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,   537,     0,   194,   195,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,     0,     0,   200,     0,     0,     0,
-     201,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,   202,   203,     0,     0,   204,     0,     0,
-     196,   197,     0,     0,     0,    82,   206,   207,   208,   209,
-       0,     0,   210,   211,   198,     0,   539,     0,   194,   195,
-     199,     0,     0,     0,     0,     0,     0,   200,     0,     0,
-       0,   201,     0,     0,     0,     0,     0,    84,     0,     0,
-      85,    24,     0,     0,   202,   203,     0,     0,   204,     0,
-       0,     0,     0,     0,     0,     0,     0,   206,   207,   208,
-     209,   196,   197,   210,   211,     0,    82,   541,     0,   194,
-     195,     0,     0,     0,     0,   198,     0,     0,     0,     0,
-       0,   199,     0,     0,     0,     0,     0,     0,   200,     0,
-       0,     0,   201,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,     0,   202,   203,     0,     0,   204,
-       0,     0,   196,   197,     0,     0,     0,    82,   206,   207,
-     208,   209,     0,     0,   210,   211,   198,     0,   543,     0,
-     194,   195,   199,     0,     0,     0,     0,     0,     0,   200,
-       0,     0,     0,   201,     0,     0,     0,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,   202,   203,     0,     0,
-     204,     0,     0,     0,     0,     0,     0,     0,     0,   206,
-     207,   208,   209,   196,   197,   210,   211,     0,    82,   545,
-       0,   194,   195,     0,     0,     0,     0,   198,     0,     0,
-       0,     0,     0,   199,     0,     0,     0,     0,     0,     0,
-     200,     0,     0,     0,   201,     0,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,     0,   202,   203,     0,
-       0,   204,     0,     0,   196,   197,     0,     0,     0,    82,
-     206,   207,   208,   209,     0,     0,   210,   211,   198,     0,
-     547,     0,   194,   195,   199,     0,     0,     0,     0,     0,
-       0,   200,     0,     0,     0,   201,     0,     0,     0,     0,
-       0,    84,     0,     0,    85,    24,     0,     0,   202,   203,
-       0,     0,   204,     0,     0,     0,     0,     0,     0,     0,
-       0,   206,   207,   208,   209,   196,   197,   210,   211,     0,
-      82,   549,     0,   194,   195,     0,     0,     0,     0,   198,
-       0,     0,     0,     0,     0,   199,     0,     0,     0,     0,
-       0,     0,   200,     0,     0,     0,   201,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,     0,     0,   196,   197,     0,     0,
-       0,    82,   206,   207,   208,   209,     0,     0,   210,   211,
-     198,     0,   554,     0,   194,   195,   199,     0,     0,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-       0,     0,     0,    84,     0,     0,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,     0,     0,     0,     0,     0,
-       0,     0,     0,   206,   207,   208,   209,   196,   197,   210,
-     211,     0,    82,   563,     0,   194,   195,     0,     0,     0,
-       0,   198,     0,     0,     0,     0,     0,   199,     0,     0,
-       0,     0,     0,     0,   200,     0,     0,     0,   201,     0,
-       0,     0,     0,     0,    84,     0,     0,    85,    24,     0,
-       0,   202,   203,     0,     0,   204,     0,     0,   196,   197,
-       0,     0,     0,    82,   206,   207,   208,   209,     0,     0,
-     210,   211,   198,     0,   571,     0,   194,   195,   199,     0,
-       0,     0,     0,     0,     0,   200,     0,     0,     0,   201,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,     0,   202,   203,     0,     0,   204,     0,     0,     0,
-       0,     0,     0,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,   573,     0,   194,   195,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,     0,     0,   200,     0,     0,     0,
-     201,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,   202,   203,     0,     0,   204,     0,     0,
-     196,   197,     0,     0,     0,    82,   206,   207,   208,   209,
-       0,     0,   210,   211,   198,     0,   598,     0,   194,   195,
-     199,     0,     0,     0,     0,     0,     0,   200,     0,     0,
-       0,   201,     0,     0,     0,     0,     0,    84,     0,     0,
-      85,    24,     0,     0,   202,   203,     0,     0,   204,     0,
-       0,     0,     0,     0,     0,     0,     0,   206,   207,   208,
-     209,   196,   197,   210,   211,     0,    82,   613,     0,   194,
-     195,     0,     0,     0,     0,   198,     0,     0,     0,     0,
-       0,   199,     0,     0,     0,     0,     0,     0,   200,     0,
-       0,     0,   201,     0,     0,     0,     0,     0,    84,     0,
-       0,    85,    24,     0,     0,   202,   203,     0,     0,   204,
-       0,     0,   196,   197,     0,     0,     0,    82,   206,   207,
-     208,   209,     0,     0,   210,   211,   198,     0,   678,     0,
-     194,   195,   199,     0,     0,     0,     0,     0,     0,   200,
-       0,     0,     0,   201,     0,     0,     0,     0,     0,    84,
-       0,     0,    85,    24,     0,     0,   202,   203,     0,     0,
-     204,     0,     0,     0,     0,     0,     0,     0,     0,   206,
-     207,   208,   209,   196,   197,   210,   211,     0,    82,   682,
-       0,   194,   195,     0,     0,     0,     0,   198,     0,     0,
-       0,     0,     0,   199,     0,     0,     0,     0,     0,     0,
-     200,     0,     0,     0,   201,     0,     0,     0,     0,     0,
-      84,     0,     0,    85,    24,     0,     0,   202,   203,     0,
-       0,   204,     0,     0,   196,   197,     0,     0,     0,    82,
-     206,   207,   208,   209,     0,     0,   210,   211,   198,     0,
-     688,     0,   194,   195,   199,     0,     0,     0,     0,     0,
-       0,   200,     0,     0,     0,   201,     0,     0,     0,     0,
-       0,    84,     0,     0,    85,    24,     0,     0,   202,   203,
-       0,     0,   204,     0,     0,     0,     0,     0,     0,     0,
-       0,   206,   207,   208,   209,   196,   197,   210,   211,     0,
-      82,   714,     0,   194,   195,     0,     0,     0,     0,   198,
-       0,     0,     0,     0,     0,   199,     0,     0,     0,     0,
-       0,     0,   200,     0,     0,     0,   201,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,     0,     0,   196,   197,     0,     0,
-       0,    82,   206,   207,   208,   209,     0,     0,   210,   211,
-     198,     0,   665,     0,     0,     0,   199,     0,     0,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-       0,     0,     0,    84,     0,     0,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,     0,     0,     0,     0,     0,
-       0,     0,     0,   206,   207,   208,   209,   196,   197,   210,
-     211,     0,    82,   725,     0,     0,     0,     0,     0,     0,
-       0,   198,     0,     0,     0,     0,     0,   199,     0,     0,
-       0,     0,     0,     0,   200,     0,     0,     0,   201,     0,
-       0,     0,     0,     0,    84,     0,     0,    85,    24,     0,
-       0,     0,     0,     0,     0,   283,  -295,     0,   196,   197,
-       0,     0,     0,    82,   206,   207,   208,   209,     0,     0,
-     210,   211,   198,     0,   663,     0,     0,     0,   199,     0,
-       0,     0,     0,     0,     0,   200,     0,     0,     0,   201,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,   194,   195,     0,     0,     0,   283,  -295,     0,     0,
-       0,     0,     0,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,     0,     0,     0,     0,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,   196,   197,   200,     0,     0,    82,
-     201,     0,     0,     0,     0,     0,    84,     0,   198,    85,
-      24,     0,   194,   195,   199,     0,     0,   283,     0,     0,
-       0,   200,     0,     0,     0,   201,   206,   207,   208,   209,
-       0,    84,   210,   211,    85,    24,     0,     0,   202,   203,
-       0,     0,   204,     0,   205,   363,     0,     0,     0,   364,
-       0,   206,   207,   208,   209,   196,   197,   210,   211,     0,
-      82,     0,     0,   194,   195,     0,     0,     0,     0,   198,
-       0,     0,     0,     0,     0,   199,     0,     0,     0,     0,
-       0,     0,   200,     0,     0,     0,   201,     0,     0,     0,
-       0,     0,    84,     0,     0,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,   495,     0,   196,   197,     0,     0,
-       0,    82,   206,   207,   208,   209,     0,     0,   210,   211,
-     198,     0,     0,     0,   194,   195,   199,     0,     0,     0,
-       0,     0,     0,   200,     0,     0,     0,   201,     0,     0,
-       0,     0,     0,    84,     0,     0,    85,    24,     0,     0,
-     202,   203,     0,     0,   204,   629,     0,     0,     0,     0,
-       0,     0,     0,   206,   207,   208,   209,   196,   197,   210,
-     211,     0,    82,     0,     0,   194,   195,     0,     0,     0,
-       0,   198,     0,     0,     0,     0,     0,   199,     0,     0,
-       0,     0,     0,     0,   200,     0,     0,     0,   201,     0,
-       0,     0,     0,     0,    84,     0,     0,    85,    24,     0,
-       0,   202,   203,     0,     0,   204,   671,     0,   196,   197,
-       0,     0,     0,    82,   206,   207,   208,   209,     0,     0,
-     210,   211,   198,     0,     0,     0,   194,   195,   199,     0,
-       0,     0,     0,     0,     0,   200,     0,     0,     0,   201,
-       0,     0,     0,     0,     0,    84,     0,     0,    85,    24,
-       0,     0,   202,   203,     0,     0,   204,   684,     0,     0,
-       0,     0,     0,     0,     0,   206,   207,   208,   209,   196,
-     197,   210,   211,     0,    82,     0,     0,     0,     0,     0,
-       0,     0,     0,   198,     0,     0,     0,     0,     0,   199,
-       0,     0,     0,     0,     0,     0,   200,     0,     0,     0,
-     201,     0,     0,     0,     0,     0,    84,     0,     0,    85,
-      24,     0,     0,   202,   203,     0,     0,   204,     0,     5,
-     196,   197,     0,     0,     0,    82,   206,   207,   208,   209,
-       0,     0,   210,   211,   198,     0,     0,     0,     0,     0,
-     199,     0,     0,     0,     0,     0,     0,   200,     0,     0,
-      82,   201,     0,     0,     0,     0,     0,    84,     0,   198,
-      85,    24,     0,     0,     0,   199,     0,     0,   283,     0,
-       0,     0,   200,     0,     0,     0,   201,   206,   207,   208,
-     209,     0,    84,   210,   211,    85,    24,     0,     0,   202,
-     203,     0,     0,   204,     0,     0,     0,     0,     0,     0,
-       0,     0,   206,   207,   208,   209,     0,     0,   210,   211
-};
-
-static const short yycheck[] =
-{
-       6,   136,   314,     9,   127,   294,   334,    66,   205,   180,
-     137,   488,   133,   301,     1,    66,     1,   175,   138,   668,
-       2,   309,     1,   311,     1,    15,    54,     1,    48,   133,
-      12,    13,    14,     0,    93,   442,     1,     1,   639,    98,
-      46,   162,    93,    63,    50,    87,   660,    98,   169,    46,
-      88,     1,    34,    50,     1,    37,    38,    69,   162,     1,
-      66,     1,    68,   121,    76,    73,   133,    73,     1,    96,
-      98,    68,     1,    55,   133,   482,    73,    97,   137,    87,
-     200,    68,   133,   144,    66,     1,   137,    93,     1,   100,
-     101,    68,    98,   151,     1,   162,   154,   698,    88,   111,
-     701,   160,   509,   162,   194,   719,   196,   197,     1,   160,
-     759,   162,   202,   203,   172,   100,    98,   102,     1,   768,
-      94,   100,     1,   102,   175,   184,   132,   133,   102,     7,
-       8,   137,   138,   184,   261,   132,   100,   102,     1,     1,
-     617,   138,     1,   204,   205,   266,    96,    89,    95,   200,
-     100,   133,     1,   204,   160,   137,   162,     1,   279,    99,
-       1,   284,    40,    41,   335,   766,    44,   100,   101,   175,
-     771,   100,   773,     1,   775,   213,    54,    93,   184,    95,
-     162,     1,    98,    99,   100,   101,    99,     1,   194,   195,
-     196,   197,    99,   175,   200,   602,   202,   203,   204,   639,
-       0,     1,   261,   200,   262,    83,    99,   334,    87,    87,
-     261,   272,     1,     1,   275,     1,   336,   100,   101,   626,
-       1,   100,   283,     1,     0,     1,     1,     1,    87,   636,
-      93,    94,   291,    95,   639,    98,    99,   100,   101,   101,
-     291,   100,     1,   294,   651,    45,    95,   285,   126,   127,
-       1,    95,   101,   411,    95,   261,    56,   101,   698,     1,
-     101,   701,    62,   314,     1,   143,     1,    53,    68,    45,
-       1,   101,   100,   562,    94,   334,    76,     1,    64,   261,
-      56,    95,   594,   334,   596,   291,    62,   101,   294,   379,
-     380,   381,    68,   698,   491,   301,   701,   175,    95,    95,
-     100,    98,   180,   309,     1,   311,   102,    95,   314,   370,
-      96,   100,   294,   374,   352,   353,   644,     1,   441,   100,
-      94,    99,   360,   361,   100,   100,   766,   734,   334,     1,
-     336,   771,   314,   773,     1,   775,    53,    12,   399,   336,
-     391,   100,     1,   100,   101,   223,   635,     1,    99,     0,
-       1,   639,   334,     1,     1,   416,   668,     1,   100,     1,
-     411,   766,    37,   100,    99,   426,   771,   428,   773,   100,
-     775,    95,    66,   379,   380,   381,   382,   383,   384,   385,
-     386,   387,   388,   389,   390,   391,   392,   393,   394,   395,
-     396,   397,   398,   483,    45,    66,   274,    94,   459,    93,
-     461,   559,   102,   281,    98,   411,   284,     0,     1,   175,
-     698,    62,    96,   701,   475,     1,   294,    68,    46,    47,
-      98,     1,    64,   301,    96,     1,    96,    98,    95,   411,
-     491,   309,   721,   311,     1,    94,   724,   639,   476,   133,
-      87,   479,    96,   137,     0,     1,     1,   759,    96,   100,
-     738,    95,    45,     1,    96,   576,   768,   335,   579,     0,
-       1,     1,   133,    56,   752,     5,   160,    53,   162,    62,
-      98,   101,   350,    53,   102,    68,    94,   483,   766,     1,
-     175,   175,   488,   771,    64,   773,     1,   775,    64,    45,
-     184,   162,     1,   371,   629,   373,   698,   535,    98,   701,
-      56,     1,   102,     1,    45,     1,    62,   100,   559,     1,
-      96,   562,    68,     0,     1,     1,    96,   644,    93,     2,
-      96,    62,    89,    98,    99,    99,   616,    68,   294,    12,
-      13,    14,     1,   411,    95,   301,    98,    98,     1,    94,
-     675,     1,     1,   309,   100,   311,    94,    87,   314,   670,
-       1,    34,   687,   559,    37,    38,   562,     1,    45,   100,
-     438,    68,   623,   441,   766,    87,    73,   261,    95,   771,
-     175,   773,    55,   775,   101,    62,     1,   559,    87,    94,
-     562,    68,    45,    66,   635,   644,     1,     1,     1,    87,
-       0,     1,    97,   644,    94,   656,   731,   291,    94,   294,
-     294,   662,    94,   133,    94,    68,   301,    51,    94,   660,
-     616,   617,     2,   100,   309,    98,   311,     1,    87,   314,
-     314,     1,    12,    13,    14,   132,   632,    87,    87,   635,
-     160,    94,   162,   639,     1,    45,    87,     1,   644,    83,
-     334,    96,    86,    87,    34,   411,    45,    37,    38,   175,
-     133,    48,    62,   635,   660,    68,     1,    45,    68,     1,
-      73,    45,   644,    62,    77,    55,    63,    51,   719,    68,
-     721,    98,    87,    87,    87,   102,   737,     1,   660,   162,
-     741,   559,    46,    47,   562,     1,    54,    95,     1,   294,
-     100,     1,   698,   101,     1,   701,   301,   391,     1,    83,
-      97,     1,    86,    87,   309,   476,   311,    87,   479,   314,
-     101,    95,     1,   719,     1,   721,   411,   411,   724,     1,
-      87,    45,    98,    87,    66,    89,    68,    51,    92,    93,
-      94,    73,   738,   559,    98,    77,   562,   719,   102,   721,
-      94,    51,    87,   133,    98,    87,   752,     1,   102,     1,
-      96,     3,     4,   102,   100,   633,    96,   635,    98,    83,
-     766,   639,    86,    87,    12,   771,    14,   773,   294,   775,
-     102,    87,   162,    83,    87,   301,    86,    87,    11,    66,
-      87,    68,   660,   309,    87,   311,    73,    87,   314,    37,
-      77,    45,   175,   559,    46,    47,   562,    51,    87,    51,
-      87,    46,    47,   175,    95,    87,   411,    98,    60,   635,
-     478,   102,   480,    12,    66,    18,    19,    20,    21,   102,
-     698,    73,     1,   701,    13,    77,    14,    51,   594,    83,
-     596,    83,    86,    87,    86,    87,    96,   698,    90,    91,
-     701,   719,    94,   721,    96,    97,   724,    87,    92,    93,
-      13,   103,   104,   105,   106,    58,    94,   109,   110,    83,
-     738,   100,    86,    87,   559,   559,    45,   562,   562,   635,
-      95,    34,    51,   639,   752,    38,   101,    94,    46,    47,
-     100,    60,   175,    62,    95,   411,   126,   127,   766,    68,
-     101,   100,    55,   771,   660,   773,    98,   775,    68,   594,
-      95,   596,   668,    95,    83,   766,   101,    86,    87,   101,
-     771,   294,   773,    97,   775,    96,    97,    96,   301,   100,
-      97,    61,   294,   101,   101,    65,   309,    96,   311,   301,
-      98,   314,   698,    67,   102,   701,    94,   309,    94,   311,
-     635,   635,   314,    89,   639,     1,    45,     5,     6,     7,
-     644,    94,    51,   719,   559,   721,    95,   562,   724,    92,
-      93,    60,     1,    62,    94,   660,   660,     3,     4,    68,
-      87,   100,   738,   668,    95,    92,    93,    94,     8,     9,
-      10,    98,    16,    17,    83,   102,   752,    86,    87,   594,
-      95,   596,    96,   759,   387,   388,   389,   390,    97,     1,
-     766,   294,   768,   698,    45,   771,   701,   773,   301,   775,
-      51,    92,    93,    92,    93,    94,   309,    95,   311,    98,
-      96,   314,     1,   102,   719,   719,   721,   721,   411,   724,
-     635,    46,    47,   559,   639,   101,   562,    46,    47,   411,
-     392,   393,    83,   738,    57,    86,    87,    98,    99,   100,
-      92,    93,    94,    57,    95,   660,    98,   752,    98,    99,
-     102,   382,   383,   668,   759,   100,   175,    95,   594,    95,
-     596,   766,    51,   768,     1,    95,   771,    87,   773,    95,
-     775,    60,    92,    93,    94,     1,   100,    66,    98,   384,
-     385,   386,   102,   698,    73,    87,   701,   100,    77,    95,
-      92,    93,    94,    57,    83,    95,    98,    86,    87,   635,
-     102,    90,    91,   639,   719,    94,   721,   391,   411,   724,
-      14,     1,    58,    79,   103,   104,   105,   106,   160,   162,
-     109,   110,   143,   738,   660,   261,   411,    56,    98,   294,
-     268,   314,   668,   314,   658,   658,   577,   752,   577,   353,
-     195,   394,   398,   395,   759,   396,   632,    -1,    -1,    -1,
-     397,   766,    -1,   768,    -1,    45,   771,   402,   773,    -1,
-     775,    51,   698,    -1,    -1,   701,   559,    -1,    -1,   562,
-      60,    -1,    62,    -1,    -1,   294,    -1,   559,    68,     1,
-     562,     3,   301,   719,    -1,   721,    -1,    -1,   724,    -1,
-     309,    -1,   311,    83,    -1,   314,    86,    87,    -1,    -1,
-      -1,   594,   738,   596,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,   594,    -1,   596,    -1,   752,    -1,    -1,    -1,
-      -1,    -1,    -1,   759,    46,    47,    -1,    -1,    -1,    51,
-     766,    -1,   768,    -1,    -1,   771,    -1,   773,    60,   775,
-      -1,    -1,   635,    -1,    66,    -1,   639,    -1,    -1,    -1,
-      -1,    73,    -1,   635,    -1,    77,   559,   639,    -1,   562,
-      -1,    83,    -1,    -1,    86,    87,    -1,   660,    90,    91,
-      -1,    -1,    94,    -1,    -1,   668,    -1,    -1,   660,    -1,
-      -1,   103,   104,   105,   106,    -1,   668,   109,   110,    -1,
-      -1,   594,   411,   596,   194,   195,   196,   197,    -1,    -1,
-      -1,    -1,   202,   203,    -1,   698,    -1,    -1,   701,    -1,
-      -1,    -1,    45,    -1,    -1,    -1,   698,    -1,    51,   701,
-      -1,    -1,    -1,    -1,    -1,    -1,   719,    60,   721,    62,
-      -1,   724,   635,    -1,    -1,    68,   639,   719,    -1,   721,
-      -1,    -1,   724,    -1,    -1,   738,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,   738,   660,    -1,   752,
-      -1,    -1,    -1,    96,    97,   668,   759,   100,    -1,    -1,
-     752,    -1,    -1,   766,    -1,   768,    -1,   759,   771,    -1,
-     773,    -1,   775,    -1,   766,    -1,   768,    -1,    -1,   771,
-      45,   773,    -1,   775,    -1,   698,    51,    -1,   701,    -1,
-      -1,    -1,    -1,    -1,    -1,    60,    -1,    62,    -1,    -1,
-      -1,    -1,    -1,    68,    -1,    -1,   719,    -1,   721,    -1,
-      -1,   724,    -1,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    -1,   738,    -1,    -1,    -1,    -1,
-     559,    96,    97,   562,    -1,   100,    -1,    -1,    -1,   752,
-      -1,    -1,    -1,    -1,    -1,    -1,   759,    -1,    -1,    -1,
-       1,    -1,    -1,   766,    -1,   768,    -1,    -1,   771,    -1,
-     773,    -1,   775,    -1,    -1,   594,    -1,   596,    -1,   379,
-     380,   381,   382,   383,   384,   385,   386,   387,   388,   389,
-     390,    -1,   392,   393,   394,   395,   396,   397,   398,   194,
-     195,   196,   197,    -1,    45,    46,    47,   202,   203,    -1,
-      51,    -1,    -1,    -1,    -1,    -1,   635,    -1,    -1,    60,
-     639,     1,    -1,     3,     4,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,   660,    83,    -1,    -1,    86,    87,    -1,    -1,   668,
-      -1,    -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,   100,
-      -1,    -1,   103,   104,   105,   106,    46,    47,   109,   110,
-      -1,    51,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   698,
-      60,    -1,   701,   483,    -1,    -1,    66,    -1,   488,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-     719,    -1,   721,    83,    -1,   724,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    -1,    96,    -1,    -1,   738,
-      -1,    45,    -1,   103,   104,   105,   106,    51,    -1,   109,
-     110,    -1,    -1,   752,    -1,    -1,    60,    -1,    62,    -1,
-     759,    -1,    -1,    -1,    68,    -1,    -1,   766,    -1,   768,
-      -1,    -1,   771,    -1,   773,    -1,   775,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    97,    -1,     1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,   379,   380,   381,   382,   383,   384,
-     385,   386,   387,   388,   389,   390,    -1,   392,   393,   394,
-     395,   396,   397,   398,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,   616,   617,    -1,    45,
-      46,    47,    48,    49,    50,    51,    52,    -1,    -1,    55,
-      -1,    -1,   632,    59,    60,    -1,    -1,    63,    -1,    -1,
-      66,    67,    68,    69,    -1,    71,    72,    73,    74,    -1,
-       1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,
-      86,    87,    -1,    -1,    -1,    -1,    -1,    -1,    94,    -1,
-      96,    97,    -1,    -1,   100,    -1,    -1,   103,   104,   105,
-     106,    -1,    -1,   109,   110,    -1,    -1,    -1,   483,    -1,
-      -1,    -1,    -1,   488,    45,    46,    47,    48,    49,    50,
-      51,    52,    -1,    -1,    55,    -1,    -1,    -1,    59,    60,
-      -1,    -1,    63,    -1,    -1,    66,    67,    68,    69,    -1,
-      71,    72,    73,    74,     1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    -1,
-      -1,    -1,    -1,    94,    -1,    96,    97,    -1,    -1,   100,
-      -1,    -1,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    45,    46,
-      47,    48,    49,    50,    51,    52,    -1,    -1,    55,    -1,
-      -1,    -1,    59,    60,    -1,    -1,    63,    -1,    -1,    66,
-      67,    68,    69,    -1,    71,    72,    73,    74,     1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    -1,    -1,    -1,    -1,    94,    -1,    96,
-      97,   616,   617,   100,    -1,    -1,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    -1,    -1,    -1,   632,    -1,    -1,
-      -1,    -1,    45,    46,    47,    -1,    49,    50,    51,    52,
-      -1,    -1,    55,    -1,    -1,    -1,    59,    60,    -1,    -1,
-      -1,    -1,    -1,    66,    67,    68,    69,     1,    71,    72,
-      73,    74,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,    -1,    -1,    -1,    -1,
-      -1,    94,    -1,    96,    97,    -1,    -1,   100,    -1,    -1,
-     103,   104,   105,   106,    -1,    -1,   109,   110,    -1,    -1,
-      -1,    45,    46,    47,    -1,    49,    50,    51,    52,    -1,
-      -1,    55,    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,
-      -1,    -1,    66,    67,    68,    69,     1,    71,    72,    73,
-      74,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    -1,    -1,    -1,    -1,
-      94,    -1,    96,    -1,    -1,    -1,   100,    -1,    -1,   103,
-     104,   105,   106,    -1,    -1,   109,   110,    -1,    -1,    -1,
-      45,    46,    47,    -1,    49,    50,    51,    52,    -1,    -1,
-      55,    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    -1,
-      -1,    66,    67,     1,    69,    -1,    71,    72,    73,    74,
-      -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    -1,    -1,    -1,    -1,    -1,    94,
-      -1,    96,    -1,    -1,    -1,   100,    -1,    -1,   103,   104,
-     105,   106,    -1,    -1,   109,   110,    -1,    45,    46,    47,
-      -1,    49,    50,    51,    52,    -1,    -1,    55,    -1,    -1,
-      -1,    59,    60,    -1,     1,    -1,     3,     4,    66,    67,
-      -1,    69,    -1,    71,    72,    73,    74,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,    -1,    -1,    -1,    -1,    -1,    94,    -1,    96,    -1,
-      -1,    -1,   100,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,     1,    -1,     3,     4,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,
-      46,    47,    -1,   100,    -1,    51,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    60,    -1,     1,    -1,     3,     4,
-      66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,
-      -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,
-      86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,
-      -1,    -1,    -1,    99,    -1,    -1,    -1,   103,   104,   105,
-     106,    46,    47,   109,   110,    -1,    51,     1,    -1,     3,
-       4,    -1,    -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,
-      -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,
-      -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    89,    90,    91,    -1,    -1,    94,
-      -1,    -1,    46,    47,    -1,    -1,    -1,    51,   103,   104,
-     105,   106,    -1,    -1,   109,   110,    60,    -1,     1,    -1,
-       3,     4,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,
-      -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,
-      94,    95,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,
-     104,   105,   106,    46,    47,   109,   110,    -1,    51,     1,
-      -1,     3,     4,    -1,    -1,    -1,    -1,    60,    -1,    -1,
-      -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,
-      73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,
-      -1,    94,    -1,    -1,    46,    47,    -1,   100,    -1,    51,
-     103,   104,   105,   106,    -1,    -1,   109,   110,    60,    -1,
-       1,    -1,     3,     4,    66,    -1,    -1,    -1,    -1,    -1,
-      -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,
-      -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,
-      -1,    -1,    94,    -1,    -1,    -1,    -1,    99,    -1,    -1,
-      -1,   103,   104,   105,   106,    46,    47,   109,   110,    -1,
-      51,     1,    -1,     3,     4,    -1,    -1,    -1,    -1,    60,
-      -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    95,    -1,    46,    47,    -1,    -1,
-      -1,    51,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      60,    -1,     1,    -1,     3,     4,    66,    -1,    -1,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-      -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    95,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,   103,   104,   105,   106,    46,    47,   109,
-     110,    -1,    51,     1,    -1,     3,     4,    -1,    -1,    -1,
-      -1,    60,    -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,
-      -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,
-      -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,
-      -1,    90,    91,    -1,    -1,    94,    95,    -1,    46,    47,
-      -1,    -1,    -1,    51,   103,   104,   105,   106,    -1,    -1,
-     109,   110,    60,    -1,     1,    -1,     3,     4,    66,    -1,
-      -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,    -1,    90,    91,    -1,    -1,    94,    95,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,     1,    -1,     3,     4,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,
-      46,    47,    -1,   100,    -1,    51,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    60,    -1,     1,    -1,     3,     4,
-      66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,
-      -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,
-      86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,   104,   105,
-     106,    46,    47,   109,   110,    -1,    51,     1,    -1,     3,
-       4,    -1,    -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,
-      -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,
-      -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,
-      -1,    -1,    46,    47,    -1,    -1,    -1,    51,   103,   104,
-     105,   106,    -1,    -1,   109,   110,    60,    -1,     1,    -1,
-       3,     4,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,
-      -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,
-      94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,
-     104,   105,   106,    46,    47,   109,   110,    -1,    51,     1,
-      -1,     3,     4,    -1,    -1,    -1,    -1,    60,    -1,    -1,
-      -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,
-      73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,
-      -1,    94,    -1,    -1,    46,    47,    -1,    -1,    -1,    51,
-     103,   104,   105,   106,    -1,    -1,   109,   110,    60,    -1,
-       1,    -1,     3,     4,    66,    -1,    -1,    -1,    -1,    -1,
-      -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,
-      -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,
-      -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,   103,   104,   105,   106,    46,    47,   109,   110,    -1,
-      51,     1,    -1,     3,     4,    -1,    -1,    -1,    -1,    60,
-      -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    -1,    -1,    46,    47,    -1,    -1,
-      -1,    51,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      60,    -1,     1,    -1,     3,     4,    66,    -1,    -1,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-      -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,   103,   104,   105,   106,    46,    47,   109,
-     110,    -1,    51,     1,    -1,     3,     4,    -1,    -1,    -1,
-      -1,    60,    -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,
-      -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,
-      -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,
-      -1,    90,    91,    -1,    -1,    94,    -1,    -1,    46,    47,
-      -1,    -1,    -1,    51,   103,   104,   105,   106,    -1,    -1,
-     109,   110,    60,    -1,     1,    -1,     3,     4,    66,    -1,
-      -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,     1,    -1,     3,     4,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,
-      46,    47,    -1,    -1,    -1,    51,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    60,    -1,     1,    -1,     3,     4,
-      66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,
-      -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,
-      86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,   104,   105,
-     106,    46,    47,   109,   110,    -1,    51,     1,    -1,     3,
-       4,    -1,    -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,
-      -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,
-      -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,
-      -1,    -1,    46,    47,    -1,    -1,    -1,    51,   103,   104,
-     105,   106,    -1,    -1,   109,   110,    60,    -1,     1,    -1,
-       3,     4,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,
-      -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,
-      94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,
-     104,   105,   106,    46,    47,   109,   110,    -1,    51,     1,
-      -1,     3,     4,    -1,    -1,    -1,    -1,    60,    -1,    -1,
-      -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,
-      73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,
-      -1,    94,    -1,    -1,    46,    47,    -1,    -1,    -1,    51,
-     103,   104,   105,   106,    -1,    -1,   109,   110,    60,    -1,
-       1,    -1,     3,     4,    66,    -1,    -1,    -1,    -1,    -1,
-      -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,
-      -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,
-      -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,   103,   104,   105,   106,    46,    47,   109,   110,    -1,
-      51,     1,    -1,     3,     4,    -1,    -1,    -1,    -1,    60,
-      -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    -1,    -1,    46,    47,    -1,    -1,
-      -1,    51,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      60,    -1,     1,    -1,     3,     4,    66,    -1,    -1,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-      -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,   103,   104,   105,   106,    46,    47,   109,
-     110,    -1,    51,     1,    -1,     3,     4,    -1,    -1,    -1,
-      -1,    60,    -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,
-      -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,
-      -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,
-      -1,    90,    91,    -1,    -1,    94,    -1,    -1,    46,    47,
-      -1,    -1,    -1,    51,   103,   104,   105,   106,    -1,    -1,
-     109,   110,    60,    -1,     1,    -1,     3,     4,    66,    -1,
-      -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,     1,    -1,     3,     4,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,
-      46,    47,    -1,    -1,    -1,    51,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    60,    -1,     1,    -1,     3,     4,
-      66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,
-      -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,
-      86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,   104,   105,
-     106,    46,    47,   109,   110,    -1,    51,     1,    -1,     3,
-       4,    -1,    -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,
-      -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,
-      -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,
-      -1,    -1,    46,    47,    -1,    -1,    -1,    51,   103,   104,
-     105,   106,    -1,    -1,   109,   110,    60,    -1,     1,    -1,
-       3,     4,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,
-      -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,
-      94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,
-     104,   105,   106,    46,    47,   109,   110,    -1,    51,     1,
-      -1,     3,     4,    -1,    -1,    -1,    -1,    60,    -1,    -1,
-      -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,
-      73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,
-      -1,    94,    -1,    -1,    46,    47,    -1,    -1,    -1,    51,
-     103,   104,   105,   106,    -1,    -1,   109,   110,    60,    -1,
-       1,    -1,     3,     4,    66,    -1,    -1,    -1,    -1,    -1,
-      -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,
-      -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,
-      -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,   103,   104,   105,   106,    46,    47,   109,   110,    -1,
-      51,     1,    -1,     3,     4,    -1,    -1,    -1,    -1,    60,
-      -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    -1,    -1,    46,    47,    -1,    -1,
-      -1,    51,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      60,    -1,     1,    -1,     3,     4,    66,    -1,    -1,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-      -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,   103,   104,   105,   106,    46,    47,   109,
-     110,    -1,    51,     1,    -1,     3,     4,    -1,    -1,    -1,
-      -1,    60,    -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,
-      -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,
-      -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,
-      -1,    90,    91,    -1,    -1,    94,    -1,    -1,    46,    47,
-      -1,    -1,    -1,    51,   103,   104,   105,   106,    -1,    -1,
-     109,   110,    60,    -1,     1,    -1,     3,     4,    66,    -1,
-      -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,     1,    -1,     3,     4,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,    -1,
-      46,    47,    -1,    -1,    -1,    51,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    60,    -1,     1,    -1,     3,     4,
-      66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,
-      -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,
-      86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,
-      -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,   104,   105,
-     106,    46,    47,   109,   110,    -1,    51,     1,    -1,     3,
-       4,    -1,    -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,
-      -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,
-      -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,
-      -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,    94,
-      -1,    -1,    46,    47,    -1,    -1,    -1,    51,   103,   104,
-     105,   106,    -1,    -1,   109,   110,    60,    -1,     1,    -1,
-       3,     4,    66,    -1,    -1,    -1,    -1,    -1,    -1,    73,
-      -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,    83,
-      -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,    -1,
-      94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   103,
-     104,   105,   106,    46,    47,   109,   110,    -1,    51,     1,
-      -1,     3,     4,    -1,    -1,    -1,    -1,    60,    -1,    -1,
-      -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,    -1,    -1,
-      73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,    -1,
-      83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,    -1,
-      -1,    94,    -1,    -1,    46,    47,    -1,    -1,    -1,    51,
-     103,   104,   105,   106,    -1,    -1,   109,   110,    60,    -1,
-       1,    -1,     3,     4,    66,    -1,    -1,    -1,    -1,    -1,
-      -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,    -1,
-      -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,    91,
-      -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,   103,   104,   105,   106,    46,    47,   109,   110,    -1,
-      51,     1,    -1,     3,     4,    -1,    -1,    -1,    -1,    60,
-      -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    -1,    -1,    46,    47,    -1,    -1,
-      -1,    51,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      60,    -1,     1,    -1,    -1,    -1,    66,    -1,    -1,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-      -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,   103,   104,   105,   106,    46,    47,   109,
-     110,    -1,    51,     1,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,    60,    -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,
-      -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,
-      -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,
-      -1,    -1,    -1,    -1,    -1,    94,    95,    -1,    46,    47,
-      -1,    -1,    -1,    51,   103,   104,   105,   106,    -1,    -1,
-     109,   110,    60,    -1,     1,    -1,    -1,    -1,    66,    -1,
-      -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,     3,     4,    -1,    -1,    -1,    94,    95,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    46,    47,    73,    -1,    -1,    51,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    60,    86,
-      87,    -1,     3,     4,    66,    -1,    -1,    94,    -1,    -1,
-      -1,    73,    -1,    -1,    -1,    77,   103,   104,   105,   106,
-      -1,    83,   109,   110,    86,    87,    -1,    -1,    90,    91,
-      -1,    -1,    94,    -1,    96,    97,    -1,    -1,    -1,   101,
-      -1,   103,   104,   105,   106,    46,    47,   109,   110,    -1,
-      51,    -1,    -1,     3,     4,    -1,    -1,    -1,    -1,    60,
-      -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,    -1,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,    -1,
-      -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    95,    -1,    46,    47,    -1,    -1,
-      -1,    51,   103,   104,   105,   106,    -1,    -1,   109,   110,
-      60,    -1,    -1,    -1,     3,     4,    66,    -1,    -1,    -1,
-      -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,    -1,
-      -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,    -1,
-      90,    91,    -1,    -1,    94,    95,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,   103,   104,   105,   106,    46,    47,   109,
-     110,    -1,    51,    -1,    -1,     3,     4,    -1,    -1,    -1,
-      -1,    60,    -1,    -1,    -1,    -1,    -1,    66,    -1,    -1,
-      -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,    -1,
-      -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,    -1,
-      -1,    90,    91,    -1,    -1,    94,    95,    -1,    46,    47,
-      -1,    -1,    -1,    51,   103,   104,   105,   106,    -1,    -1,
-     109,   110,    60,    -1,    -1,    -1,     3,     4,    66,    -1,
-      -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,    77,
-      -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,    87,
-      -1,    -1,    90,    91,    -1,    -1,    94,    95,    -1,    -1,
-      -1,    -1,    -1,    -1,    -1,   103,   104,   105,   106,    46,
-      47,   109,   110,    -1,    51,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,    -1,    60,    -1,    -1,    -1,    -1,    -1,    66,
-      -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,    -1,
-      77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    -1,    86,
-      87,    -1,    -1,    90,    91,    -1,    -1,    94,    -1,    45,
-      46,    47,    -1,    -1,    -1,    51,   103,   104,   105,   106,
-      -1,    -1,   109,   110,    60,    -1,    -1,    -1,    -1,    -1,
-      66,    -1,    -1,    -1,    -1,    -1,    -1,    73,    -1,    -1,
-      51,    77,    -1,    -1,    -1,    -1,    -1,    83,    -1,    60,
-      86,    87,    -1,    -1,    -1,    66,    -1,    -1,    94,    -1,
-      -1,    -1,    73,    -1,    -1,    -1,    77,   103,   104,   105,
-     106,    -1,    83,   109,   110,    86,    87,    -1,    -1,    90,
-      91,    -1,    -1,    94,    -1,    -1,    -1,    -1,    -1,    -1,
-      -1,    -1,   103,   104,   105,   106,    -1,    -1,   109,   110
-};
-
-/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
-   symbol of state STATE-NUM.  */
-static const unsigned short yystos[] =
-{
-       0,   112,   113,     0,     1,    45,    56,    62,    68,    76,
-     100,   126,   127,   128,   129,   130,   131,   132,   133,   134,
-     135,   170,   193,     1,    87,   122,   123,   124,   125,   125,
-       1,   125,     1,   122,   128,   130,   133,   127,   128,    45,
-      62,    68,     1,   100,   102,     1,    64,   171,   175,     1,
-      64,   138,     1,   100,   102,   128,   125,     1,   125,     1,
-       5,   125,     1,   118,   120,   122,    96,   176,   101,   173,
-       1,   118,   119,    53,   139,     1,   172,   175,     1,   138,
-       1,   100,    51,    60,    83,    86,    97,   115,   116,   117,
-     118,   121,   122,   134,   135,   145,   152,   170,   177,   178,
-     179,   180,     1,   120,   176,     1,     1,   120,   140,   137,
-     176,   174,   139,     1,   125,   153,     1,   125,   146,   147,
-     148,   153,    98,   245,   245,     1,    60,   115,     1,   100,
-      97,   178,   101,    96,   141,   176,   136,    94,    54,    98,
-     157,     1,   100,   101,    93,    98,    99,   157,    99,    98,
-       1,   153,     1,   146,   153,     1,   120,    96,    97,   123,
-     134,   135,   142,   143,   144,   145,   150,   152,   160,   161,
-     162,   164,   165,   170,   183,   184,   193,   141,     1,    95,
-     115,   134,   154,   155,   156,     1,   119,   158,     1,    99,
-       1,   125,   147,     1,     3,     4,    46,    47,    60,    66,
-      73,    77,    90,    91,    94,    96,   103,   104,   105,   106,
-     109,   110,   114,   116,   121,   122,   149,   181,   233,   234,
-     235,   236,   237,   240,   242,   246,   247,   248,   249,   250,
-     251,   252,   253,   254,   255,   256,   257,   258,   259,   260,
-     261,   262,   263,   264,   265,   266,   267,   268,   269,   270,
-     271,   273,     1,    99,     1,     1,    99,   157,   100,   157,
-      97,    94,   165,    97,   143,     1,   151,   183,   163,   157,
-       1,    49,    50,    52,    55,    59,    66,    67,    69,    71,
-      72,    74,    77,    94,   115,   116,   121,   122,   125,   134,
-     135,   156,   169,   183,   186,   187,   188,   189,   190,   192,
-     193,   194,   195,   197,   198,   199,   200,   202,   204,   210,
-     211,   213,   214,   215,   217,   218,   222,   223,   224,   225,
-     226,   227,   228,   236,   247,   249,   250,   251,   254,   255,
-     270,     1,   148,    95,   101,   115,   101,     1,   122,   246,
-     248,   253,     1,   252,     1,   253,     1,   253,   102,     1,
-     102,     1,   116,   118,   119,     1,   253,     1,   253,     1,
-     116,   122,   273,    97,   101,   149,   182,   102,   102,    94,
-      98,   102,     1,   102,    98,     1,   125,    46,    47,     5,
-       6,     7,     3,     4,     8,     9,    10,    18,    19,    20,
-      21,    58,    16,    17,    11,    12,    13,    14,    15,    88,
-      92,    93,   272,    95,   154,   157,   100,   159,   183,    96,
-     166,   184,    96,    97,   100,     1,    94,     1,   273,     1,
-     100,   125,     1,   100,   273,     1,    94,     1,    94,     1,
-     183,     1,    94,     1,   100,   125,   273,   146,   102,     1,
-      89,   115,    94,    97,   185,   187,   100,   122,   134,   190,
-     100,   203,   190,   190,   122,   189,   198,   219,   221,   100,
-       1,    94,     1,   155,     1,   148,     1,   119,     1,    68,
-       1,   125,    98,    99,   100,    98,   243,   244,   245,   243,
-     245,     1,    94,    95,    98,   245,   245,     1,    95,    97,
-      97,   101,     1,    68,    68,    95,   241,   273,     1,   273,
-       1,    68,    73,    77,    73,   125,     1,   273,     1,    94,
-       1,   253,     1,   253,     1,   253,     1,   258,     1,   258,
-       1,   259,     1,   259,     1,   259,     1,   260,     1,   260,
-       1,   260,     1,   260,     1,   116,   117,     1,   261,     1,
-     261,     1,   262,     1,   263,     1,   264,     1,   265,     1,
-     266,     1,    89,   273,     1,   269,    95,   122,   167,   168,
-     169,   185,   186,     1,   273,     1,   100,     1,   100,     1,
-     100,     1,   273,     1,   273,    61,    65,   229,   230,   231,
-     232,     1,     1,   100,    95,    66,   146,     1,    95,   241,
-      96,   205,    67,     1,   101,     1,   100,   273,     1,   273,
-      95,   102,    94,     1,   273,   244,   245,   181,   245,   181,
-       1,    95,   241,     1,   253,     1,    95,    95,   256,     1,
-      97,   149,    95,   101,     1,    99,    94,     1,    99,    95,
-     241,     1,    89,   102,   167,   186,    94,   167,     1,    95,
-       1,    95,    95,     1,    94,     1,   183,   230,   232,   183,
-       1,    94,     1,     1,    95,    48,    63,    97,   206,   207,
-     208,   209,    94,     1,   198,     1,   220,   221,   100,    95,
-      95,    95,   241,     1,    99,   239,     1,    95,     1,   253,
-       1,   256,     1,   273,    95,   241,   141,    95,     1,   268,
-      66,   167,    95,   241,    49,   190,   191,   192,   194,   196,
-     201,   210,   212,   216,   218,     1,     1,   155,     1,    95,
-     241,     1,     1,    89,     1,   273,   274,    97,   207,   208,
-      97,   186,   209,   273,    95,     1,   220,     1,   183,    95,
-     141,   238,    95,   141,    94,   100,    95,    94,    57,   191,
-     191,   100,    95,    95,     1,     1,    95,     1,    89,    97,
-      95,   190,    95,   141,    95,   241,   100,   273,   190,   100,
-     273,     1,   100,   190,   100,    95,    95,   220,   100,   100,
-     191,    95,   220,    57,   191,    95,   191,   191
-};
-
-#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
-# define YYSIZE_T __SIZE_TYPE__
-#endif
-#if ! defined (YYSIZE_T) && defined (size_t)
-# define YYSIZE_T size_t
-#endif
-#if ! defined (YYSIZE_T)
-# if defined (__STDC__) || defined (__cplusplus)
-#  include <stddef.h> /* INFRINGES ON USER NAME SPACE */
-#  define YYSIZE_T size_t
-# endif
-#endif
-#if ! defined (YYSIZE_T)
-# define YYSIZE_T unsigned int
-#endif
-
-#define yyerrok                (yyerrstatus = 0)
-#define yyclearin      (yychar = YYEMPTY)
-#define YYEMPTY                (-2)
-#define YYEOF          0
-
-#define YYACCEPT       goto yyacceptlab
-#define YYABORT                goto yyabortlab
-#define YYERROR                goto yyerrlab1
-
-/* Like YYERROR except do call yyerror.  This remains here temporarily
-   to ease the transition to the new meaning of YYERROR, for GCC.
-   Once GCC version 2 has supplanted version 1, this can go.  */
-
-#define YYFAIL         goto yyerrlab
-
-#define YYRECOVERING()  (!!yyerrstatus)
-
-#define YYBACKUP(Token, Value)                                 \
-do                                                             \
-  if (yychar == YYEMPTY && yylen == 1)                         \
-    {                                                          \
-      yychar = (Token);                                                \
-      yylval = (Value);                                                \
-      yytoken = YYTRANSLATE (yychar);                          \
-      YYPOPSTACK;                                              \
-      goto yybackup;                                           \
-    }                                                          \
-  else                                                         \
-    {                                                          \
-      yyerror ("syntax error: cannot back up");\
-      YYERROR;                                                 \
-    }                                                          \
-while (0)
-
-#define YYTERROR       1
-#define YYERRCODE      256
-
-/* YYLLOC_DEFAULT -- Compute the default location (before the actions
-   are run).  */
-
-#ifndef YYLLOC_DEFAULT
-# define YYLLOC_DEFAULT(Current, Rhs, N)         \
-  Current.first_line   = Rhs[1].first_line;      \
-  Current.first_column = Rhs[1].first_column;    \
-  Current.last_line    = Rhs[N].last_line;       \
-  Current.last_column  = Rhs[N].last_column;
-#endif
-
-/* YYLEX -- calling `yylex' with the right arguments.  */
-
-#ifdef YYLEX_PARAM
-# define YYLEX yylex (&yylval, YYLEX_PARAM)
-#else
-# define YYLEX yylex (&yylval)
-#endif
-
-/* Enable debugging if requested.  */
-#if YYDEBUG
-
-# ifndef YYFPRINTF
-#  include <stdio.h> /* INFRINGES ON USER NAME SPACE */
-#  define YYFPRINTF fprintf
-# endif
-
-# define YYDPRINTF(Args)                       \
-do {                                           \
-  if (yydebug)                                 \
-    YYFPRINTF Args;                            \
-} while (0)
-
-# define YYDSYMPRINT(Args)                     \
-do {                                           \
-  if (yydebug)                                 \
-    yysymprint Args;                           \
-} while (0)
-
-# define YYDSYMPRINTF(Title, Token, Value, Location)           \
-do {                                                           \
-  if (yydebug)                                                 \
-    {                                                          \
-      YYFPRINTF (stderr, "%s ", Title);                                \
-      yysymprint (stderr,                                      \
-                  Token, Value);       \
-      YYFPRINTF (stderr, "\n");                                        \
-    }                                                          \
-} while (0)
-
-/*------------------------------------------------------------------.
-| yy_stack_print -- Print the state stack from its BOTTOM up to its |
-| TOP (cinluded).                                                   |
-`------------------------------------------------------------------*/
-
-#if defined (__STDC__) || defined (__cplusplus)
-static void
-yy_stack_print (short *bottom, short *top)
-#else
-static void
-yy_stack_print (bottom, top)
-    short *bottom;
-    short *top;
-#endif
-{
-  YYFPRINTF (stderr, "Stack now");
-  for (/* Nothing. */; bottom <= top; ++bottom)
-    YYFPRINTF (stderr, " %d", *bottom);
-  YYFPRINTF (stderr, "\n");
-}
-
-# define YY_STACK_PRINT(Bottom, Top)                           \
-do {                                                           \
-  if (yydebug)                                                 \
-    yy_stack_print ((Bottom), (Top));                          \
-} while (0)
-
-
-/*------------------------------------------------.
-| Report that the YYRULE is going to be reduced.  |
-`------------------------------------------------*/
-
-#if defined (__STDC__) || defined (__cplusplus)
-static void
-yy_reduce_print (int yyrule)
-#else
-static void
-yy_reduce_print (yyrule)
-    int yyrule;
-#endif
-{
-  int yyi;
-  unsigned int yylineno = yyrline[yyrule];
-  YYFPRINTF (stderr, "Reducing stack by rule %d (line %u), ",
-             yyrule - 1, yylineno);
-  /* Print the symbols being reduced, and their result.  */
-  for (yyi = yyprhs[yyrule]; 0 <= yyrhs[yyi]; yyi++)
-    YYFPRINTF (stderr, "%s ", yytname [yyrhs[yyi]]);
-  YYFPRINTF (stderr, "-> %s\n", yytname [yyr1[yyrule]]);
-}
-
-# define YY_REDUCE_PRINT(Rule)         \
-do {                                   \
-  if (yydebug)                         \
-    yy_reduce_print (Rule);            \
-} while (0)
-
-/* Nonzero means print parse trace.  It is left uninitialized so that
-   multiple parsers can coexist.  */
-int yydebug;
-#else /* !YYDEBUG */
-# define YYDPRINTF(Args)
-# define YYDSYMPRINT(Args)
-# define YYDSYMPRINTF(Title, Token, Value, Location)
-# define YY_STACK_PRINT(Bottom, Top)
-# define YY_REDUCE_PRINT(Rule)
-#endif /* !YYDEBUG */
-
-
-/* YYINITDEPTH -- initial size of the parser's stacks.  */
-#ifndef        YYINITDEPTH
-# define YYINITDEPTH 200
-#endif
-
-/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
-   if the built-in stack extension method is used).
-
-   Do not make this value too large; the results are undefined if
-   SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH)
-   evaluated with infinite-precision integer arithmetic.  */
-
-#if YYMAXDEPTH == 0
-# undef YYMAXDEPTH
-#endif
-
-#ifndef YYMAXDEPTH
-# define YYMAXDEPTH 10000
-#endif
-
-\f
-
-#if YYERROR_VERBOSE
-
-# ifndef yystrlen
-#  if defined (__GLIBC__) && defined (_STRING_H)
-#   define yystrlen strlen
-#  else
-/* Return the length of YYSTR.  */
-static YYSIZE_T
-#   if defined (__STDC__) || defined (__cplusplus)
-yystrlen (const char *yystr)
-#   else
-yystrlen (yystr)
-     const char *yystr;
-#   endif
-{
-  register const char *yys = yystr;
-
-  while (*yys++ != '\0')
-    continue;
-
-  return yys - yystr - 1;
-}
-#  endif
-# endif
-
-# ifndef yystpcpy
-#  if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE)
-#   define yystpcpy stpcpy
-#  else
-/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
-   YYDEST.  */
-static char *
-#   if defined (__STDC__) || defined (__cplusplus)
-yystpcpy (char *yydest, const char *yysrc)
-#   else
-yystpcpy (yydest, yysrc)
-     char *yydest;
-     const char *yysrc;
-#   endif
-{
-  register char *yyd = yydest;
-  register const char *yys = yysrc;
-
-  while ((*yyd++ = *yys++) != '\0')
-    continue;
-
-  return yyd - 1;
-}
-#  endif
-# endif
-
-#endif /* !YYERROR_VERBOSE */
-
-\f
-
-#if YYDEBUG
-/*--------------------------------.
-| Print this symbol on YYOUTPUT.  |
-`--------------------------------*/
-
-#if defined (__STDC__) || defined (__cplusplus)
-static void
-yysymprint (FILE *yyoutput, int yytype, YYSTYPE *yyvaluep)
-#else
-static void
-yysymprint (yyoutput, yytype, yyvaluep)
-    FILE *yyoutput;
-    int yytype;
-    YYSTYPE *yyvaluep;
-#endif
-{
-  /* Pacify ``unused variable'' warnings.  */
-  (void) yyvaluep;
-
-  if (yytype < YYNTOKENS)
-    {
-      YYFPRINTF (yyoutput, "token %s (", yytname[yytype]);
-# ifdef YYPRINT
-      YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
-# endif
-    }
-  else
-    YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]);
-
-  switch (yytype)
-    {
-      default:
-        break;
-    }
-  YYFPRINTF (yyoutput, ")");
-}
-
-#endif /* ! YYDEBUG */
-/*-----------------------------------------------.
-| Release the memory associated to this symbol.  |
-`-----------------------------------------------*/
-
-#if defined (__STDC__) || defined (__cplusplus)
-static void
-yydestruct (int yytype, YYSTYPE *yyvaluep)
-#else
-static void
-yydestruct (yytype, yyvaluep)
-    int yytype;
-    YYSTYPE *yyvaluep;
-#endif
-{
-  /* Pacify ``unused variable'' warnings.  */
-  (void) yyvaluep;
-
-  switch (yytype)
-    {
-
-      default:
-        break;
-    }
-}
-\f
-
-/* Prevent warnings from -Wmissing-prototypes.  */
-
-#ifdef YYPARSE_PARAM
-# if defined (__STDC__) || defined (__cplusplus)
-int yyparse (void *YYPARSE_PARAM);
-# else
-int yyparse ();
-# endif
-#else /* ! YYPARSE_PARAM */
-#if defined (__STDC__) || defined (__cplusplus)
-int yyparse (void);
-#else
-int yyparse ();
-#endif
-#endif /* ! YYPARSE_PARAM */
-
-
-
-
-
-
-/*----------.
-| yyparse.  |
-`----------*/
-
-#ifdef YYPARSE_PARAM
-# if defined (__STDC__) || defined (__cplusplus)
-int yyparse (void *YYPARSE_PARAM)
-# else
-int yyparse (YYPARSE_PARAM)
-  void *YYPARSE_PARAM;
-# endif
-#else /* ! YYPARSE_PARAM */
-#if defined (__STDC__) || defined (__cplusplus)
-int
-yyparse (void)
-#else
-int
-yyparse ()
-
-#endif
-#endif
-{
-  /* The lookahead symbol.  */
-int yychar;
-
-/* The semantic value of the lookahead symbol.  */
-YYSTYPE yylval;
-
-/* Number of syntax errors so far.  */
-int yynerrs;
-
-  register int yystate;
-  register int yyn;
-  int yyresult;
-  /* Number of tokens to shift before error messages enabled.  */
-  int yyerrstatus;
-  /* Lookahead token as an internal (translated) token number.  */
-  int yytoken = 0;
-
-  /* Three stacks and their tools:
-     `yyss': related to states,
-     `yyvs': related to semantic values,
-     `yyls': related to locations.
-
-     Refer to the stacks thru separate pointers, to allow yyoverflow
-     to reallocate them elsewhere.  */
-
-  /* The state stack.  */
-  short        yyssa[YYINITDEPTH];
-  short *yyss = yyssa;
-  register short *yyssp;
-
-  /* The semantic value stack.  */
-  YYSTYPE yyvsa[YYINITDEPTH];
-  YYSTYPE *yyvs = yyvsa;
-  register YYSTYPE *yyvsp;
-
-
-
-#define YYPOPSTACK   (yyvsp--, yyssp--)
-
-  YYSIZE_T yystacksize = YYINITDEPTH;
-
-  /* The variables used to return semantic value and location from the
-     action routines.  */
-  YYSTYPE yyval;
-
-
-  /* When reducing, the number of symbols on the RHS of the reduced
-     rule.  */
-  int yylen;
-
-  YYDPRINTF ((stderr, "Starting parse\n"));
-
-  yystate = 0;
-  yyerrstatus = 0;
-  yynerrs = 0;
-  yychar = YYEMPTY;            /* Cause a token to be read.  */
-
-  /* Initialize stack pointers.
-     Waste one element of value and location stack
-     so that they stay on the same level as the state stack.
-     The wasted elements are never initialized.  */
-
-  yyssp = yyss;
-  yyvsp = yyvs;
-
-  goto yysetstate;
-
-/*------------------------------------------------------------.
-| yynewstate -- Push a new state, which is found in yystate.  |
-`------------------------------------------------------------*/
- yynewstate:
-  /* In all cases, when you get here, the value and location stacks
-     have just been pushed. so pushing a state here evens the stacks.
-     */
-  yyssp++;
-
- yysetstate:
-  *yyssp = yystate;
-
-  if (yyss + yystacksize - 1 <= yyssp)
-    {
-      /* Get the current used size of the three stacks, in elements.  */
-      YYSIZE_T yysize = yyssp - yyss + 1;
-
-#ifdef yyoverflow
-      {
-       /* Give user a chance to reallocate the stack. Use copies of
-          these so that the &'s don't force the real ones into
-          memory.  */
-       YYSTYPE *yyvs1 = yyvs;
-       short *yyss1 = yyss;
-
-
-       /* Each stack pointer address is followed by the size of the
-          data in use in that stack, in bytes.  This used to be a
-          conditional around just the two extra args, but that might
-          be undefined if yyoverflow is a macro.  */
-       yyoverflow ("parser stack overflow",
-                   &yyss1, yysize * sizeof (*yyssp),
-                   &yyvs1, yysize * sizeof (*yyvsp),
-
-                   &yystacksize);
-
-       yyss = yyss1;
-       yyvs = yyvs1;
-      }
-#else /* no yyoverflow */
-# ifndef YYSTACK_RELOCATE
-      goto yyoverflowlab;
-# else
-      /* Extend the stack our own way.  */
-      if (YYMAXDEPTH <= yystacksize)
-       goto yyoverflowlab;
-      yystacksize *= 2;
-      if (YYMAXDEPTH < yystacksize)
-       yystacksize = YYMAXDEPTH;
-
-      {
-       short *yyss1 = yyss;
-       union yyalloc *yyptr =
-         (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
-       if (! yyptr)
-         goto yyoverflowlab;
-       YYSTACK_RELOCATE (yyss);
-       YYSTACK_RELOCATE (yyvs);
-
-#  undef YYSTACK_RELOCATE
-       if (yyss1 != yyssa)
-         YYSTACK_FREE (yyss1);
-      }
-# endif
-#endif /* no yyoverflow */
-
-      yyssp = yyss + yysize - 1;
-      yyvsp = yyvs + yysize - 1;
-
-
-      YYDPRINTF ((stderr, "Stack size increased to %lu\n",
-                 (unsigned long int) yystacksize));
-
-      if (yyss + yystacksize - 1 <= yyssp)
-       YYABORT;
-    }
-
-  YYDPRINTF ((stderr, "Entering state %d\n", yystate));
-
-  goto yybackup;
-
-/*-----------.
-| yybackup.  |
-`-----------*/
-yybackup:
-
-/* Do appropriate processing given the current state.  */
-/* Read a lookahead token if we need one and don't already have one.  */
-/* yyresume: */
-
-  /* First try to decide what to do without reference to lookahead token.  */
-
-  yyn = yypact[yystate];
-  if (yyn == YYPACT_NINF)
-    goto yydefault;
-
-  /* Not known => get a lookahead token if don't already have one.  */
-
-  /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol.  */
-  if (yychar == YYEMPTY)
-    {
-      YYDPRINTF ((stderr, "Reading a token: "));
-      yychar = YYLEX;
-    }
-
-  if (yychar <= YYEOF)
-    {
-      yychar = yytoken = YYEOF;
-      YYDPRINTF ((stderr, "Now at end of input.\n"));
-    }
-  else
-    {
-      yytoken = YYTRANSLATE (yychar);
-      YYDSYMPRINTF ("Next token is", yytoken, &yylval, &yylloc);
-    }
-
-  /* If the proper action on seeing token YYTOKEN is to reduce or to
-     detect an error, take that action.  */
-  yyn += yytoken;
-  if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
-    goto yydefault;
-  yyn = yytable[yyn];
-  if (yyn <= 0)
-    {
-      if (yyn == 0 || yyn == YYTABLE_NINF)
-       goto yyerrlab;
-      yyn = -yyn;
-      goto yyreduce;
-    }
-
-  if (yyn == YYFINAL)
-    YYACCEPT;
-
-  /* Shift the lookahead token.  */
-  YYDPRINTF ((stderr, "Shifting token %s, ", yytname[yytoken]));
-
-  /* Discard the token being shifted unless it is eof.  */
-  if (yychar != YYEOF)
-    yychar = YYEMPTY;
-
-  *++yyvsp = yylval;
-
-
-  /* Count tokens shifted since error; after three, turn off error
-     status.  */
-  if (yyerrstatus)
-    yyerrstatus--;
-
-  yystate = yyn;
-  goto yynewstate;
-
-
-/*-----------------------------------------------------------.
-| yydefault -- do the default action for the current state.  |
-`-----------------------------------------------------------*/
-yydefault:
-  yyn = yydefact[yystate];
-  if (yyn == 0)
-    goto yyerrlab;
-  goto yyreduce;
-
-
-/*-----------------------------.
-| yyreduce -- Do a reduction.  |
-`-----------------------------*/
-yyreduce:
-  /* yyn is the number of a rule to reduce with.  */
-  yylen = yyr2[yyn];
-
-  /* If YYLEN is nonzero, implement the default value of the action:
-     `$$ = $1'.
-
-     Otherwise, the following line sets YYVAL to garbage.
-     This behavior is undocumented and Bison
-     users should not rely upon it.  Assigning to YYVAL
-     unconditionally makes the parser a bit smaller, and it avoids a
-     GCC warning that YYVAL may be used uninitialized.  */
-  yyval = yyvsp[1-yylen];
-
-
-  YY_REDUCE_PRINT (yyn);
-  switch (yyn)
-    {
-        case 2:
-#line 606 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 /* Register static variables with the garbage
-                    collector.  */
-                 ggc_add_tree_root (&label_id, 1);
-                 ggc_add_tree_root (&wfl_string_buffer, 1);
-                 ggc_add_tree_root (&wfl_append, 1);
-                 ggc_add_tree_root (&wfl_to_string, 1);
-                 ggc_add_tree_root (&java_lang_id, 1);
-                 ggc_add_tree_root (&inst_id, 1);
-                 ggc_add_tree_root (&java_lang_cloneable, 1);
-                 ggc_add_tree_root (&java_io_serializable, 1);
-                 ggc_add_tree_root (&current_static_block, 1);
-                 ggc_add_tree_root (&wpv_id, 1);
-                 ggc_add_tree_root (&package_list, 1);
-                 ggc_add_tree_root (&current_this, 1);
-                 ggc_add_tree_root (&currently_caught_type_list, 1);
-                 ggc_add_tree_root (&case_label_list, 1);
-                 ggc_add_root (&ctxp, 1, 
-                               sizeof (struct parser_ctxt *),
-                               mark_parser_ctxt);
-                 ggc_add_root (&ctxp_for_generation, 1, 
-                               sizeof (struct parser_ctxt *),
-                               mark_parser_ctxt);
-               ;}
-    break;
-
-  case 3:
-#line 631 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {;}
-    break;
-
-  case 20:
-#line 675 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 int osb = pop_current_osb (ctxp);
-                 tree t = build_java_array_type ((yyvsp[-1].node), -1);
-                 while (--osb)
-                   t = build_unresolved_array_type (t);
-                 yyval.node = t;
-               ;}
-    break;
-
-  case 21:
-#line 683 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 int osb = pop_current_osb (ctxp);
-                 tree t = yyvsp[-1].node;
-                 while (osb--)
-                   t = build_unresolved_array_type (t);
-                 yyval.node = t;
-               ;}
-    break;
-
-  case 25:
-#line 704 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = make_qualified_name (yyvsp[-2].node, yyvsp[0].node, yyvsp[-1].operator.location); ;}
-    break;
-
-  case 27:
-#line 713 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = NULL;;}
-    break;
-
-  case 35:
-#line 725 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = NULL;
-               ;}
-    break;
-
-  case 36:
-#line 729 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = NULL;
-               ;}
-    break;
-
-  case 39:
-#line 741 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->package = EXPR_WFL_NODE (yyvsp[-1].node);
-                 register_package (ctxp->package);
-               ;}
-    break;
-
-  case 40:
-#line 746 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing name"); RECOVER;;}
-    break;
-
-  case 41:
-#line 748 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 44:
-#line 758 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 tree name = EXPR_WFL_NODE (yyvsp[-1].node), last_name;
-                 int   i = IDENTIFIER_LENGTH (name)-1;
-                 const char *last = &IDENTIFIER_POINTER (name)[i];
-                 while (last != IDENTIFIER_POINTER (name))
-                   {
-                     if (last [0] == '.')
-                       break;
-                     last--;
-                   }
-                 last_name = get_identifier (++last);
-                 if (IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P (last_name))
-                   {
-                     tree err = find_name_in_single_imports (last_name);
-                     if (err && err != name)
-                       parse_error_context
-                         (yyvsp[-1].node, "Ambiguous class: `%s' and `%s'",
-                          IDENTIFIER_POINTER (name), 
-                          IDENTIFIER_POINTER (err));
-                     else
-                       REGISTER_IMPORT (yyvsp[-1].node, last_name);
-                   }
-                 else
-                   REGISTER_IMPORT (yyvsp[-1].node, last_name);
-               ;}
-    break;
-
-  case 45:
-#line 784 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing name"); RECOVER;;}
-    break;
-
-  case 46:
-#line 786 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 47:
-#line 791 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 tree name = EXPR_WFL_NODE (yyvsp[-3].node);
-                 tree it;
-                 /* Search for duplicates. */
-                 for (it = ctxp->import_demand_list; it; it = TREE_CHAIN (it))
-                   if (EXPR_WFL_NODE (TREE_PURPOSE (it)) == name)
-                     break;
-                 /* Don't import the same thing more than once, just ignore
-                    duplicates (7.5.2) */
-                 if (! it)
-                   {
-                     read_import_dir (yyvsp[-3].node);
-                     ctxp->import_demand_list = 
-                       chainon (ctxp->import_demand_list,
-                                build_tree_list (yyvsp[-3].node, NULL_TREE));
-                   }
-               ;}
-    break;
-
-  case 48:
-#line 809 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'*' expected"); RECOVER;;}
-    break;
-
-  case 49:
-#line 811 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 50:
-#line 816 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { end_class_declaration (0); ;}
-    break;
-
-  case 51:
-#line 818 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { end_class_declaration (0); ;}
-    break;
-
-  case 53:
-#line 821 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYERROR_NOW;
-                 yyerror ("Class or interface declaration expected");
-               ;}
-    break;
-
-  case 54:
-#line 832 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.value = (1 << yyvsp[0].value);
-               ;}
-    break;
-
-  case 55:
-#line 836 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 int acc = (1 << yyvsp[0].value);
-                 if (yyval.value & acc)
-                   parse_error_context 
-                     (ctxp->modifier_ctx [yyvsp[0].value], "Modifier `%s' declared twice",
-                      java_accstring_lookup (acc));
-                 else
-                   {
-                     yyval.value |= acc;
-                   }
-               ;}
-    break;
-
-  case 56:
-#line 852 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_class (yyvsp[-4].value, yyvsp[-2].node, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 57:
-#line 854 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {;;}
-    break;
-
-  case 58:
-#line 856 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_class (0, yyvsp[-2].node, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 59:
-#line 858 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {;;}
-    break;
-
-  case 60:
-#line 860 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing class name"); RECOVER;;}
-    break;
-
-  case 61:
-#line 862 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing class name"); RECOVER;;}
-    break;
-
-  case 62:
-#line 864 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 if (!ctxp->class_err) yyerror ("'{' expected"); 
-                 DRECOVER(class1);
-               ;}
-    break;
-
-  case 63:
-#line 869 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {if (!ctxp->class_err) yyerror ("'{' expected"); RECOVER;;}
-    break;
-
-  case 64:
-#line 873 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL; ;}
-    break;
-
-  case 65:
-#line 875 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 66:
-#line 877 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); ctxp->class_err=1;;}
-    break;
-
-  case 67:
-#line 879 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing super class name"); ctxp->class_err=1;;}
-    break;
-
-  case 68:
-#line 883 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 69:
-#line 885 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 70:
-#line 887 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 ctxp->class_err=1;
-                 yyerror ("Missing interface name"); 
-               ;}
-    break;
-
-  case 71:
-#line 895 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->interface_number = 1;
-                 yyval.node = build_tree_list (yyvsp[0].node, NULL_TREE);
-               ;}
-    break;
-
-  case 72:
-#line 900 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->interface_number++;
-                 yyval.node = chainon (yyvsp[-2].node, build_tree_list (yyvsp[0].node, NULL_TREE));
-               ;}
-    break;
-
-  case 73:
-#line 905 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing interface name"); RECOVER;;}
-    break;
-
-  case 74:
-#line 910 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* Store the location of the `}' when doing xrefs */
-                 if (flag_emit_xref)
-                   DECL_END_SOURCE_LINE (GET_CPC ()) = 
-                     EXPR_WFL_ADD_COL (yyvsp[0].operator.location, 1);
-                 yyval.node = GET_CPC ();
-               ;}
-    break;
-
-  case 75:
-#line 918 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* Store the location of the `}' when doing xrefs */
-                 if (flag_emit_xref)
-                   DECL_END_SOURCE_LINE (GET_CPC ()) = 
-                     EXPR_WFL_ADD_COL (yyvsp[0].operator.location, 1);
-                 yyval.node = GET_CPC ();
-               ;}
-    break;
-
-  case 81:
-#line 937 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 if (yyvsp[0].node != empty_stmt_node)
-                   {
-                     TREE_CHAIN (yyvsp[0].node) = CPC_INSTANCE_INITIALIZER_STMT (ctxp);
-                     SET_CPC_INSTANCE_INITIALIZER_STMT (ctxp, yyvsp[0].node);
-                   }
-               ;}
-    break;
-
-  case 84:
-#line 950 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { end_class_declaration (1); ;}
-    break;
-
-  case 85:
-#line 952 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { end_class_declaration (1); ;}
-    break;
-
-  case 87:
-#line 959 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { register_fields (0, yyvsp[-2].node, yyvsp[-1].node); ;}
-    break;
-
-  case 88:
-#line 961 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 check_modifiers 
-                   ("Illegal modifier `%s' for field declaration",
-                    yyvsp[-3].value, FIELD_MODIFIERS);
-                 check_modifiers_consistency (yyvsp[-3].value);
-                 register_fields (yyvsp[-3].value, yyvsp[-2].node, yyvsp[-1].node);
-               ;}
-    break;
-
-  case 90:
-#line 974 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = chainon (yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 91:
-#line 976 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 92:
-#line 981 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_tree_list (yyvsp[0].node, NULL_TREE); ;}
-    break;
-
-  case 93:
-#line 983 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 if (java_error_count)
-                   yyvsp[0].node = NULL_TREE;
-                 yyval.node = build_tree_list 
-                   (yyvsp[-2].node, build_assignment (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[-2].node, yyvsp[0].node));
-               ;}
-    break;
-
-  case 94:
-#line 990 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing variable initializer");
-                 yyval.node = build_tree_list (yyvsp[-2].node, NULL_TREE);
-                 RECOVER;
-               ;}
-    break;
-
-  case 95:
-#line 996 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("';' expected");
-                 yyval.node = build_tree_list (yyvsp[-3].node, NULL_TREE);
-                 RECOVER;
-               ;}
-    break;
-
-  case 97:
-#line 1006 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_unresolved_array_type (yyvsp[-2].node); ;}
-    break;
-
-  case 98:
-#line 1008 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid declaration"); DRECOVER(vdi);;}
-    break;
-
-  case 99:
-#line 1010 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree node = java_lval.node;
-                 if (node && (TREE_CODE (node) == INTEGER_CST
-                              || TREE_CODE (node) == EXPR_WITH_FILE_LOCATION))
-                   yyerror ("Can't specify array dimension in a declaration");
-                 else
-                   yyerror ("']' expected");
-                 DRECOVER(vdi);
-               ;}
-    break;
-
-  case 100:
-#line 1020 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Unbalanced ']'"); DRECOVER(vdi);;}
-    break;
-
-  case 103:
-#line 1031 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 current_function_decl = yyvsp[0].node;
-                 if (current_function_decl
-                     && TREE_CODE (current_function_decl) == FUNCTION_DECL)
-                   source_start_java_method (current_function_decl);
-                 else
-                   current_function_decl = NULL_TREE;
-               ;}
-    break;
-
-  case 104:
-#line 1040 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { finish_method_declaration (yyvsp[0].node); ;}
-    break;
-
-  case 105:
-#line 1042 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {YYNOT_TWICE yyerror ("'{' expected"); RECOVER;;}
-    break;
-
-  case 106:
-#line 1047 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_header (0, yyvsp[-2].node, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 107:
-#line 1049 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_header (0, void_type_node, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 108:
-#line 1051 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_header (yyvsp[-3].value, yyvsp[-2].node, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 109:
-#line 1053 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_header (yyvsp[-3].value, void_type_node, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 110:
-#line 1055 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Invalid method declaration, method name required");
-                 RECOVER;
-               ;}
-    break;
-
-  case 111:
-#line 1060 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {RECOVER;;}
-    break;
-
-  case 112:
-#line 1062 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Identifier expected"); RECOVER;;}
-    break;
-
-  case 113:
-#line 1064 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Identifier expected"); RECOVER;;}
-    break;
-
-  case 114:
-#line 1066 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Invalid method declaration, return type required");
-                 RECOVER;
-               ;}
-    break;
-
-  case 115:
-#line 1074 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->formal_parameter_number = 0;
-                 yyval.node = method_declarator (yyvsp[-2].node, NULL_TREE);
-               ;}
-    break;
-
-  case 116:
-#line 1079 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_declarator (yyvsp[-3].node, yyvsp[-1].node); ;}
-    break;
-
-  case 117:
-#line 1081 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 EXPR_WFL_LINECOL (wfl_operator) = yyvsp[-1].operator.location;
-                 TREE_PURPOSE (yyvsp[-2].node) = 
-                   build_unresolved_array_type (TREE_PURPOSE (yyvsp[-2].node));
-                 parse_warning_context 
-                   (wfl_operator, 
-                    "Discouraged form of returned type specification");
-               ;}
-    break;
-
-  case 118:
-#line 1090 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); DRECOVER(method_declarator);;}
-    break;
-
-  case 119:
-#line 1092 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("']' expected"); RECOVER;;}
-    break;
-
-  case 120:
-#line 1097 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 ctxp->formal_parameter_number = 1;
-               ;}
-    break;
-
-  case 121:
-#line 1101 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 ctxp->formal_parameter_number += 1;
-                 yyval.node = chainon (yyvsp[-2].node, yyvsp[0].node);
-               ;}
-    break;
-
-  case 122:
-#line 1106 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyerror ("Missing formal parameter term"); RECOVER; ;}
-    break;
-
-  case 123:
-#line 1111 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_tree_list (yyvsp[0].node, yyvsp[-1].node);
-               ;}
-    break;
-
-  case 124:
-#line 1115 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build_tree_list (yyvsp[0].node, yyvsp[-1].node);
-                 ARG_FINAL_P (yyval.node) = 1;
-               ;}
-    break;
-
-  case 125:
-#line 1120 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing identifier"); RECOVER;
-                 yyval.node = NULL_TREE;
-               ;}
-    break;
-
-  case 126:
-#line 1125 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing identifier"); RECOVER;
-                 yyval.node = NULL_TREE;
-               ;}
-    break;
-
-  case 127:
-#line 1133 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 check_modifiers ("Illegal modifier `%s'. Only `final' was expected here",
-                                  yyvsp[0].value, ACC_FINAL);
-                 if (yyvsp[0].value != ACC_FINAL)
-                   MODIFIER_WFL (FINAL_TK) = build_wfl_node (NULL_TREE);
-               ;}
-    break;
-
-  case 128:
-#line 1142 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 129:
-#line 1144 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 130:
-#line 1146 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing class type term"); RECOVER;;}
-    break;
-
-  case 131:
-#line 1151 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_tree_list (yyvsp[0].node, yyvsp[0].node); ;}
-    break;
-
-  case 132:
-#line 1153 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = tree_cons (yyvsp[0].node, yyvsp[0].node, yyvsp[-2].node); ;}
-    break;
-
-  case 133:
-#line 1155 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing class type term"); RECOVER;;}
-    break;
-
-  case 135:
-#line 1160 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 136:
-#line 1166 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 TREE_CHAIN (yyvsp[0].node) = CPC_STATIC_INITIALIZER_STMT (ctxp);
-                 SET_CPC_STATIC_INITIALIZER_STMT (ctxp, yyvsp[0].node);
-                 current_static_block = NULL_TREE;
-               ;}
-    break;
-
-  case 137:
-#line 1175 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 check_modifiers ("Illegal modifier `%s' for static initializer", yyvsp[0].value, ACC_STATIC);
-                 /* Can't have a static initializer in an innerclass */
-                 if (yyvsp[0].value | ACC_STATIC &&
-                     GET_CPC_LIST () && !TOPLEVEL_CLASS_DECL_P (GET_CPC ()))
-                   parse_error_context 
-                     (MODIFIER_WFL (STATIC_TK),
-                      "Can't define static initializer in class `%s'. Static initializer can only be defined in top-level classes",
-                      IDENTIFIER_POINTER (DECL_NAME (GET_CPC ())));
-                 SOURCE_FRONTEND_DEBUG (("Modifiers: %d", yyvsp[0].value));
-               ;}
-    break;
-
-  case 138:
-#line 1191 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 current_function_decl = yyvsp[0].node;
-                 source_start_java_method (current_function_decl);
-               ;}
-    break;
-
-  case 139:
-#line 1196 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { finish_method_declaration (yyvsp[0].node); ;}
-    break;
-
-  case 140:
-#line 1201 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_header (0, NULL_TREE, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 141:
-#line 1203 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_header (yyvsp[-2].value, NULL_TREE, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 142:
-#line 1208 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->formal_parameter_number = 0;  
-                 yyval.node = method_declarator (yyvsp[-2].node, NULL_TREE);
-               ;}
-    break;
-
-  case 143:
-#line 1213 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = method_declarator (yyvsp[-3].node, yyvsp[-1].node); ;}
-    break;
-
-  case 144:
-#line 1221 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 BLOCK_EXPR_BODY (yyvsp[0].node) = empty_stmt_node;
-                 yyval.node = yyvsp[0].node;
-               ;}
-    break;
-
-  case 145:
-#line 1226 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 146:
-#line 1228 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 147:
-#line 1230 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 149:
-#line 1240 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build_method_invocation (yyvsp[-3].node, NULL_TREE); 
-                 yyval.node = build_debugable_stmt (EXPR_WFL_LINECOL (yyvsp[-3].node), yyval.node);
-                 yyval.node = java_method_add_stmt (current_function_decl, yyval.node);
-               ;}
-    break;
-
-  case 150:
-#line 1246 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build_method_invocation (yyvsp[-4].node, yyvsp[-2].node); 
-                 yyval.node = build_debugable_stmt (EXPR_WFL_LINECOL (yyvsp[-4].node), yyval.node);
-                 yyval.node = java_method_add_stmt (current_function_decl, yyval.node);
-               ;}
-    break;
-
-  case 151:
-#line 1254 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = parse_jdk1_1_error ("explicit constructor invocation"); ;}
-    break;
-
-  case 152:
-#line 1256 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = parse_jdk1_1_error ("explicit constructor invocation"); ;}
-    break;
-
-  case 153:
-#line 1261 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 tree wfl = build_wfl_node (this_identifier_node);
-                 EXPR_WFL_LINECOL (wfl) = yyvsp[0].operator.location;
-                 yyval.node = wfl;
-               ;}
-    break;
-
-  case 154:
-#line 1267 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 tree wfl = build_wfl_node (super_identifier_node);
-                 EXPR_WFL_LINECOL (wfl) = yyvsp[0].operator.location;
-                 yyval.node = wfl;
-               ;}
-    break;
-
-  case 155:
-#line 1278 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_interface (0, yyvsp[0].node, NULL_TREE); ;}
-    break;
-
-  case 156:
-#line 1280 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { ; ;}
-    break;
-
-  case 157:
-#line 1282 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_interface (yyvsp[-2].value, yyvsp[0].node, NULL_TREE); ;}
-    break;
-
-  case 158:
-#line 1284 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { ; ;}
-    break;
-
-  case 159:
-#line 1286 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_interface (0, yyvsp[-1].node, yyvsp[0].node);     ;}
-    break;
-
-  case 160:
-#line 1288 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { ; ;}
-    break;
-
-  case 161:
-#line 1290 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_interface (yyvsp[-3].value, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 162:
-#line 1292 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { ; ;}
-    break;
-
-  case 163:
-#line 1294 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); RECOVER;;}
-    break;
-
-  case 164:
-#line 1296 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); RECOVER;;}
-    break;
-
-  case 165:
-#line 1301 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->interface_number = 1;
-                 yyval.node = build_tree_list (yyvsp[0].node, NULL_TREE);
-               ;}
-    break;
-
-  case 166:
-#line 1306 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 ctxp->interface_number++;
-                 yyval.node = chainon (yyvsp[-2].node, build_tree_list (yyvsp[0].node, NULL_TREE));
-               ;}
-    break;
-
-  case 167:
-#line 1311 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid interface type"); RECOVER;;}
-    break;
-
-  case 168:
-#line 1313 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 169:
-#line 1318 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 170:
-#line 1320 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 175:
-#line 1332 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { end_class_declaration (1); ;}
-    break;
-
-  case 176:
-#line 1334 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { end_class_declaration (1); ;}
-    break;
-
-  case 178:
-#line 1343 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 check_abstract_method_header (yyvsp[-1].node);
-                 current_function_decl = NULL_TREE; /* FIXME ? */
-               ;}
-    break;
-
-  case 179:
-#line 1348 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 180:
-#line 1354 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_new_array_init (yyvsp[-1].operator.location, NULL_TREE); ;}
-    break;
-
-  case 181:
-#line 1356 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_new_array_init (yyvsp[-2].operator.location, NULL_TREE); ;}
-    break;
-
-  case 182:
-#line 1358 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_new_array_init (yyvsp[-2].operator.location, yyvsp[-1].node); ;}
-    break;
-
-  case 183:
-#line 1360 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_new_array_init (yyvsp[-3].operator.location, yyvsp[-2].node); ;}
-    break;
-
-  case 184:
-#line 1365 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = tree_cons (maybe_build_array_element_wfl (yyvsp[0].node), 
-                                 yyvsp[0].node, NULL_TREE);
-               ;}
-    break;
-
-  case 185:
-#line 1370 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = tree_cons (maybe_build_array_element_wfl (yyvsp[0].node), yyvsp[0].node, yyvsp[-2].node);
-               ;}
-    break;
-
-  case 186:
-#line 1374 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 187:
-#line 1380 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* Store the location of the `}' when doing xrefs */
-                 if (current_function_decl && flag_emit_xref)
-                   DECL_END_SOURCE_LINE (current_function_decl) = 
-                     EXPR_WFL_ADD_COL (yyvsp[0].operator.location, 1);
-                 yyval.node = empty_stmt_node; 
-               ;}
-    break;
-
-  case 188:
-#line 1388 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 189:
-#line 1393 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { enter_block (); ;}
-    break;
-
-  case 190:
-#line 1398 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 maybe_absorb_scoping_blocks ();
-                 /* Store the location of the `}' when doing xrefs */
-                 if (current_function_decl && flag_emit_xref)
-                   DECL_END_SOURCE_LINE (current_function_decl) = 
-                     EXPR_WFL_ADD_COL (yyvsp[0].operator.location, 1);           
-                 yyval.node = exit_block ();
-                 if (!BLOCK_SUBBLOCKS (yyval.node))
-                   BLOCK_SUBBLOCKS (yyval.node) = empty_stmt_node;
-               ;}
-    break;
-
-  case 194:
-#line 1418 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { java_method_add_stmt (current_function_decl, yyvsp[0].node); ;}
-    break;
-
-  case 195:
-#line 1420 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 LOCAL_CLASS_P (TREE_TYPE (GET_CPC ())) = 1;
-                 end_class_declaration (1);
-               ;}
-    break;
-
-  case 197:
-#line 1432 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { declare_local_variables (0, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 198:
-#line 1434 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { declare_local_variables (yyvsp[-2].value, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 204:
-#line 1444 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = exit_block (); ;}
-    break;
-
-  case 209:
-#line 1453 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = exit_block (); ;}
-    break;
-
-  case 221:
-#line 1472 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 if (flag_extraneous_semicolon 
-                     && ! current_static_block 
-                     && (! current_function_decl || 
-                         /* Verify we're not in a inner class declaration */
-                         (GET_CPC () != TYPE_NAME
-                          (DECL_CONTEXT (current_function_decl)))))
-                          
-                   {
-                     EXPR_WFL_SET_LINECOL (wfl_operator, lineno, -1);
-                     parse_warning_context (wfl_operator, "An empty declaration is a deprecated feature that should not be used");
-                   }
-                 yyval.node = empty_stmt_node;
-               ;}
-    break;
-
-  case 222:
-#line 1490 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_labeled_block (EXPR_WFL_LINECOL (yyvsp[-1].node), 
-                                           EXPR_WFL_NODE (yyvsp[-1].node));
-                 pushlevel (2);
-                 push_labeled_block (yyval.node);
-                 PUSH_LABELED_BLOCK (yyval.node);
-               ;}
-    break;
-
-  case 223:
-#line 1501 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = finish_labeled_statement (yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 224:
-#line 1503 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("':' expected"); RECOVER;;}
-    break;
-
-  case 225:
-#line 1508 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = finish_labeled_statement (yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 226:
-#line 1515 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 /* We have a statement. Generate a WFL around it so
-                    we can debug it */
-                 yyval.node = build_expr_wfl (yyvsp[-1].node, input_filename, lineno, 0);
-                 /* We know we have a statement, so set the debug
-                     info to be eventually generate here. */
-                 yyval.node = JAVA_MAYBE_GENERATE_DEBUG_INFO (yyval.node);
-               ;}
-    break;
-
-  case 227:
-#line 1524 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYNOT_TWICE yyerror ("Invalid expression statement");
-                 DRECOVER (expr_stmt);
-               ;}
-    break;
-
-  case 228:
-#line 1529 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYNOT_TWICE yyerror ("Invalid expression statement");
-                 DRECOVER (expr_stmt);
-               ;}
-    break;
-
-  case 229:
-#line 1534 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYNOT_TWICE yyerror ("Invalid expression statement");
-                 DRECOVER (expr_stmt);
-               ;}
-    break;
-
-  case 230:
-#line 1539 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 231:
-#line 1541 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 parse_ctor_invocation_error ();
-                 RECOVER;
-               ;}
-    break;
-
-  case 232:
-#line 1546 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 233:
-#line 1548 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 parse_ctor_invocation_error ();
-                 RECOVER;
-               ;}
-    break;
-
-  case 234:
-#line 1553 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 235:
-#line 1555 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 236:
-#line 1557 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 237:
-#line 1559 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 238:
-#line 1561 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 246:
-#line 1576 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build_if_else_statement (yyvsp[-3].operator.location, yyvsp[-2].node, 
-                                               yyvsp[0].node, NULL_TREE);
-               ;}
-    break;
-
-  case 247:
-#line 1581 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 248:
-#line 1583 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 249:
-#line 1585 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 250:
-#line 1590 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_if_else_statement (yyvsp[-5].operator.location, yyvsp[-4].node, yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 251:
-#line 1595 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_if_else_statement (yyvsp[-5].operator.location, yyvsp[-4].node, yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 252:
-#line 1600 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 enter_block ();
-               ;}
-    break;
-
-  case 253:
-#line 1604 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* Make into "proper list" of COMPOUND_EXPRs.
-                    I.e. make the last statement also have its own
-                    COMPOUND_EXPR. */
-                 maybe_absorb_scoping_blocks ();
-                 TREE_OPERAND (yyvsp[-2].node, 1) = exit_block ();
-                 yyval.node = build_debugable_stmt (EXPR_WFL_LINECOL (yyvsp[-2].node), yyvsp[-2].node);
-               ;}
-    break;
-
-  case 254:
-#line 1616 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build (SWITCH_EXPR, NULL_TREE, yyvsp[-1].node, NULL_TREE);
-                 EXPR_WFL_LINECOL (yyval.node) = yyvsp[-2].operator.location;
-               ;}
-    break;
-
-  case 255:
-#line 1621 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 256:
-#line 1623 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term or ')'"); DRECOVER(switch_statement);;}
-    break;
-
-  case 257:
-#line 1625 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); RECOVER;;}
-    break;
-
-  case 258:
-#line 1633 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 259:
-#line 1635 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 260:
-#line 1637 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 261:
-#line 1639 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = NULL_TREE; ;}
-    break;
-
-  case 267:
-#line 1658 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree lab = build1 (CASE_EXPR, NULL_TREE, yyvsp[-1].node);
-                 EXPR_WFL_LINECOL (lab) = yyvsp[-2].operator.location;
-                 java_method_add_stmt (current_function_decl, lab);
-               ;}
-    break;
-
-  case 268:
-#line 1664 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree lab = build (DEFAULT_EXPR, NULL_TREE, NULL_TREE);
-                 EXPR_WFL_LINECOL (lab) = yyvsp[-1].operator.location;
-                 java_method_add_stmt (current_function_decl, lab);
-               ;}
-    break;
-
-  case 269:
-#line 1670 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing or invalid constant expression"); RECOVER;;}
-    break;
-
-  case 270:
-#line 1672 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("':' expected"); RECOVER;;}
-    break;
-
-  case 271:
-#line 1674 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("':' expected"); RECOVER;;}
-    break;
-
-  case 272:
-#line 1679 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree body = build_loop_body (yyvsp[-2].operator.location, yyvsp[-1].node, 0);
-                 yyval.node = build_new_loop (body);
-               ;}
-    break;
-
-  case 273:
-#line 1687 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = finish_loop_body (0, NULL_TREE, yyvsp[0].node, 0); ;}
-    break;
-
-  case 274:
-#line 1689 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {YYERROR_NOW; yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 275:
-#line 1691 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term and ')' expected"); RECOVER;;}
-    break;
-
-  case 276:
-#line 1693 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 277:
-#line 1698 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = finish_loop_body (0, NULL_TREE, yyvsp[0].node, 0); ;}
-    break;
-
-  case 278:
-#line 1703 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree body = build_loop_body (0, NULL_TREE, 1);
-                 yyval.node = build_new_loop (body);
-               ;}
-    break;
-
-  case 279:
-#line 1712 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = finish_loop_body (yyvsp[-3].operator.location, yyvsp[-2].node, yyvsp[-5].node, 1); ;}
-    break;
-
-  case 280:
-#line 1717 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 if (TREE_CODE_CLASS (TREE_CODE (yyvsp[-4].node)) == 'c')
-                   yyvsp[-4].node = build_wfl_node (yyvsp[-4].node);
-                 yyval.node = finish_for_loop (EXPR_WFL_LINECOL (yyvsp[-4].node), yyvsp[-4].node, yyvsp[-2].node, yyvsp[0].node);
-               ;}
-    break;
-
-  case 281:
-#line 1723 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = finish_for_loop (0, NULL_TREE, yyvsp[-2].node, yyvsp[0].node);
-                 /* We have not condition, so we get rid of the EXIT_EXPR */
-                 LOOP_EXPR_BODY_CONDITION_EXPR (LOOP_EXPR_BODY (yyval.node), 0) = 
-                   empty_stmt_node;
-               ;}
-    break;
-
-  case 282:
-#line 1730 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid control expression"); RECOVER;;}
-    break;
-
-  case 283:
-#line 1732 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid update expression"); RECOVER;;}
-    break;
-
-  case 284:
-#line 1734 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid update expression"); RECOVER;;}
-    break;
-
-  case 285:
-#line 1739 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = finish_for_loop (EXPR_WFL_LINECOL (yyvsp[-4].node), yyvsp[-4].node, yyvsp[-2].node, yyvsp[0].node);;}
-    break;
-
-  case 286:
-#line 1741 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = finish_for_loop (0, NULL_TREE, yyvsp[-2].node, yyvsp[0].node);
-                 /* We have not condition, so we get rid of the EXIT_EXPR */
-                 LOOP_EXPR_BODY_CONDITION_EXPR (LOOP_EXPR_BODY (yyval.node), 0) = 
-                   empty_stmt_node;
-               ;}
-    break;
-
-  case 287:
-#line 1751 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* This scope defined for local variable that may be
-                     defined within the scope of the for loop */
-                 enter_block (); 
-               ;}
-    break;
-
-  case 288:
-#line 1757 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); DRECOVER(for_1);;}
-    break;
-
-  case 289:
-#line 1759 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid init statement"); RECOVER;;}
-    break;
-
-  case 290:
-#line 1764 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* We now declare the loop body. The loop is
-                     declared as a for loop. */
-                 tree body = build_loop_body (0, NULL_TREE, 0);
-                 yyval.node =  build_new_loop (body);
-                 FOR_LOOP_P (yyval.node) = 1;
-                 /* The loop is added to the current block the for
-                     statement is defined within */
-                 java_method_add_stmt (current_function_decl, yyval.node);
-               ;}
-    break;
-
-  case 291:
-#line 1776 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = empty_stmt_node; ;}
-    break;
-
-  case 292:
-#line 1778 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* Init statement recorded within the previously
-                     defined block scope */
-                 yyval.node = java_method_add_stmt (current_function_decl, yyvsp[0].node);
-               ;}
-    break;
-
-  case 293:
-#line 1784 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* Local variable are recorded within the previously
-                    defined block scope */
-                 yyval.node = NULL_TREE;
-               ;}
-    break;
-
-  case 294:
-#line 1790 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); DRECOVER(for_init_1);;}
-    break;
-
-  case 295:
-#line 1794 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = empty_stmt_node;;}
-    break;
-
-  case 296:
-#line 1796 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_debugable_stmt (BUILD_LOCATION (), yyvsp[0].node); ;}
-    break;
-
-  case 297:
-#line 1801 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = add_stmt_to_compound (NULL_TREE, NULL_TREE, yyvsp[0].node); ;}
-    break;
-
-  case 298:
-#line 1803 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = add_stmt_to_compound (yyvsp[-2].node, NULL_TREE, yyvsp[0].node); ;}
-    break;
-
-  case 299:
-#line 1805 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 300:
-#line 1810 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_bc_statement (yyvsp[-1].operator.location, 1, NULL_TREE); ;}
-    break;
-
-  case 301:
-#line 1812 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_bc_statement (yyvsp[-2].operator.location, 1, yyvsp[-1].node); ;}
-    break;
-
-  case 302:
-#line 1814 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 303:
-#line 1816 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 304:
-#line 1821 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_bc_statement (yyvsp[-1].operator.location, 0, NULL_TREE); ;}
-    break;
-
-  case 305:
-#line 1823 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_bc_statement (yyvsp[-2].operator.location, 0, yyvsp[-1].node); ;}
-    break;
-
-  case 306:
-#line 1825 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 307:
-#line 1827 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 308:
-#line 1832 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_return (yyvsp[-1].operator.location, NULL_TREE); ;}
-    break;
-
-  case 309:
-#line 1834 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_return (yyvsp[-2].operator.location, yyvsp[-1].node); ;}
-    break;
-
-  case 310:
-#line 1836 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 311:
-#line 1838 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 312:
-#line 1843 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build1 (THROW_EXPR, NULL_TREE, yyvsp[-1].node);
-                 EXPR_WFL_LINECOL (yyval.node) = yyvsp[-2].operator.location;
-               ;}
-    break;
-
-  case 313:
-#line 1848 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 314:
-#line 1850 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("';' expected"); RECOVER;;}
-    break;
-
-  case 315:
-#line 1855 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build (SYNCHRONIZED_EXPR, NULL_TREE, yyvsp[-2].node, yyvsp[0].node);
-                 EXPR_WFL_LINECOL (yyval.node) = 
-                   EXPR_WFL_LINECOL (MODIFIER_WFL (SYNCHRONIZED_TK));
-               ;}
-    break;
-
-  case 316:
-#line 1861 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); RECOVER;;}
-    break;
-
-  case 317:
-#line 1863 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 318:
-#line 1865 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 319:
-#line 1867 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 320:
-#line 1872 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 check_modifiers (
-             "Illegal modifier `%s'. Only `synchronized' was expected here",
-                                  yyvsp[0].value, ACC_SYNCHRONIZED);
-                 if (yyvsp[0].value != ACC_SYNCHRONIZED)
-                   MODIFIER_WFL (SYNCHRONIZED_TK) = 
-                     build_wfl_node (NULL_TREE);
-               ;}
-    break;
-
-  case 321:
-#line 1884 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_try_statement (yyvsp[-2].operator.location, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 322:
-#line 1886 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_try_finally_statement (yyvsp[-2].operator.location, yyvsp[-1].node, yyvsp[0].node); ;}
-    break;
-
-  case 323:
-#line 1888 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_try_finally_statement 
-                   (yyvsp[-3].operator.location, build_try_statement (yyvsp[-3].operator.location,
-                                                      yyvsp[-2].node, yyvsp[-1].node), yyvsp[0].node);
-               ;}
-    break;
-
-  case 324:
-#line 1893 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); DRECOVER (try_statement);;}
-    break;
-
-  case 326:
-#line 1899 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 TREE_CHAIN (yyvsp[0].node) = yyvsp[-1].node;
-                 yyval.node = yyvsp[0].node;
-               ;}
-    break;
-
-  case 327:
-#line 1907 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 java_method_add_stmt (current_function_decl, yyvsp[0].node);
-                 exit_block ();
-                 yyval.node = yyvsp[-1].node;
-               ;}
-    break;
-
-  case 328:
-#line 1916 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 /* We add a block to define a scope for
-                    formal_parameter (CCBP). The formal parameter is
-                    declared initialized by the appropriate function
-                    call */
-                 tree ccpb = enter_block ();
-                 tree init = build_assignment
-                   (ASSIGN_TK, yyvsp[-2].operator.location, TREE_PURPOSE (yyvsp[-1].node), 
-                    build (JAVA_EXC_OBJ_EXPR, ptr_type_node));
-                 declare_local_variables (0, TREE_VALUE (yyvsp[-1].node),
-                                          build_tree_list (TREE_PURPOSE (yyvsp[-1].node),
-                                                           init));
-                 yyval.node = build1 (CATCH_EXPR, NULL_TREE, ccpb);
-                 EXPR_WFL_LINECOL (yyval.node) = yyvsp[-3].operator.location;
-               ;}
-    break;
-
-  case 329:
-#line 1932 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER; yyval.node = NULL_TREE;;}
-    break;
-
-  case 330:
-#line 1934 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing term or ')' expected"); 
-                 RECOVER; yyval.node = NULL_TREE;
-               ;}
-    break;
-
-  case 331:
-#line 1939 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER; yyval.node = NULL_TREE;;}
-    break;
-
-  case 332:
-#line 1944 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[0].node; ;}
-    break;
-
-  case 333:
-#line 1946 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'{' expected"); RECOVER; ;}
-    break;
-
-  case 337:
-#line 1958 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_this (yyvsp[0].operator.location); ;}
-    break;
-
-  case 338:
-#line 1960 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = yyvsp[-1].node;;}
-    break;
-
-  case 344:
-#line 1970 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree wfl = build_wfl_node (this_identifier_node);
-                 yyval.node = make_qualified_primary (yyvsp[-2].node, wfl, EXPR_WFL_LINECOL (yyvsp[-2].node));
-               ;}
-    break;
-
-  case 345:
-#line 1975 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 346:
-#line 1977 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'class' or 'this' expected" ); RECOVER;;}
-    break;
-
-  case 347:
-#line 1979 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'class' expected" ); RECOVER;;}
-    break;
-
-  case 348:
-#line 1981 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'class' expected" ); RECOVER;;}
-    break;
-
-  case 349:
-#line 1986 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_incomplete_class_ref (yyvsp[-1].operator.location, yyvsp[-2].node); ;}
-    break;
-
-  case 350:
-#line 1988 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_incomplete_class_ref (yyvsp[-1].operator.location, yyvsp[-2].node); ;}
-    break;
-
-  case 351:
-#line 1990 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_incomplete_class_ref (yyvsp[-1].operator.location, yyvsp[-2].node); ;}
-    break;
-
-  case 352:
-#line 1992 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                   yyval.node = build_incomplete_class_ref (yyvsp[-1].operator.location,
-                                                   void_type_node);
-                ;}
-    break;
-
-  case 353:
-#line 2000 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_new_invocation (yyvsp[-3].node, yyvsp[-1].node); ;}
-    break;
-
-  case 354:
-#line 2002 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_new_invocation (yyvsp[-2].node, NULL_TREE); ;}
-    break;
-
-  case 356:
-#line 2008 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree ctor = build_new_invocation (yyvsp[-2].node, NULL_TREE);
-                 yyval.node = make_qualified_primary (yyvsp[-3].node, ctor, 
-                                              EXPR_WFL_LINECOL (yyvsp[-3].node));
-               ;}
-    break;
-
-  case 358:
-#line 2015 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree ctor = build_new_invocation (yyvsp[-3].node, yyvsp[-1].node);
-                 yyval.node = make_qualified_primary (yyvsp[-4].node, ctor, 
-                                              EXPR_WFL_LINECOL (yyvsp[-4].node));
-               ;}
-    break;
-
-  case 360:
-#line 2022 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); DRECOVER(new_1);;}
-    break;
-
-  case 361:
-#line 2024 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 362:
-#line 2026 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' or term expected"); RECOVER;;}
-    break;
-
-  case 363:
-#line 2028 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("')' expected"); RECOVER;;}
-    break;
-
-  case 364:
-#line 2030 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {YYERROR_NOW; yyerror ("Identifier expected"); RECOVER;;}
-    break;
-
-  case 365:
-#line 2032 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'(' expected"); RECOVER;;}
-    break;
-
-  case 366:
-#line 2042 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_anonymous_class (yyvsp[-4].operator.location, yyvsp[-3].node); ;}
-    break;
-
-  case 367:
-#line 2044 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree id = build_wfl_node (DECL_NAME (GET_CPC ()));
-                 EXPR_WFL_LINECOL (id) = EXPR_WFL_LINECOL (yyvsp[-5].node);
-
-                 end_class_declaration (1);
-
-                 /* Now we can craft the new expression */
-                 yyval.node = build_new_invocation (id, yyvsp[-3].node);
-
-                 /* Note that we can't possibly be here if
-                    `class_type' is an interface (in which case the
-                    anonymous class extends Object and implements
-                    `class_type', hence its constructor can't have
-                    arguments.) */
-
-                 /* Otherwise, the innerclass must feature a
-                    constructor matching `argument_list'. Anonymous
-                    classes are a bit special: it's impossible to
-                    define constructor for them, hence constructors
-                    must be generated following the hints provided by
-                    the `new' expression. Whether a super constructor
-                    of that nature exists or not is to be verified
-                    later on in verify_constructor_super. 
-
-                    It's during the expansion of a `new' statement
-                    refering to an anonymous class that a ctor will
-                    be generated for the anonymous class, with the
-                    right arguments. */
-
-               ;}
-    break;
-
-  case 368:
-#line 2075 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { create_anonymous_class (yyvsp[-3].operator.location, yyvsp[-2].node); ;}
-    break;
-
-  case 369:
-#line 2077 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree id = build_wfl_node (DECL_NAME (GET_CPC ()));
-                 EXPR_WFL_LINECOL (id) = EXPR_WFL_LINECOL (yyvsp[-4].node);
-
-                 end_class_declaration (1);
-
-                 /* Now we can craft the new expression. The
-                     statement doesn't need to be remember so that a
-                     constructor can be generated, since its signature
-                     is already known. */
-                 yyval.node = build_new_invocation (id, NULL_TREE);
-               ;}
-    break;
-
-  case 370:
-#line 2093 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[-2].node; ;}
-    break;
-
-  case 371:
-#line 2095 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = yyvsp[-2].node; ;}
-    break;
-
-  case 372:
-#line 2100 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = tree_cons (NULL_TREE, yyvsp[0].node, NULL_TREE);
-                 ctxp->formal_parameter_number = 1; 
-               ;}
-    break;
-
-  case 373:
-#line 2105 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 ctxp->formal_parameter_number += 1;
-                 yyval.node = tree_cons (NULL_TREE, yyvsp[0].node, yyvsp[-2].node);
-               ;}
-    break;
-
-  case 374:
-#line 2110 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 375:
-#line 2115 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_newarray_node (yyvsp[-1].node, yyvsp[0].node, 0); ;}
-    break;
-
-  case 376:
-#line 2117 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_newarray_node (yyvsp[-1].node, yyvsp[0].node, 0); ;}
-    break;
-
-  case 377:
-#line 2119 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_newarray_node (yyvsp[-2].node, yyvsp[-1].node, pop_current_osb (ctxp));;}
-    break;
-
-  case 378:
-#line 2121 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_newarray_node (yyvsp[-2].node, yyvsp[-1].node, pop_current_osb (ctxp));;}
-    break;
-
-  case 379:
-#line 2125 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 char *sig;
-                 int osb = pop_current_osb (ctxp);
-                 while (osb--)
-                   obstack_grow (&temporary_obstack, "[]", 2);
-                 obstack_1grow (&temporary_obstack, '\0');
-                 sig = obstack_finish (&temporary_obstack);
-                 yyval.node = build (NEW_ANONYMOUS_ARRAY_EXPR, NULL_TREE,
-                             yyvsp[-2].node, get_identifier (sig), yyvsp[0].node);
-               ;}
-    break;
-
-  case 380:
-#line 2136 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 int osb = pop_current_osb (ctxp);
-                 tree type = yyvsp[-2].node;
-                 while (osb--)
-                   type = build_java_array_type (type, -1);
-                 yyval.node = build (NEW_ANONYMOUS_ARRAY_EXPR, NULL_TREE, 
-                             build_pointer_type (type), NULL_TREE, yyvsp[0].node);
-               ;}
-    break;
-
-  case 381:
-#line 2145 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("'[' expected"); DRECOVER ("]");;}
-    break;
-
-  case 382:
-#line 2147 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("']' expected"); RECOVER;;}
-    break;
-
-  case 383:
-#line 2152 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_tree_list (NULL_TREE, yyvsp[0].node); ;}
-    break;
-
-  case 384:
-#line 2154 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = tree_cons (NULL_TREE, yyvsp[0].node, yyval.node); ;}
-    break;
-
-  case 385:
-#line 2159 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 if (JNUMERIC_TYPE_P (TREE_TYPE (yyvsp[-1].node)))
-                   {
-                     yyvsp[-1].node = build_wfl_node (yyvsp[-1].node);
-                     TREE_TYPE (yyvsp[-1].node) = NULL_TREE;
-                   }
-                 EXPR_WFL_LINECOL (yyvsp[-1].node) = yyvsp[-2].operator.location;
-                 yyval.node = yyvsp[-1].node;
-               ;}
-    break;
-
-  case 386:
-#line 2169 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("']' expected"); RECOVER;;}
-    break;
-
-  case 387:
-#line 2171 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing term");
-                 yyerror ("']' expected");
-                 RECOVER;
-               ;}
-    break;
-
-  case 388:
-#line 2180 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 int allocate = 0;
-                 /* If not initialized, allocate memory for the osb
-                     numbers stack */
-                 if (!ctxp->osb_limit)
-                   {
-                     allocate = ctxp->osb_limit = 32;
-                     ctxp->osb_depth = -1;
-                   }
-                 /* If capacity overflown, reallocate a bigger chunk */
-                 else if (ctxp->osb_depth+1 == ctxp->osb_limit)
-                   allocate = ctxp->osb_limit << 1;
-                 
-                 if (allocate)
-                   {
-                     allocate *= sizeof (int);
-                     if (ctxp->osb_number)
-                       ctxp->osb_number = (int *)xrealloc (ctxp->osb_number,
-                                                           allocate);
-                     else
-                       ctxp->osb_number = (int *)xmalloc (allocate);
-                   }
-                 ctxp->osb_depth++;
-                 CURRENT_OSB (ctxp) = 1;
-               ;}
-    break;
-
-  case 389:
-#line 2206 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { CURRENT_OSB (ctxp)++; ;}
-    break;
-
-  case 390:
-#line 2208 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyerror ("']' expected"); RECOVER;;}
-    break;
-
-  case 391:
-#line 2213 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = make_qualified_primary (yyvsp[-2].node, yyvsp[0].node, yyvsp[-1].operator.location); ;}
-    break;
-
-  case 392:
-#line 2217 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 tree super_wfl = build_wfl_node (super_identifier_node);
-                 EXPR_WFL_LINECOL (super_wfl) = yyvsp[-2].operator.location;
-                 yyval.node = make_qualified_name (super_wfl, yyvsp[0].node, yyvsp[-1].operator.location);
-               ;}
-    break;
-
-  case 393:
-#line 2223 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Field expected"); DRECOVER (super_field_acces);;}
-    break;
-
-  case 394:
-#line 2228 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_method_invocation (yyvsp[-2].node, NULL_TREE); ;}
-    break;
-
-  case 395:
-#line 2230 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_method_invocation (yyvsp[-3].node, yyvsp[-1].node); ;}
-    break;
-
-  case 396:
-#line 2232 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 if (TREE_CODE (yyvsp[-4].node) == THIS_EXPR)
-                   yyval.node = build_this_super_qualified_invocation 
-                     (1, yyvsp[-2].node, NULL_TREE, 0, yyvsp[-3].operator.location);
-                 else
-                   {
-                     tree invok = build_method_invocation (yyvsp[-2].node, NULL_TREE);
-                     yyval.node = make_qualified_primary (yyvsp[-4].node, invok, yyvsp[-3].operator.location);
-                   }
-               ;}
-    break;
-
-  case 397:
-#line 2243 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 if (TREE_CODE (yyvsp[-5].node) == THIS_EXPR)
-                   yyval.node = build_this_super_qualified_invocation 
-                     (1, yyvsp[-3].node, yyvsp[-1].node, 0, yyvsp[-4].operator.location);
-                 else
-                   {
-                     tree invok = build_method_invocation (yyvsp[-3].node, yyvsp[-1].node);
-                     yyval.node = make_qualified_primary (yyvsp[-5].node, invok, yyvsp[-4].operator.location);
-                   }
-               ;}
-    break;
-
-  case 398:
-#line 2254 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build_this_super_qualified_invocation 
-                   (0, yyvsp[-2].node, NULL_TREE, yyvsp[-4].operator.location, yyvsp[-3].operator.location);
-               ;}
-    break;
-
-  case 399:
-#line 2259 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_this_super_qualified_invocation 
-                   (0, yyvsp[-3].node, yyvsp[-1].node, yyvsp[-5].operator.location, yyvsp[-4].operator.location);
-               ;}
-    break;
-
-  case 400:
-#line 2268 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyerror ("'(' expected"); DRECOVER (method_invocation); ;}
-    break;
-
-  case 401:
-#line 2270 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyerror ("'(' expected"); DRECOVER (method_invocation); ;}
-    break;
-
-  case 402:
-#line 2275 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_array_ref (yyvsp[-2].operator.location, yyvsp[-3].node, yyvsp[-1].node); ;}
-    break;
-
-  case 403:
-#line 2277 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_array_ref (yyvsp[-2].operator.location, yyvsp[-3].node, yyvsp[-1].node); ;}
-    break;
-
-  case 404:
-#line 2279 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing term and ']' expected");
-                 DRECOVER(array_access);
-               ;}
-    break;
-
-  case 405:
-#line 2284 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("']' expected");
-                 DRECOVER(array_access);
-               ;}
-    break;
-
-  case 406:
-#line 2289 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("Missing term and ']' expected");
-                 DRECOVER(array_access);
-               ;}
-    break;
-
-  case 407:
-#line 2294 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyerror ("']' expected");
-                 DRECOVER(array_access);
-               ;}
-    break;
-
-  case 412:
-#line 2309 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_incdec (yyvsp[0].operator.token, yyvsp[0].operator.location, yyvsp[-1].node, 1); ;}
-    break;
-
-  case 413:
-#line 2314 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_incdec (yyvsp[0].operator.token, yyvsp[0].operator.location, yyvsp[-1].node, 1); ;}
-    break;
-
-  case 416:
-#line 2321 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = build_unaryop (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[0].node); ;}
-    break;
-
-  case 418:
-#line 2324 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;}
-    break;
-
-  case 419:
-#line 2329 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 error_if_numeric_overflow (yyvsp[0].node);
-                 yyval.node = yyvsp[0].node;
-               ;}
-    break;
-
-  case 420:
-#line 2334 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = build_unaryop (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[0].node); ;}
-    break;
-
-  case 421:
-#line 2336 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;}
-    break;
-
-  case 422:
-#line 2341 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = build_incdec (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[0].node, 0); ;}
-    break;
-
-  case 423:
-#line 2343 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;}
-    break;
-
-  case 424:
-#line 2348 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = build_incdec (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[0].node, 0); ;}
-    break;
-
-  case 425:
-#line 2350 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;}
-    break;
-
-  case 427:
-#line 2356 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = build_unaryop (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[0].node); ;}
-    break;
-
-  case 428:
-#line 2358 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyval.node = build_unaryop (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[0].node); ;}
-    break;
-
-  case 430:
-#line 2361 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;}
-    break;
-
-  case 431:
-#line 2363 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;}
-    break;
-
-  case 432:
-#line 2368 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 tree type = yyvsp[-3].node;
-                 int osb = pop_current_osb (ctxp);
-                 while (osb--)
-                   type = build_java_array_type (type, -1);
-                 yyval.node = build_cast (yyvsp[-4].operator.location, type, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 433:
-#line 2376 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_cast (yyvsp[-3].operator.location, yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 434:
-#line 2378 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_cast (yyvsp[-3].operator.location, yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 435:
-#line 2380 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 const char *ptr;
-                 int osb = pop_current_osb (ctxp); 
-                 obstack_grow (&temporary_obstack, 
-                               IDENTIFIER_POINTER (EXPR_WFL_NODE (yyvsp[-3].node)),
-                               IDENTIFIER_LENGTH (EXPR_WFL_NODE (yyvsp[-3].node)));
-                 while (osb--)
-                   obstack_grow (&temporary_obstack, "[]", 2);
-                 obstack_1grow (&temporary_obstack, '\0');
-                 ptr = obstack_finish (&temporary_obstack);
-                 EXPR_WFL_NODE (yyvsp[-3].node) = get_identifier (ptr);
-                 yyval.node = build_cast (yyvsp[-4].operator.location, yyvsp[-3].node, yyvsp[0].node);
-               ;}
-    break;
-
-  case 436:
-#line 2394 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("']' expected, invalid type expression");;}
-    break;
-
-  case 437:
-#line 2396 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYNOT_TWICE yyerror ("Invalid type expression"); RECOVER;
-                 RECOVER;
-               ;}
-    break;
-
-  case 438:
-#line 2401 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 439:
-#line 2403 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 440:
-#line 2405 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 442:
-#line 2411 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { 
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), 
-                                   yyvsp[-1].operator.location, yyvsp[-2].node, yyvsp[0].node);
-               ;}
-    break;
-
-  case 443:
-#line 2416 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 444:
-#line 2421 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 445:
-#line 2426 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 446:
-#line 2428 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 447:
-#line 2430 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 449:
-#line 2436 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 450:
-#line 2441 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 451:
-#line 2446 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 452:
-#line 2448 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 454:
-#line 2454 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 455:
-#line 2459 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 456:
-#line 2464 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 457:
-#line 2469 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 458:
-#line 2471 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 459:
-#line 2473 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 461:
-#line 2479 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 462:
-#line 2484 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 463:
-#line 2489 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 464:
-#line 2494 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 465:
-#line 2499 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_binop (INSTANCEOF_EXPR, yyvsp[-1].operator.location, yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 466:
-#line 2501 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 467:
-#line 2503 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 468:
-#line 2505 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 469:
-#line 2507 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 470:
-#line 2509 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Invalid reference type"); RECOVER;;}
-    break;
-
-  case 472:
-#line 2515 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 473:
-#line 2520 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 474:
-#line 2525 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 475:
-#line 2527 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 477:
-#line 2533 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 478:
-#line 2538 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 480:
-#line 2544 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 481:
-#line 2549 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 483:
-#line 2555 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 484:
-#line 2560 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 486:
-#line 2566 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 487:
-#line 2571 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 489:
-#line 2577 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build_binop (BINOP_LOOKUP (yyvsp[-1].operator.token), yyvsp[-1].operator.location,
-                                   yyvsp[-2].node, yyvsp[0].node); 
-               ;}
-    break;
-
-  case 490:
-#line 2582 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); RECOVER;;}
-    break;
-
-  case 492:
-#line 2588 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 yyval.node = build (CONDITIONAL_EXPR, NULL_TREE, yyvsp[-4].node, yyvsp[-2].node, yyvsp[0].node);
-                 EXPR_WFL_LINECOL (yyval.node) = yyvsp[-3].operator.location;
-               ;}
-    break;
-
-  case 493:
-#line 2593 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYERROR_NOW;
-                 yyerror ("Missing term");
-                 DRECOVER (1);
-               ;}
-    break;
-
-  case 494:
-#line 2599 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); DRECOVER (2);;}
-    break;
-
-  case 495:
-#line 2601 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {yyerror ("Missing term"); DRECOVER (3);;}
-    break;
-
-  case 498:
-#line 2611 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    { yyval.node = build_assignment (yyvsp[-1].operator.token, yyvsp[-1].operator.location, yyvsp[-2].node, yyvsp[0].node); ;}
-    break;
-
-  case 499:
-#line 2613 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-    {
-                 YYNOT_TWICE yyerror ("Missing term");
-                 DRECOVER (assign);
-               ;}
-    break;
-
-
-    }
-
-/* Line 991 of yacc.c.  */
-#line 5952 "p2378.c"
-\f
-  yyvsp -= yylen;
-  yyssp -= yylen;
-
-
-  YY_STACK_PRINT (yyss, yyssp);
-
-  *++yyvsp = yyval;
-
-
-  /* Now `shift' the result of the reduction.  Determine what state
-     that goes to, based on the state we popped back to and the rule
-     number reduced by.  */
-
-  yyn = yyr1[yyn];
-
-  yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
-  if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
-    yystate = yytable[yystate];
-  else
-    yystate = yydefgoto[yyn - YYNTOKENS];
-
-  goto yynewstate;
-
-
-/*------------------------------------.
-| yyerrlab -- here on detecting error |
-`------------------------------------*/
-yyerrlab:
-  /* If not already recovering from an error, report this error.  */
-  if (!yyerrstatus)
-    {
-      ++yynerrs;
-#if YYERROR_VERBOSE
-      yyn = yypact[yystate];
-
-      if (YYPACT_NINF < yyn && yyn < YYLAST)
-       {
-         YYSIZE_T yysize = 0;
-         int yytype = YYTRANSLATE (yychar);
-         char *yymsg;
-         int yyx, yycount;
-
-         yycount = 0;
-         /* Start YYX at -YYN if negative to avoid negative indexes in
-            YYCHECK.  */
-         for (yyx = yyn < 0 ? -yyn : 0;
-              yyx < (int) (sizeof (yytname) / sizeof (char *)); yyx++)
-           if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
-             yysize += yystrlen (yytname[yyx]) + 15, yycount++;
-         yysize += yystrlen ("syntax error, unexpected ") + 1;
-         yysize += yystrlen (yytname[yytype]);
-         yymsg = (char *) YYSTACK_ALLOC (yysize);
-         if (yymsg != 0)
-           {
-             char *yyp = yystpcpy (yymsg, "syntax error, unexpected ");
-             yyp = yystpcpy (yyp, yytname[yytype]);
-
-             if (yycount < 5)
-               {
-                 yycount = 0;
-                 for (yyx = yyn < 0 ? -yyn : 0;
-                      yyx < (int) (sizeof (yytname) / sizeof (char *));
-                      yyx++)
-                   if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
-                     {
-                       const char *yyq = ! yycount ? ", expecting " : " or ";
-                       yyp = yystpcpy (yyp, yyq);
-                       yyp = yystpcpy (yyp, yytname[yyx]);
-                       yycount++;
-                     }
-               }
-             yyerror (yymsg);
-             YYSTACK_FREE (yymsg);
-           }
-         else
-           yyerror ("syntax error; also virtual memory exhausted");
-       }
-      else
-#endif /* YYERROR_VERBOSE */
-       yyerror ("syntax error");
-    }
-
-
-
-  if (yyerrstatus == 3)
-    {
-      /* If just tried and failed to reuse lookahead token after an
-        error, discard it.  */
-
-      /* Return failure if at end of input.  */
-      if (yychar == YYEOF)
-        {
-         /* Pop the error token.  */
-          YYPOPSTACK;
-         /* Pop the rest of the stack.  */
-         while (yyss < yyssp)
-           {
-             YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
-             yydestruct (yystos[*yyssp], yyvsp);
-             YYPOPSTACK;
-           }
-         YYABORT;
-        }
-
-      YYDSYMPRINTF ("Error: discarding", yytoken, &yylval, &yylloc);
-      yydestruct (yytoken, &yylval);
-      yychar = YYEMPTY;
-
-    }
-
-  /* Else will try to reuse lookahead token after shifting the error
-     token.  */
-  goto yyerrlab2;
-
-
-/*----------------------------------------------------.
-| yyerrlab1 -- error raised explicitly by an action.  |
-`----------------------------------------------------*/
-yyerrlab1:
-
-  /* Suppress GCC warning that yyerrlab1 is unused when no action
-     invokes YYERROR.  */
-#if defined (__GNUC_MINOR__) && 2093 <= (__GNUC__ * 1000 + __GNUC_MINOR__)
- __attribute__ ((__unused__));
-#endif
-
-
-  goto yyerrlab2;
-
-
-/*---------------------------------------------------------------.
-| yyerrlab2 -- pop states until the error token can be shifted.  |
-`---------------------------------------------------------------*/
-yyerrlab2:
-  yyerrstatus = 3;     /* Each real token shifted decrements this.  */
-
-  for (;;)
-    {
-      yyn = yypact[yystate];
-      if (yyn != YYPACT_NINF)
-       {
-         yyn += YYTERROR;
-         if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
-           {
-             yyn = yytable[yyn];
-             if (0 < yyn)
-               break;
-           }
-       }
-
-      /* Pop the current state because it cannot handle the error token.  */
-      if (yyssp == yyss)
-       YYABORT;
-
-      YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
-      yydestruct (yystos[yystate], yyvsp);
-      yyvsp--;
-      yystate = *--yyssp;
-
-      YY_STACK_PRINT (yyss, yyssp);
-    }
-
-  if (yyn == YYFINAL)
-    YYACCEPT;
-
-  YYDPRINTF ((stderr, "Shifting error token, "));
-
-  *++yyvsp = yylval;
-
-
-  yystate = yyn;
-  goto yynewstate;
-
-
-/*-------------------------------------.
-| yyacceptlab -- YYACCEPT comes here.  |
-`-------------------------------------*/
-yyacceptlab:
-  yyresult = 0;
-  goto yyreturn;
-
-/*-----------------------------------.
-| yyabortlab -- YYABORT comes here.  |
-`-----------------------------------*/
-yyabortlab:
-  yyresult = 1;
-  goto yyreturn;
-
-#ifndef yyoverflow
-/*----------------------------------------------.
-| yyoverflowlab -- parser overflow comes here.  |
-`----------------------------------------------*/
-yyoverflowlab:
-  yyerror ("parser stack overflow");
-  yyresult = 2;
-  /* Fall through.  */
-#endif
-
-yyreturn:
-#ifndef yyoverflow
-  if (yyss != yyssa)
-    YYSTACK_FREE (yyss);
-#endif
-  return yyresult;
-}
-
-
-#line 2638 "/u/molotova/0/galaad/gdosreis/gcc-3.2.3/gcc-3.2.3/gcc/java/parse.y"
-
-
-/* Helper function to retrieve an OSB count. Should be used when the
-   `dims:' rule is being used.  */
-
-static int
-pop_current_osb (ctxp)
-     struct parser_ctxt *ctxp;
-{
-  int to_return;
-
-  if (ctxp->osb_depth < 0)
-    abort ();
-  
-  to_return = CURRENT_OSB (ctxp);
-  ctxp->osb_depth--;
-  
-  return to_return;
-}
-
-\f
-
-/* This section of the code deal with save/restoring parser contexts.
-   Add mode documentation here. FIXME */
-
-/* Helper function. Create a new parser context. With
-   COPY_FROM_PREVIOUS set to a non zero value, content of the previous
-   context is copied, otherwise, the new context is zeroed. The newly
-   created context becomes the current one.  */
-
-static void
-create_new_parser_context (copy_from_previous)
-    int copy_from_previous;
-{
-  struct parser_ctxt *new;
-
-  new =  (struct parser_ctxt *)xmalloc(sizeof (struct parser_ctxt));
-  if (copy_from_previous)
-    {
-      memcpy ((PTR)new, (PTR)ctxp, sizeof (struct parser_ctxt));
-      new->saved_data_ctx = 1;
-    }
-  else
-    memset ((PTR) new, 0, sizeof (struct parser_ctxt));
-      
-  new->next = ctxp;
-  ctxp = new;
-}
-
-/* Create a new parser context and make it the current one. */
-
-void
-java_push_parser_context ()
-{
-  create_new_parser_context (0);
-}  
-
-void 
-java_pop_parser_context (generate)
-     int generate;
-{
-  tree current;
-  struct parser_ctxt *toFree, *next;
-
-  if (!ctxp)
-    return;
-
-  toFree = ctxp;
-  next = ctxp->next;
-  if (next)
-    {
-      lineno = ctxp->lineno;
-      current_class = ctxp->class_type;
-    }
-
-  /* If the old and new lexers differ, then free the old one.  */
-  if (ctxp->lexer && next && ctxp->lexer != next->lexer)
-    java_destroy_lexer (ctxp->lexer);
-
-  /* Set the single import class file flag to 0 for the current list
-     of imported things */
-  for (current = ctxp->import_list; current; current = TREE_CHAIN (current))
-    IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P (TREE_VALUE (current)) = 0;
-
-  /* And restore those of the previous context */
-  if ((ctxp = next))           /* Assignment is really meant here */
-    for (current = ctxp->import_list; current; current = TREE_CHAIN (current))
-      IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P (TREE_VALUE (current)) = 1;
-  
-  /* If we pushed a context to parse a class intended to be generated,
-     we keep it so we can remember the class. What we could actually
-     do is to just update a list of class names.  */
-  if (generate)
-    {
-      toFree->next = ctxp_for_generation;
-      ctxp_for_generation = toFree;
-    }
-  else
-    free (toFree);
-}
-
-/* Create a parser context for the use of saving some global
-   variables.  */
-
-void
-java_parser_context_save_global ()
-{
-  if (!ctxp)
-    {
-      java_push_parser_context ();
-      ctxp->saved_data_ctx = 1;
-    }
-
-  /* If this context already stores data, create a new one suitable
-     for data storage. */
-  else if (ctxp->saved_data)
-    create_new_parser_context (1);
-
-  ctxp->lineno = lineno;
-  ctxp->class_type = current_class;
-  ctxp->filename = input_filename;
-  ctxp->function_decl = current_function_decl;
-  ctxp->saved_data = 1;
-}
-
-/* Restore some global variables from the previous context. Make the
-   previous context the current one.  */
-
-void
-java_parser_context_restore_global ()
-{
-  lineno = ctxp->lineno;
-  current_class = ctxp->class_type;
-  input_filename = ctxp->filename;
-  if (wfl_operator)
-    {
-      tree s;
-      BUILD_FILENAME_IDENTIFIER_NODE (s, input_filename);
-      EXPR_WFL_FILENAME_NODE (wfl_operator) = s;
-    }
-  current_function_decl = ctxp->function_decl;
-  ctxp->saved_data = 0;
-  if (ctxp->saved_data_ctx)
-    java_pop_parser_context (0);
-}
-
-/* Suspend vital data for the current class/function being parsed so
-   that an other class can be parsed. Used to let local/anonymous
-   classes be parsed.  */
-
-static void
-java_parser_context_suspend ()
-{
-  /* This makes debugging through java_debug_context easier */
-  static const char *const name = "<inner buffer context>";
-
-  /* Duplicate the previous context, use it to save the globals we're
-     interested in */
-  create_new_parser_context (1);
-  ctxp->function_decl = current_function_decl;
-  ctxp->class_type = current_class;
-
-  /* Then create a new context which inherits all data from the
-     previous one. This will be the new current context  */
-  create_new_parser_context (1);
-
-  /* Help debugging */
-  ctxp->next->filename = name;
-}
-
-/* Resume vital data for the current class/function being parsed so
-   that an other class can be parsed. Used to let local/anonymous
-   classes be parsed.  The trick is the data storing file position
-   informations must be restored to their current value, so parsing
-   can resume as if no context was ever saved. */
-
-static void
-java_parser_context_resume ()
-{
-  struct parser_ctxt *old = ctxp;             /* This one is to be discarded */
-  struct parser_ctxt *saver = old->next;      /* This one contain saved info */
-  struct parser_ctxt *restored = saver->next; /* This one is the old current */
-
-  /* We need to inherit the list of classes to complete/generate */
-  restored->classd_list = old->classd_list;
-  restored->class_list = old->class_list;
-
-  /* Restore the current class and function from the saver */
-  current_class = saver->class_type;
-  current_function_decl = saver->function_decl;
-
-  /* Retrive the restored context */
-  ctxp = restored;
-
-  /* Re-installed the data for the parsing to carry on */
-  memcpy (&ctxp->marker_begining, &old->marker_begining, 
-         (size_t)(&ctxp->marker_end - &ctxp->marker_begining));
-
-  /* Buffer context can now be discarded */
-  free (saver);
-  free (old);
-}
-
-/* Add a new anchor node to which all statement(s) initializing static
-   and non static initialized upon declaration field(s) will be
-   linked.  */
-
-static void
-java_parser_context_push_initialized_field ()
-{
-  tree node;
-
-  node = build_tree_list (NULL_TREE, NULL_TREE);
-  TREE_CHAIN (node) = CPC_STATIC_INITIALIZER_LIST (ctxp);
-  CPC_STATIC_INITIALIZER_LIST (ctxp) = node;
-
-  node = build_tree_list (NULL_TREE, NULL_TREE);
-  TREE_CHAIN (node) = CPC_INITIALIZER_LIST (ctxp);
-  CPC_INITIALIZER_LIST (ctxp) = node;
-
-  node = build_tree_list (NULL_TREE, NULL_TREE);
-  TREE_CHAIN (node) = CPC_INSTANCE_INITIALIZER_LIST (ctxp);
-  CPC_INSTANCE_INITIALIZER_LIST (ctxp) = node;
-}
-
-/* Pop the lists of initialized field. If this lists aren't empty,
-   remember them so we can use it to create and populate the finit$
-   or <clinit> functions. */
-
-static void
-java_parser_context_pop_initialized_field ()
-{
-  tree stmts;
-  tree class_type = TREE_TYPE (GET_CPC ());
-
-  if (CPC_INITIALIZER_LIST (ctxp))
-    {
-      stmts = CPC_INITIALIZER_STMT (ctxp);
-      CPC_INITIALIZER_LIST (ctxp) = TREE_CHAIN (CPC_INITIALIZER_LIST (ctxp));
-      if (stmts && !java_error_count)
-       TYPE_FINIT_STMT_LIST (class_type) = reorder_static_initialized (stmts);
-    }
-
-  if (CPC_STATIC_INITIALIZER_LIST (ctxp))
-    {
-      stmts = CPC_STATIC_INITIALIZER_STMT (ctxp);
-      CPC_STATIC_INITIALIZER_LIST (ctxp) = 
-       TREE_CHAIN (CPC_STATIC_INITIALIZER_LIST (ctxp));
-      /* Keep initialization in order to enforce 8.5 */
-      if (stmts && !java_error_count)
-       TYPE_CLINIT_STMT_LIST (class_type) = nreverse (stmts);
-    }
-
-  /* JDK 1.1 instance initializers */
-  if (CPC_INSTANCE_INITIALIZER_LIST (ctxp))
-    {
-      stmts = CPC_INSTANCE_INITIALIZER_STMT (ctxp);
-      CPC_INSTANCE_INITIALIZER_LIST (ctxp) = 
-       TREE_CHAIN (CPC_INSTANCE_INITIALIZER_LIST (ctxp));
-      if (stmts && !java_error_count)
-       TYPE_II_STMT_LIST (class_type) = nreverse (stmts);
-    }
-}
-
-static tree
-reorder_static_initialized (list)
-     tree list;
-{
-  /* We have to keep things in order. The alias initializer have to
-     come first, then the initialized regular field, in reverse to
-     keep them in lexical order. */
-  tree marker, previous = NULL_TREE;
-  for (marker = list; marker; previous = marker, marker = TREE_CHAIN (marker))
-    if (TREE_CODE (marker) == TREE_LIST 
-       && !TREE_VALUE (marker) && !TREE_PURPOSE (marker))
-      break;
-  
-  /* No static initialized, the list is fine as is */
-  if (!previous)
-    list = TREE_CHAIN (marker);
-
-  /* No marker? reverse the whole list */
-  else if (!marker)
-    list = nreverse (list);
-
-  /* Otherwise, reverse what's after the marker and the new reordered
-     sublist will replace the marker. */
-  else
-    {
-      TREE_CHAIN (previous) = NULL_TREE;
-      list = nreverse (list);
-      list = chainon (TREE_CHAIN (marker), list);
-    }
-  return list;
-}
-
-/* Helper functions to dump the parser context stack.  */
-
-#define TAB_CONTEXT(C) \
-  {int i; for (i = 0; i < (C); i++) fputc (' ', stderr);}
-
-static void
-java_debug_context_do (tab)
-     int tab;
-{
-  struct parser_ctxt *copy = ctxp;
-  while (copy)
-    {
-      TAB_CONTEXT (tab);
-      fprintf (stderr, "ctxt: 0x%0lX\n", (unsigned long)copy);
-      TAB_CONTEXT (tab);
-      fprintf (stderr, "filename: %s\n", copy->filename);
-      TAB_CONTEXT (tab);
-      fprintf (stderr, "lineno: %d\n", copy->lineno);
-      TAB_CONTEXT (tab);
-      fprintf (stderr, "package: %s\n",
-              (copy->package ? 
-               IDENTIFIER_POINTER (copy->package) : "<none>"));
-      TAB_CONTEXT (tab);
-      fprintf (stderr, "context for saving: %d\n", copy->saved_data_ctx);
-      TAB_CONTEXT (tab);
-      fprintf (stderr, "saved data: %d\n", copy->saved_data);
-      copy = copy->next;
-      tab += 2;
-    }
-}
-
-/* Dump the stacked up parser contexts. Intended to be called from a
-   debugger.  */
-
-void
-java_debug_context ()
-{
-  java_debug_context_do (0);
-}
-
-\f
-
-/* Flag for the error report routine to issue the error the first time
-   it's called (overriding the default behavior which is to drop the
-   first invocation and honor the second one, taking advantage of a
-   richer context.  */
-static int force_error = 0;
-
-/* Reporting an constructor invocation error.  */
-static void
-parse_ctor_invocation_error ()
-{
-  if (DECL_CONSTRUCTOR_P (current_function_decl))
-    yyerror ("Constructor invocation must be first thing in a constructor"); 
-  else
-    yyerror ("Only constructors can invoke constructors");
-}
-
-/* Reporting JDK1.1 features not implemented.  */
-
-static tree
-parse_jdk1_1_error (msg)
-    const char *msg;
-{
-  sorry (": `%s' JDK1.1(TM) feature", msg);
-  java_error_count++;
-  return empty_stmt_node;
-}
-
-static int do_warning = 0;
-
-void
-yyerror (msg)
-     const char *msg;
-{
-  static java_lc elc;
-  static int  prev_lineno;
-  static const char *prev_msg;
-
-  int save_lineno;
-  char *remainder, *code_from_source;
-  
-  if (!force_error && prev_lineno == lineno)
-    return;
-
-  /* Save current error location but report latter, when the context is
-     richer.  */
-  if (ctxp->java_error_flag == 0)
-    {
-      ctxp->java_error_flag = 1;
-      elc = ctxp->elc;
-      /* Do something to use the previous line if we're reaching the
-        end of the file... */
-#ifdef VERBOSE_SKELETON
-      printf ("* Error detected (%s)\n", (msg ? msg : "(null)"));
-#endif
-      return;
-    }
-
-  /* Ignore duplicate message on the same line. BTW, this is dubious. FIXME */
-  if (!force_error && msg == prev_msg && prev_lineno == elc.line)
-    return;
-
-  ctxp->java_error_flag = 0;
-  if (do_warning)
-    java_warning_count++;
-  else
-    java_error_count++;
-  
-  if (elc.col == 0 && msg && msg[1] == ';')
-    {
-      elc.col  = ctxp->p_line->char_col-1;
-      elc.line = ctxp->p_line->lineno;
-    }
-
-  save_lineno = lineno;
-  prev_lineno = lineno = elc.line;
-  prev_msg = msg;
-
-  code_from_source = java_get_line_col (ctxp->filename, elc.line, elc.col);
-  obstack_grow0 (&temporary_obstack, 
-                code_from_source, strlen (code_from_source));
-  remainder = obstack_finish (&temporary_obstack);
-  if (do_warning)
-    warning ("%s.\n%s", msg, remainder);
-  else
-    error ("%s.\n%s", msg, remainder);
-
-  /* This allow us to cheaply avoid an extra 'Invalid expression
-     statement' error report when errors have been already reported on
-     the same line. This occurs when we report an error but don't have
-     a synchronization point other than ';', which
-     expression_statement is the only one to take care of.  */
-  ctxp->prevent_ese = lineno = save_lineno;
-}
-
-static void
-issue_warning_error_from_context (cl, msg, ap)
-     tree cl;
-     const char *msg;
-     va_list ap;
-{
-  const char *saved, *saved_input_filename;
-  char buffer [4096];
-  vsprintf (buffer, msg, ap);
-  force_error = 1;
-
-  ctxp->elc.line = EXPR_WFL_LINENO (cl);
-  ctxp->elc.col  = (EXPR_WFL_COLNO (cl) == 0xfff ? -1 : 
-                   (EXPR_WFL_COLNO (cl) == 0xffe ? -2 : EXPR_WFL_COLNO (cl)));
-
-  /* We have a CL, that's a good reason for using it if it contains data */
-  saved = ctxp->filename;
-  if (TREE_CODE (cl) == EXPR_WITH_FILE_LOCATION && EXPR_WFL_FILENAME_NODE (cl))
-    ctxp->filename = EXPR_WFL_FILENAME (cl);
-  saved_input_filename = input_filename;
-  input_filename = ctxp->filename;
-  java_error (NULL);
-  java_error (buffer);
-  ctxp->filename = saved;
-  input_filename = saved_input_filename;
-  force_error = 0;
-}
-
-/* Issue an error message at a current source line CL */
-
-void
-parse_error_context VPARAMS ((tree cl, const char *msg, ...))
-{
-  VA_OPEN (ap, msg);
-  VA_FIXEDARG (ap, tree, cl);
-  VA_FIXEDARG (ap, const char *, msg);
-  issue_warning_error_from_context (cl, msg, ap);
-  VA_CLOSE (ap);
-}
-
-/* Issue a warning at a current source line CL */
-
-static void
-parse_warning_context VPARAMS ((tree cl, const char *msg, ...))
-{
-  VA_OPEN (ap, msg);
-  VA_FIXEDARG (ap, tree, cl);
-  VA_FIXEDARG (ap, const char *, msg);
-
-  force_error = do_warning = 1;
-  issue_warning_error_from_context (cl, msg, ap);
-  do_warning = force_error = 0;
-  VA_CLOSE (ap);
-}
-
-static tree
-find_expr_with_wfl (node)
-     tree node;
-{
-  while (node)
-    {
-      char code;
-      tree to_return;
-
-      switch (TREE_CODE (node))
-       {
-       case BLOCK:
-         node = BLOCK_EXPR_BODY (node);
-         continue;
-
-       case COMPOUND_EXPR:
-         to_return = find_expr_with_wfl (TREE_OPERAND (node, 0));
-         if (to_return)
-           return to_return;
-         node = TREE_OPERAND (node, 1);
-         continue;
-
-       case LOOP_EXPR:
-         node = TREE_OPERAND (node, 0);
-         continue;
-         
-       case LABELED_BLOCK_EXPR:
-         node = TREE_OPERAND (node, 1);
-         continue;
-
-       default:
-         code = TREE_CODE_CLASS (TREE_CODE (node));
-         if (((code == '1') || (code == '2') || (code == 'e'))
-             && EXPR_WFL_LINECOL (node))
-           return node;
-         return NULL_TREE;
-       }
-    }
-  return NULL_TREE;
-}
-
-/* Issue a missing return statement error. Uses METHOD to figure the
-   last line of the method the error occurs in.  */
-
-static void
-missing_return_error (method)
-     tree method;
-{
-  EXPR_WFL_SET_LINECOL (wfl_operator, DECL_SOURCE_LINE_LAST (method), -2);
-  parse_error_context (wfl_operator, "Missing return statement");
-}
-
-/* Issue an unreachable statement error. From NODE, find the next
-   statement to report appropriately.  */
-static void
-unreachable_stmt_error (node)
-     tree node;
-{
-  /* Browse node to find the next expression node that has a WFL. Use
-     the location to report the error */
-  if (TREE_CODE (node) == COMPOUND_EXPR)
-    node = find_expr_with_wfl (TREE_OPERAND (node, 1));
-  else
-    node = find_expr_with_wfl (node);
-
-  if (node)
-    {
-      EXPR_WFL_SET_LINECOL (wfl_operator, EXPR_WFL_LINENO (node), -2);
-      parse_error_context (wfl_operator, "Unreachable statement");
-    }
-  else
-    abort ();
-}
-
-int
-java_report_errors ()
-{
-  if (java_error_count)
-    fprintf (stderr, "%d error%s", 
-            java_error_count, (java_error_count == 1 ? "" : "s"));
-  if (java_warning_count)
-    fprintf (stderr, "%s%d warning%s", (java_error_count ? ", " : ""),
-            java_warning_count, (java_warning_count == 1 ? "" : "s"));
-  if (java_error_count || java_warning_count)
-    putc ('\n', stderr);
-  return java_error_count;
-}
-
-static char *
-java_accstring_lookup (flags)
-     int flags;
-{
-  static char buffer [80];
-#define COPY_RETURN(S) {strcpy (buffer, S); return buffer;}
-
-  /* Access modifier looked-up first for easier report on forbidden
-     access. */
-  if (flags & ACC_PUBLIC) COPY_RETURN ("public");
-  if (flags & ACC_PRIVATE) COPY_RETURN ("private");
-  if (flags & ACC_PROTECTED) COPY_RETURN ("protected");
-  if (flags & ACC_STATIC) COPY_RETURN ("static");
-  if (flags & ACC_FINAL) COPY_RETURN ("final");
-  if (flags & ACC_SYNCHRONIZED) COPY_RETURN ("synchronized");
-  if (flags & ACC_VOLATILE) COPY_RETURN ("volatile");
-  if (flags & ACC_TRANSIENT) COPY_RETURN ("transient");
-  if (flags & ACC_NATIVE) COPY_RETURN ("native");
-  if (flags & ACC_INTERFACE) COPY_RETURN ("interface");
-  if (flags & ACC_ABSTRACT) COPY_RETURN ("abstract");
-
-  buffer [0] = '\0';
-  return buffer;
-#undef COPY_RETURN
-}
-
-/* Issuing error messages upon redefinition of classes, interfaces or
-   variables. */
-
-static void
-classitf_redefinition_error (context, id, decl, cl)
-     const char *context;
-     tree id, decl, cl;
-{
-  parse_error_context (cl, "%s `%s' already defined in %s:%d", 
-                      context, IDENTIFIER_POINTER (id), 
-                      DECL_SOURCE_FILE (decl), DECL_SOURCE_LINE (decl));
-  /* Here we should point out where its redefined. It's a unicode. FIXME */
-}
-
-static void
-variable_redefinition_error (context, name, type, line)
-     tree context, name, type;
-     int line;
-{
-  const char *type_name;
-
-  /* Figure a proper name for type. We might haven't resolved it */
-  if (TREE_CODE (type) == POINTER_TYPE && !TREE_TYPE (type))
-    type_name = IDENTIFIER_POINTER (TYPE_NAME (type));
-  else
-    type_name = lang_printable_name (type, 0);
-
-  parse_error_context (context,
-                      "Variable `%s' is already defined in this method and was declared `%s %s' at line %d", 
-                      IDENTIFIER_POINTER (name),
-                      type_name, IDENTIFIER_POINTER (name), line);
-}
-
-/* If ANAME is terminated with `[]', it indicates an array. This
-   function returns the number of `[]' found and if this number is
-   greater than zero, it extracts the array type name and places it in
-   the node pointed to by TRIMMED unless TRIMMED is null.  */
-
-static int
-build_type_name_from_array_name (aname, trimmed)
-     tree aname;
-     tree *trimmed;
-{
-  const char *name = IDENTIFIER_POINTER (aname);
-  int len = IDENTIFIER_LENGTH (aname);
-  int array_dims;
-
-  STRING_STRIP_BRACKETS (name, len, array_dims);
-
-  if (array_dims && trimmed)
-    *trimmed = get_identifier_with_length (name, len);
-
-  return array_dims;
-}
-
-static tree
-build_array_from_name (type, type_wfl, name, ret_name)
-     tree type, type_wfl, name, *ret_name;
-{
-  int more_dims = 0;
-
-  /* Eventually get more dims */
-  more_dims = build_type_name_from_array_name (name, &name);
-  
-  /* If we have, then craft a new type for this variable */
-  if (more_dims)
-    {
-      tree save = type;
-
-      /* If we have a pointer, use its type */
-      if (TREE_CODE (type) == POINTER_TYPE)
-        type = TREE_TYPE (type);
-
-      /* Building the first dimension of a primitive type uses this
-         function */
-      if (JPRIMITIVE_TYPE_P (type))
-       {
-         type = build_java_array_type (type, -1);
-         more_dims--;
-       }
-      /* Otherwise, if we have a WFL for this type, use it (the type
-         is already an array on an unresolved type, and we just keep
-         on adding dimensions) */
-      else if (type_wfl)
-       {
-         type = type_wfl;
-         more_dims += build_type_name_from_array_name (TYPE_NAME (save),
-                                                       NULL);
-       }
-
-      /* Add all the dimensions */
-      while (more_dims--)
-       type = build_unresolved_array_type (type);
-
-      /* The type may have been incomplete in the first place */
-      if (type_wfl)
-       type = obtain_incomplete_type (type);
-    }
-
-  if (ret_name)
-    *ret_name = name;
-  return type;
-}
-
-/* Build something that the type identifier resolver will identify as
-   being an array to an unresolved type. TYPE_WFL is a WFL on a
-   identifier. */
-
-static tree
-build_unresolved_array_type (type_or_wfl)
-     tree type_or_wfl;
-{
-  const char *ptr;
-  tree wfl;
-
-  /* TYPE_OR_WFL might be an array on a resolved type. In this case,
-     just create a array type */
-  if (TREE_CODE (type_or_wfl) == RECORD_TYPE)
-    return build_java_array_type (type_or_wfl, -1);
-
-  obstack_grow (&temporary_obstack,
-                IDENTIFIER_POINTER (EXPR_WFL_NODE (type_or_wfl)),
-                IDENTIFIER_LENGTH (EXPR_WFL_NODE (type_or_wfl)));
-  obstack_grow0 (&temporary_obstack, "[]", 2);
-  ptr = obstack_finish (&temporary_obstack);
-  wfl = build_expr_wfl (get_identifier (ptr),
-                       EXPR_WFL_FILENAME (type_or_wfl),
-                       EXPR_WFL_LINENO (type_or_wfl),
-                       EXPR_WFL_COLNO (type_or_wfl));
-  /* Re-install the existing qualifications so that the type can be
-     resolved properly. */
-  EXPR_WFL_QUALIFICATION (wfl) = EXPR_WFL_QUALIFICATION (type_or_wfl);
-  return wfl;
-}
-
-static void
-parser_add_interface (class_decl, interface_decl, wfl)
-     tree class_decl, interface_decl, wfl;
-{
-  if (maybe_add_interface (TREE_TYPE (class_decl), TREE_TYPE (interface_decl)))
-    parse_error_context (wfl, "Interface `%s' repeated",
-                        IDENTIFIER_POINTER (DECL_NAME (interface_decl)));
-}
-
-/* Bulk of common class/interface checks. Return 1 if an error was
-   encountered. TAG is 0 for a class, 1 for an interface.  */
-
-static int
-check_class_interface_creation (is_interface, flags, raw_name, qualified_name, decl, cl)
-     int is_interface, flags;
-     tree raw_name, qualified_name, decl, cl;
-{
-  tree node;
-  int sca = 0;                 /* Static class allowed */
-  int icaf = 0;                        /* Inner class allowed flags */
-  int uaaf = CLASS_MODIFIERS;  /* Usually allowed access flags */
-
-  if (!quiet_flag)
-    fprintf (stderr, " %s%s %s", 
-            (CPC_INNER_P () ? "inner" : ""),
-            (is_interface ? "interface" : "class"), 
-            IDENTIFIER_POINTER (qualified_name));
-
-  /* Scope of an interface/class type name:
-       - Can't be imported by a single type import
-       - Can't already exists in the package */
-  if (IS_A_SINGLE_IMPORT_CLASSFILE_NAME_P (raw_name)
-      && (node = find_name_in_single_imports (raw_name))
-      && !CPC_INNER_P ())
-    {
-      parse_error_context 
-       (cl, "%s name `%s' clashes with imported type `%s'",
-        (is_interface ? "Interface" : "Class"),
-        IDENTIFIER_POINTER (raw_name), IDENTIFIER_POINTER (node));
-      return 1;
-    }
-  if (decl && CLASS_COMPLETE_P (decl))
-    {
-      classitf_redefinition_error ((is_interface ? "Interface" : "Class"), 
-                                  qualified_name, decl, cl);
-      return 1;
-    }
-
-  if (check_inner_class_redefinition (raw_name, cl))
-    return 1;
-
-  /* If public, file name should match class/interface name, except
-     when dealing with an inner class */
-  if (!CPC_INNER_P () && (flags & ACC_PUBLIC ))
-    {
-      const char *f;
-
-      /* Contains OS dependent assumption on path separator. FIXME */
-      for (f = &input_filename [strlen (input_filename)]; 
-          f != input_filename && f[0] != '/' && f[0] != DIR_SEPARATOR;
-          f--)
-       ;
-      if (f[0] == '/' || f[0] == DIR_SEPARATOR)
-       f++;
-      if (strncmp (IDENTIFIER_POINTER (raw_name), 
-                  f , IDENTIFIER_LENGTH (raw_name)) ||
-         f [IDENTIFIER_LENGTH (raw_name)] != '.')
-       parse_error_context
-         (cl, "Public %s `%s' must be defined in a file called `%s.java'", 
-                            (is_interface ? "interface" : "class"),
-                            IDENTIFIER_POINTER (qualified_name),
-                            IDENTIFIER_POINTER (raw_name));
-    }
-
-  /* Static classes can be declared only in top level classes. Note:
-     once static, a inner class is a top level class. */
-  if (flags & ACC_STATIC)
-    {
-      /* Catch the specific error of declaring an class inner class
-        with no toplevel enclosing class. Prevent check_modifiers from
-        complaining a second time */
-      if (CPC_INNER_P () && !TOPLEVEL_CLASS_DECL_P (GET_CPC()))
-       {
-         parse_error_context (cl, "Inner class `%s' can't be static. Static classes can only occur in interfaces and top-level classes", 
-                              IDENTIFIER_POINTER (qualified_name));
-         sca = ACC_STATIC;
-       }
-      /* Else, in the context of a top-level class declaration, let
-         `check_modifiers' do its job, otherwise, give it a go */
-      else
-       sca = (GET_CPC_LIST () ? ACC_STATIC : 0);
-    }
-
-  /* Inner classes can be declared private or protected
-     within their enclosing classes. */
-  if (CPC_INNER_P ())
-    {
-      /* A class which is local to a block can't be public, private,
-        protected or static. But it is created final, so allow this
-        one. */
-      if (current_function_decl)
-       icaf = sca = uaaf = ACC_FINAL;
-      else
-       {
-         check_modifiers_consistency (flags);
-         icaf = ACC_PROTECTED;
-         if (! CLASS_INTERFACE (GET_CPC ()))
-           icaf |= ACC_PRIVATE;
-       }
-    }
-
-  if (is_interface) 
-    {
-      if (CPC_INNER_P ())
-       uaaf = INTERFACE_INNER_MODIFIERS;
-      else
-       uaaf = INTERFACE_MODIFIERS;
-      
-      check_modifiers ("Illegal modifier `%s' for interface declaration", 
-                      flags, uaaf);
-    }
-  else
-    check_modifiers ((current_function_decl ?
-                     "Illegal modifier `%s' for local class declaration" :
-                     "Illegal modifier `%s' for class declaration"),
-                    flags, uaaf|sca|icaf);
-  return 0;
-}
-
-static void
-make_nested_class_name (cpc_list)
-     tree cpc_list;
-{
-  tree name;
-
-  if (!cpc_list)
-    return;
-  else
-    make_nested_class_name (TREE_CHAIN (cpc_list));
-
-  /* Pick the qualified name when dealing with the first upmost
-     enclosing class */
-  name = (TREE_CHAIN (cpc_list) ? 
-         TREE_PURPOSE (cpc_list) : DECL_NAME (TREE_VALUE (cpc_list)));
-  obstack_grow (&temporary_obstack,
-               IDENTIFIER_POINTER (name), IDENTIFIER_LENGTH (name));
-  obstack_1grow (&temporary_obstack, '$');
-}
-
-/* Can't redefine a class already defined in an earlier scope. */
-
-static int
-check_inner_class_redefinition (raw_name, cl)
-     tree raw_name, cl;
-{
-  tree scope_list;
-
-  for (scope_list = GET_CPC_LIST (); scope_list; 
-       scope_list = GET_NEXT_ENCLOSING_CPC (scope_list))
-    if (raw_name == GET_CPC_UN_NODE (scope_list))
-      {
-       parse_error_context 
-         (cl, "The class name `%s' is already defined in this scope. An inner class may not have the same simple name as any of its enclosing classes",
-          IDENTIFIER_POINTER (raw_name));
-       return 1;
-      }
-  return 0;
-}
-
-/* Tries to find a decl for CLASS_TYPE within ENCLOSING. If we fail,
-   we remember ENCLOSING and SUPER.  */
-
-static tree
-resolve_inner_class (circularity_hash, cl, enclosing, super, class_type)
-     struct hash_table *circularity_hash;
-     tree cl, *enclosing, *super, class_type;
-{
-  tree local_enclosing = *enclosing;
-  tree local_super = NULL_TREE;
-
-  while (local_enclosing)
-    {
-      tree intermediate, decl;
-
-      hash_lookup (circularity_hash, 
-                  (const  hash_table_key) local_enclosing, TRUE, NULL);
-
-      if ((decl = find_as_inner_class (local_enclosing, class_type, cl)))
-       return decl;
-
-      intermediate = local_enclosing;
-      /* Explore enclosing contexts. */
-      while (INNER_CLASS_DECL_P (intermediate))
-       {
-         intermediate = DECL_CONTEXT (intermediate);
-         if ((decl = find_as_inner_class (intermediate, class_type, cl)))
-           return decl;
-       }
-
-      /* Now go to the upper classes, bail out if necessary. We will
-        analyze the returned SUPER and act accordingly (see
-        do_resolve_class.) */
-      local_super = CLASSTYPE_SUPER (TREE_TYPE (local_enclosing));
-      if (!local_super || local_super == object_type_node)
-        break;
-
-      if (TREE_CODE (local_super) == POINTER_TYPE)
-        local_super = do_resolve_class (NULL, local_super, NULL, NULL);
-      else
-       local_super = TYPE_NAME (local_super);
-
-      /* We may not have checked for circular inheritance yet, so do so
-         here to prevent an infinite loop. */
-      if (hash_lookup (circularity_hash,
-                      (const hash_table_key) local_super, FALSE, NULL))
-        {
-          if (!cl)
-            cl = lookup_cl (local_enclosing);
-         
-          parse_error_context
-            (cl, "Cyclic inheritance involving %s",
-            IDENTIFIER_POINTER (DECL_NAME (local_enclosing)));
-         local_enclosing = NULL_TREE;
-        }
-      else
-       local_enclosing = local_super;
-    }
-
-  /* We failed. Return LOCAL_SUPER and LOCAL_ENCLOSING. */
-  *super = local_super;
-  *enclosing = local_enclosing;
-
-  return NULL_TREE;
-}
-
-/* Within ENCLOSING, find a decl for NAME and return it. NAME can be
-   qualified. */
-
-static tree
-find_as_inner_class (enclosing, name, cl)
-     tree enclosing, name, cl;
-{
-  tree qual, to_return;
-  if (!enclosing)
-    return NULL_TREE;
-
-  name = TYPE_NAME (name);
-
-  /* First search: within the scope of `enclosing', search for name */
-  if (QUALIFIED_P (name) && cl && EXPR_WFL_NODE (cl) == name)
-    qual = EXPR_WFL_QUALIFICATION (cl);
-  else if (cl)
-    qual = build_tree_list (cl, NULL_TREE);
-  else
-    qual = build_tree_list (build_expr_wfl (name, NULL, 0, 0), NULL_TREE);
-  
-  if ((to_return = find_as_inner_class_do (qual, enclosing)))
-    return to_return;
-
-  /* We're dealing with a qualified name. Try to resolve thing until
-     we get something that is an enclosing class. */
-  if (QUALIFIED_P (name) && cl && EXPR_WFL_NODE (cl) == name)
-    {
-      tree acc = NULL_TREE, decl = NULL_TREE, ptr;
-
-      for (qual = EXPR_WFL_QUALIFICATION (cl); qual && !decl; 
-          qual = TREE_CHAIN (qual))
-       {
-         acc = merge_qualified_name (acc, 
-                                     EXPR_WFL_NODE (TREE_PURPOSE (qual)));
-         BUILD_PTR_FROM_NAME (ptr, acc);
-         decl = do_resolve_class (NULL_TREE, ptr, NULL_TREE, cl);
-       }
-
-      /* A NULL qual and a decl means that the search ended
-         successfully?!? We have to do something then. FIXME */
-      
-      if (decl)
-       enclosing = decl;
-      else
-       qual = EXPR_WFL_QUALIFICATION (cl);
-    }
-  /* Otherwise, create a qual for the other part of the resolution. */
-  else
-    qual = build_tree_list (build_expr_wfl (name, NULL, 0, 0), NULL_TREE);
-  
-  return find_as_inner_class_do (qual, enclosing);
-}
-
-/* We go inside the list of sub classes and try to find a way
-   through. */
-
-static tree
-find_as_inner_class_do (qual, enclosing)
-     tree qual, enclosing;
-{
-  if (!qual)
-    return NULL_TREE;
-
-  for (; qual && enclosing; qual = TREE_CHAIN (qual))
-    {
-      tree name_to_match = EXPR_WFL_NODE (TREE_PURPOSE (qual));
-      tree next_enclosing = NULL_TREE;
-      tree inner_list;
-
-      for (inner_list = DECL_INNER_CLASS_LIST (enclosing);
-           inner_list; inner_list = TREE_CHAIN (inner_list))
-       {
-         if (TREE_VALUE (inner_list) == name_to_match)
-           {
-             next_enclosing = TREE_PURPOSE (inner_list);
-             break;
-           }
-       }
-      enclosing = next_enclosing;
-    }
-
-  return (!qual && enclosing ? enclosing : NULL_TREE);
-}
-
-/* Reach all inner classes and tie their unqualified name to a
-   DECL. */
-
-static void
-set_nested_class_simple_name_value (outer, set)
-     tree outer;
-     int set;
-{
-  tree l;
-
-  for (l = DECL_INNER_CLASS_LIST (outer); l; l = TREE_CHAIN (l))
-    IDENTIFIER_GLOBAL_VALUE (TREE_VALUE (l)) = (set ? 
-                                               TREE_PURPOSE (l) : NULL_TREE);
-}
-
-static void
-link_nested_class_to_enclosing ()
-{
-  if (GET_ENCLOSING_CPC ())
-    {
-      tree enclosing = GET_ENCLOSING_CPC_CONTEXT ();
-      DECL_INNER_CLASS_LIST (enclosing) = 
-       tree_cons (GET_CPC (), GET_CPC_UN (),
-                  DECL_INNER_CLASS_LIST (enclosing));
-    }
-}
-
-static tree
-maybe_make_nested_class_name (name)
-     tree name;
-{
-  tree id = NULL_TREE;
-
-  if (CPC_INNER_P ())
-    {
-      make_nested_class_name (GET_CPC_LIST ());
-      obstack_grow0 (&temporary_obstack,
-                    IDENTIFIER_POINTER (name), 
-                    IDENTIFIER_LENGTH (name));
-      id = get_identifier (obstack_finish (&temporary_obstack));
-      if (ctxp->package)
-       QUALIFIED_P (id) = 1;
-    }
-  return id;
-}
-
-/* If DECL is NULL, create and push a new DECL, record the current
-   line CL and do other maintenance things.  */
-
-static tree
-maybe_create_class_interface_decl (decl, raw_name, qualified_name, cl)
-     tree decl, raw_name, qualified_name, cl;
-{
-  if (!decl)
-    decl = push_class (make_class (), qualified_name);
-
-  /* Take care of the file and line business */
-  DECL_SOURCE_FILE (decl) = EXPR_WFL_FILENAME (cl);
-  /* If we're emiting xrefs, store the line/col number information */
-  if (flag_emit_xref)
-    DECL_SOURCE_LINE (decl) = EXPR_WFL_LINECOL (cl);
-  else
-    DECL_SOURCE_LINE (decl) = EXPR_WFL_LINENO (cl);
-  CLASS_FROM_SOURCE_P (TREE_TYPE (decl)) = 1;
-  CLASS_PARSED_P (TREE_TYPE (decl)) = 1;
-  CLASS_FROM_CURRENTLY_COMPILED_P (TREE_TYPE (decl)) =
-    IS_A_COMMAND_LINE_FILENAME_P (EXPR_WFL_FILENAME_NODE (cl));
-
-  PUSH_CPC (decl, raw_name);
-  DECL_CONTEXT (decl) = GET_ENCLOSING_CPC_CONTEXT ();
-
-  /* Link the declaration to the already seen ones */
-  TREE_CHAIN (decl) = ctxp->class_list;
-  ctxp->class_list = decl;
-
-  /* Create a new nodes in the global lists */
-  gclass_list = tree_cons (NULL_TREE, decl, gclass_list);
-  all_class_list = tree_cons (NULL_TREE, decl, all_class_list);
-
-  /* Install a new dependency list element */
-  create_jdep_list (ctxp);
-
-  SOURCE_FRONTEND_DEBUG (("Defining class/interface %s", 
-                         IDENTIFIER_POINTER (qualified_name)));
-  return decl;
-}
-
-static void
-add_superinterfaces (decl, interface_list)
-     tree decl, interface_list;
-{
-  tree node;
-  /* Superinterface(s): if present and defined, parser_check_super_interface ()
-     takes care of ensuring that:
-       - This is an accessible interface type,
-       - Circularity detection.
-   parser_add_interface is then called. If present but not defined,
-   the check operation is delayed until the super interface gets
-   defined.  */
-  for (node = interface_list; node; node = TREE_CHAIN (node))
-    {
-      tree current = TREE_PURPOSE (node);
-      tree idecl = IDENTIFIER_CLASS_VALUE (EXPR_WFL_NODE (current));
-      if (idecl && CLASS_LOADED_P (TREE_TYPE (idecl)))
-       {
-         if (!parser_check_super_interface (idecl, decl, current))
-           parser_add_interface (decl, idecl, current);
-       }
-      else
-       register_incomplete_type (JDEP_INTERFACE,
-                                 current, decl, NULL_TREE);
-    }
-}
-
-/* Create an interface in pass1 and return its decl. Return the
-   interface's decl in pass 2.  */
-
-static tree
-create_interface (flags, id, super)
-     int flags;
-     tree id, super;
-{
-  tree raw_name = EXPR_WFL_NODE (id);
-  tree q_name = parser_qualified_classname (raw_name);
-  tree decl = IDENTIFIER_CLASS_VALUE (q_name);
-
-  /* Certain syntax errors are making SUPER be like ID. Avoid this
-     case. */
-  if (ctxp->class_err && id == super)
-    super = NULL;
-
-  EXPR_WFL_NODE (id) = q_name; /* Keep source location, even if refined. */
-
-  /* Basic checks: scope, redefinition, modifiers */ 
-  if (check_class_interface_creation (1, flags, raw_name, q_name, decl, id))
-    {
-      PUSH_ERROR ();
-      return NULL_TREE;
-    }
-
-  /* Suspend the current parsing context if we're parsing an inner
-     interface */
-  if (CPC_INNER_P ())
-    {
-      java_parser_context_suspend ();
-      /* Interface members are public. */
-      if (CLASS_INTERFACE (GET_CPC ()))
-       flags |= ACC_PUBLIC;
-    }
-
-  /* Push a new context for (static) initialized upon declaration fields */
-  java_parser_context_push_initialized_field ();
-
-  /* Interface modifiers check
-       - public/abstract allowed (already done at that point)
-       - abstract is obsolete (comes first, it's a warning, or should be)
-       - Can't use twice the same (checked in the modifier rule) */
-  if ((flags & ACC_ABSTRACT) && flag_redundant)
-    parse_warning_context 
-      (MODIFIER_WFL (ABSTRACT_TK),
-       "Redundant use of `abstract' modifier. Interface `%s' is implicitly abstract", IDENTIFIER_POINTER (raw_name));
-
-  /* Create a new decl if DECL is NULL, otherwise fix it */
-  decl = maybe_create_class_interface_decl (decl, raw_name, q_name, id);
-
-  /* Set super info and mark the class a complete */
-  set_super_info (ACC_INTERFACE | flags, TREE_TYPE (decl), 
-                 object_type_node, ctxp->interface_number);
-  ctxp->interface_number = 0;
-  CLASS_COMPLETE_P (decl) = 1;
-  add_superinterfaces (decl, super);
-
-  return decl;
-}
-
-/* Anonymous class counter. Will be reset to 1 every time a non
-   anonymous class gets created. */
-static int anonymous_class_counter = 1;
-
-/* Patch anonymous class CLASS, by either extending or implementing
-   DEP.  */
-
-static void
-patch_anonymous_class (type_decl, class_decl, wfl)
-    tree type_decl, class_decl, wfl;
-{
-  tree class = TREE_TYPE (class_decl);
-  tree type =  TREE_TYPE (type_decl);
-  tree binfo = TYPE_BINFO (class);
-
-  /* If it's an interface, implement it */
-  if (CLASS_INTERFACE (type_decl))
-    {
-      tree s_binfo;
-      int length;
-
-      if (parser_check_super_interface (type_decl, class_decl, wfl))
-       return;
-
-      s_binfo = TREE_VEC_ELT (BINFO_BASETYPES (TYPE_BINFO (class)), 0);
-      length = TREE_VEC_LENGTH (TYPE_BINFO_BASETYPES (class))+1;
-      TYPE_BINFO_BASETYPES (class) = make_tree_vec (length);
-      TREE_VEC_ELT (BINFO_BASETYPES (TYPE_BINFO (class)), 0) = s_binfo;
-      /* And add the interface */
-      parser_add_interface (class_decl, type_decl, wfl);
-    }
-  /* Otherwise, it's a type we want to extend */
-  else
-    {
-      if (parser_check_super (type_decl, class_decl, wfl))
-       return;
-      BINFO_TYPE (TREE_VEC_ELT (BINFO_BASETYPES (binfo), 0)) = type;
-    }
-}
-
-static tree
-create_anonymous_class (location, type_name)
-    int location;
-    tree type_name;
-{
-  char buffer [80];
-  tree super = NULL_TREE, itf = NULL_TREE;
-  tree id, type_decl, class;
-
-  /* The unqualified name of the anonymous class. It's just a number. */
-  sprintf (buffer, "%d", anonymous_class_counter++);
-  id = build_wfl_node (get_identifier (buffer));
-  EXPR_WFL_LINECOL (id) = location;
-
-  /* We know about the type to extend/implement. We go ahead */
-  if ((type_decl = IDENTIFIER_CLASS_VALUE (EXPR_WFL_NODE (type_name))))
-    {
-      /* Create a class which either implements on extends the designated
-        class. The class bears an innacessible name. */
-      if (CLASS_INTERFACE (type_decl))
-       {
-         /* It's OK to modify it here. It's been already used and
-             shouldn't be reused */
-         ctxp->interface_number = 1;
-         /* Interfaces should presented as a list of WFLs */
-         itf = build_tree_list (type_name, NULL_TREE);
-       }
-      else
-       super = type_name;
-    }
-
-  class = create_class (ACC_FINAL, id, super, itf);
-
-  /* We didn't know anything about the stuff. We register a dependence. */
-  if (!type_decl)
-    register_incomplete_type (JDEP_ANONYMOUS, type_name, class, NULL_TREE);
-
-  ANONYMOUS_CLASS_P (TREE_TYPE (class)) = 1;
-  return class;
-}
-
-/* Create a class in pass1 and return its decl. Return class
-   interface's decl in pass 2.  */
-
-static tree
-create_class (flags, id, super, interfaces)
-     int flags;
-     tree id, super, interfaces;
-{
-  tree raw_name = EXPR_WFL_NODE (id);
-  tree class_id, decl;
-  tree super_decl_type;
-
-  /* Certain syntax errors are making SUPER be like ID. Avoid this
-     case. */
-  if (ctxp->class_err && id == super)
-    super = NULL;
-
-  class_id = parser_qualified_classname (raw_name);
-  decl = IDENTIFIER_CLASS_VALUE (class_id);
-  EXPR_WFL_NODE (id) = class_id;
-
-  /* Basic check: scope, redefinition, modifiers */
-  if (check_class_interface_creation (0, flags, raw_name, class_id, decl, id))
-    {
-      PUSH_ERROR ();
-      return NULL_TREE;
-    }
-  
-  /* Suspend the current parsing context if we're parsing an inner
-     class or an anonymous class. */
-  if (CPC_INNER_P ())
-    {
-      java_parser_context_suspend ();
-      /* Interface members are public. */
-      if (CLASS_INTERFACE (GET_CPC ()))
-       flags |= ACC_PUBLIC;
-    }
-    
-  /* Push a new context for (static) initialized upon declaration fields */
-  java_parser_context_push_initialized_field ();
-
-  /* Class modifier check: 
-       - Allowed modifier (already done at that point)
-       - abstract AND final forbidden 
-       - Public classes defined in the correct file */
-  if ((flags & ACC_ABSTRACT) && (flags & ACC_FINAL))
-    parse_error_context
-      (id, "Class `%s' can't be declared both abstract and final",
-       IDENTIFIER_POINTER (raw_name));
-
-  /* Create a new decl if DECL is NULL, otherwise fix it */
-  decl = maybe_create_class_interface_decl (decl, raw_name, class_id, id);
-
-  /* If SUPER exists, use it, otherwise use Object */
-  if (super)
-    {
-      /* Can't extend java.lang.Object */
-      if (TREE_TYPE (IDENTIFIER_CLASS_VALUE (class_id)) == object_type_node)
-       {
-         parse_error_context (id, "Can't extend `java.lang.Object'");
-         return NULL_TREE;
-       }
-
-      super_decl_type = 
-       register_incomplete_type (JDEP_SUPER, super, decl, NULL_TREE);
-    }
-  else if (TREE_TYPE (decl) != object_type_node)
-    super_decl_type = object_type_node;
-  /* We're defining java.lang.Object */
-  else
-    super_decl_type = NULL_TREE;
-
-  /* A class nested in an interface is implicitly static. */
-  if (INNER_CLASS_DECL_P (decl)
-      && CLASS_INTERFACE (TYPE_NAME (TREE_TYPE (DECL_CONTEXT (decl)))))
-    {
-      flags |= ACC_STATIC;
-    }
-
-  /* Set super info and mark the class as complete. */
-  set_super_info (flags, TREE_TYPE (decl), super_decl_type, 
-                 ctxp->interface_number);
-  ctxp->interface_number = 0;
-  CLASS_COMPLETE_P (decl) = 1;
-  add_superinterfaces (decl, interfaces);
-
-  /* Add the private this$<n> field, Replicate final locals still in
-     scope as private final fields mangled like val$<local_name>.
-     This doesn't not occur for top level (static) inner classes. */
-  if (PURE_INNER_CLASS_DECL_P (decl))
-    add_inner_class_fields (decl, current_function_decl);
-
-  /* If doing xref, store the location at which the inherited class
-     (if any) was seen. */
-  if (flag_emit_xref && super)
-    DECL_INHERITED_SOURCE_LINE (decl) = EXPR_WFL_LINECOL (super);
-
-  /* Eventually sets the @deprecated tag flag */
-  CHECK_DEPRECATED (decl);
-
-  /* Reset the anonymous class counter when declaring non inner classes */
-  if (!INNER_CLASS_DECL_P (decl))
-    anonymous_class_counter = 1;
-
-  return decl;
-}
-
-/* End a class declaration: register the statements used to create
-   finit$ and <clinit>, pop the current class and resume the prior
-   parser context if necessary.  */
-
-static void
-end_class_declaration (resume)
-     int resume;
-{
-  /* If an error occurred, context weren't pushed and won't need to be
-     popped by a resume. */
-  int no_error_occurred = ctxp->next && GET_CPC () != error_mark_node;
-
-  if (GET_CPC () != error_mark_node)
-    dump_java_tree (TDI_class, GET_CPC ());
-
-  java_parser_context_pop_initialized_field ();
-  POP_CPC ();
-  if (resume && no_error_occurred)
-    java_parser_context_resume ();
-
-  /* We're ending a class declaration, this is a good time to reset
-     the interface cout. Note that might have been already done in
-     create_interface, but if at that time an inner class was being
-     dealt with, the interface count was reset in a context created
-     for the sake of handling inner classes declaration. */
-  ctxp->interface_number = 0;
-}
-
-static void
-add_inner_class_fields (class_decl, fct_decl)
-     tree class_decl;
-     tree fct_decl;
-{
-  tree block, marker, f;
-
-  f = add_field (TREE_TYPE (class_decl),
-                build_current_thisn (TREE_TYPE (class_decl)),
-                build_pointer_type (TREE_TYPE (DECL_CONTEXT (class_decl))), 
-                ACC_PRIVATE);
-  FIELD_THISN (f) = 1;
-
-  if (!fct_decl)
-    return;
-    
-  for (block = GET_CURRENT_BLOCK (fct_decl); 
-       block && TREE_CODE (block) == BLOCK; block = BLOCK_SUPERCONTEXT (block))
-    {
-      tree decl;
-      for (decl = BLOCK_EXPR_DECLS (block); decl; decl = TREE_CHAIN (decl))
-       {
-         tree name, pname;
-         tree wfl, init, list;
-         
-         /* Avoid non final arguments. */
-         if (!LOCAL_FINAL_P (decl))
-           continue;
-         
-         MANGLE_OUTER_LOCAL_VARIABLE_NAME (name, DECL_NAME (decl));
-         MANGLE_ALIAS_INITIALIZER_PARAMETER_NAME_ID (pname, DECL_NAME (decl));
-         wfl = build_wfl_node (name);
-         init = build_wfl_node (pname);
-         /* Build an initialization for the field: it will be
-            initialized by a parameter added to finit$, bearing a
-            mangled name of the field itself (param$<n>.) The
-            parameter is provided to finit$ by the constructor
-            invoking it (hence the constructor will also feature a
-            hidden parameter, set to the value of the outer context
-            local at the time the inner class is created.)
-            
-            Note: we take into account all possible locals that can
-            be accessed by the inner class. It's actually not trivial
-            to minimize these aliases down to the ones really
-            used. One way to do that would be to expand all regular
-            methods first, then finit$ to get a picture of what's
-            used.  It works with the exception that we would have to
-            go back on all constructor invoked in regular methods to
-            have their invokation reworked (to include the right amount
-            of alias initializer parameters.)
-
-            The only real way around, I think, is a first pass to
-            identify locals really used in the inner class. We leave
-            the flag FIELD_LOCAL_ALIAS_USED around for that future
-            use.
-            
-            On the other hand, it only affect local inner classes,
-            whose constructors (and finit$ call) will be featuring
-            unecessary arguments. It's easy for a developper to keep
-            this number of parameter down by using the `final'
-            keyword only when necessary. For the time being, we can
-            issue a warning on unecessary finals. FIXME */
-         init = build_assignment (ASSIGN_TK, EXPR_WFL_LINECOL (wfl), 
-                                  wfl, init);
-
-         /* Register the field. The TREE_LIST holding the part
-            initialized/initializer will be marked ARG_FINAL_P so
-            that the created field can be marked
-            FIELD_LOCAL_ALIAS. */
-         list = build_tree_list (wfl, init);
-         ARG_FINAL_P (list) = 1;
-         register_fields (ACC_PRIVATE | ACC_FINAL, TREE_TYPE (decl), list);
-       }
-    }
-
-  if (!CPC_INITIALIZER_STMT (ctxp))
-    return;
-
-  /* If we ever registered an alias field, insert and marker to
-     remeber where the list ends. The second part of the list (the one
-     featuring initialized fields) so it can be later reversed to
-     enforce 8.5. The marker will be removed during that operation. */
-  marker = build_tree_list (NULL_TREE, NULL_TREE);
-  TREE_CHAIN (marker) = CPC_INITIALIZER_STMT (ctxp);
-  SET_CPC_INITIALIZER_STMT (ctxp, marker);
-}
-
-/* Can't use lookup_field () since we don't want to load the class and
-   can't set the CLASS_LOADED_P flag */
-
-static tree
-find_field (class, name)
-     tree class;
-     tree name;
-{
-  tree decl;
-  for (decl = TYPE_FIELDS (class); decl; decl = TREE_CHAIN (decl))
-    {
-      if (DECL_NAME (decl) == name)
-       return decl;
-    }
-  return NULL_TREE;
-}
-
-/* Wrap around lookup_field that doesn't potentially upset the value
-   of CLASS */
-
-static tree
-lookup_field_wrapper (class, name)
-     tree class, name;
-{
-  tree type = class;
-  tree decl = NULL_TREE;
-  java_parser_context_save_global ();
-
-  /* Last chance: if we're within the context of an inner class, we
-     might be trying to access a local variable defined in an outer
-     context. We try to look for it now. */
-  if (INNER_CLASS_TYPE_P (class) && TREE_CODE (name) == IDENTIFIER_NODE)
-    {
-      tree new_name;
-      MANGLE_OUTER_LOCAL_VARIABLE_NAME (new_name, name);
-      decl = lookup_field (&type, new_name);
-      if (decl && decl != error_mark_node)
-       FIELD_LOCAL_ALIAS_USED (decl) = 1;
-    }
-  if (!decl || decl == error_mark_node)
-    {
-      type = class;
-      decl = lookup_field (&type, name);
-    }
-
-  /* If the field still hasn't been found, try the next enclosing context. */
-  if (!decl && INNER_CLASS_TYPE_P (class))
-    {
-      tree outer_type = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (class)));
-      decl = lookup_field_wrapper (outer_type, name);
-    }
-
-  java_parser_context_restore_global ();
-  return decl == error_mark_node ? NULL : decl;
-}
-
-/* Find duplicate field within the same class declarations and report
-   the error. Returns 1 if a duplicated field was found, 0
-   otherwise.  */
-
-static int
-duplicate_declaration_error_p (new_field_name, new_type, cl)
-     tree new_field_name, new_type, cl;
-{
-  /* This might be modified to work with method decl as well */
-  tree decl = find_field (TREE_TYPE (GET_CPC ()), new_field_name);
-  if (decl)
-    {
-      char *t1 = xstrdup (purify_type_name
-                        ((TREE_CODE (new_type) == POINTER_TYPE 
-                          && TREE_TYPE (new_type) == NULL_TREE) ?
-                         IDENTIFIER_POINTER (TYPE_NAME (new_type)) :
-                         lang_printable_name (new_type, 1)));
-      /* The type may not have been completed by the time we report
-        the error */
-      char *t2 = xstrdup (purify_type_name
-                        ((TREE_CODE (TREE_TYPE (decl)) == POINTER_TYPE 
-                          && TREE_TYPE (TREE_TYPE (decl)) == NULL_TREE) ?
-                         IDENTIFIER_POINTER (TYPE_NAME (TREE_TYPE (decl))) :
-                         lang_printable_name (TREE_TYPE (decl), 1)));
-      parse_error_context 
-       (cl , "Duplicate variable declaration: `%s %s' was `%s %s' (%s:%d)", 
-        t1, IDENTIFIER_POINTER (new_field_name),
-        t2, IDENTIFIER_POINTER (DECL_NAME (decl)),
-        DECL_SOURCE_FILE (decl), DECL_SOURCE_LINE (decl));
-      free (t1);
-      free (t2);
-      return 1;
-    }
-  return 0;
-}
-
-/* Field registration routine. If TYPE doesn't exist, field
-   declarations are linked to the undefined TYPE dependency list, to
-   be later resolved in java_complete_class () */
-
-static void
-register_fields (flags, type, variable_list)
-     int flags;
-     tree type, variable_list;
-{
-  tree current, saved_type;
-  tree class_type = NULL_TREE;
-  int saved_lineno = lineno;
-  int must_chain = 0;
-  tree wfl = NULL_TREE;
-
-  if (GET_CPC ())
-    class_type = TREE_TYPE (GET_CPC ());
-
-  if (!class_type || class_type == error_mark_node)
-    return;
-
-  /* If we're adding fields to interfaces, those fields are public,
-     static, final */
-  if (CLASS_INTERFACE (TYPE_NAME (class_type)))
-    {
-      OBSOLETE_MODIFIER_WARNING (MODIFIER_WFL (PUBLIC_TK),
-                                flags, ACC_PUBLIC, "interface field(s)");
-      OBSOLETE_MODIFIER_WARNING (MODIFIER_WFL (STATIC_TK),
-                                flags, ACC_STATIC, "interface field(s)");
-      OBSOLETE_MODIFIER_WARNING (MODIFIER_WFL (FINAL_TK),
-                                flags, ACC_FINAL, "interface field(s)");
-      check_modifiers ("Illegal interface member modifier `%s'", flags,
-                      INTERFACE_FIELD_MODIFIERS);
-      flags |= (ACC_PUBLIC | ACC_STATIC | ACC_FINAL);
-    }
-
-  /* Obtain a suitable type for resolution, if necessary */
-  SET_TYPE_FOR_RESOLUTION (type, wfl, must_chain);
-
-  /* If TYPE is fully resolved and we don't have a reference, make one */
-  PROMOTE_RECORD_IF_COMPLETE (type, must_chain);
-
-  for (current = variable_list, saved_type = type; current; 
-       current = TREE_CHAIN (current), type = saved_type)
-    {
-      tree real_type;
-      tree field_decl;
-      tree cl = TREE_PURPOSE (current);
-      tree init = TREE_VALUE (current);
-      tree current_name = EXPR_WFL_NODE (cl);
-
-      /* Can't declare non-final static fields in inner classes */
-      if ((flags & ACC_STATIC) && !TOPLEVEL_CLASS_TYPE_P (class_type)
-          && !(flags & ACC_FINAL))
-       parse_error_context 
-          (cl, "Field `%s' can't be static in inner class `%s' unless it is final",
-          IDENTIFIER_POINTER (EXPR_WFL_NODE (cl)),
-          lang_printable_name (class_type, 0));
-
-      /* Process NAME, as it may specify extra dimension(s) for it */
-      type = build_array_from_name (type, wfl, current_name, &current_name);
-
-      /* Type adjustment. We may have just readjusted TYPE because
-        the variable specified more dimensions. Make sure we have
-        a reference if we can and don't have one already. Also
-        change the name if we have an init. */
-      if (type != saved_type)
-       {
-         PROMOTE_RECORD_IF_COMPLETE (type, must_chain);
-         if (init)
-           EXPR_WFL_NODE (TREE_OPERAND (init, 0)) = current_name;
-       }
-
-      real_type = GET_REAL_TYPE (type);
-      /* Check for redeclarations */
-      if (duplicate_declaration_error_p (current_name, real_type, cl))
-       continue;
-
-      /* Set lineno to the line the field was found and create a
-         declaration for it. Eventually sets the @deprecated tag flag. */
-      if (flag_emit_xref)
-       lineno = EXPR_WFL_LINECOL (cl);
-      else
-       lineno = EXPR_WFL_LINENO (cl);
-      field_decl = add_field (class_type, current_name, real_type, flags);
-      CHECK_DEPRECATED (field_decl);
-
-      /* If the field denotes a final instance variable, then we
-        allocate a LANG_DECL_SPECIFIC part to keep track of its
-        initialization. We also mark whether the field was
-        initialized upon its declaration. We don't do that if the
-        created field is an alias to a final local. */
-      if (!ARG_FINAL_P (current) && (flags & ACC_FINAL))
-       {
-         MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (field_decl);
-         DECL_FIELD_FINAL_WFL (field_decl) = cl;
-       }
-
-      /* If the couple initializer/initialized is marked ARG_FINAL_P,
-        we mark the created field FIELD_LOCAL_ALIAS, so that we can
-        hide parameters to this inner class finit$ and
-        constructors. It also means that the field isn't final per
-        say. */
-      if (ARG_FINAL_P (current))
-       {
-         FIELD_LOCAL_ALIAS (field_decl) = 1;
-         FIELD_FINAL (field_decl) = 0;
-       }
-      
-      /* Check if we must chain. */
-      if (must_chain)
-       register_incomplete_type (JDEP_FIELD, wfl, field_decl, type);
-         
-      /* If we have an initialization value tied to the field */
-      if (init)
-       {
-         /* The field is declared static */
-         if (flags & ACC_STATIC)
-           {
-             /* We include the field and its initialization part into
-                a list used to generate <clinit>. After <clinit> is
-                walked, field initializations will be processed and
-                fields initialized with known constants will be taken
-                out of <clinit> and have their DECL_INITIAL set
-                appropriately. */
-             TREE_CHAIN (init) = CPC_STATIC_INITIALIZER_STMT (ctxp);
-             SET_CPC_STATIC_INITIALIZER_STMT (ctxp, init);
-             if (TREE_OPERAND (init, 1) 
-                 && TREE_CODE (TREE_OPERAND (init, 1)) == NEW_ARRAY_INIT)
-               TREE_STATIC (TREE_OPERAND (init, 1)) = 1;
-           }
-         /* A non-static field declared with an immediate initialization is
-            to be initialized in <init>, if any.  This field is remembered
-            to be processed at the time of the generation of <init>. */
-         else
-           {
-             TREE_CHAIN (init) = CPC_INITIALIZER_STMT (ctxp);
-             SET_CPC_INITIALIZER_STMT (ctxp, init);
-           }
-         MODIFY_EXPR_FROM_INITIALIZATION_P (init) = 1;
-         DECL_INITIAL (field_decl) = TREE_OPERAND (init, 1);
-       }
-    }
-  lineno = saved_lineno;
-}
-
-/* Generate finit$, using the list of initialized fields to populate
-   its body. finit$'s parameter(s) list is adjusted to include the
-   one(s) used to initialized the field(s) caching outer context
-   local(s).  */
-
-static tree
-generate_finit (class_type)
-     tree class_type;
-{
-  int count = 0;
-  tree list = TYPE_FINIT_STMT_LIST (class_type);
-  tree mdecl, current, parms;
-
-  parms = build_alias_initializer_parameter_list (AIPL_FUNCTION_CREATION, 
-                                                 class_type, NULL_TREE, 
-                                                 &count);
-  CRAFTED_PARAM_LIST_FIXUP (parms);
-  mdecl = create_artificial_method (class_type, ACC_PRIVATE, void_type_node,
-                                   finit_identifier_node, parms);
-  fix_method_argument_names (parms, mdecl);
-  layout_class_method (class_type, CLASSTYPE_SUPER (class_type),
-                      mdecl, NULL_TREE);
-  DECL_FUNCTION_NAP (mdecl) = count;
-  start_artificial_method_body (mdecl);
-
-  for (current = list; current; current = TREE_CHAIN (current))
-    java_method_add_stmt (mdecl, 
-                         build_debugable_stmt (EXPR_WFL_LINECOL (current), 
-                                               current));
-  end_artificial_method_body (mdecl);
-  return mdecl;
-}
-
-/* Generate a function to run the instance initialization code. The
-   private method is called `instinit$'. Unless we're dealing with an
-   anonymous class, we determine whether all ctors of CLASS_TYPE
-   declare a checked exception in their `throws' clause in order to
-   see whether it's necessary to encapsulate the instance initializer
-   statements in a try/catch/rethrow sequence.  */
-
-static tree
-generate_instinit (class_type)
-     tree class_type;
-{
-  tree current;
-  tree compound = NULL_TREE;
-  tree parms = tree_cons (this_identifier_node,
-                         build_pointer_type (class_type), end_params_node);
-  tree mdecl = create_artificial_method (class_type, ACC_PRIVATE,
-                                        void_type_node,
-                                        instinit_identifier_node, parms);
-
-  layout_class_method (class_type, CLASSTYPE_SUPER (class_type),
-                      mdecl, NULL_TREE);
-
-  /* Gather all the statements in a compound */
-  for (current = TYPE_II_STMT_LIST (class_type); 
-       current; current = TREE_CHAIN (current))
-    compound = add_stmt_to_compound (compound, NULL_TREE, current);
-
-  /* We need to encapsulate COMPOUND by a try/catch statement to
-     rethrow exceptions that might occur in the instance initializer.
-     We do that only if all ctors of CLASS_TYPE are set to catch a
-     checked exception. This doesn't apply to anonymous classes (since
-     they don't have declared ctors.) */
-  if (!ANONYMOUS_CLASS_P (class_type) && 
-      ctors_unchecked_throws_clause_p (class_type))
-    {
-      compound = encapsulate_with_try_catch (0, exception_type_node, compound, 
-                                            build1 (THROW_EXPR, NULL_TREE,
-                                                    build_wfl_node (wpv_id)));
-      DECL_FUNCTION_THROWS (mdecl) = build_tree_list (NULL_TREE,
-                                                     exception_type_node);
-    }
-
-  start_artificial_method_body (mdecl);
-  java_method_add_stmt (mdecl, compound);
-  end_artificial_method_body (mdecl);
-
-  return mdecl;
-}
-
-/* FIXME */
-static tree
-build_instinit_invocation (class_type)
-     tree class_type;
-{
-  tree to_return = NULL_TREE;
-
-  if (TYPE_II_STMT_LIST (class_type))
-    {
-      tree parm = build_tree_list (NULL_TREE,
-                                  build_wfl_node (this_identifier_node));
-      to_return =
-       build_method_invocation (build_wfl_node (instinit_identifier_node),
-                                parm);
-    }
-  return to_return;
-}
-
-/* Shared accros method_declarator and method_header to remember the
-   patch stage that was reached during the declaration of the method.
-   A method DECL is built differently is there is no patch
-   (JDEP_NO_PATCH) or a patch (JDEP_METHOD or JDEP_METHOD_RETURN)
-   pending on the currently defined method.  */
-
-static int patch_stage;
-
-/* Check the method declaration and add the method to its current
-   class.  If the argument list is known to contain incomplete types,
-   the method is partially added and the registration will be resume
-   once the method arguments resolved. If TYPE is NULL, we're dealing
-   with a constructor.  */
-
-static tree
-method_header (flags, type, mdecl, throws)
-     int flags;
-     tree type, mdecl, throws;
-{
-  tree type_wfl = NULL_TREE;
-  tree meth_name = NULL_TREE;
-  tree current, orig_arg, this_class = NULL;
-  tree id, meth;
-  int saved_lineno;
-  int constructor_ok = 0, must_chain;
-  int count;
-
-  if (mdecl == error_mark_node)
-    return error_mark_node;
-  meth = TREE_VALUE (mdecl);
-  id = TREE_PURPOSE (mdecl);
-  
-  check_modifiers_consistency (flags);
-
-  if (GET_CPC ())
-    this_class = TREE_TYPE (GET_CPC ());
-
-  if (!this_class || this_class == error_mark_node)
-    return NULL_TREE;
-  
-  /* There are some forbidden modifiers for an abstract method and its
-     class must be abstract as well.  */
-  if (type && (flags & ACC_ABSTRACT))
-    {
-      ABSTRACT_CHECK (flags, ACC_PRIVATE, id, "Private");
-      ABSTRACT_CHECK (flags, ACC_STATIC, id, "Static");
-      ABSTRACT_CHECK (flags, ACC_FINAL, id, "Final");
-      ABSTRACT_CHECK (flags, ACC_NATIVE, id, "Native");
-      ABSTRACT_CHECK (flags, ACC_SYNCHRONIZED, id, "Synchronized");
-      ABSTRACT_CHECK (flags, ACC_STRICT, id, "Strictfp");
-      if (!CLASS_ABSTRACT (TYPE_NAME (this_class))
-         && !CLASS_INTERFACE (TYPE_NAME (this_class)))
-       parse_error_context 
-         (id, "Class `%s' must be declared abstract to define abstract method `%s'", 
-          IDENTIFIER_POINTER (DECL_NAME (GET_CPC ())),
-          IDENTIFIER_POINTER (EXPR_WFL_NODE (id)));
-    }
-
-  /* Things to be checked when declaring a constructor */
-  if (!type)
-    {
-      int ec = java_error_count;
-      /* 8.6: Constructor declarations: we might be trying to define a
-         method without specifying a return type. */
-      if (EXPR_WFL_NODE (id) != GET_CPC_UN ())
-       parse_error_context 
-         (id, "Invalid method declaration, return type required");
-      /* 8.6.3: Constructor modifiers */
-      else
-       {
-         JCONSTRUCTOR_CHECK (flags, ACC_ABSTRACT, id, "abstract");
-         JCONSTRUCTOR_CHECK (flags, ACC_STATIC, id, "static");
-         JCONSTRUCTOR_CHECK (flags, ACC_FINAL, id, "final");
-         JCONSTRUCTOR_CHECK (flags, ACC_NATIVE, id, "native");
-         JCONSTRUCTOR_CHECK (flags, ACC_SYNCHRONIZED, id, "synchronized");
-         JCONSTRUCTOR_CHECK (flags, ACC_STRICT, id, "strictfp");
-       }
-      /* If we found error here, we don't consider it's OK to tread
-        the method definition as a constructor, for the rest of this
-        function */
-      if (ec == java_error_count)
-       constructor_ok = 1;
-    }
-
-  /* Method declared within the scope of an interface are implicitly
-     abstract and public. Conflicts with other erroneously provided
-     modifiers are checked right after. */
-
-  if (CLASS_INTERFACE (TYPE_NAME (this_class)))
-    {
-      /* If FLAGS isn't set because of a modifier, turn the
-        corresponding modifier WFL to NULL so we issue a warning on
-        the obsolete use of the modifier */
-      if (!(flags & ACC_PUBLIC))
-        MODIFIER_WFL (PUBLIC_TK) = NULL;
-      if (!(flags & ACC_ABSTRACT))
-        MODIFIER_WFL (ABSTRACT_TK) = NULL;
-      flags |= ACC_PUBLIC;
-      flags |= ACC_ABSTRACT;
-    }
-
-  /* Inner class can't declare static methods */
-  if ((flags & ACC_STATIC) && !TOPLEVEL_CLASS_TYPE_P (this_class))
-    {
-      parse_error_context 
-       (id, "Method `%s' can't be static in inner class `%s'. Only members of interfaces and top-level classes can be static",
-        IDENTIFIER_POINTER (EXPR_WFL_NODE (id)),
-        lang_printable_name (this_class, 0));
-    }
-
-  /* Modifiers context reset moved up, so abstract method declaration
-     modifiers can be later checked.  */
-
-  /* Set constructor returned type to void and method name to <init>,
-     unless we found an error identifier the constructor (in which
-     case we retain the original name) */
-  if (!type)
-    {
-      type = void_type_node;
-      if (constructor_ok)
-       meth_name = init_identifier_node;
-    }
-  else
-    meth_name = EXPR_WFL_NODE (id);
-
-  /* Do the returned type resolution and registration if necessary */
-  SET_TYPE_FOR_RESOLUTION (type, type_wfl, must_chain);
-
-  if (meth_name)
-    type = build_array_from_name (type, type_wfl, meth_name, &meth_name);
-  EXPR_WFL_NODE (id) = meth_name;
-  PROMOTE_RECORD_IF_COMPLETE (type, must_chain);
-
-  if (must_chain)
-    {
-      patch_stage = JDEP_METHOD_RETURN;
-      register_incomplete_type (patch_stage, type_wfl, id, type);
-      TREE_TYPE (meth) = GET_REAL_TYPE (type);
-    }
-  else
-    TREE_TYPE (meth) = type;
-
-  saved_lineno = lineno;
-  /* When defining an abstract or interface method, the curly
-     bracket at level 1 doesn't exist because there is no function
-     body */
-  lineno = (ctxp->first_ccb_indent1 ? ctxp->first_ccb_indent1 : 
-           EXPR_WFL_LINENO (id));
-
-  /* Remember the original argument list */
-  orig_arg = TYPE_ARG_TYPES (meth);
-
-  if (patch_stage)             /* includes ret type and/or all args */
-    {
-      jdep *jdep;
-      meth = add_method_1 (this_class, flags, meth_name, meth);
-      /* Patch for the return type */
-      if (patch_stage == JDEP_METHOD_RETURN)
-       {
-         jdep = CLASSD_LAST (ctxp->classd_list);
-         JDEP_GET_PATCH (jdep) = &TREE_TYPE (TREE_TYPE (meth));
-       }
-      /* This is the stop JDEP. METH allows the function's signature
-        to be computed. */
-      register_incomplete_type (JDEP_METHOD_END, NULL_TREE, meth, NULL_TREE);
-    }
-  else
-    meth = add_method (this_class, flags, meth_name, 
-                      build_java_signature (meth));
-
-  /* Remember final parameters */
-  MARK_FINAL_PARMS (meth, orig_arg);
-
-  /* Fix the method argument list so we have the argument name
-     information */
-  fix_method_argument_names (orig_arg, meth);
-
-  /* Register the parameter number and re-install the current line
-     number */
-  DECL_MAX_LOCALS (meth) = ctxp->formal_parameter_number+1;
-  lineno = saved_lineno;
-
-  /* Register exception specified by the `throws' keyword for
-     resolution and set the method decl appropriate field to the list.
-     Note: the grammar ensures that what we get here are class
-     types. */
-  if (throws)
-    {
-      throws = nreverse (throws);
-      for (current = throws; current; current = TREE_CHAIN (current))
-       {
-         register_incomplete_type (JDEP_EXCEPTION, TREE_VALUE (current),
-                                   NULL_TREE, NULL_TREE);
-         JDEP_GET_PATCH (CLASSD_LAST (ctxp->classd_list)) = 
-           &TREE_VALUE (current);
-       }
-      DECL_FUNCTION_THROWS (meth) = throws;
-    }
-
-  if (TREE_TYPE (GET_CPC ()) != object_type_node)
-    DECL_FUNCTION_WFL (meth) = id;
-
-  /* Set the flag if we correctly processed a constructor */
-  if (constructor_ok)
-    {
-      DECL_CONSTRUCTOR_P (meth) = 1;
-      /* Compute and store the number of artificial parameters declared
-        for this constructor */
-      for (count = 0, current = TYPE_FIELDS (this_class); current; 
-          current = TREE_CHAIN (current))
-       if (FIELD_LOCAL_ALIAS (current))
-         count++;
-      DECL_FUNCTION_NAP (meth) = count;
-    }
-
-  /* Eventually set the @deprecated tag flag */
-  CHECK_DEPRECATED (meth);
-
-  /* If doing xref, store column and line number information instead
-     of the line number only. */
-  if (flag_emit_xref)
-    DECL_SOURCE_LINE (meth) = EXPR_WFL_LINECOL (id);
-
-  return meth;
-}
-
-static void
-fix_method_argument_names (orig_arg, meth)
-    tree orig_arg, meth;
-{
-  tree arg = TYPE_ARG_TYPES (TREE_TYPE (meth));
-  if (TREE_CODE (TREE_TYPE (meth)) == METHOD_TYPE)
-    {
-      TREE_PURPOSE (arg) = this_identifier_node;
-      arg = TREE_CHAIN (arg);
-    }
-  while (orig_arg != end_params_node)
-    {
-      TREE_PURPOSE (arg) = TREE_PURPOSE (orig_arg);
-      orig_arg = TREE_CHAIN (orig_arg);
-      arg = TREE_CHAIN (arg);
-    }
-}
-
-/* Complete the method declaration with METHOD_BODY.  */
-
-static void
-finish_method_declaration (method_body)
-     tree method_body;
-{
-  int flags;
-
-  if (!current_function_decl)
-    return;
-
-  flags = get_access_flags_from_decl (current_function_decl);
-
-  /* 8.4.5 Method Body */
-  if ((flags & ACC_ABSTRACT || flags & ACC_NATIVE) && method_body)
-    {
-      tree name = DECL_NAME (current_function_decl);
-      parse_error_context (DECL_FUNCTION_WFL (current_function_decl), 
-                          "%s method `%s' can't have a body defined",
-                          (METHOD_NATIVE (current_function_decl) ?
-                           "Native" : "Abstract"),
-                          IDENTIFIER_POINTER (name));
-      method_body = NULL_TREE;
-    }
-  else if (!(flags & ACC_ABSTRACT) && !(flags & ACC_NATIVE) && !method_body)
-    {
-      tree name = DECL_NAME (current_function_decl);
-      parse_error_context
-       (DECL_FUNCTION_WFL (current_function_decl), 
-        "Non native and non abstract method `%s' must have a body defined",
-        IDENTIFIER_POINTER (name));
-      method_body = NULL_TREE;
-    }
-
-  if (flag_emit_class_files && method_body 
-      && TREE_CODE (method_body) == NOP_EXPR 
-      && TREE_TYPE (current_function_decl) 
-      && TREE_TYPE (TREE_TYPE (current_function_decl)) == void_type_node)
-    method_body = build1 (RETURN_EXPR, void_type_node, NULL);
-
-  BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (current_function_decl)) = method_body;
-  maybe_absorb_scoping_blocks ();
-  /* Exit function's body */
-  exit_block ();
-  /* Merge last line of the function with first line, directly in the
-     function decl. It will be used to emit correct debug info. */
-  if (!flag_emit_xref)
-    DECL_SOURCE_LINE_MERGE (current_function_decl, ctxp->last_ccb_indent1);
-
-  /* Since function's argument's list are shared, reset the
-     ARG_FINAL_P parameter that might have been set on some of this
-     function parameters. */
-  UNMARK_FINAL_PARMS (current_function_decl);
-  
-  /* So we don't have an irrelevant function declaration context for
-     the next static block we'll see. */
-  current_function_decl = NULL_TREE;
-}
-
-/* Build a an error message for constructor circularity errors.  */
-
-static char *
-constructor_circularity_msg (from, to)
-     tree from, to;
-{
-  static char string [4096];
-  char *t = xstrdup (lang_printable_name (from, 0));
-  sprintf (string, "`%s' invokes `%s'", t, lang_printable_name (to, 0));
-  free (t);
-  return string;
-}
-
-/* Verify a circular call to METH. Return 1 if an error is found, 0
-   otherwise.  */
-
-static int
-verify_constructor_circularity (meth, current)
-     tree meth, current;
-{
-  static tree list = NULL_TREE;
-  static int initialized_p;
-  tree c;
-
-  /* If we haven't already registered LIST with the garbage collector,
-     do so now.  */
-  if (!initialized_p)
-    {
-      ggc_add_tree_root (&list, 1);
-      initialized_p = 1;
-    }
-
-  for (c = DECL_CONSTRUCTOR_CALLS (current); c; c = TREE_CHAIN (c))
-    {
-      if (TREE_VALUE (c) == meth)
-       {
-         char *t;
-         if (list)
-           {
-             tree liste;
-             list = nreverse (list);
-             for (liste = list; liste; liste = TREE_CHAIN (liste))
-               {
-                 parse_error_context 
-                   (TREE_PURPOSE (TREE_PURPOSE (liste)), "%s",
-                    constructor_circularity_msg
-                     (TREE_VALUE (liste), TREE_VALUE (TREE_PURPOSE (liste)))); 
-                 java_error_count--;
-               }
-           }
-         t = xstrdup (lang_printable_name (meth, 0));
-         parse_error_context (TREE_PURPOSE (c), 
-                              "%s: recursive invocation of constructor `%s'",
-                              constructor_circularity_msg (current, meth), t);
-         free (t);
-         list = NULL_TREE;
-         return 1;
-       }
-    }
-  for (c = DECL_CONSTRUCTOR_CALLS (current); c; c = TREE_CHAIN (c))
-    {
-      list = tree_cons (c, current, list);
-      if (verify_constructor_circularity (meth, TREE_VALUE (c)))
-       return 1;
-      list = TREE_CHAIN (list);
-    }
-  return 0;
-}
-
-/* Check modifiers that can be declared but exclusively */
-
-static void
-check_modifiers_consistency (flags)
-     int flags;
-{
-  int acc_count = 0;
-  tree cl = NULL_TREE;
-
-  THIS_MODIFIER_ONLY (flags, ACC_PUBLIC, PUBLIC_TK, acc_count, cl);
-  THIS_MODIFIER_ONLY (flags, ACC_PRIVATE, PRIVATE_TK, acc_count, cl);
-  THIS_MODIFIER_ONLY (flags, ACC_PROTECTED, PROTECTED_TK, acc_count, cl);
-  if (acc_count > 1)
-    parse_error_context
-      (cl, "Inconsistent member declaration.  At most one of `public', `private', or `protected' may be specified");
-
-  acc_count = 0;
-  cl = NULL_TREE;
-  THIS_MODIFIER_ONLY (flags, ACC_FINAL, FINAL_TK, acc_count, cl);
-  THIS_MODIFIER_ONLY (flags, ACC_VOLATILE, VOLATILE_TK, acc_count, cl);
-  if (acc_count > 1)
-    parse_error_context (cl,
-                        "Inconsistent member declaration.  At most one of `final' or `volatile' may be specified");
-}
-
-/* Check the methode header METH for abstract specifics features */
-
-static void
-check_abstract_method_header (meth)
-     tree meth;
-{
-  int flags = get_access_flags_from_decl (meth);
-
-  OBSOLETE_MODIFIER_WARNING2 (MODIFIER_WFL (ABSTRACT_TK), flags,
-                             ACC_ABSTRACT, "abstract method",
-                             IDENTIFIER_POINTER (DECL_NAME (meth)));
-  OBSOLETE_MODIFIER_WARNING2 (MODIFIER_WFL (PUBLIC_TK), flags, 
-                             ACC_PUBLIC, "abstract method",
-                             IDENTIFIER_POINTER (DECL_NAME (meth)));
-
-  check_modifiers ("Illegal modifier `%s' for interface method",
-                 flags, INTERFACE_METHOD_MODIFIERS);
-}
-
-/* Create a FUNCTION_TYPE node and start augmenting it with the
-   declared function arguments. Arguments type that can't be resolved
-   are left as they are, but the returned node is marked as containing
-   incomplete types.  */
-
-static tree
-method_declarator (id, list)
-     tree id, list;
-{
-  tree arg_types = NULL_TREE, current, node;
-  tree meth = make_node (FUNCTION_TYPE);
-  jdep *jdep;
-
-  patch_stage = JDEP_NO_PATCH;
-
-  if (GET_CPC () == error_mark_node)
-    return error_mark_node;
-
-  /* If we're dealing with an inner class constructor, we hide the
-     this$<n> decl in the name field of its parameter declaration.  We
-     also might have to hide the outer context local alias
-     initializers. Not done when the class is a toplevel class. */
-  if (PURE_INNER_CLASS_DECL_P (GET_CPC ()) 
-      && EXPR_WFL_NODE (id) == GET_CPC_UN ())
-    {
-      tree aliases_list, type, thisn;
-      /* First the aliases, linked to the regular parameters */
-      aliases_list =
-       build_alias_initializer_parameter_list (AIPL_FUNCTION_DECLARATION, 
-                                               TREE_TYPE (GET_CPC ()),
-                                               NULL_TREE, NULL);
-      list = chainon (nreverse (aliases_list), list);
-
-      /* Then this$<n> */
-      type = TREE_TYPE (DECL_CONTEXT (GET_CPC ()));
-      thisn = build_current_thisn (TREE_TYPE (GET_CPC ()));
-      list = tree_cons (build_wfl_node (thisn), build_pointer_type (type),
-                       list);
-    }
-  
-  for (current = list; current; current = TREE_CHAIN (current))
-    {
-      int must_chain = 0;
-      tree wfl_name = TREE_PURPOSE (current);
-      tree type = TREE_VALUE (current);
-      tree name = EXPR_WFL_NODE (wfl_name);
-      tree already, arg_node;
-      tree type_wfl = NULL_TREE;
-      tree real_type;
-
-      /* Obtain a suitable type for resolution, if necessary */
-      SET_TYPE_FOR_RESOLUTION (type, type_wfl, must_chain);
-
-      /* Process NAME, as it may specify extra dimension(s) for it */
-      type = build_array_from_name (type, type_wfl, name, &name);
-      EXPR_WFL_NODE (wfl_name) = name;
-
-      real_type = GET_REAL_TYPE (type);
-      if (TREE_CODE (real_type) == RECORD_TYPE)
-       {
-         real_type = promote_type (real_type);
-         if (TREE_CODE (type) == TREE_LIST)
-           TREE_PURPOSE (type) = real_type;
-       }
-
-      /* Check redefinition */
-      for (already = arg_types; already; already = TREE_CHAIN (already))
-       if (TREE_PURPOSE (already) == name)
-         {
-           parse_error_context
-             (wfl_name, "Variable `%s' is used more than once in the argument list of method `%s'",
-              IDENTIFIER_POINTER (name),
-              IDENTIFIER_POINTER (EXPR_WFL_NODE (id)));
-           break;
-         }
-
-      /* If we've an incomplete argument type, we know there is a location
-        to patch when the type get resolved, later.  */
-      jdep = NULL;
-      if (must_chain)
-       {
-         patch_stage = JDEP_METHOD;
-         type = register_incomplete_type (patch_stage, 
-                                          type_wfl, wfl_name, type);
-         jdep = CLASSD_LAST (ctxp->classd_list);
-         JDEP_MISC (jdep) = id;
-       }
-
-      /* The argument node: a name and a (possibly) incomplete type.  */
-      arg_node = build_tree_list (name, real_type);
-      /* Remeber arguments declared final. */
-      ARG_FINAL_P (arg_node) = ARG_FINAL_P (current);
-      
-      if (jdep)
-       JDEP_GET_PATCH (jdep) = &TREE_VALUE (arg_node);
-      TREE_CHAIN (arg_node) = arg_types;
-      arg_types = arg_node;
-    }
-  TYPE_ARG_TYPES (meth) = chainon (nreverse (arg_types), end_params_node);
-  node = build_tree_list (id, meth);
-  return node;
-}
-
-static int
-unresolved_type_p (wfl, returned)
-     tree wfl;
-     tree *returned;
-     
-{
-  if (TREE_CODE (wfl) == EXPR_WITH_FILE_LOCATION)
-    {
-      if (returned)
-       {
-         tree decl = IDENTIFIER_CLASS_VALUE (EXPR_WFL_NODE (wfl));
-         if (decl && current_class && (decl == TYPE_NAME (current_class)))
-           *returned = TREE_TYPE (decl);
-         else if (GET_CPC_UN () == EXPR_WFL_NODE (wfl))
-           *returned = TREE_TYPE (GET_CPC ());
-         else
-           *returned = NULL_TREE;
-       }
-      return 1;
-    }
-  if (returned)
-    *returned = wfl;
-  return 0;
-}
-
-/* From NAME, build a qualified identifier node using the
-   qualification from the current package definition. */
-
-static tree
-parser_qualified_classname (name)
-     tree name;
-{
-  tree nested_class_name;
-
-  if ((nested_class_name = maybe_make_nested_class_name (name)))
-    return nested_class_name;
-
-  if (ctxp->package)
-    return merge_qualified_name (ctxp->package, name);
-  else 
-    return name;
-}
-
-/* Called once the type a interface extends is resolved. Returns 0 if
-   everything is OK.  */
-
-static int
-parser_check_super_interface (super_decl, this_decl, this_wfl)
-     tree super_decl, this_decl, this_wfl;
-{
-  tree super_type = TREE_TYPE (super_decl);
-
-  /* Has to be an interface */
-  if (!CLASS_INTERFACE (super_decl))
-    {
-      parse_error_context 
-       (this_wfl, "%s `%s' can't implement/extend %s `%s'",
-        (CLASS_INTERFACE (TYPE_NAME (TREE_TYPE (this_decl))) ? 
-         "Interface" : "Class"),
-        IDENTIFIER_POINTER (DECL_NAME (this_decl)),
-        (TYPE_ARRAY_P (super_type) ? "array" : "class"),
-        IDENTIFIER_POINTER (DECL_NAME (super_decl)));
-      return 1;
-    }
-
-  /* Check top-level interface access. Inner classes are subject to member 
-     access rules (6.6.1). */
-  if (! INNER_CLASS_P (super_type)
-      && check_pkg_class_access (DECL_NAME (super_decl),
-                                lookup_cl (this_decl), true))
-    return 1;
-
-  SOURCE_FRONTEND_DEBUG (("Completing interface %s with %s",
-                         IDENTIFIER_POINTER (DECL_NAME (this_decl)),
-                         IDENTIFIER_POINTER (DECL_NAME (super_decl))));
-  return 0;
-}
-
-/* Makes sure that SUPER_DECL is suitable to extend THIS_DECL. Returns
-   0 if everthing is OK.  */
-
-static int
-parser_check_super (super_decl, this_decl, wfl)
-     tree super_decl, this_decl, wfl;
-{
-  tree super_type = TREE_TYPE (super_decl);
-
-  /* SUPER should be a CLASS (neither an array nor an interface) */
-  if (TYPE_ARRAY_P (super_type) || CLASS_INTERFACE (TYPE_NAME (super_type)))
-    {
-      parse_error_context 
-       (wfl, "Class `%s' can't subclass %s `%s'",
-        IDENTIFIER_POINTER (DECL_NAME (this_decl)),
-        (CLASS_INTERFACE (TYPE_NAME (super_type)) ? "interface" : "array"),
-        IDENTIFIER_POINTER (DECL_NAME (super_decl)));
-      return 1;
-    }
-
-  if (CLASS_FINAL (TYPE_NAME (super_type)))
-    {
-      parse_error_context (wfl, "Can't subclass final classes: %s",
-                          IDENTIFIER_POINTER (DECL_NAME (super_decl)));
-      return 1;
-    }
-
-  /* Check top-level class scope. Inner classes are subject to member access
-     rules (6.6.1). */
-  if (! INNER_CLASS_P (super_type)
-      && (check_pkg_class_access (DECL_NAME (super_decl), wfl, true)))
-    return 1;
-  
-  SOURCE_FRONTEND_DEBUG (("Completing class %s with %s",
-                         IDENTIFIER_POINTER (DECL_NAME (this_decl)),
-                         IDENTIFIER_POINTER (DECL_NAME (super_decl))));
-  return 0;
-}
-
-/* Create a new dependency list and link it (in a LIFO manner) to the
-   CTXP list of type dependency list.  */
-
-static void
-create_jdep_list (ctxp)
-     struct parser_ctxt *ctxp;
-{
-  jdeplist *new = (jdeplist *)xmalloc (sizeof (jdeplist));     
-  new->first = new->last = NULL;
-  new->next = ctxp->classd_list;
-  ctxp->classd_list = new;
-}
-
-static jdeplist *
-reverse_jdep_list (ctxp)
-     struct parser_ctxt *ctxp;
-{
-  register jdeplist *prev = NULL, *current, *next;
-  for (current = ctxp->classd_list; current; current = next)
-    {
-      next = current->next;
-      current->next = prev;
-      prev = current;
-    }
-  return prev;
-}
-
-/* Create a fake pointer based on the ID stored in
-   TYPE_NAME. TYPE_NAME can be a WFL or a incomplete type asking to be
-   registered again. */
-
-static tree
-obtain_incomplete_type (type_name)
-     tree type_name;
-{
-  tree ptr = NULL_TREE, name;
-
-  if (TREE_CODE (type_name) == EXPR_WITH_FILE_LOCATION)
-    name = EXPR_WFL_NODE (type_name);
-  else if (INCOMPLETE_TYPE_P (type_name))
-    name = TYPE_NAME (type_name);
-  else
-    abort ();
-
-  BUILD_PTR_FROM_NAME (ptr, name);
-  layout_type (ptr);
-
-  return ptr;
-}
-
-/* Register a incomplete type whose name is WFL. Reuse PTR if PTR is
-   non NULL instead of computing a new fake type based on WFL. The new
-   dependency is inserted in the current type dependency list, in FIFO
-   manner.  */
-
-static tree
-register_incomplete_type (kind, wfl, decl, ptr)
-     int kind;
-     tree wfl, decl, ptr;
-{
-  jdep *new = (jdep *)xmalloc (sizeof (jdep));
-
-  if (!ptr && kind != JDEP_METHOD_END) /* JDEP_METHOD_END is a mere marker */
-    ptr = obtain_incomplete_type (wfl);
-
-  JDEP_KIND (new) = kind;
-  JDEP_DECL (new) = decl;
-  JDEP_TO_RESOLVE (new) = ptr;
-  JDEP_WFL (new) = wfl;
-  JDEP_CHAIN (new) = NULL;
-  JDEP_MISC (new) = NULL_TREE;
-  /* For some dependencies, set the enclosing class of the current
-     class to be the enclosing context */
-  if ((kind == JDEP_INTERFACE  || kind == JDEP_ANONYMOUS)
-      && GET_ENCLOSING_CPC ())
-    JDEP_ENCLOSING (new) = TREE_VALUE (GET_ENCLOSING_CPC ());
-  else if (kind == JDEP_SUPER)
-    JDEP_ENCLOSING (new) = (GET_ENCLOSING_CPC () ? 
-                           TREE_VALUE (GET_ENCLOSING_CPC ()) : NULL_TREE);
-  else
-    JDEP_ENCLOSING (new) = GET_CPC ();
-  JDEP_GET_PATCH (new) = (tree *)NULL;
-
-  JDEP_INSERT (ctxp->classd_list, new);
-
-  return ptr;
-}
-
-/* This checks for circular references with innerclasses. We start
-   from SOURCE and should never reach TARGET. Extended/implemented
-   types in SOURCE have their enclosing context checked not to reach
-   TARGET. When the last enclosing context of SOURCE is reached, its
-   extended/implemented types are also checked not to reach TARGET.
-   In case of error, WFL of the offending type is returned; NULL_TREE
-   otherwise.  */
-
-static tree
-check_inner_circular_reference (source, target)
-     tree source;
-     tree target;
-{
-  tree basetype_vec = TYPE_BINFO_BASETYPES (source);
-  tree ctx, cl;
-  int i;
-
-  if (!basetype_vec)
-    return NULL_TREE;
-
-  for (i = 0; i < TREE_VEC_LENGTH (basetype_vec); i++)
-    {
-      tree su;
-
-      /* We can end up with a NULL_TREE or an incomplete type here if
-        we encountered previous type resolution errors. It's safe to
-        simply ignore these cases.  */
-      if (TREE_VEC_ELT (basetype_vec, i) == NULL_TREE)
-       continue;
-      su = BINFO_TYPE (TREE_VEC_ELT (basetype_vec, i));
-      if (INCOMPLETE_TYPE_P (su))
-       continue;
-
-      if (inherits_from_p (su, target))
-       return lookup_cl (TYPE_NAME (su));
-
-      for (ctx = DECL_CONTEXT (TYPE_NAME (su)); ctx; ctx = DECL_CONTEXT (ctx))
-       {
-         /* An enclosing context shouldn't be TARGET */
-         if (ctx == TYPE_NAME (target))
-           return lookup_cl (TYPE_NAME (su));
-
-         /* When we reach the enclosing last context, start a check
-            on it, with the same target */
-         if (! DECL_CONTEXT (ctx) &&
-             (cl = check_inner_circular_reference (TREE_TYPE (ctx), target)))
-           return cl;
-       }
-    }
-  return NULL_TREE;
-}
-
-/* Explore TYPE's `extends' clause member(s) and return the WFL of the
-   offending type if a circularity is detected. NULL_TREE is returned
-   otherwise. TYPE can be an interface or a class.   */
-
-static tree
-check_circular_reference (type)
-     tree type;
-{
-  tree basetype_vec = TYPE_BINFO_BASETYPES (type);
-  int i;
-
-  if (!basetype_vec)
-    return NULL_TREE;
-
-  if (! CLASS_INTERFACE (TYPE_NAME (type)))
-    {
-      if (inherits_from_p (CLASSTYPE_SUPER (type), type))
-       return lookup_cl (TYPE_NAME (type));
-      return NULL_TREE;
-    }
-    
-  for (i = 0; i < TREE_VEC_LENGTH (basetype_vec); i++)
-    {
-      tree vec_elt = TREE_VEC_ELT (basetype_vec, i);
-      if (vec_elt && BINFO_TYPE (vec_elt) != object_type_node
-         && interface_of_p (type, BINFO_TYPE (vec_elt)))
-       return lookup_cl (TYPE_NAME (BINFO_TYPE (vec_elt)));
-    }
-  return NULL_TREE;
-}
-
-void
-java_check_circular_reference ()
-{
-  tree current;
-  for (current = ctxp->class_list; current; current = TREE_CHAIN (current))
-    {
-      tree type = TREE_TYPE (current);
-      tree cl;
-
-      cl = check_circular_reference (type);
-      if (! cl)
-       cl = check_inner_circular_reference (type, type);
-      if (cl)
-       parse_error_context (cl, "Cyclic class inheritance%s",
-                            (cyclic_inheritance_report ?
-                             cyclic_inheritance_report : ""));
-    }
-}
-
-/* Augment the parameter list PARM with parameters crafted to
-   initialize outer context locals aliases. Through ARTIFICIAL, a
-   count is kept of the number of crafted parameters. MODE governs
-   what eventually gets created: something suitable for a function
-   creation or a function invocation, either the constructor or
-   finit$.  */
-
-static tree
-build_alias_initializer_parameter_list (mode, class_type, parm, artificial)
-    int mode;
-    tree class_type, parm;
-    int *artificial;
-{
-  tree field;
-  tree additional_parms = NULL_TREE;
-
-  for (field = TYPE_FIELDS (class_type); field; field = TREE_CHAIN (field))
-    if (FIELD_LOCAL_ALIAS (field))
-      {
-       const char *buffer = IDENTIFIER_POINTER (DECL_NAME (field));
-       tree purpose = NULL_TREE, value = NULL_TREE, name = NULL_TREE;
-       tree mangled_id;
-
-       switch (mode)
-         {
-         case AIPL_FUNCTION_DECLARATION:
-           MANGLE_ALIAS_INITIALIZER_PARAMETER_NAME_STR (mangled_id, 
-                                                        &buffer [4]);
-           purpose = build_wfl_node (mangled_id);
-           if (TREE_CODE (TREE_TYPE (field)) == POINTER_TYPE)
-             value = build_wfl_node (TYPE_NAME (TREE_TYPE (field)));
-           else
-             value = TREE_TYPE (field);
-           break;
-
-         case AIPL_FUNCTION_CREATION:
-           MANGLE_ALIAS_INITIALIZER_PARAMETER_NAME_STR (purpose,
-                                                        &buffer [4]);
-           value = TREE_TYPE (field);
-           break;
-
-         case AIPL_FUNCTION_FINIT_INVOCATION:
-           MANGLE_ALIAS_INITIALIZER_PARAMETER_NAME_STR (mangled_id, 
-                                                        &buffer [4]);
-           /* Now, this is wrong. purpose should always be the NAME
-              of something and value its matching value (decl, type,
-              etc...) FIXME -- but there is a lot to fix. */
-
-           /* When invoked for this kind of operation, we already
-              know whether a field is used or not. */
-           purpose = TREE_TYPE (field);
-           value = build_wfl_node (mangled_id);
-           break;
-
-         case AIPL_FUNCTION_CTOR_INVOCATION:
-           /* There are two case: the constructor invokation happends
-              outside the local inner, in which case, locales from the outer
-              context are directly used.
-
-              Otherwise, we fold to using the alias directly. */
-           if (class_type == current_class)
-             value = field;
-           else
-             {
-               name = get_identifier (&buffer[4]);
-               value = IDENTIFIER_LOCAL_VALUE (name);
-             }
-           break;
-         }
-       additional_parms = tree_cons (purpose, value, additional_parms);
-       if (artificial)
-         *artificial +=1;
-      }
-  if (additional_parms)
-    {
-      if (ANONYMOUS_CLASS_P (class_type) 
-          && mode == AIPL_FUNCTION_CTOR_INVOCATION)
-        additional_parms = nreverse (additional_parms);
-      parm = chainon (additional_parms, parm);
-    }
-
-   return parm;
-}
-
-/* Craft a constructor for CLASS_DECL -- what we should do when none
-   where found. ARGS is non NULL when a special signature must be
-   enforced. This is the case for anonymous classes.  */
-
-static tree
-craft_constructor (class_decl, args)
-     tree class_decl, args;
-{
-  tree class_type = TREE_TYPE (class_decl);
-  tree parm = NULL_TREE;
-  int flags = (get_access_flags_from_decl (class_decl) & ACC_PUBLIC ?
-              ACC_PUBLIC : 0);
-  int i = 0, artificial = 0;
-  tree decl, ctor_name;
-  char buffer [80];
-  
-  /* The constructor name is <init> unless we're dealing with an
-     anonymous class, in which case the name will be fixed after having
-     be expanded. */
-  if (ANONYMOUS_CLASS_P (class_type))
-    ctor_name = DECL_NAME (class_decl);
-  else
-    ctor_name = init_identifier_node;
-
-  /* If we're dealing with an inner class constructor, we hide the
-     this$<n> decl in the name field of its parameter declaration. */
-  if (PURE_INNER_CLASS_TYPE_P (class_type))
-    {
-      tree type = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (class_type)));
-      parm = tree_cons (build_current_thisn (class_type),
-                       build_pointer_type (type), parm);
-
-      /* Some more arguments to be hidden here. The values of the local
-        variables of the outer context that the inner class needs to see. */
-      parm = build_alias_initializer_parameter_list (AIPL_FUNCTION_CREATION,
-                                                    class_type, parm, 
-                                                    &artificial);
-    }
-
-  /* Then if there are any args to be enforced, enforce them now */
-  for (; args && args != end_params_node; args = TREE_CHAIN (args))
-    {
-      sprintf (buffer, "parm%d", i++);
-      parm = tree_cons (get_identifier (buffer), TREE_VALUE (args), parm);
-    }
-
-  CRAFTED_PARAM_LIST_FIXUP (parm);
-  decl = create_artificial_method (class_type, flags, void_type_node, 
-                                  ctor_name, parm);
-  fix_method_argument_names (parm, decl);
-  /* Now, mark the artificial parameters. */
-  DECL_FUNCTION_NAP (decl) = artificial;
-  DECL_FUNCTION_SYNTHETIC_CTOR (decl) = DECL_CONSTRUCTOR_P (decl) = 1;
-  return decl;
-}
-
-
-/* Fix the constructors. This will be called right after circular
-   references have been checked. It is necessary to fix constructors
-   early even if no code generation will take place for that class:
-   some generated constructor might be required by the class whose
-   compilation triggered this one to be simply loaded.  */
-
-void
-java_fix_constructors ()
-{
-  tree current;
-
-  for (current = ctxp->class_list; current; current = TREE_CHAIN (current))
-    {
-      tree class_type = TREE_TYPE (current);
-      int saw_ctor = 0;
-      tree decl;
-
-      if (CLASS_INTERFACE (TYPE_NAME (class_type)))
-       continue;
-
-      current_class = class_type;
-      for (decl = TYPE_METHODS (class_type); decl; decl = TREE_CHAIN (decl))
-       {
-         if (DECL_CONSTRUCTOR_P (decl))
-           {
-             fix_constructors (decl);
-             saw_ctor = 1;
-           }
-       }
-
-      /* Anonymous class constructor can't be generated that early. */
-      if (!saw_ctor && !ANONYMOUS_CLASS_P (class_type))
-       craft_constructor (current, NULL_TREE);
-    }
-}
-
-/* safe_layout_class just makes sure that we can load a class without
-   disrupting the current_class, input_file, lineno, etc, information
-   about the class processed currently.  */
-
-void
-safe_layout_class (class)
-     tree class;
-{
-  tree save_current_class = current_class;
-  const char *save_input_filename = input_filename;
-  int save_lineno = lineno;
-
-  layout_class (class);
-
-  current_class = save_current_class;
-  input_filename = save_input_filename;
-  lineno = save_lineno;
-}
-
-static tree
-jdep_resolve_class (dep)
-     jdep *dep;
-{
-  tree decl;
-
-  if (JDEP_RESOLVED_P (dep))
-    decl = JDEP_RESOLVED_DECL (dep);
-  else
-    {
-      decl = resolve_class (JDEP_ENCLOSING (dep), JDEP_TO_RESOLVE (dep),
-                           JDEP_DECL (dep), JDEP_WFL (dep));
-      JDEP_RESOLVED (dep, decl);
-    }
-    
-  if (!decl)
-    complete_class_report_errors (dep);
-  else if (PURE_INNER_CLASS_DECL_P (decl))
-    {
-      tree inner = TREE_TYPE (decl);
-      if (! CLASS_LOADED_P (inner))
-       {
-         safe_layout_class (inner);
-         if (TYPE_SIZE (inner) == error_mark_node)
-           TYPE_SIZE (inner) = NULL_TREE;
-       }
-      check_inner_class_access (decl, JDEP_ENCLOSING (dep), JDEP_WFL (dep));
-    }
-  return decl;
-}
-
-/* Complete unsatisfied class declaration and their dependencies */
-
-void
-java_complete_class ()
-{
-  tree cclass;
-  jdeplist *cclassd;
-  int error_found;
-  tree type;
-
-  /* Process imports */
-  process_imports ();
-
-  /* Rever things so we have the right order */
-  ctxp->class_list = nreverse (ctxp->class_list);
-  ctxp->classd_list = reverse_jdep_list (ctxp);
-
-  for (cclassd = ctxp->classd_list, cclass = ctxp->class_list; 
-       cclass && cclassd; 
-       cclass = TREE_CHAIN (cclass), cclassd = CLASSD_CHAIN (cclassd))
-    {
-      jdep *dep;
-
-      /* We keep the compilation unit imports in the class so that
-        they can be used later to resolve type dependencies that
-        aren't necessary to solve now. */
-      TYPE_IMPORT_LIST (TREE_TYPE (cclass)) = ctxp->import_list;
-      TYPE_IMPORT_DEMAND_LIST (TREE_TYPE (cclass)) = ctxp->import_demand_list;
-
-      for (dep = CLASSD_FIRST (cclassd); dep; dep = JDEP_CHAIN (dep))
-       {
-         tree decl;
-         if (!(decl = jdep_resolve_class (dep)))
-           continue;
-
-         /* Now it's time to patch */
-         switch (JDEP_KIND (dep))
-           {
-           case JDEP_SUPER:
-             /* Simply patch super */
-             if (parser_check_super (decl, JDEP_DECL (dep), JDEP_WFL (dep)))
-               continue;
-             BINFO_TYPE (TREE_VEC_ELT (BINFO_BASETYPES (TYPE_BINFO 
-               (TREE_TYPE (JDEP_DECL (dep)))), 0)) = TREE_TYPE (decl);
-             break;
-
-           case JDEP_FIELD:
-             {
-               /* We do part of the job done in add_field */
-               tree field_decl = JDEP_DECL (dep);
-               tree field_type = TREE_TYPE (decl);
-               if (TREE_CODE (field_type) == RECORD_TYPE)
-                 field_type = promote_type (field_type);
-               TREE_TYPE (field_decl) = field_type;
-               DECL_ALIGN (field_decl) = 0;
-               DECL_USER_ALIGN (field_decl) = 0;
-               layout_decl (field_decl, 0);
-               SOURCE_FRONTEND_DEBUG 
-                 (("Completed field/var decl `%s' with `%s'",
-                   IDENTIFIER_POINTER (DECL_NAME (field_decl)),
-                   IDENTIFIER_POINTER (DECL_NAME (decl))));
-               break;
-             }
-           case JDEP_METHOD:   /* We start patching a method */
-           case JDEP_METHOD_RETURN:
-             error_found = 0;
-             while (1)
-               {
-                 if (decl)
-                   {
-                     type = TREE_TYPE(decl);
-                     if (TREE_CODE (type) == RECORD_TYPE)
-                       type = promote_type (type);
-                     JDEP_APPLY_PATCH (dep, type);
-                     SOURCE_FRONTEND_DEBUG 
-                       (((JDEP_KIND (dep) == JDEP_METHOD_RETURN ?
-                          "Completing fct `%s' with ret type `%s'":
-                          "Completing arg `%s' with type `%s'"),
-                         IDENTIFIER_POINTER (EXPR_WFL_NODE 
-                                             (JDEP_DECL_WFL (dep))),
-                         IDENTIFIER_POINTER (DECL_NAME (decl))));
-                   }
-                 else
-                   error_found = 1;
-                 dep = JDEP_CHAIN (dep);
-                 if (JDEP_KIND (dep) == JDEP_METHOD_END)
-                   break;
-                 else
-                   decl = jdep_resolve_class (dep);
-               }
-             if (!error_found)
-               {
-                 tree mdecl = JDEP_DECL (dep), signature;
-                 /* Recompute and reset the signature, check first that
-                    all types are now defined. If they're not,
-                    don't build the signature. */
-                 if (check_method_types_complete (mdecl))
-                   {
-                     signature = build_java_signature (TREE_TYPE (mdecl));
-                     set_java_signature (TREE_TYPE (mdecl), signature);
-                   }
-               }
-             else
-               continue;
-             break;
-
-           case JDEP_INTERFACE:
-             if (parser_check_super_interface (decl, JDEP_DECL (dep),
-                                               JDEP_WFL (dep)))
-               continue;
-             parser_add_interface (JDEP_DECL (dep), decl, JDEP_WFL (dep));
-             break;
-
-           case JDEP_PARM:
-           case JDEP_VARIABLE:
-             type = TREE_TYPE(decl);
-             if (TREE_CODE (type) == RECORD_TYPE)
-               type = promote_type (type);
-             JDEP_APPLY_PATCH (dep, type);
-             break;
-
-           case JDEP_TYPE:
-             JDEP_APPLY_PATCH (dep, TREE_TYPE (decl));
-             SOURCE_FRONTEND_DEBUG 
-               (("Completing a random type dependency on a '%s' node",
-                 tree_code_name [TREE_CODE (JDEP_DECL (dep))]));
-             break;
-
-           case JDEP_EXCEPTION:
-             JDEP_APPLY_PATCH (dep, TREE_TYPE (decl));
-             SOURCE_FRONTEND_DEBUG 
-               (("Completing `%s' `throws' argument node",
-                 IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_WFL (dep)))));
-             break;
-
-           case JDEP_ANONYMOUS:
-             patch_anonymous_class (decl, JDEP_DECL (dep), JDEP_WFL (dep));
-             break;
-
-           default:
-             abort ();
-           }
-       }
-    }
-  return;
-}
-
-/* Resolve class CLASS_TYPE. Handle the case of trying to resolve an
-   array.  */
-
-static tree
-resolve_class (enclosing, class_type, decl, cl)
-     tree enclosing, class_type, decl, cl;
-{
-  tree tname = TYPE_NAME (class_type);
-  tree resolved_type = TREE_TYPE (class_type);
-  int array_dims = 0;
-  tree resolved_type_decl;
-  
-  if (resolved_type != NULL_TREE)
-    {
-      tree resolved_type_decl = TYPE_NAME (resolved_type);
-      if (resolved_type_decl == NULL_TREE
-         || TREE_CODE (resolved_type_decl) == IDENTIFIER_NODE)
-       {
-         resolved_type_decl = build_decl (TYPE_DECL,
-                                          TYPE_NAME (class_type),
-                                          resolved_type);
-       }
-      return resolved_type_decl;
-    }
-
-  /* 1- Check to see if we have an array. If true, find what we really
-     want to resolve  */
-  if ((array_dims = build_type_name_from_array_name (tname,
-                                                    &TYPE_NAME (class_type))))
-    WFL_STRIP_BRACKET (cl, cl);
-
-  /* 2- Resolve the bare type */
-  if (!(resolved_type_decl = do_resolve_class (enclosing, class_type, 
-                                              decl, cl)))
-    return NULL_TREE;
-  resolved_type = TREE_TYPE (resolved_type_decl);
-
-  /* 3- If we have and array, reconstruct the array down to its nesting */
-  if (array_dims)
-    {
-      for (; array_dims; array_dims--)
-       resolved_type = build_java_array_type (resolved_type, -1);
-      resolved_type_decl = TYPE_NAME (resolved_type);
-    }
-  TREE_TYPE (class_type) = resolved_type;
-  return resolved_type_decl;
-}
-
-/* Effectively perform the resolution of class CLASS_TYPE. DECL or CL
-   are used to report error messages. Do not try to replace TYPE_NAME
-   (class_type) by a variable, since it is changed by
-   find_in_imports{_on_demand} and (but it doesn't really matter)
-   qualify_and_find.  */
-
-tree
-do_resolve_class (enclosing, class_type, decl, cl)
-     tree enclosing, class_type, decl, cl;
-{
-  tree new_class_decl = NULL_TREE, super = NULL_TREE;
-  tree saved_enclosing_type = enclosing ? TREE_TYPE (enclosing) : NULL_TREE;
-  tree decl_result;
-  struct hash_table _ht, *circularity_hash = &_ht;
-
-  /* This hash table is used to register the classes we're going
-     through when searching the current class as an inner class, in
-     order to detect circular references. Remember to free it before
-     returning the section 0- of this function. */
-  hash_table_init (circularity_hash, hash_newfunc,
-                  java_hash_hash_tree_node, java_hash_compare_tree_node);
-
-  /* 0- Search in the current class as an inner class.
-     Maybe some code here should be added to load the class or
-     something, at least if the class isn't an inner class and ended
-     being loaded from class file. FIXME. */
-  while (enclosing)
-    {
-      new_class_decl = resolve_inner_class (circularity_hash, cl, &enclosing,
-                                           &super, class_type);
-      if (new_class_decl)
-       break;
-
-      /* If we haven't found anything because SUPER reached Object and
-        ENCLOSING happens to be an innerclass, try the enclosing context. */
-      if ((!super || super == object_type_node) && 
-         enclosing && INNER_CLASS_DECL_P (enclosing))
-       enclosing = DECL_CONTEXT (enclosing);
-      else
-       enclosing = NULL_TREE;
-    }
-
-  hash_table_free (circularity_hash);
-
-  if (new_class_decl)
-    return new_class_decl;
-
-  /* 1- Check for the type in single imports. This will change
-     TYPE_NAME() if something relevant is found */
-  find_in_imports (saved_enclosing_type, class_type);
-
-  /* 2- And check for the type in the current compilation unit */
-  if ((new_class_decl = IDENTIFIER_CLASS_VALUE (TYPE_NAME (class_type))))
-    {
-      if (!CLASS_LOADED_P (TREE_TYPE (new_class_decl)) &&
-         !CLASS_FROM_SOURCE_P (TREE_TYPE (new_class_decl)))
-       load_class (TYPE_NAME (class_type), 0);
-      return IDENTIFIER_CLASS_VALUE (TYPE_NAME (class_type));
-    }
-
-  /* 3- Search according to the current package definition */
-  if (!QUALIFIED_P (TYPE_NAME (class_type)))
-    {
-      if ((new_class_decl = qualify_and_find (class_type, ctxp->package,
-                                            TYPE_NAME (class_type))))
-       return new_class_decl;
-    }
-
-  /* 4- Check the import on demands. Don't allow bar.baz to be
-     imported from foo.* */
-  if (!QUALIFIED_P (TYPE_NAME (class_type)))
-    if (find_in_imports_on_demand (saved_enclosing_type, class_type))
-      return NULL_TREE;
-
-  /* If found in find_in_imports_on_demant, the type has already been
-     loaded. */
-  if ((new_class_decl = IDENTIFIER_CLASS_VALUE (TYPE_NAME (class_type))))
-    return new_class_decl;
-
-  /* 5- Try with a name qualified with the package name we've seen so far */
-  if (!QUALIFIED_P (TYPE_NAME (class_type)))
-    {
-      tree package;
-
-      /* If there is a current package (ctxp->package), it's the first
-        element of package_list and we can skip it. */
-      for (package = (ctxp->package ? 
-                     TREE_CHAIN (package_list) : package_list);
-          package; package = TREE_CHAIN (package))
-       if ((new_class_decl = qualify_and_find (class_type,
-                                              TREE_PURPOSE (package), 
-                                              TYPE_NAME (class_type))))
-         return new_class_decl;
-    }
-
-  /* 5- Check an other compilation unit that bears the name of type */
-  load_class (TYPE_NAME (class_type), 0);
-  
-  if (!cl)
-    cl = lookup_cl (decl);
-  
-  /* If we don't have a value for CL, then we're being called recursively. 
-     We can't check package access just yet, but it will be taken care of
-     by the caller. */
-  if (cl)
-    {
-      if (check_pkg_class_access (TYPE_NAME (class_type), cl, true))
-        return NULL_TREE;
-    }
-
-  /* 6- Last call for a resolution */
-  decl_result = IDENTIFIER_CLASS_VALUE (TYPE_NAME (class_type));
-
-  /* The final lookup might have registered a.b.c into a.b$c If we
-     failed at the first lookup, progressively change the name if
-     applicable and use the matching DECL instead. */
-  if (!decl_result && QUALIFIED_P (TYPE_NAME (class_type)))
-    {
-      char *separator;
-      tree name = TYPE_NAME (class_type);
-      char *namebuffer = alloca (IDENTIFIER_LENGTH (name) + 1);
-
-      strcpy (namebuffer, IDENTIFIER_POINTER (name));
-
-      do {
-
-       /* Reach the last '.', and if applicable, replace it by a `$' and
-          see if this exists as a type. */
-       if ((separator = strrchr (namebuffer, '.')))
-         {
-           *separator = '$';
-           name = get_identifier (namebuffer);
-           decl_result = IDENTIFIER_CLASS_VALUE (name);
-         }
-      } while (!decl_result && separator);
-    }
-  return decl_result;
-}
-
-static tree
-qualify_and_find (class_type, package, name)
-     tree class_type, package, name;
-{
-  tree new_qualified = merge_qualified_name (package, name);
-  tree new_class_decl;
-
-  if (!IDENTIFIER_CLASS_VALUE (new_qualified))
-    load_class (new_qualified, 0);
-  if ((new_class_decl = IDENTIFIER_CLASS_VALUE (new_qualified)))
-    {
-      if (!CLASS_LOADED_P (TREE_TYPE (new_class_decl)) &&
-         !CLASS_FROM_SOURCE_P (TREE_TYPE (new_class_decl)))
-       load_class (new_qualified, 0);
-      TYPE_NAME (class_type) = new_qualified;
-      return IDENTIFIER_CLASS_VALUE (new_qualified);
-    }
-  return NULL_TREE;
-}
-
-/* Resolve NAME and lay it out (if not done and if not the current
-   parsed class). Return a decl node. This function is meant to be
-   called when type resolution is necessary during the walk pass.  */
-
-static tree
-resolve_and_layout (something, cl)
-     tree something;
-     tree cl;
-{
-  tree decl, decl_type;
-
-  /* Don't do that on the current class */
-  if (something == current_class)
-    return TYPE_NAME (current_class);
-
-  /* Don't do anything for void and other primitive types */
-  if (JPRIMITIVE_TYPE_P (something) || something == void_type_node)
-    return NULL_TREE;
-
-  /* Pointer types can be reall pointer types or fake pointers. When
-     finding a real pointer, recheck for primitive types */
-  if (TREE_CODE (something) == POINTER_TYPE)
-    {
-      if (TREE_TYPE (something))
-       {
-         something = TREE_TYPE (something);
-         if (JPRIMITIVE_TYPE_P (something) || something == void_type_node)
-           return NULL_TREE;
-       }
-      else
-       something = TYPE_NAME (something);
-    }
-
-  /* Don't do anything for arrays of primitive types */
-  if (TREE_CODE (something) == RECORD_TYPE && TYPE_ARRAY_P (something)
-      && JPRIMITIVE_TYPE_P (TYPE_ARRAY_ELEMENT (something)))
-    return NULL_TREE;
-
-  /* Something might be a WFL */
-  if (TREE_CODE (something) == EXPR_WITH_FILE_LOCATION)
-    something = EXPR_WFL_NODE (something);
-
-  /* Otherwise, if something is not and IDENTIFIER_NODE, it can be a a
-     TYPE_DECL or a real TYPE */
-  else if (TREE_CODE (something) != IDENTIFIER_NODE)
-    something = (TREE_CODE (TYPE_NAME (something)) == TYPE_DECL ?
-           DECL_NAME (TYPE_NAME (something)) : TYPE_NAME (something));
-
-  if (!(decl = resolve_no_layout (something, cl)))
-    return NULL_TREE;
-
-  /* Resolve and layout if necessary */
-  decl_type = TREE_TYPE (decl);
-  layout_class_methods (decl_type);
-  /* Check methods */
-  if (CLASS_FROM_SOURCE_P (decl_type))
-    java_check_methods (decl);
-  /* Layout the type if necessary */ 
-  if (decl_type != current_class && !CLASS_LOADED_P (decl_type))
-    safe_layout_class (decl_type);
-
-  return decl;
-}
-
-/* Resolve a class, returns its decl but doesn't perform any
-   layout. The current parsing context is saved and restored */
-
-static tree
-resolve_no_layout (name, cl)
-     tree name, cl;
-{
-  tree ptr, decl;
-  BUILD_PTR_FROM_NAME (ptr, name);
-  java_parser_context_save_global ();
-  decl = resolve_class (TYPE_NAME (current_class), ptr, NULL_TREE, cl);
-  java_parser_context_restore_global ();
-  
-  return decl;
-}
-
-/* Called when reporting errors. Skip the '[]'s in a complex array
-   type description that failed to be resolved. purify_type_name can't
-   use an identifier tree.  */
-
-static const char *
-purify_type_name (name)
-     const char *name;
-{
-  int len = strlen (name);
-  int bracket_found;
-
-  STRING_STRIP_BRACKETS (name, len, bracket_found);
-  if (bracket_found)
-    {
-      char *stripped_name = xmemdup (name, len, len+1);
-      stripped_name [len] = '\0';
-      return stripped_name;
-    }
-  return name;
-}
-
-/* The type CURRENT refers to can't be found. We print error messages.  */
-
-static void
-complete_class_report_errors (dep)
-     jdep *dep;
-{
-  const char *name;
-
-  if (!JDEP_WFL (dep))
-    return;
-
-  name = IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_WFL (dep)));
-  switch (JDEP_KIND (dep))
-    {
-    case JDEP_SUPER:
-      parse_error_context  
-       (JDEP_WFL (dep), "Superclass `%s' of class `%s' not found",
-        purify_type_name (name),
-        IDENTIFIER_POINTER (DECL_NAME (JDEP_DECL (dep))));
-      break;
-    case JDEP_FIELD:
-      parse_error_context
-       (JDEP_WFL (dep), "Type `%s' not found in declaration of field `%s'",
-        purify_type_name (name),
-        IDENTIFIER_POINTER (DECL_NAME (JDEP_DECL (dep))));
-      break;
-    case JDEP_METHOD:          /* Covers arguments */
-      parse_error_context
-       (JDEP_WFL (dep), "Type `%s' not found in the declaration of the argument `%s' of method `%s'",
-        purify_type_name (name),
-        IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_DECL_WFL (dep))),
-        IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_MISC (dep))));
-      break;
-    case JDEP_METHOD_RETURN:   /* Covers return type */
-      parse_error_context
-       (JDEP_WFL (dep), "Type `%s' not found in the declaration of the return type of method `%s'", 
-        purify_type_name (name),
-        IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_DECL_WFL (dep))));
-      break;
-    case JDEP_INTERFACE:
-      parse_error_context
-       (JDEP_WFL (dep), "Superinterface `%s' of %s `%s' not found",
-        IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_WFL (dep))),
-        (CLASS_OR_INTERFACE (JDEP_DECL (dep), "class", "interface")),
-        IDENTIFIER_POINTER (DECL_NAME (JDEP_DECL (dep))));
-      break;
-    case JDEP_VARIABLE:
-      parse_error_context
-       (JDEP_WFL (dep), "Type `%s' not found in the declaration of the local variable `%s'", 
-        purify_type_name (IDENTIFIER_POINTER 
-                          (EXPR_WFL_NODE (JDEP_WFL (dep)))),
-        IDENTIFIER_POINTER (DECL_NAME (JDEP_DECL (dep))));
-      break;
-    case JDEP_EXCEPTION:       /* As specified by `throws' */
-      parse_error_context 
-         (JDEP_WFL (dep), "Class `%s' not found in `throws'",
-        IDENTIFIER_POINTER (EXPR_WFL_NODE (JDEP_WFL (dep))));
-      break;
-    default:
-      /* Fix for -Wall. Just break doing nothing. The error will be
-         caught later */
-      break;
-    }
-}
-
-/* Return a static string containing the DECL prototype string. If
-   DECL is a constructor, use the class name instead of the form
-   <init> */
-
-static const char *
-get_printable_method_name (decl)
-     tree decl;
-{
-  const char *to_return;
-  tree name = NULL_TREE;
-
-  if (DECL_CONSTRUCTOR_P (decl))
-    {
-      name = DECL_NAME (decl);
-      DECL_NAME (decl) = DECL_NAME (TYPE_NAME (DECL_CONTEXT (decl)));
-    }
-      
-  to_return = lang_printable_name (decl, 0);
-  if (DECL_CONSTRUCTOR_P (decl))
-    DECL_NAME (decl) = name;
-  
-  return to_return;
-}
-
-/* Track method being redefined inside the same class. As a side
-   effect, set DECL_NAME to an IDENTIFIER (prior entering this
-   function it's a FWL, so we can track errors more accurately.)  */
-
-static int
-check_method_redefinition (class, method)
-     tree class, method;
-{
-  tree redef, sig;
-
-  /* There's no need to verify <clinit> and finit$ and instinit$ */
-  if (DECL_CLINIT_P (method)
-      || DECL_FINIT_P (method) || DECL_INSTINIT_P (method))
-    return 0;
-
-  sig = TYPE_ARGUMENT_SIGNATURE (TREE_TYPE (method));
-  for (redef = TYPE_METHODS (class); redef; redef = TREE_CHAIN (redef))
-    {
-      if (redef == method)
-       break;
-      if (DECL_NAME (redef) == DECL_NAME (method)
-         && sig == TYPE_ARGUMENT_SIGNATURE (TREE_TYPE (redef))
-         && !DECL_ARTIFICIAL (method))
-       {
-         parse_error_context 
-           (DECL_FUNCTION_WFL (method), "Duplicate %s declaration `%s'",
-            (DECL_CONSTRUCTOR_P (redef) ? "constructor" : "method"),
-            get_printable_method_name (redef));
-         return 1;
-       }
-    }
-  return 0;
-}
-
-/* Return 1 if check went ok, 0 otherwise.  */
-static int
-check_abstract_method_definitions (do_interface, class_decl, type)
-     int do_interface;
-     tree class_decl, type;
-{
-  tree class = TREE_TYPE (class_decl);
-  tree method, end_type;
-  int ok = 1;
-
-  end_type = (do_interface ? object_type_node : type);
-  for (method = TYPE_METHODS (type); method; method = TREE_CHAIN (method))
-    {
-      tree other_super, other_method, method_sig, method_name;
-      int found = 0;
-      int end_type_reached = 0;
-      
-      if (!METHOD_ABSTRACT (method) || METHOD_FINAL (method))
-       continue;
-      
-      /* Now verify that somewhere in between TYPE and CLASS,
-        abstract method METHOD gets a non abstract definition
-        that is inherited by CLASS.  */
-      
-      method_sig = build_java_signature (TREE_TYPE (method));
-      method_name = DECL_NAME (method);
-      if (TREE_CODE (method_name) == EXPR_WITH_FILE_LOCATION)
-       method_name = EXPR_WFL_NODE (method_name);
-
-      other_super = class;
-      do {
-       if (other_super == end_type)
-         end_type_reached = 1;
-       
-       /* Method search */
-       for (other_method = TYPE_METHODS (other_super); other_method;
-            other_method = TREE_CHAIN (other_method))
-         {
-           tree s = build_java_signature (TREE_TYPE (other_method));
-           tree other_name = DECL_NAME (other_method);
-           
-           if (TREE_CODE (other_name) == EXPR_WITH_FILE_LOCATION)
-             other_name = EXPR_WFL_NODE (other_name);
-           if (!DECL_CLINIT_P (other_method)
-               && !DECL_CONSTRUCTOR_P (other_method)
-               && method_name == other_name
-               && method_sig == s
-               && !METHOD_ABSTRACT (other_method))
-             {
-               found = 1;
-               break;
-             }
-         }
-       other_super = CLASSTYPE_SUPER (other_super);
-      } while (!end_type_reached);
-      /* Report that abstract METHOD didn't find an implementation
-        that CLASS can use. */
-      if (!found)
-       {
-         char *t = xstrdup (lang_printable_name 
-                           (TREE_TYPE (TREE_TYPE (method)), 0));
-         tree ccn = DECL_NAME (TYPE_NAME (DECL_CONTEXT (method)));
-         
-         parse_error_context 
-           (lookup_cl (class_decl),
-            "Class `%s' doesn't define the abstract method `%s %s' from %s `%s'. This method must be defined or %s `%s' must be declared abstract",
-            IDENTIFIER_POINTER (DECL_NAME (class_decl)),
-            t, lang_printable_name (method, 0), 
-            (CLASS_INTERFACE (TYPE_NAME (DECL_CONTEXT (method))) ? 
-             "interface" : "class"),
-            IDENTIFIER_POINTER (ccn),
-            (CLASS_INTERFACE (class_decl) ? "interface" : "class"),
-            IDENTIFIER_POINTER (DECL_NAME (class_decl)));
-         ok = 0;
-         free (t);
-       }
-    }
-
-  if (ok && do_interface)
-    {
-      /* Check for implemented interfaces. */
-      int i;
-      tree vector = TYPE_BINFO_BASETYPES (type);
-      for (i = 1; ok && vector && i < TREE_VEC_LENGTH (vector); i++)
-       {
-         tree super = BINFO_TYPE (TREE_VEC_ELT (vector, i));
-         ok = check_abstract_method_definitions (1, class_decl, super);
-       }
-    }
-
-  return ok;
-}
-
-/* Check that CLASS_DECL somehow implements all inherited abstract
-   methods.  */
-
-static void
-java_check_abstract_method_definitions (class_decl)
-     tree class_decl;
-{
-  tree class = TREE_TYPE (class_decl);
-  tree super, vector;
-  int i;
-
-  if (CLASS_ABSTRACT (class_decl))
-    return;
-
-  /* Check for inherited types */
-  super = class;
-  do {
-    super = CLASSTYPE_SUPER (super);
-    check_abstract_method_definitions (0, class_decl, super);
-  } while (super != object_type_node);
-
-  /* Check for implemented interfaces. */
-  vector = TYPE_BINFO_BASETYPES (class);
-  for (i = 1; i < TREE_VEC_LENGTH (vector); i++)
-    {
-      super = BINFO_TYPE (TREE_VEC_ELT (vector, i));
-      check_abstract_method_definitions (1, class_decl, super);
-    }
-}
-
-/* Check all the types method DECL uses and return 1 if all of them
-   are now complete, 0 otherwise. This is used to check whether its
-   safe to build a method signature or not.  */
-
-static int
-check_method_types_complete (decl)
-     tree decl;
-{
-  tree type = TREE_TYPE (decl);
-  tree args;
-
-  if (!INCOMPLETE_TYPE_P (TREE_TYPE (type)))
-    return 0;
-  
-  args = TYPE_ARG_TYPES (type);
-  if (TREE_CODE (type) == METHOD_TYPE)
-    args = TREE_CHAIN (args);
-  for (; args != end_params_node; args = TREE_CHAIN (args))
-    if (INCOMPLETE_TYPE_P (TREE_VALUE (args)))
-      return 0;
-
-  return 1;
-}
-
-/* Visible interface to check methods contained in CLASS_DECL */
-
-void
-java_check_methods (class_decl)
-     tree class_decl;
-{
-  if (CLASS_METHOD_CHECKED_P (TREE_TYPE (class_decl)))
-    return;
-
-  if (CLASS_INTERFACE (class_decl))
-    java_check_abstract_methods (class_decl);
-  else
-    java_check_regular_methods (class_decl);
-  
-  CLASS_METHOD_CHECKED_P (TREE_TYPE (class_decl)) = 1;
-}
-
-/* Check all the methods of CLASS_DECL. Methods are first completed
-   then checked according to regular method existence rules.  If no
-   constructor for CLASS_DECL were encountered, then build its
-   declaration.  */
-
-static void
-java_check_regular_methods (class_decl)
-     tree class_decl;
-{
-  int saw_constructor = ANONYMOUS_CLASS_P (TREE_TYPE (class_decl));
-  tree method;
-  tree class = CLASS_TO_HANDLE_TYPE (TREE_TYPE (class_decl));
-  tree found = NULL_TREE;
-  tree mthrows;
-
-  /* It is not necessary to check methods defined in java.lang.Object */
-  if (class == object_type_node)
-    return;
-
-  if (!TYPE_NVIRTUALS (class))
-    TYPE_METHODS (class) = nreverse (TYPE_METHODS (class));
-
-  /* Should take interfaces into account. FIXME */
-  for (method = TYPE_METHODS (class); method; method = TREE_CHAIN (method))
-    {
-      tree sig;
-      tree method_wfl = DECL_FUNCTION_WFL (method);
-      int aflags;
-
-      /* Check for redefinitions */
-      if (check_method_redefinition (class, method))
-       continue;
-
-      /* If we see one constructor a mark so we don't generate the
-        default one. Also skip other verifications: constructors
-        can't be inherited hence hiden or overriden */
-     if (DECL_CONSTRUCTOR_P (method))
-       {
-        saw_constructor = 1;
-        continue;
-       }
-
-      /* We verify things thrown by the method. They must inherits from
-        java.lang.Throwable */
-      for (mthrows = DECL_FUNCTION_THROWS (method);
-          mthrows; mthrows = TREE_CHAIN (mthrows))
-       {
-         if (!inherits_from_p (TREE_VALUE (mthrows), throwable_type_node))
-           parse_error_context 
-             (TREE_PURPOSE (mthrows), "Class `%s' in `throws' clause must be a subclass of class `java.lang.Throwable'",
-              IDENTIFIER_POINTER 
-                (DECL_NAME (TYPE_NAME (TREE_VALUE (mthrows)))));
-       }
-
-      sig = build_java_argument_signature (TREE_TYPE (method));
-      found = lookup_argument_method2 (class, DECL_NAME (method), sig);
-
-      /* Inner class can't declare static methods */
-      if (METHOD_STATIC (method) && !TOPLEVEL_CLASS_DECL_P (class_decl))
-       {
-         char *t = xstrdup (lang_printable_name (class, 0));
-         parse_error_context 
-           (method_wfl, "Method `%s' can't be static in inner class `%s'. Only members of interfaces and top-level classes can be static",
-            lang_printable_name (method, 0), t);
-         free (t);
-       }
-
-      /* Nothing overrides or it's a private method. */
-      if (!found)
-       continue;
-      if (METHOD_PRIVATE (found))
-       {
-         found = NULL_TREE;
-         continue;
-       }
-
-      /* If `found' is declared in an interface, make sure the
-        modifier matches. */
-      if (CLASS_INTERFACE (TYPE_NAME (DECL_CONTEXT (found))) 
-         && clinit_identifier_node != DECL_NAME (found)
-         && !METHOD_PUBLIC (method))
-       {
-         tree found_decl = TYPE_NAME (DECL_CONTEXT (found));
-         parse_error_context (method_wfl, "Class `%s' must override `%s' with a public method in order to implement interface `%s'",
-                              IDENTIFIER_POINTER (DECL_NAME (class_decl)),
-                              lang_printable_name (method, 0),
-                              IDENTIFIER_POINTER (DECL_NAME (found_decl)));
-       }
-
-      /* Can't override a method with the same name and different return
-        types. */
-      if (TREE_TYPE (TREE_TYPE (found)) != TREE_TYPE (TREE_TYPE (method)))
-       {
-         char *t = xstrdup 
-           (lang_printable_name (TREE_TYPE (TREE_TYPE (found)), 0));
-         parse_error_context 
-           (method_wfl,
-            "Method `%s' was defined with return type `%s' in class `%s'", 
-            lang_printable_name (found, 0), t,
-            IDENTIFIER_POINTER 
-              (DECL_NAME (TYPE_NAME (DECL_CONTEXT (found)))));
-         free (t);
-       }
-
-      aflags = get_access_flags_from_decl (found);
-
-      /* Can't override final. Can't override static. */
-      if (METHOD_FINAL (found) || METHOD_STATIC (found))
-       {
-         /* Static *can* override static */
-         if (METHOD_STATIC (found) && METHOD_STATIC (method))
-           continue;
-         parse_error_context 
-           (method_wfl,
-            "%s methods can't be overriden. Method `%s' is %s in class `%s'",
-            (METHOD_FINAL (found) ? "Final" : "Static"),
-            lang_printable_name (found, 0),
-            (METHOD_FINAL (found) ? "final" : "static"),
-            IDENTIFIER_POINTER
-              (DECL_NAME (TYPE_NAME (DECL_CONTEXT (found)))));
-         continue;
-       }
-
-      /* Static method can't override instance method. */
-      if (METHOD_STATIC (method))
-       {
-         parse_error_context 
-           (method_wfl,
-            "Instance methods can't be overriden by a static method. Method `%s' is an instance method in class `%s'",
-            lang_printable_name (found, 0),
-            IDENTIFIER_POINTER
-              (DECL_NAME (TYPE_NAME (DECL_CONTEXT (found)))));
-         continue;
-       }
-
-      /* - Overriding/hiding public must be public
-        - Overriding/hiding protected must be protected or public
-         - If the overriden or hidden method has default (package)
-           access, then the overriding or hiding method must not be
-           private; otherwise, a compile-time error occurs.  If
-           `found' belongs to an interface, things have been already
-           taken care of.  */
-      if (!CLASS_INTERFACE (TYPE_NAME (DECL_CONTEXT (found)))
-         && ((METHOD_PUBLIC (found) && !METHOD_PUBLIC (method))
-             || (METHOD_PROTECTED (found) 
-                 && !(METHOD_PUBLIC (method) || METHOD_PROTECTED (method)))
-             || (!(aflags & (ACC_PUBLIC | ACC_PRIVATE | ACC_STATIC))
-                 && METHOD_PRIVATE (method))))
-       {
-         parse_error_context 
-           (method_wfl,
-            "Methods can't be overridden to be more private. Method `%s' is not %s in class `%s'", lang_printable_name (method, 0),
-            (METHOD_PUBLIC (method) ? "public" : 
-             (METHOD_PRIVATE (method) ? "private" : "protected")),
-            IDENTIFIER_POINTER (DECL_NAME 
-                                (TYPE_NAME (DECL_CONTEXT (found)))));
-         continue;
-       }
-
-      /* Overriding methods must have compatible `throws' clauses on checked
-        exceptions, if any */
-      check_throws_clauses (method, method_wfl, found);
-
-      /* Inheriting multiple methods with the same signature. FIXME */
-    }
-  
-  if (!TYPE_NVIRTUALS (class))
-    TYPE_METHODS (class) = nreverse (TYPE_METHODS (class));
-
-  /* Search for inherited abstract method not yet implemented in this
-     class.  */
-  java_check_abstract_method_definitions (class_decl);
-
-  if (!saw_constructor)
-    abort ();
-}
-
-/* Return a non zero value if the `throws' clause of METHOD (if any)
-   is incompatible with the `throws' clause of FOUND (if any).  */
-
-static void
-check_throws_clauses (method, method_wfl, found)
-     tree method, method_wfl, found;
-{
-  tree mthrows, fthrows;
-
-  /* Can't check these things with class loaded from bytecode. FIXME */
-  if (!CLASS_FROM_SOURCE_P (DECL_CONTEXT (found)))
-    return;
-
-  for (mthrows = DECL_FUNCTION_THROWS (method);
-       mthrows; mthrows = TREE_CHAIN (mthrows))
-    {
-      /* We don't verify unchecked expressions */
-      if (IS_UNCHECKED_EXCEPTION_P (TREE_VALUE (mthrows)))
-       continue;
-      /* Checked expression must be compatible */
-      for (fthrows = DECL_FUNCTION_THROWS (found); 
-          fthrows; fthrows = TREE_CHAIN (fthrows))
-       if (inherits_from_p (TREE_VALUE (mthrows), TREE_VALUE (fthrows)))
-         break;
-      if (!fthrows)
-       {
-         parse_error_context 
-           (method_wfl, "Invalid checked exception class `%s' in `throws' clause. The exception must be a subclass of an exception thrown by `%s' from class `%s'",
-            IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (TREE_VALUE (mthrows)))),
-            lang_printable_name (found, 0),
-            IDENTIFIER_POINTER 
-              (DECL_NAME (TYPE_NAME (DECL_CONTEXT (found)))));
-       }
-    }
-}
-
-/* Check abstract method of interface INTERFACE */
-
-static void
-java_check_abstract_methods (interface_decl)
-     tree interface_decl;
-{
-  int i, n;
-  tree method, basetype_vec, found;
-  tree interface = TREE_TYPE (interface_decl);
-
-  for (method = TYPE_METHODS (interface); method; method = TREE_CHAIN (method))
-    {
-      /* 2- Check for double definition inside the defining interface */
-      if (check_method_redefinition (interface, method))
-       continue;
-
-      /* 3- Overriding is OK as far as we preserve the return type and
-        the thrown exceptions (FIXME) */
-      found = lookup_java_interface_method2 (interface, method);
-      if (found)
-       {
-         char *t;
-         t = xstrdup (lang_printable_name (TREE_TYPE (TREE_TYPE (found)), 0));
-         parse_error_context 
-           (DECL_FUNCTION_WFL (found),
-            "Method `%s' was defined with return type `%s' in class `%s'",
-            lang_printable_name (found, 0), t,
-            IDENTIFIER_POINTER 
-              (DECL_NAME (TYPE_NAME (DECL_CONTEXT (found)))));
-         free (t);
-         continue;
-       }
-    }
-
-  /* 4- Inherited methods can't differ by their returned types */
-  if (!(basetype_vec = TYPE_BINFO_BASETYPES (interface)))
-    return;
-  n = TREE_VEC_LENGTH (basetype_vec);
-  for (i = 0; i < n; i++)
-    {
-      tree sub_interface_method, sub_interface;
-      tree vec_elt = TREE_VEC_ELT (basetype_vec, i);
-      if (!vec_elt)
-       continue;
-      sub_interface = BINFO_TYPE (vec_elt);
-      for (sub_interface_method = TYPE_METHODS (sub_interface); 
-          sub_interface_method;
-          sub_interface_method = TREE_CHAIN (sub_interface_method))
-       {
-         found = lookup_java_interface_method2 (interface, 
-                                                sub_interface_method);
-         if (found && (found != sub_interface_method))
-           {
-             parse_error_context 
-               (lookup_cl (sub_interface_method),
-                "Interface `%s' inherits method `%s' from interface `%s'. This method is redefined with a different return type in interface `%s'",
-                IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (interface))),
-                lang_printable_name (found, 0),
-                IDENTIFIER_POINTER 
-                  (DECL_NAME (TYPE_NAME 
-                              (DECL_CONTEXT (sub_interface_method)))),
-                IDENTIFIER_POINTER 
-                  (DECL_NAME (TYPE_NAME (DECL_CONTEXT (found)))));
-           }
-       }
-    }
-}
-
-/* Lookup methods in interfaces using their name and partial
-   signature. Return a matching method only if their types differ.  */
-
-static tree
-lookup_java_interface_method2 (class, method_decl)
-     tree class, method_decl;
-{
-  int i, n;
-  tree basetype_vec = TYPE_BINFO_BASETYPES (class), to_return;
-
-  if (!basetype_vec)
-    return NULL_TREE;
-
-  n = TREE_VEC_LENGTH (basetype_vec);
-  for (i = 0; i < n; i++)
-    {
-      tree vec_elt = TREE_VEC_ELT (basetype_vec, i), to_return;
-      if ((BINFO_TYPE (vec_elt) != object_type_node)
-         && (to_return = 
-             lookup_java_method2 (BINFO_TYPE (vec_elt), method_decl, 1)))
-       return to_return;
-    }
-  for (i = 0; i < n; i++)
-    {
-      to_return = lookup_java_interface_method2 
-       (BINFO_TYPE (TREE_VEC_ELT (basetype_vec, i)), method_decl);
-      if (to_return)
-       return to_return;
-    }
-
-  return NULL_TREE;
-}
-
-/* Lookup method using their name and partial signature. Return a
-   matching method only if their types differ.  */
-
-static tree
-lookup_java_method2 (clas, method_decl, do_interface)
-     tree clas, method_decl;
-     int do_interface;
-{
-  tree method, method_signature, method_name, method_type, name;
-
-  method_signature = build_java_argument_signature (TREE_TYPE (method_decl));
-  name = DECL_NAME (method_decl);
-  method_name = (TREE_CODE (name) == EXPR_WITH_FILE_LOCATION ? 
-                EXPR_WFL_NODE (name) : name);
-  method_type = TREE_TYPE (TREE_TYPE (method_decl));
-
-  while (clas != NULL_TREE)
-    {
-      for (method = TYPE_METHODS (clas);
-          method != NULL_TREE;  method = TREE_CHAIN (method))
-       {
-         tree method_sig = build_java_argument_signature (TREE_TYPE (method));
-         tree name = DECL_NAME (method);
-         if ((TREE_CODE (name) == EXPR_WITH_FILE_LOCATION ?
-              EXPR_WFL_NODE (name) : name) == method_name
-             && method_sig == method_signature 
-             && TREE_TYPE (TREE_TYPE (method)) != method_type)
-           return method;
-       }
-      clas = (do_interface ? NULL_TREE : CLASSTYPE_SUPER (clas));
-    }
-  return NULL_TREE;
-}
-
-/* Return the line that matches DECL line number, and try its best to
-   position the column number. Used during error reports.  */
-
-static tree
-lookup_cl (decl)
-     tree decl;
-{
-  static tree cl = NULL_TREE;
-  char *line, *found;
-  
-  if (!decl)
-    return NULL_TREE;
-
-  if (cl == NULL_TREE)
-    {
-      cl = build_expr_wfl (NULL_TREE, NULL, 0, 0);
-      ggc_add_tree_root (&cl, 1);
-    }
-
-  EXPR_WFL_FILENAME_NODE (cl) = get_identifier (DECL_SOURCE_FILE (decl));
-  EXPR_WFL_SET_LINECOL (cl, DECL_SOURCE_LINE_FIRST (decl), -1);
-
-  line = java_get_line_col (EXPR_WFL_FILENAME (cl), 
-                           EXPR_WFL_LINENO (cl), EXPR_WFL_COLNO (cl));
-
-  found = strstr ((const char *)line, 
-                 (const char *)IDENTIFIER_POINTER (DECL_NAME (decl)));
-  if (found)
-    EXPR_WFL_SET_LINECOL (cl, EXPR_WFL_LINENO (cl), found - line);
-
-  return cl;
-}
-
-/* Look for a simple name in the single-type import list */
-
-static tree
-find_name_in_single_imports (name)
-     tree name;
-{
-  tree node;
-
-  for (node = ctxp->import_list; node; node = TREE_CHAIN (node))
-    if (TREE_VALUE (node) == name)
-      return (EXPR_WFL_NODE (TREE_PURPOSE (node)));
-
-  return NULL_TREE;
-}
-
-/* Process all single-type import. */
-
-static int
-process_imports ()
-{
-  tree import;
-  int error_found;
-
-  for (import = ctxp->import_list; import; import = TREE_CHAIN (import))
-    {
-      tree to_be_found = EXPR_WFL_NODE (TREE_PURPOSE (import));
-      char *original_name;
-
-      obstack_grow0 (&temporary_obstack,
-                    IDENTIFIER_POINTER (to_be_found),
-                    IDENTIFIER_LENGTH (to_be_found));
-      original_name = obstack_finish (&temporary_obstack);
-
-      /* Don't load twice something already defined. */
-      if (IDENTIFIER_CLASS_VALUE (to_be_found))
-       continue;
-      
-      while (1)
-       {
-         tree left;
-
-         QUALIFIED_P (to_be_found) = 1;
-         load_class (to_be_found, 0);
-         error_found =
-           check_pkg_class_access (to_be_found, TREE_PURPOSE (import), true);
-         
-         /* We found it, we can bail out */
-         if (IDENTIFIER_CLASS_VALUE (to_be_found))
-           break;
-
-         /* We haven't found it. Maybe we're trying to access an
-            inner class.  The only way for us to know is to try again
-            after having dropped a qualifier. If we can't break it further,
-            we have an error. */
-         if (breakdown_qualified (&left, NULL, to_be_found))
-           break;
-
-         to_be_found = left;
-       }
-      if (!IDENTIFIER_CLASS_VALUE (to_be_found))
-       {
-         parse_error_context (TREE_PURPOSE (import),
-                              "Class or interface `%s' not found in import",
-                              original_name);
-         error_found = 1;
-       }
-
-      obstack_free (&temporary_obstack, original_name);
-      if (error_found)
-       return 1;
-    }
-  return 0;
-}
-
-/* Possibly find and mark a class imported by a single-type import
-   statement.  */
-
-static void
-find_in_imports (enclosing_type, class_type)
-     tree enclosing_type;
-     tree class_type;
-{
-  tree import = (enclosing_type ? TYPE_IMPORT_LIST (enclosing_type) : 
-                ctxp->import_list);
-  while (import)
-    {
-      if (TREE_VALUE (import) == TYPE_NAME (class_type))
-       {
-         TYPE_NAME (class_type) = EXPR_WFL_NODE (TREE_PURPOSE (import));
-         QUALIFIED_P (TYPE_NAME (class_type)) = 1;
-         return;
-       }
-      import = TREE_CHAIN (import);
-    }
-}
-
-static int
-note_possible_classname (name, len)
-     const char *name;
-     int len;
-{
-  tree node;
-  if (len > 5 && strncmp (&name [len-5], ".java", 5) == 0)
-    len = len - 5;
-  else if (len > 6 && strncmp (&name [len-6], ".class", 6) == 0)
-    len = len - 6;
-  else
-    return 0;
-  node = ident_subst (name, len, "", '/', '.', "");
-  IS_A_CLASSFILE_NAME (node) = 1; /* Or soon to be */
-  QUALIFIED_P (node) = strchr (name, '/') ? 1 : 0;
-  return 1;
-}
-
-/* Read a import directory, gathering potential match for further type
-   references. Indifferently reads a filesystem or a ZIP archive
-   directory.  */
-
-static void
-read_import_dir (wfl)
-     tree wfl;
-{
-  tree package_id = EXPR_WFL_NODE (wfl);
-  const char *package_name = IDENTIFIER_POINTER (package_id);
-  int package_length = IDENTIFIER_LENGTH (package_id);
-  DIR *dirp = NULL;
-  JCF *saved_jcf = current_jcf;
-
-  int found = 0;
-  int k;
-  void *entry;
-  struct buffer filename[1];
-
-  if (IS_AN_IMPORT_ON_DEMAND_P (package_id))
-    return;
-  IS_AN_IMPORT_ON_DEMAND_P (package_id) = 1;
-
-  BUFFER_INIT (filename);
-  buffer_grow (filename, package_length + 100);
-
-  for (entry = jcf_path_start (); entry != NULL; entry = jcf_path_next (entry))
-    {
-      const char *entry_name = jcf_path_name (entry);
-      int entry_length = strlen (entry_name);
-      if (jcf_path_is_zipfile (entry))
-       {
-         ZipFile *zipf;
-         buffer_grow (filename, entry_length);
-         memcpy (filename->data, entry_name, entry_length - 1);
-         filename->data[entry_length-1] = '\0';
-         zipf = opendir_in_zip (filename->data, jcf_path_is_system (entry));
-         if (zipf == NULL)
-           error ("malformed .zip archive in CLASSPATH: %s", entry_name);
-         else
-           {
-             ZipDirectory *zipd = (ZipDirectory *) zipf->central_directory;
-             BUFFER_RESET (filename);
-             for (k = 0; k < package_length; k++)
-               {
-                 char ch = package_name[k];
-                 *filename->ptr++ = ch == '.' ? '/' : ch;
-               }
-             *filename->ptr++ = '/';
-
-             for (k = 0; k < zipf->count;  k++, zipd = ZIPDIR_NEXT (zipd))
-               {
-                 const char *current_entry = ZIPDIR_FILENAME (zipd);
-                 int current_entry_len = zipd->filename_length;
-
-                 if (current_entry_len >= BUFFER_LENGTH (filename)
-                     && strncmp (filename->data, current_entry, 
-                                 BUFFER_LENGTH (filename)) != 0)
-                   continue;
-                 found |= note_possible_classname (current_entry,
-                                                   current_entry_len);
-               }
-           }
-       }
-      else
-       {
-         BUFFER_RESET (filename);
-         buffer_grow (filename, entry_length + package_length + 4);
-         strcpy (filename->data, entry_name);
-         filename->ptr = filename->data + entry_length;
-         for (k = 0; k < package_length; k++)
-           {
-             char ch = package_name[k];
-             *filename->ptr++ = ch == '.' ? '/' : ch;
-           }
-         *filename->ptr = '\0';
-
-         dirp = opendir (filename->data);
-         if (dirp == NULL)
-           continue;
-         *filename->ptr++ = '/';
-         for (;;)
-           {
-             int len; 
-             const char *d_name;
-             struct dirent *direntp = readdir (dirp);
-             if (!direntp)
-               break;
-             d_name = direntp->d_name;
-             len = strlen (direntp->d_name);
-             buffer_grow (filename, len+1);
-             strcpy (filename->ptr, d_name);
-             found |= note_possible_classname (filename->data + entry_length,
-                                               package_length+len+1);
-           }
-         if (dirp)
-           closedir (dirp);
-       }
-    }
-
-  free (filename->data);
-
-  /* Here we should have a unified way of retrieving an entry, to be
-     indexed. */
-  if (!found)
-    {
-      static int first = 1;
-      if (first)
-       {
-         error ("Can't find default package `%s'. Check the CLASSPATH environment variable and the access to the archives", package_name);
-         java_error_count++;
-         first = 0;
-       }
-      else
-       parse_error_context (wfl, "Package `%s' not found in import",
-                            package_name);
-      current_jcf = saved_jcf;
-      return;
-    }
-  current_jcf = saved_jcf;
-}
-
-/* Possibly find a type in the import on demands specified
-   types. Returns 1 if an error occurred, 0 otherwise. Run through the
-   entire list, to detected potential double definitions.  */
-                
-static int
-find_in_imports_on_demand (enclosing_type, class_type)
-     tree enclosing_type;
-     tree class_type;
-{
-  tree class_type_name = TYPE_NAME (class_type);
-  tree import = (enclosing_type ? TYPE_IMPORT_DEMAND_LIST (enclosing_type) :
-                 ctxp->import_demand_list);
-  tree cl = NULL_TREE;
-  int seen_once = -1;  /* -1 when not set, 1 if seen once, >1 otherwise. */
-  int to_return = -1;  /* -1 when not set, 0 or 1 otherwise */
-  tree node;
-
-  for (; import; import = TREE_CHAIN (import))
-    {
-      int saved_lineno = lineno;
-      int access_check;
-      const char *id_name;
-      tree decl, type_name_copy;
-
-      obstack_grow (&temporary_obstack, 
-                   IDENTIFIER_POINTER (EXPR_WFL_NODE (TREE_PURPOSE (import))),
-                   IDENTIFIER_LENGTH (EXPR_WFL_NODE (TREE_PURPOSE (import))));
-      obstack_1grow (&temporary_obstack, '.');
-      obstack_grow0 (&temporary_obstack, 
-                    IDENTIFIER_POINTER (class_type_name),
-                    IDENTIFIER_LENGTH (class_type_name));
-      id_name = obstack_finish (&temporary_obstack);
-             
-      if (! (node = maybe_get_identifier (id_name)))
-       continue;
-
-      /* Setup lineno so that it refers to the line of the import (in
-        case we parse a class file and encounter errors */
-      lineno = EXPR_WFL_LINENO (TREE_PURPOSE (import));
-
-      type_name_copy = TYPE_NAME (class_type);
-      TYPE_NAME (class_type) = node;
-      QUALIFIED_P (node) = 1;
-      decl = IDENTIFIER_CLASS_VALUE (node);
-      access_check = -1;
-      /* If there is no DECL set for the class or if the class isn't
-        loaded and not seen in source yet, then load */
-      if (!decl || (!CLASS_LOADED_P (TREE_TYPE (decl))
-                   && !CLASS_FROM_SOURCE_P (TREE_TYPE (decl))))
-       {
-         load_class (node, 0);
-         decl = IDENTIFIER_CLASS_VALUE (node);
-       }
-      if (decl && ! INNER_CLASS_P (TREE_TYPE (decl)))
-       access_check = check_pkg_class_access (node, TREE_PURPOSE (import),
-                                              false);
-      else
-       /* 6.6.1: Inner classes are subject to member access rules. */
-       access_check = 0;
-
-      lineno = saved_lineno;
-
-      /* If the loaded class is not accessible or couldn't be loaded,
-        we restore the original TYPE_NAME and process the next
-        import. */
-      if (access_check || !decl)
-       {
-         TYPE_NAME (class_type) = type_name_copy;
-         continue;
-       }
-      
-      /* If the loaded class is accessible, we keep a tab on it to
-        detect and report multiple inclusions. */
-      if (IS_A_CLASSFILE_NAME (node))
-       {
-         if (seen_once < 0)
-           {
-             cl = TREE_PURPOSE (import);
-             seen_once = 1;
-           }
-         else if (seen_once >= 0)
-           {
-             tree location = (cl ? cl : TREE_PURPOSE (import));
-             tree package = (cl ? EXPR_WFL_NODE (cl) : 
-                             EXPR_WFL_NODE (TREE_PURPOSE (import)));
-             seen_once++;
-             parse_error_context 
-               (location,
-                "Type `%s' also potentially defined in package `%s'",
-                IDENTIFIER_POINTER (TYPE_NAME (class_type)), 
-                IDENTIFIER_POINTER (package));
-           }
-       }
-      to_return = access_check;
-    }
-
-  if (seen_once == 1)
-    return to_return;
-  else
-    return (seen_once < 0 ? 0 : seen_once); /* It's ok not to have found */
-}
-
-/* Add package NAME to the list of package encountered so far. To
-   speed up class lookup in do_resolve_class, we make sure a
-   particular package is added only once.  */
-
-static void
-register_package (name)
-     tree name;
-{
-  static struct hash_table _pht, *pht = NULL;
-
-  if (!pht)
-    {
-      hash_table_init (&_pht, hash_newfunc, 
-                      java_hash_hash_tree_node, java_hash_compare_tree_node);
-      pht = &_pht;
-    }
-  
-  if (!hash_lookup (pht, (const hash_table_key) name, FALSE, NULL))
-    {
-      package_list = chainon (package_list, build_tree_list (name, NULL));
-      hash_lookup (pht, (const hash_table_key) name, TRUE, NULL);
-    }
-}
-
-static tree
-resolve_package (pkg, next, type_name)
-     tree pkg, *next, *type_name;
-{
-  tree current;
-  tree decl = NULL_TREE;
-  *type_name = NULL_TREE;
-
-  /* The trick is to determine when the package name stops and were
-     the name of something contained in the package starts. Then we
-     return a fully qualified name of what we want to get. */
-
-  *next = EXPR_WFL_QUALIFICATION (pkg);
-
-  /* Try to progressively construct a type name */
-  if (TREE_CODE (pkg) == EXPR_WITH_FILE_LOCATION)
-    for (current = EXPR_WFL_QUALIFICATION (pkg); 
-        current; current = TREE_CHAIN (current))
-      {
-       /* If we don't have what we're expecting, exit now. TYPE_NAME
-          will be null and the error caught later. */
-       if (TREE_CODE (QUAL_WFL (current)) != EXPR_WITH_FILE_LOCATION)
-         break;
-       *type_name = 
-         merge_qualified_name (*type_name, EXPR_WFL_NODE (QUAL_WFL (current)));
-       if ((decl = resolve_no_layout (*type_name, NULL_TREE)))
-         {
-           /* resolve_package should be used in a loop, hence we
-              point at this one to naturally process the next one at
-              the next iteration. */
-           *next = current;
-           break;
-         }
-      }
-  return decl;
-}
-
-
-/* Check accessibility of inner classes according to member access rules. 
-   DECL is the inner class, ENCLOSING_DECL is the class from which the
-   access is being attempted. */
-
-static void
-check_inner_class_access (decl, enclosing_decl, cl)
-     tree decl, enclosing_decl, cl;
-{
-  const char *access;
-  tree enclosing_decl_type;
-
-  /* We don't issue an error message when CL is null. CL can be null
-     as a result of processing a JDEP crafted by source_start_java_method
-     for the purpose of patching its parm decl. But the error would
-     have been already trapped when fixing the method's signature.
-     DECL can also be NULL in case of earlier errors. */
-  if (!decl || !cl)
-    return;
-
-  enclosing_decl_type = TREE_TYPE (enclosing_decl);
-
-  if (CLASS_PRIVATE (decl))
-    {
-      /* Access is permitted only within the body of the top-level
-         class in which DECL is declared. */
-      tree top_level = decl;
-      while (DECL_CONTEXT (top_level))
-        top_level = DECL_CONTEXT (top_level);      
-      while (DECL_CONTEXT (enclosing_decl))
-        enclosing_decl = DECL_CONTEXT (enclosing_decl);
-      if (top_level == enclosing_decl)
-        return;      
-      access = "private";
-    }
-  else if (CLASS_PROTECTED (decl))
-    {
-      tree decl_context;
-      /* Access is permitted from within the same package... */
-      if (in_same_package (decl, enclosing_decl))
-        return;
-      
-      /* ... or from within the body of a subtype of the context in which
-         DECL is declared. */
-      decl_context = DECL_CONTEXT (decl);
-      while (enclosing_decl)
-        {
-         if (CLASS_INTERFACE (decl))
-           {
-             if (interface_of_p (TREE_TYPE (decl_context), 
-                                 enclosing_decl_type))
-               return;
-           }
-         else
-           {
-             /* Eww. The order of the arguments is different!! */
-             if (inherits_from_p (enclosing_decl_type, 
-                                  TREE_TYPE (decl_context)))
-               return;
-           }
-         enclosing_decl = DECL_CONTEXT (enclosing_decl);
-       }      
-      access = "protected";
-    }
-  else if (! CLASS_PUBLIC (decl))
-    {
-      /* Access is permitted only from within the same package as DECL. */
-      if (in_same_package (decl, enclosing_decl))
-        return;
-      access = "non-public";
-    }
-  else
-    /* Class is public. */
-    return;
-
-  parse_error_context (cl, "Nested %s %s is %s; cannot be accessed from here",
-                      (CLASS_INTERFACE (decl) ? "interface" : "class"),
-                      lang_printable_name (decl, 0), access);
-}
-
-/* Accessibility check for top-level classes. If CLASS_NAME is in a
-   foreign package, it must be PUBLIC. Return 0 if no access
-   violations were found, 1 otherwise. If VERBOSE is true and an error
-   was found, it is reported and accounted for.  */
-
-static int
-check_pkg_class_access (class_name, cl, verbose)
-     tree class_name;
-     tree cl;
-     bool verbose;
-{
-  tree type;
-
-  if (!IDENTIFIER_CLASS_VALUE (class_name))
-    return 0;
-
-  if (!(type = TREE_TYPE (IDENTIFIER_CLASS_VALUE (class_name))))
-    return 0;
-
-  if (!CLASS_PUBLIC (TYPE_NAME (type)))
-    {
-      /* Access to a private class within the same package is
-         allowed. */
-      tree l, r;
-      breakdown_qualified (&l, &r, class_name);
-      if (!QUALIFIED_P (class_name) && !ctxp->package)
-       /* Both in the empty package. */
-        return 0;
-      if (l == ctxp->package)
-       /* Both in the same package. */
-       return 0;
-
-      if (verbose)
-       parse_error_context 
-         (cl, "Can't access %s `%s'. Only public classes and interfaces in other packages can be accessed",
-          (CLASS_INTERFACE (TYPE_NAME (type)) ? "interface" : "class"),
-          IDENTIFIER_POINTER (class_name));
-      return 1;
-    }
-  return 0;
-}
-
-/* Local variable declaration. */
-
-static void
-declare_local_variables (modifier, type, vlist)
-     int modifier;
-     tree type;
-     tree vlist;
-{
-  tree decl, current, saved_type;
-  tree type_wfl = NULL_TREE;
-  int must_chain = 0;
-  int final_p = 0;
-
-  /* Push a new block if statements were seen between the last time we
-     pushed a block and now. Keep a count of blocks to close */
-  if (BLOCK_EXPR_BODY (GET_CURRENT_BLOCK (current_function_decl)))
-    {
-      tree b = enter_block ();
-      BLOCK_IS_IMPLICIT (b) = 1;
-    }
-
-  if (modifier)
-    {
-      int i;
-      for (i = 0; i <= 10; i++) if (1 << i & modifier) break;
-      if (modifier == ACC_FINAL)
-       final_p = 1;
-      else 
-       {
-         parse_error_context 
-           (ctxp->modifier_ctx [i], 
-            "Only `final' is allowed as a local variables modifier");
-         return;
-       }
-    }
-
-  /* Obtain an incomplete type if TYPE is not complete. TYPE_WFL will
-     hold the TYPE value if a new incomplete has to be created (as
-     opposed to being found already existing and reused). */
-  SET_TYPE_FOR_RESOLUTION (type, type_wfl, must_chain);
-
-  /* If TYPE is fully resolved and we don't have a reference, make one */
-  PROMOTE_RECORD_IF_COMPLETE (type, must_chain);
-
-  /* Go through all the declared variables */
-  for (current = vlist, saved_type = type; current;
-       current = TREE_CHAIN (current), type = saved_type)
-    {
-      tree other, real_type;
-      tree wfl  = TREE_PURPOSE (current);
-      tree name = EXPR_WFL_NODE (wfl);
-      tree init = TREE_VALUE (current);
-
-      /* Process NAME, as it may specify extra dimension(s) for it */
-      type = build_array_from_name (type, type_wfl, name, &name);
-
-      /* Variable redefinition check */
-      if ((other = lookup_name_in_blocks (name)))
-       {
-         variable_redefinition_error (wfl, name, TREE_TYPE (other),
-                                      DECL_SOURCE_LINE (other));
-         continue;
-       }
-
-      /* Type adjustment. We may have just readjusted TYPE because
-        the variable specified more dimensions. Make sure we have
-        a reference if we can and don't have one already. */
-      PROMOTE_RECORD_IF_COMPLETE (type, must_chain);
-
-      real_type = GET_REAL_TYPE (type);
-      /* Never layout this decl. This will be done when its scope
-        will be entered */
-      decl = build_decl (VAR_DECL, name, real_type);
-      MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (decl);
-      DECL_FINAL (decl) = final_p;
-      BLOCK_CHAIN_DECL (decl);
-      
-      /* If doing xreferencing, replace the line number with the WFL
-         compound value */
-      if (flag_emit_xref)
-       DECL_SOURCE_LINE (decl) = EXPR_WFL_LINECOL (wfl);
-      
-      /* Don't try to use an INIT statement when an error was found */
-      if (init && java_error_count)
-       init = NULL_TREE;
-      
-      /* Add the initialization function to the current function's code */
-      if (init)
-       {
-         /* Name might have been readjusted */
-         EXPR_WFL_NODE (TREE_OPERAND (init, 0)) = name;
-         MODIFY_EXPR_FROM_INITIALIZATION_P (init) = 1;
-         java_method_add_stmt (current_function_decl,
-                               build_debugable_stmt (EXPR_WFL_LINECOL (init),
-                                                     init));
-       }
-    
-      /* Setup dependency the type of the decl */
-      if (must_chain)
-       {
-         jdep *dep;
-         register_incomplete_type (JDEP_VARIABLE, type_wfl, decl, type);
-         dep = CLASSD_LAST (ctxp->classd_list);
-         JDEP_GET_PATCH (dep) = &TREE_TYPE (decl);
-       }
-    }
-  SOURCE_FRONTEND_DEBUG (("Defined locals"));
-}
-
-/* Called during parsing. Build decls from argument list.  */
-
-static void
-source_start_java_method (fndecl)
-     tree fndecl;
-{
-  tree tem;
-  tree parm_decl;
-  int i;
-
-  if (!fndecl)
-    return;
-
-  current_function_decl = fndecl;
-
-  /* New scope for the function */
-  enter_block ();
-  for (tem = TYPE_ARG_TYPES (TREE_TYPE (fndecl)), i = 0;
-       tem != end_params_node; tem = TREE_CHAIN (tem), i++)
-    {
-      tree type = TREE_VALUE (tem);
-      tree name = TREE_PURPOSE (tem);
-      
-      /* If type is incomplete. Create an incomplete decl and ask for
-        the decl to be patched later */
-      if (INCOMPLETE_TYPE_P (type))
-       {
-         jdep *jdep;
-         tree real_type = GET_REAL_TYPE (type);
-         parm_decl = build_decl (PARM_DECL, name, real_type);
-         type = obtain_incomplete_type (type);
-         register_incomplete_type (JDEP_PARM, NULL_TREE, NULL_TREE, type);
-         jdep = CLASSD_LAST (ctxp->classd_list);
-         JDEP_MISC (jdep) = name;
-         JDEP_GET_PATCH (jdep) = &TREE_TYPE (parm_decl);
-       }
-      else
-       parm_decl = build_decl (PARM_DECL, name, type);
-
-      /* Remember if a local variable was declared final (via its
-         TREE_LIST of type/name.) Set DECL_FINAL accordingly. */
-      if (ARG_FINAL_P (tem))
-       {
-         MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (parm_decl);
-         DECL_FINAL (parm_decl) = 1;
-       }
-
-      BLOCK_CHAIN_DECL (parm_decl);
-    }
-  tem = BLOCK_EXPR_DECLS (DECL_FUNCTION_BODY (current_function_decl));
-  BLOCK_EXPR_DECLS (DECL_FUNCTION_BODY (current_function_decl)) =
-    nreverse (tem);
-  DECL_ARG_SLOT_COUNT (current_function_decl) = i;
-  DECL_MAX_LOCALS (current_function_decl) = i;
-}
-
-/* Called during parsing. Creates an artificial method declaration.  */
-
-static tree
-create_artificial_method (class, flags, type, name, args)
-     tree class;
-     int flags;
-     tree type, name, args;
-{
-  tree mdecl;
-
-  java_parser_context_save_global ();
-  lineno = 0;                                                              
-  mdecl = make_node (FUNCTION_TYPE);                               
-  TREE_TYPE (mdecl) = type;
-  TYPE_ARG_TYPES (mdecl) = args;
-  mdecl = add_method (class, flags, name, build_java_signature (mdecl)); 
-  java_parser_context_restore_global ();
-  DECL_ARTIFICIAL (mdecl) = 1;                                     
-  return mdecl;
-}
-
-/* Starts the body if an artificial method.  */
-
-static void
-start_artificial_method_body (mdecl)
-     tree mdecl;
-{
-  DECL_SOURCE_LINE (mdecl) = 1;
-  DECL_SOURCE_LINE_MERGE (mdecl, 1);
-  source_start_java_method (mdecl);
-  enter_block ();
-}
-
-static void
-end_artificial_method_body (mdecl)
-     tree mdecl;
-{
-  /* exit_block modifies DECL_FUNCTION_BODY (current_function_decl).
-     It has to be evaluated first. (if mdecl is current_function_decl,
-     we have an undefined behavior if no temporary variable is used.) */
-  tree b = exit_block ();
-  BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (mdecl)) = b;
-  exit_block ();
-}
-
-/* Dump a tree of some kind.  This is a convenience wrapper for the
-   dump_* functions in tree-dump.c.  */
-static void
-dump_java_tree (phase, t)
-     enum tree_dump_index phase;
-     tree t;
-{
-  FILE *stream;
-  int flags;
-
-  stream = dump_begin (phase, &flags);
-  if (stream)
-    {
-      dump_node (t, flags, stream);
-      dump_end (phase, stream);
-    }
-}
-
-/* Terminate a function and expand its body.  */
-
-static void
-source_end_java_method ()
-{
-  tree fndecl = current_function_decl;
-
-  if (!fndecl)
-    return;
-
-  java_parser_context_save_global ();
-  lineno = ctxp->last_ccb_indent1;
-
-  /* Turn function bodies with only a NOP expr null, so they don't get
-     generated at all and we won't get warnings when using the -W
-     -Wall flags. */
-  if (BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (fndecl)) == empty_stmt_node)
-    BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (fndecl)) = NULL_TREE;
-
-  /* We've generated all the trees for this function, and it has been
-     patched.  Dump it to a file if the user requested it.  */
-  dump_java_tree (TDI_original, fndecl);
-
-  /* Generate function's code */
-  if (BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (fndecl))
-      && ! flag_emit_class_files
-      && ! flag_emit_xref)
-    expand_expr_stmt (BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (fndecl)));
-
-  /* pop out of its parameters */
-  pushdecl_force_head (DECL_ARGUMENTS (fndecl));
-  poplevel (1, 0, 1);
-  BLOCK_SUPERCONTEXT (DECL_INITIAL (fndecl)) = fndecl;
-
-  /* Generate rtl for function exit.  */
-  if (! flag_emit_class_files && ! flag_emit_xref)
-    {
-      lineno = DECL_SOURCE_LINE_LAST (fndecl);
-      expand_function_end (input_filename, lineno, 0);
-
-      DECL_SOURCE_LINE (fndecl) = DECL_SOURCE_LINE_FIRST (fndecl);
-
-      /* Run the optimizers and output assembler code for this function. */
-      rest_of_compilation (fndecl);
-    }
-
-  current_function_decl = NULL_TREE;
-  java_parser_context_restore_global ();
-}
-
-/* Record EXPR in the current function block. Complements compound
-   expression second operand if necessary.  */
-
-tree
-java_method_add_stmt (fndecl, expr)
-     tree fndecl, expr;
-{
-  if (!GET_CURRENT_BLOCK (fndecl))
-    return NULL_TREE;
-  return add_stmt_to_block (GET_CURRENT_BLOCK (fndecl), NULL_TREE, expr);
-}
-
-static tree
-add_stmt_to_block (b, type, stmt)
-     tree b, type, stmt;
-{
-  tree body = BLOCK_EXPR_BODY (b), c;
-  
-  if (java_error_count)
-    return body;
-    
-  if ((c = add_stmt_to_compound (body, type, stmt)) == body)
-    return body;
-
-  BLOCK_EXPR_BODY (b) = c;
-  TREE_SIDE_EFFECTS (c) = 1;
-  return c;
-}
-
-/* Add STMT to EXISTING if possible, otherwise create a new
-   COMPOUND_EXPR and add STMT to it. */
-
-static tree
-add_stmt_to_compound (existing, type, stmt)
-     tree existing, type, stmt;
-{
-  if (existing)
-    return build (COMPOUND_EXPR, type, existing, stmt);
-  else
-    return stmt;
-}
-
-void java_layout_seen_class_methods ()
-{
-  tree previous_list = all_class_list;
-  tree end = NULL_TREE;
-  tree current;
-
-  while (1)
-    {
-      for (current = previous_list; 
-          current != end; current = TREE_CHAIN (current))
-       layout_class_methods (TREE_TYPE (TREE_VALUE (current)));
-      
-      if (previous_list != all_class_list)
-       {
-         end = previous_list;
-         previous_list = all_class_list;
-       }
-      else
-       break;
-    }
-}
-
-void
-java_reorder_fields ()
-{
-  static tree stop_reordering = NULL_TREE;
-  static int initialized_p;
-  tree current;
-
-  /* Register STOP_REORDERING with the garbage collector.  */
-  if (!initialized_p)
-    {
-      ggc_add_tree_root (&stop_reordering, 1);
-      initialized_p = 1;
-    }
-
-  for (current = gclass_list; current; current = TREE_CHAIN (current))
-    {
-      current_class = TREE_TYPE (TREE_VALUE (current));
-
-      if (current_class == stop_reordering)
-       break;
-
-      /* Reverse the fields, but leave the dummy field in front.
-        Fields are already ordered for Object and Class */
-      if (TYPE_FIELDS (current_class) && current_class != object_type_node
-         && current_class != class_type_node)
-      {
-       /* If the dummy field is there, reverse the right fields and
-          just layout the type for proper fields offset */
-       if (!DECL_NAME (TYPE_FIELDS (current_class)))
-         {
-           tree fields = TYPE_FIELDS (current_class);
-           TREE_CHAIN (fields) = nreverse (TREE_CHAIN (fields));
-           TYPE_SIZE (current_class) = NULL_TREE;
-         }
-       /* We don't have a dummy field, we need to layout the class,
-           after having reversed the fields */
-       else
-         {
-           TYPE_FIELDS (current_class) = 
-             nreverse (TYPE_FIELDS (current_class));
-           TYPE_SIZE (current_class) = NULL_TREE;
-         }
-      }
-    }
-  /* There are cases were gclass_list will be empty. */
-  if (gclass_list)
-    stop_reordering = TREE_TYPE (TREE_VALUE (gclass_list));
-}
-
-/* Layout the methods of all classes loaded in one way or another.
-   Check methods of source parsed classes. Then reorder the
-   fields and layout the classes or the type of all source parsed
-   classes */
-
-void
-java_layout_classes ()
-{
-  tree current;
-  int save_error_count = java_error_count;
-
-  /* Layout the methods of all classes seen so far */
-  java_layout_seen_class_methods ();
-  java_parse_abort_on_error ();
-  all_class_list = NULL_TREE;
-
-  /* Then check the methods of all parsed classes */
-  for (current = gclass_list; current; current = TREE_CHAIN (current))
-    if (CLASS_FROM_SOURCE_P (TREE_TYPE (TREE_VALUE (current))))
-      java_check_methods (TREE_VALUE (current));
-  java_parse_abort_on_error ();
-
-  for (current = gclass_list; current; current = TREE_CHAIN (current))
-    {
-      current_class = TREE_TYPE (TREE_VALUE (current));
-      layout_class (current_class);
-
-      /* Error reported by the caller */
-      if (java_error_count)
-       return;
-    }
-
-  /* We might have reloaded classes durign the process of laying out
-     classes for code generation. We must layout the methods of those
-     late additions, as constructor checks might use them */
-  java_layout_seen_class_methods ();
-  java_parse_abort_on_error ();
-}
-
-/* Expand methods in the current set of classes rememebered for
-   generation.  */
-
-static void
-java_complete_expand_classes ()
-{
-  tree current;
-
-  do_not_fold = flag_emit_xref;
-
-  for (current = ctxp->class_list; current; current = TREE_CHAIN (current))
-    if (!INNER_CLASS_DECL_P (current))
-      java_complete_expand_class (current);
-}
-
-/* Expand the methods found in OUTER, starting first by OUTER's inner
-   classes, if any.  */
-
-static void
-java_complete_expand_class (outer)
-     tree outer;
-{
-  tree inner_list;
-
-  set_nested_class_simple_name_value (outer, 1); /* Set */
-
-  /* We need to go after all inner classes and start expanding them,
-     starting with most nested ones. We have to do that because nested
-     classes might add functions to outer classes */
-
-  for (inner_list = DECL_INNER_CLASS_LIST (outer);
-       inner_list; inner_list = TREE_CHAIN (inner_list))
-    java_complete_expand_class (TREE_PURPOSE (inner_list));
-
-  java_complete_expand_methods (outer);
-  set_nested_class_simple_name_value (outer, 0); /* Reset */
-}
-
-/* Expand methods registered in CLASS_DECL. The general idea is that
-   we expand regular methods first. This allows us get an estimate on
-   how outer context local alias fields are really used so we can add
-   to the constructor just enough code to initialize them properly (it
-   also lets us generate finit$ correctly.) Then we expand the
-   constructors and then <clinit>.  */
-
-static void
-java_complete_expand_methods (class_decl)
-     tree class_decl;
-{
-  tree clinit, decl, first_decl;
-
-  current_class = TREE_TYPE (class_decl);
-
-  /* Initialize a new constant pool */
-  init_outgoing_cpool ();
-
-  /* Pre-expand <clinit> to figure whether we really need it or
-     not. If we do need it, we pre-expand the static fields so they're
-     ready to be used somewhere else. <clinit> will be fully expanded
-     after we processed the constructors. */
-  first_decl = TYPE_METHODS (current_class);
-  clinit = maybe_generate_pre_expand_clinit (current_class);
-
-  /* Then generate finit$ (if we need to) because constructors will
-   try to use it.*/
-  if (TYPE_FINIT_STMT_LIST (current_class))
-    java_complete_expand_method (generate_finit (current_class));
-
-  /* Then generate instinit$ (if we need to) because constructors will
-     try to use it. */
-  if (TYPE_II_STMT_LIST (current_class))
-    java_complete_expand_method (generate_instinit (current_class));
-
-  /* Now do the constructors */
-  for (decl = first_decl ; !java_error_count && decl; decl = TREE_CHAIN (decl))
-    {
-      int no_body;
-
-      if (!DECL_CONSTRUCTOR_P (decl))
-       continue;
-      
-      no_body = !DECL_FUNCTION_BODY (decl);
-      /* Don't generate debug info on line zero when expanding a
-        generated constructor. */
-      if (no_body)
-       restore_line_number_status (1);
-
-      java_complete_expand_method (decl);
-
-      if (no_body)
-       restore_line_number_status (0);
-    }
-
-  /* First, do the ordinary methods. */
-  for (decl = first_decl; decl; decl = TREE_CHAIN (decl))
-    {
-      /* Ctors aren't part of this batch. */
-      if (DECL_CONSTRUCTOR_P (decl) || DECL_CLINIT_P (decl))
-       continue;
-      
-      /* Skip abstract or native methods -- but do handle native
-        methods when generating JNI stubs.  */
-      if (METHOD_ABSTRACT (decl) || (! flag_jni && METHOD_NATIVE (decl)))
-       {
-         DECL_FUNCTION_BODY (decl) = NULL_TREE;
-         continue;
-       }
-
-      if (METHOD_NATIVE (decl))
-       {
-         tree body;
-         current_function_decl = decl;
-         body = build_jni_stub (decl);
-         BLOCK_EXPR_BODY (DECL_FUNCTION_BODY (decl)) = body;
-       }
-
-      java_complete_expand_method (decl);
-    }
-
-  /* If there is indeed a <clinit>, fully expand it now */
-  if (clinit)
-    {
-      /* Prevent the use of `this' inside <clinit> */
-      ctxp->explicit_constructor_p = 1;
-      java_complete_expand_method (clinit);
-      ctxp->explicit_constructor_p = 0;
-    }
-  
-  /* We might have generated a class$ that we now want to expand */
-  if (TYPE_DOT_CLASS (current_class))
-    java_complete_expand_method (TYPE_DOT_CLASS (current_class));
-
-  /* Now verify constructor circularity (stop after the first one we
-     prove wrong.) */
-  if (!CLASS_INTERFACE (class_decl))
-    for (decl = TYPE_METHODS (current_class); decl; decl = TREE_CHAIN (decl))
-      if (DECL_CONSTRUCTOR_P (decl) 
-         && verify_constructor_circularity (decl, decl))
-       break;
-
-  /* Save the constant pool. We'll need to restore it later. */
-  TYPE_CPOOL (current_class) = outgoing_cpool;
-}
-
-/* Attempt to create <clinit>. Pre-expand static fields so they can be
-   safely used in some other methods/constructors.  */
-
-static tree
-maybe_generate_pre_expand_clinit (class_type)
-     tree class_type;
-{
-  tree current, mdecl;
-
-  if (!TYPE_CLINIT_STMT_LIST (class_type))
-    return NULL_TREE;
-
-  /* Go through all static fields and pre expand them */
-  for (current = TYPE_FIELDS (class_type); current; 
-       current = TREE_CHAIN (current))
-    if (FIELD_STATIC (current))
-      build_field_ref (NULL_TREE, class_type, DECL_NAME (current));
-
-  /* Then build the <clinit> method */
-  mdecl = create_artificial_method (class_type, ACC_STATIC, void_type_node,
-                                   clinit_identifier_node, end_params_node);
-  layout_class_method (class_type, CLASSTYPE_SUPER (class_type),
-                      mdecl, NULL_TREE);
-  start_artificial_method_body (mdecl);
-
-  /* We process the list of assignment we produced as the result of
-     the declaration of initialized static field and add them as
-     statement to the <clinit> method. */
-  for (current = TYPE_CLINIT_STMT_LIST (class_type); current;
-       current = TREE_CHAIN (current))
-    {
-      tree stmt = current;
-      /* We build the assignment expression that will initialize the
-        field to its value. There are strict rules on static
-        initializers (8.5). FIXME */
-      if (TREE_CODE (stmt) != BLOCK && stmt != empty_stmt_node)
-       stmt = build_debugable_stmt (EXPR_WFL_LINECOL (stmt), stmt);
-      java_method_add_stmt (mdecl, stmt);
-    }
-
-  end_artificial_method_body (mdecl);
-
-  /* Now we want to place <clinit> as the last method (because we need
-     it at least for interface so that it doesn't interfere with the
-     dispatch table based lookup. */
-  if (TREE_CHAIN (TYPE_METHODS (class_type)))
-    {
-      current = TREE_CHAIN (TYPE_METHODS (class_type));
-      TYPE_METHODS (class_type) = current;
-
-      while (TREE_CHAIN (current))
-       current = TREE_CHAIN (current);
-
-      TREE_CHAIN (current) = mdecl;
-      TREE_CHAIN (mdecl) = NULL_TREE;
-    }
-
-  return mdecl;
-}
-
-/* Analyzes a method body and look for something that isn't a
-   MODIFY_EXPR with a constant value.  */
-
-static int
-analyze_clinit_body (this_class, bbody)
-     tree this_class, bbody;
-{
-  while (bbody)
-    switch (TREE_CODE (bbody))
-      {
-      case BLOCK:
-       bbody = BLOCK_EXPR_BODY (bbody);
-       break;
-       
-      case EXPR_WITH_FILE_LOCATION:
-       bbody = EXPR_WFL_NODE (bbody);
-       break;
-       
-      case COMPOUND_EXPR:
-       if (analyze_clinit_body (this_class, TREE_OPERAND (bbody, 0)))
-         return 1;
-       bbody = TREE_OPERAND (bbody, 1);
-       break;
-       
-      case MODIFY_EXPR:
-       /* If we're generating to class file and we're dealing with an
-          array initialization, we return 1 to keep <clinit> */
-       if (TREE_CODE (TREE_OPERAND (bbody, 1)) == NEW_ARRAY_INIT
-           && flag_emit_class_files)
-         return 1;
-
-       /* There are a few cases where we're required to keep
-          <clinit>:
-          - If this is an assignment whose operand is not constant,
-          - If this is an assignment to a non-initialized field,
-          - If this field is not a member of the current class.
-       */
-       return (! TREE_CONSTANT (TREE_OPERAND (bbody, 1))
-               || ! DECL_INITIAL (TREE_OPERAND (bbody, 0))
-               || DECL_CONTEXT (TREE_OPERAND (bbody, 0)) != this_class);
-
-      default:
-       return 1;
-      }
-  return 0;
-}
-
-
-/* See whether we could get rid of <clinit>. Criteria are: all static
-   final fields have constant initial values and the body of <clinit>
-   is empty. Return 1 if <clinit> was discarded, 0 otherwise. */
-
-static int
-maybe_yank_clinit (mdecl)
-     tree mdecl;
-{
-  tree type, current;
-  tree fbody, bbody;
-  
-  if (!DECL_CLINIT_P (mdecl))
-    return 0;
-
-  /* If the body isn't empty, then we keep <clinit>. Note that if
-     we're emitting classfiles, this isn't enough not to rule it
-     out. */
-  fbody = DECL_FUNCTION_BODY (mdecl);
-  bbody = BLOCK_EXPR_BODY (fbody);
-  if (bbody && bbody != error_mark_node)
-    bbody = BLOCK_EXPR_BODY (bbody);
-  else
-    return 0;
-  if (bbody && ! flag_emit_class_files && bbody != empty_stmt_node)
-    return 0;
-
-  type = DECL_CONTEXT (mdecl);
-  current = TYPE_FIELDS (type);
-
-  for (current = (current ? TREE_CHAIN (current) : current); 
-       current; current = TREE_CHAIN (current))
-    {
-      tree f_init;
-
-      /* We're not interested in non-static fields.  */
-      if (!FIELD_STATIC (current))
-       continue;
-
-      /* Nor in fields without initializers. */
-      f_init = DECL_INITIAL (current);
-      if (f_init == NULL_TREE)
-       continue;
-
-      /* Anything that isn't String or a basic type is ruled out -- or
-        if we know how to deal with it (when doing things natively) we
-        should generated an empty <clinit> so that SUID are computed
-        correctly. */
-      if (! JSTRING_TYPE_P (TREE_TYPE (current))
-         && ! JNUMERIC_TYPE_P (TREE_TYPE (current)))
-       return 0;
-
-      if (! FIELD_FINAL (current) || ! TREE_CONSTANT (f_init))
-       return 0;
-    }
-
-  /* Now we analyze the method body and look for something that
-     isn't a MODIFY_EXPR */
-  if (bbody != empty_stmt_node && analyze_clinit_body (type, bbody))
-    return 0;
-
-  /* Get rid of <clinit> in the class' list of methods */
-  if (TYPE_METHODS (type) == mdecl)
-    TYPE_METHODS (type) = TREE_CHAIN (mdecl);
-  else
-    for (current = TYPE_METHODS (type); current; 
-        current = TREE_CHAIN (current))
-      if (TREE_CHAIN (current) == mdecl)
-       {
-         TREE_CHAIN (current) = TREE_CHAIN (mdecl);
-         break;
-       }
-
-  return 1;
-}
-
-/* Install the argument from MDECL. Suitable to completion and
-   expansion of mdecl's body.  */
-
-static void
-start_complete_expand_method (mdecl)
-     tree mdecl;
-{
-  tree tem;
-
-  pushlevel (1);               /* Prepare for a parameter push */
-  tem = BLOCK_EXPR_DECLS (DECL_FUNCTION_BODY (current_function_decl));
-  DECL_ARGUMENTS (mdecl) = tem;
-
-  for (; tem; tem = TREE_CHAIN (tem))
-    {
-      /* TREE_CHAIN (tem) will change after pushdecl. */ 
-      tree next = TREE_CHAIN (tem);
-      tree type = TREE_TYPE (tem);
-      if (PROMOTE_PROTOTYPES
-         && TYPE_PRECISION (type) < TYPE_PRECISION (integer_type_node)
-         && INTEGRAL_TYPE_P (type))
-       type = integer_type_node;
-      DECL_ARG_TYPE (tem) = type;
-      layout_decl (tem, 0);
-      pushdecl (tem);
-      /* Re-install the next so that the list is kept and the loop
-        advances. */
-      TREE_CHAIN (tem) = next;
-    }
-  pushdecl_force_head (DECL_ARGUMENTS (mdecl));
-  lineno = DECL_SOURCE_LINE_FIRST (mdecl);
-  build_result_decl (mdecl);
-}
-
-
-/* Complete and expand a method.  */
-
-static void
-java_complete_expand_method (mdecl)
-     tree mdecl;
-{
-  tree fbody, block_body, exception_copy;
-
-  current_function_decl = mdecl;
-  /* Fix constructors before expanding them */
-  if (DECL_CONSTRUCTOR_P (mdecl))
-    fix_constructors (mdecl);
-  
-  /* Expand functions that have a body */
-  if (!DECL_FUNCTION_BODY (mdecl))
-    return;
-
-  fbody = DECL_FUNCTION_BODY (mdecl);
-  block_body = BLOCK_EXPR_BODY (fbody);
-  exception_copy = NULL_TREE;
-
-  current_function_decl = mdecl;
-
-  if (! quiet_flag)
-    fprintf (stderr, " [%s.",
-            lang_printable_name (DECL_CONTEXT (mdecl), 0));
-  announce_function (mdecl);
-  if (! quiet_flag)
-    fprintf (stderr, "]");
-  
-  /* Prepare the function for tree completion */
-  start_complete_expand_method (mdecl);
-
-  /* Install the current this */
-  current_this = (!METHOD_STATIC (mdecl) ? 
-                 BLOCK_EXPR_DECLS (DECL_FUNCTION_BODY (mdecl)) : NULL_TREE);
-
-  /* Purge the `throws' list of unchecked exceptions (we save a copy
-     of the list and re-install it later.) */
-  exception_copy = copy_list (DECL_FUNCTION_THROWS (mdecl));
-  purge_unchecked_exceptions (mdecl);
-  
-  /* Install exceptions thrown with `throws' */
-  PUSH_EXCEPTIONS (DECL_FUNCTION_THROWS (mdecl));
-  
-  if (block_body != NULL_TREE)
-    {
-      block_body = java_complete_tree (block_body);
-      
-      /* Before we check initialization, attached all class initialization
-        variable to the block_body */
-      hash_traverse (&DECL_FUNCTION_INIT_TEST_TABLE (mdecl),
-                    attach_init_test_initialization_flags, block_body);
-      
-      if (! flag_emit_xref && ! METHOD_NATIVE (mdecl))
-       {
-         check_for_initialization (block_body, mdecl);
-         
-         /* Go through all the flags marking the initialization of
-            static variables and see whether they're definitively
-            assigned, in which case the type is remembered as
-            definitively initialized in MDECL. */
-         if (STATIC_CLASS_INIT_OPT_P ())
-           {
-             /* Always register the context as properly initialized in
-                MDECL. This used with caution helps removing extra
-                initialization of self. */
-             if (METHOD_STATIC (mdecl))
-               hash_lookup (&DECL_FUNCTION_INITIALIZED_CLASS_TABLE (mdecl),
-                            (hash_table_key) DECL_CONTEXT (mdecl),
-                            TRUE, NULL);
-           }
-       }
-      ctxp->explicit_constructor_p = 0;
-    }
-  
-  BLOCK_EXPR_BODY (fbody) = block_body;
-  
-  /* If we saw a return but couldn't evaluate it properly, we'll have
-     an error_mark_node here. */
-  if (block_body != error_mark_node
-      && (block_body == NULL_TREE || CAN_COMPLETE_NORMALLY (block_body))
-      && TREE_CODE (TREE_TYPE (TREE_TYPE (mdecl))) != VOID_TYPE
-      && !flag_emit_xref)
-    missing_return_error (current_function_decl);
-
-  /* See if we can get rid of <clinit> if MDECL happens to be <clinit> */
-  maybe_yank_clinit (mdecl);
-
-  /* Pop the current level, with special measures if we found errors. */
-  if (java_error_count)
-    pushdecl_force_head (DECL_ARGUMENTS (mdecl));
-  poplevel (1, 0, 1);
-
-  /* Pop the exceptions and sanity check */
-  POP_EXCEPTIONS();
-  if (currently_caught_type_list)
-    abort ();
-
-  /* Restore the copy of the list of exceptions if emitting xrefs. */
-  DECL_FUNCTION_THROWS (mdecl) = exception_copy;
-}
-
-/* For with each class for which there's code to generate. */
-
-static void
-java_expand_method_bodies (class)
-     tree class;
-{
-  tree decl;
-  for (decl = TYPE_METHODS (class); decl; decl = TREE_CHAIN (decl))
-    {
-      if (!DECL_FUNCTION_BODY (decl))
-       continue;
-
-      current_function_decl = decl;
-
-      /* It's time to assign the variable flagging static class
-        initialization based on which classes invoked static methods
-        are definitely initializing. This should be flagged. */
-      if (STATIC_CLASS_INIT_OPT_P ())
-       {
-         tree list = DECL_FUNCTION_STATIC_METHOD_INVOCATION_COMPOUND (decl);
-         for (; list != NULL_TREE;  list = TREE_CHAIN (list))
-           {
-             /* Executed for each statement calling a static function.
-                LIST is a TREE_LIST whose PURPOSE is the called function
-                and VALUE is a compound whose second operand can be patched
-                with static class initialization flag assignments.  */
-
-             tree called_method = TREE_PURPOSE (list);
-             tree compound = TREE_VALUE (list);
-             tree assignment_compound_list
-               = build_tree_list (called_method, NULL);
-
-             /* For each class definitely initialized in
-                CALLED_METHOD, fill ASSIGNMENT_COMPOUND with
-                assignment to the class initialization flag. */
-             hash_traverse (&DECL_FUNCTION_INITIALIZED_CLASS_TABLE (called_method),
-                            emit_test_initialization,
-                            assignment_compound_list);
-
-             if (TREE_VALUE (assignment_compound_list))
-               TREE_OPERAND (compound, 1)
-                 = TREE_VALUE (assignment_compound_list);
-           }
-       }
-
-      /* Prepare the function for RTL expansion */  
-      start_complete_expand_method (decl);
-
-      /* Expand function start, generate initialization flag
-        assignment, and handle synchronized methods. */
-      complete_start_java_method (decl);
-
-      /* Expand the rest of the function body and terminate
-         expansion. */
-      source_end_java_method ();
-    }
-}
-
-\f
-
-/* This section of the code deals with accessing enclosing context
-   fields either directly by using the relevant access to this$<n> or
-   by invoking an access method crafted for that purpose.  */
-
-/* Build the necessary access from an inner class to an outer
-   class. This routine could be optimized to cache previous result
-   (decl, current_class and returned access).  When an access method
-   needs to be generated, it always takes the form of a read. It might
-   be later turned into a write by calling outer_field_access_fix.  */
-
-static tree
-build_outer_field_access (id, decl)
-     tree id, decl;
-{
-  tree access = NULL_TREE;
-  tree ctx = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (current_class)));
-  tree decl_ctx = DECL_CONTEXT (decl);
-
-  /* If the immediate enclosing context of the current class is the
-     field decl's class or inherits from it; build the access as
-     `this$<n>.<field>'. Note that we will break the `private' barrier
-     if we're not emitting bytecodes. */
-  if ((ctx == decl_ctx || inherits_from_p (ctx, decl_ctx))
-      && (!FIELD_PRIVATE (decl) || !flag_emit_class_files ))
-    {
-      tree thisn = build_current_thisn (current_class);
-      access = make_qualified_primary (build_wfl_node (thisn), 
-                                      id, EXPR_WFL_LINECOL (id));
-    }
-  /* Otherwise, generate access methods to outer this and access the
-     field (either using an access method or by direct access.) */
-  else
-    {
-      int lc = EXPR_WFL_LINECOL (id);
-
-      /* Now we chain the required number of calls to the access$0 to
-        get a hold to the enclosing instance we need, and then we
-        build the field access. */
-      access = build_access_to_thisn (current_class, decl_ctx, lc);
-
-      /* If the field is private and we're generating bytecode, then
-         we generate an access method */
-      if (FIELD_PRIVATE (decl) && flag_emit_class_files )
-       {
-         tree name = build_outer_field_access_methods (decl);
-         access = build_outer_field_access_expr (lc, decl_ctx,
-                                                 name, access, NULL_TREE);
-       }
-      /* Otherwise we use `access$(this$<j>). ... access$(this$<i>).<field>'.
-        Once again we break the `private' access rule from a foreign
-        class. */
-      else
-       access = make_qualified_primary (access, id, lc);
-    }
-  return resolve_expression_name (access, NULL);
-}
-
-/* Return a non zero value if NODE describes an outer field inner
-   access.  */
-
-static int
-outer_field_access_p (type, decl)
-    tree type, decl;
-{
-  if (!INNER_CLASS_TYPE_P (type) 
-      || TREE_CODE (decl) != FIELD_DECL
-      || DECL_CONTEXT (decl) == type)
-    return 0;
-  
-  /* If the inner class extends the declaration context of the field
-     we're try to acces, then this isn't an outer field access */
-  if (inherits_from_p (type, DECL_CONTEXT (decl)))
-    return 0;
-
-  for (type = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (type))); ;
-       type = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (type))))
-    {
-      if (type == DECL_CONTEXT (decl))
-       return 1;
-
-      if (!DECL_CONTEXT (TYPE_NAME (type)))
-       {
-         /* Before we give up, see whether the field is inherited from
-            the enclosing context we're considering. */
-         if (inherits_from_p (type, DECL_CONTEXT (decl)))
-           return 1;
-         break;
-       }
-    }
-
-  return 0;
-}
-
-/* Return a non zero value if NODE represents an outer field inner
-   access that was been already expanded. As a side effect, it returns
-   the name of the field being accessed and the argument passed to the
-   access function, suitable for a regeneration of the access method
-   call if necessary. */
-
-static int
-outer_field_expanded_access_p (node, name, arg_type, arg)
-    tree node, *name, *arg_type, *arg;
-{
-  int identified = 0;
-
-  if (TREE_CODE (node) != CALL_EXPR)
-    return 0;
-
-  /* Well, gcj generates slightly different tree nodes when compiling
-     to native or bytecodes. It's the case for function calls. */
-
-  if (flag_emit_class_files 
-      && TREE_CODE (node) == CALL_EXPR
-      && OUTER_FIELD_ACCESS_IDENTIFIER_P (DECL_NAME (TREE_OPERAND (node, 0))))
-    identified = 1;
-  else if (!flag_emit_class_files)
-    {
-      node = TREE_OPERAND (node, 0);
-      
-      if (node && TREE_OPERAND (node, 0)
-         && TREE_CODE (TREE_OPERAND (node, 0)) == ADDR_EXPR)
-       {
-         node = TREE_OPERAND (node, 0);
-         if (TREE_OPERAND (node, 0)
-             && TREE_CODE (TREE_OPERAND (node, 0)) == FUNCTION_DECL
-             && (OUTER_FIELD_ACCESS_IDENTIFIER_P 
-                 (DECL_NAME (TREE_OPERAND (node, 0)))))
-           identified = 1;
-       }
-    }
-
-  if (identified && name && arg_type && arg)
-    {
-      tree argument = TREE_OPERAND (node, 1);
-      *name = DECL_NAME (TREE_OPERAND (node, 0));
-      *arg_type = TREE_TYPE (TREE_TYPE (TREE_VALUE (argument)));
-      *arg = TREE_VALUE (argument);
-    }
-  return identified;
-}
-
-/* Detect in NODE an outer field read access from an inner class and
-   transform it into a write with RHS as an argument. This function is
-   called from the java_complete_lhs when an assignment to a LHS can
-   be identified. */
-
-static tree
-outer_field_access_fix (wfl, node, rhs)
-    tree wfl, node, rhs;
-{
-  tree name, arg_type, arg;
-  
-  if (outer_field_expanded_access_p (node, &name, &arg_type, &arg))
-    {
-      node = build_outer_field_access_expr (EXPR_WFL_LINECOL (wfl), 
-                                           arg_type, name, arg, rhs);
-      return java_complete_tree (node);
-    }
-  return NULL_TREE;
-}
-
-/* Construct the expression that calls an access method:
-     <type>.access$<n>(<arg1> [, <arg2>]); 
-
-   ARG2 can be NULL and will be omitted in that case. It will denote a
-   read access.  */
-
-static tree
-build_outer_field_access_expr (lc, type, access_method_name, arg1, arg2)
-    int lc;
-    tree type, access_method_name, arg1, arg2;
-{
-  tree args, cn, access;
-
-  args = arg1 ? arg1 : 
-    build_wfl_node (build_current_thisn (current_class));
-  args = build_tree_list (NULL_TREE, args);
-
-  if (arg2)
-    args = tree_cons (NULL_TREE, arg2, args);
-
-  access = build_method_invocation (build_wfl_node (access_method_name), args);
-  cn = build_wfl_node (DECL_NAME (TYPE_NAME (type)));
-  return make_qualified_primary (cn, access, lc);
-}
-
-static tree
-build_new_access_id ()
-{
-  static int access_n_counter = 1;
-  char buffer [128];
-
-  sprintf (buffer, "access$%d", access_n_counter++);
-  return get_identifier (buffer);
-}
-
-/* Create the static access functions for the outer field DECL. We define a
-   read:
-     TREE_TYPE (<field>) access$<n> (DECL_CONTEXT (<field>) inst$) {
-       return inst$.field;
-     }
-   and a write access:
-     TREE_TYPE (<field>) access$<n> (DECL_CONTEXT (<field>) inst$,
-                                     TREE_TYPE (<field>) value$) {
-       return inst$.field = value$;
-     }
-   We should have a usage flags on the DECL so we can lazily turn the ones
-   we're using for code generation. FIXME.
-*/
-
-static tree
-build_outer_field_access_methods (decl)
-    tree decl;
-{
-  tree id, args, stmt, mdecl;
-  
-  if (FIELD_INNER_ACCESS_P (decl))
-    return FIELD_INNER_ACCESS (decl);
-
-  MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (decl);
-  /* Create the identifier and a function named after it. */
-  id = build_new_access_id ();
-
-  /* The identifier is marked as bearing the name of a generated write
-     access function for outer field accessed from inner classes. */
-  OUTER_FIELD_ACCESS_IDENTIFIER_P (id) = 1;
-
-  /* Create the read access */
-  args = build_tree_list (inst_id, build_pointer_type (DECL_CONTEXT (decl)));
-  TREE_CHAIN (args) = end_params_node;
-  stmt = make_qualified_primary (build_wfl_node (inst_id),
-                                build_wfl_node (DECL_NAME (decl)), 0);
-  stmt = build_return (0, stmt);
-  mdecl = build_outer_field_access_method (DECL_CONTEXT (decl), 
-                                          TREE_TYPE (decl), id, args, stmt);
-  DECL_FUNCTION_ACCESS_DECL (mdecl) = decl;
-
-  /* Create the write access method. No write access for final variable */
-  if (!FIELD_FINAL (decl))
-    {
-      args = build_tree_list (inst_id, 
-                             build_pointer_type (DECL_CONTEXT (decl)));
-      TREE_CHAIN (args) = build_tree_list (wpv_id, TREE_TYPE (decl));
-      TREE_CHAIN (TREE_CHAIN (args)) = end_params_node;
-      stmt = make_qualified_primary (build_wfl_node (inst_id),
-                                    build_wfl_node (DECL_NAME (decl)), 0);
-      stmt = build_return (0, build_assignment (ASSIGN_TK, 0, stmt,
-                                               build_wfl_node (wpv_id)));
-      mdecl = build_outer_field_access_method (DECL_CONTEXT (decl), 
-                                              TREE_TYPE (decl), id, 
-                                              args, stmt);
-    }
-  DECL_FUNCTION_ACCESS_DECL (mdecl) = decl;
-
-  /* Return the access name */
-  return FIELD_INNER_ACCESS (decl) = id;
-}
-
-/* Build an field access method NAME.  */
-
-static tree 
-build_outer_field_access_method (class, type, name, args, body)
-    tree class, type, name, args, body;
-{
-  tree saved_current_function_decl, mdecl;
-
-  /* Create the method */
-  mdecl = create_artificial_method (class, ACC_STATIC, type, name, args);
-  fix_method_argument_names (args, mdecl);
-  layout_class_method (class, NULL_TREE, mdecl, NULL_TREE);
-
-  /* Attach the method body. */
-  saved_current_function_decl = current_function_decl;
-  start_artificial_method_body (mdecl);
-  java_method_add_stmt (mdecl, body);
-  end_artificial_method_body (mdecl);
-  current_function_decl = saved_current_function_decl;
-
-  return mdecl;
-}
-
-\f
-/* This section deals with building access function necessary for
-   certain kinds of method invocation from inner classes.  */
-
-static tree
-build_outer_method_access_method (decl)
-    tree decl;
-{
-  tree saved_current_function_decl, mdecl;
-  tree args = NULL_TREE, call_args = NULL_TREE;
-  tree carg, id, body, class;
-  char buffer [80];
-  int parm_id_count = 0;
-
-  /* Test this abort with an access to a private field */
-  if (!strcmp (IDENTIFIER_POINTER (DECL_NAME (decl)), "access$"))
-    abort ();
-
-  /* Check the cache first */
-  if (DECL_FUNCTION_INNER_ACCESS (decl))
-    return DECL_FUNCTION_INNER_ACCESS (decl);
-
-  class = DECL_CONTEXT (decl);
-
-  /* Obtain an access identifier and mark it */
-  id = build_new_access_id ();
-  OUTER_FIELD_ACCESS_IDENTIFIER_P (id) = 1;
-
-  carg = TYPE_ARG_TYPES (TREE_TYPE (decl));
-  /* Create the arguments, as much as the original */
-  for (; carg && carg != end_params_node; 
-       carg = TREE_CHAIN (carg))
-    {
-      sprintf (buffer, "write_parm_value$%d", parm_id_count++);
-      args = chainon (args, build_tree_list (get_identifier (buffer), 
-                                            TREE_VALUE (carg)));
-    }
-  args = chainon (args, end_params_node);
-
-  /* Create the method */
-  mdecl = create_artificial_method (class, ACC_STATIC, 
-                                   TREE_TYPE (TREE_TYPE (decl)), id, args);
-  layout_class_method (class, NULL_TREE, mdecl, NULL_TREE);
-  /* There is a potential bug here. We should be able to use
-     fix_method_argument_names, but then arg names get mixed up and
-     eventually a constructor will have its this$0 altered and the
-     outer context won't be assignment properly. The test case is
-     stub.java FIXME */
-  TYPE_ARG_TYPES (TREE_TYPE (mdecl)) = args;
-
-  /* Attach the method body. */
-  saved_current_function_decl = current_function_decl;
-  start_artificial_method_body (mdecl);
-
-  /* The actual method invocation uses the same args. When invoking a
-     static methods that way, we don't want to skip the first
-     argument. */
-  carg = args;
-  if (!METHOD_STATIC (decl))
-    carg = TREE_CHAIN (carg);
-  for (; carg && carg != end_params_node; carg = TREE_CHAIN (carg))
-    call_args = tree_cons (NULL_TREE, build_wfl_node (TREE_PURPOSE (carg)),
-                          call_args);
-
-  body = build_method_invocation (build_wfl_node (DECL_NAME (decl)), 
-                                 call_args);
-  if (!METHOD_STATIC (decl))
-    body = make_qualified_primary (build_wfl_node (TREE_PURPOSE (args)), 
-                                  body, 0);
-  if (TREE_TYPE (TREE_TYPE (decl)) != void_type_node)
-    body = build_return (0, body);
-  java_method_add_stmt (mdecl,body);
-  end_artificial_method_body (mdecl);
-  current_function_decl = saved_current_function_decl;
-
-  /* Back tag the access function so it know what it accesses */
-  DECL_FUNCTION_ACCESS_DECL (decl) = mdecl;
-
-  /* Tag the current method so it knows it has an access generated */
-  return DECL_FUNCTION_INNER_ACCESS (decl) = mdecl;
-}
-
-\f
-/* This section of the code deals with building expressions to access
-   the enclosing instance of an inner class. The enclosing instance is
-   kept in a generated field called this$<n>, with <n> being the
-   inner class nesting level (starting from 0.)  */
-    
-/* Build an access to a given this$<n>, always chaining access call to
-   others. Access methods to this$<n> are build on the fly if
-   necessary. This CAN'T be used to solely access this$<n-1> from
-   this$<n> (which alway yield to special cases and optimization, see
-   for example build_outer_field_access).  */
-
-static tree
-build_access_to_thisn (from, to, lc)
-     tree from, to;
-     int lc;
-{
-  tree access = NULL_TREE;
-
-  while (from != to && PURE_INNER_CLASS_TYPE_P (from))
-    {
-      if (!access)
-        {
-          access = build_current_thisn (from);
-          access = build_wfl_node (access);
-        }
-      else
-       {
-         tree access0_wfl, cn;
-
-         maybe_build_thisn_access_method (from);
-         access0_wfl = build_wfl_node (access0_identifier_node);
-         cn = build_wfl_node (DECL_NAME (TYPE_NAME (from)));
-         EXPR_WFL_LINECOL (access0_wfl) = lc;
-         access = build_tree_list (NULL_TREE, access);
-         access = build_method_invocation (access0_wfl, access);
-         access = make_qualified_primary (cn, access, lc);
-       }
-
-      /* If FROM isn't an inner class, that's fine, we've done enough.
-         What we're looking for can be accessed from there.  */
-      from = DECL_CONTEXT (TYPE_NAME (from));
-      if (!from)
-       break;
-      from = TREE_TYPE (from);
-    }
-  return access;
-}
-
-/* Build an access function to the this$<n> local to TYPE. NULL_TREE
-   is returned if nothing needs to be generated. Otherwise, the method
-   generated and a method decl is returned.  
-
-   NOTE: These generated methods should be declared in a class file
-   attribute so that they can't be referred to directly.  */
-
-static tree
-maybe_build_thisn_access_method (type)
-    tree type;
-{
-  tree mdecl, args, stmt, rtype;
-  tree saved_current_function_decl;
-
-  /* If TYPE is a top-level class, no access method is required.
-     If there already is such an access method, bail out. */
-  if (CLASS_ACCESS0_GENERATED_P (type) || !PURE_INNER_CLASS_TYPE_P (type))
-    return NULL_TREE;
-
-  /* We generate the method. The method looks like:
-     static <outer_of_type> access$0 (<type> inst$) { return inst$.this$<n>; }
-  */
-  args = build_tree_list (inst_id, build_pointer_type (type));
-  TREE_CHAIN (args) = end_params_node;
-  rtype = build_pointer_type (TREE_TYPE (DECL_CONTEXT (TYPE_NAME (type))));
-  mdecl = create_artificial_method (type, ACC_STATIC, rtype,
-                                   access0_identifier_node, args);
-  fix_method_argument_names (args, mdecl);
-  layout_class_method (type, NULL_TREE, mdecl, NULL_TREE);
-  stmt = build_current_thisn (type);
-  stmt = make_qualified_primary (build_wfl_node (inst_id), 
-                                build_wfl_node (stmt), 0);
-  stmt = build_return (0, stmt);
-
-  saved_current_function_decl = current_function_decl;
-  start_artificial_method_body (mdecl);
-  java_method_add_stmt (mdecl, stmt);
-  end_artificial_method_body (mdecl);
-  current_function_decl = saved_current_function_decl;
-
-  CLASS_ACCESS0_GENERATED_P (type) = 1;
-
-  return mdecl;
-}
-
-/* Craft an correctly numbered `this$<n>'string. this$0 is used for
-   the first level of innerclassing. this$1 for the next one, etc...
-   This function can be invoked with TYPE to NULL, available and then
-   has to count the parser context.  */
-
-static tree
-build_current_thisn (type)
-    tree type;
-{
-  static int saved_i = -1;
-  static tree saved_thisn = NULL_TREE;
-  static tree saved_type = NULL_TREE;
-  static int saved_type_i = 0;
-  static int initialized_p;
-  tree decl;
-  char buffer [24];
-  int i = 0;
-
-  /* Register SAVED_THISN and SAVED_TYPE with the garbage collector.  */
-  if (!initialized_p)
-    {
-      ggc_add_tree_root (&saved_thisn, 1);
-      ggc_add_tree_root (&saved_type, 1);
-      initialized_p = 1;
-    }
-
-  if (type)
-    {
-      if (type == saved_type)
-       i = saved_type_i;
-      else
-       {
-         for (i = -1, decl = DECL_CONTEXT (TYPE_NAME (type)); 
-              decl; decl = DECL_CONTEXT (decl), i++)
-           ;
-      
-         saved_type = type;
-         saved_type_i = i;
-       }
-    }
-  else
-    i = list_length (GET_CPC_LIST ())-2;
-
-  if (i == saved_i)
-    return saved_thisn;
-    
-  sprintf (buffer, "this$%d", i);
-  saved_i = i;
-  saved_thisn = get_identifier (buffer);
-  return saved_thisn;
-}
-
-/* Return the assignement to the hidden enclosing context `this$<n>'
-   by the second incoming parameter to the innerclass constructor. The
-   form used is `this.this$<n> = this$<n>;'.  */
-
-static tree
-build_thisn_assign ()
-{
-  if (current_class && PURE_INNER_CLASS_TYPE_P (current_class))
-    {
-      tree thisn = build_current_thisn (current_class);
-      tree lhs = make_qualified_primary (build_wfl_node (this_identifier_node),
-                                        build_wfl_node (thisn), 0);
-      tree rhs = build_wfl_node (thisn);
-      EXPR_WFL_SET_LINECOL (lhs, lineno, 0);
-      return build_assignment (ASSIGN_TK, EXPR_WFL_LINECOL (lhs), lhs, rhs);
-    }
-  return NULL_TREE;
-}
-
-\f
-/* Building the synthetic `class$' used to implement the `.class' 1.1
-   extension for non primitive types. This method looks like:
-
-    static Class class$(String type) throws NoClassDefFoundError
-    {
-      try {return (java.lang.Class.forName (String));}
-      catch (ClassNotFoundException e) {
-        throw new NoClassDefFoundError(e.getMessage());}
-    } */
-
-static tree
-build_dot_class_method (class)
-     tree class;
-{
-#define BWF(S) build_wfl_node (get_identifier ((S)))
-#define MQN(X,Y) make_qualified_name ((X), (Y), 0)
-  tree args, tmp, saved_current_function_decl, mdecl;
-  tree stmt, throw_stmt;
-
-  static tree get_message_wfl, type_parm_wfl;
-
-  if (!get_message_wfl)
-    {
-      get_message_wfl = build_wfl_node (get_identifier ("getMessage"));
-      type_parm_wfl = build_wfl_node (get_identifier ("type$"));
-      ggc_add_tree_root (&get_message_wfl, 1);
-      ggc_add_tree_root (&type_parm_wfl, 1);
-    }
-
-  /* Build the arguments */
-  args = build_tree_list (get_identifier ("type$"),
-                         build_pointer_type (string_type_node));
-  TREE_CHAIN (args) = end_params_node;
-
-  /* Build the qualified name java.lang.Class.forName */
-  tmp = MQN (MQN (MQN (BWF ("java"), 
-                      BWF ("lang")), BWF ("Class")), BWF ("forName"));
-  load_class (class_not_found_type_node, 1);
-  load_class (no_class_def_found_type_node, 1);
-  
-  /* Create the "class$" function */
-  mdecl = create_artificial_method (class, ACC_STATIC, 
-                                   build_pointer_type (class_type_node),
-                                   classdollar_identifier_node, args);
-  DECL_FUNCTION_THROWS (mdecl) = 
-    build_tree_list (NULL_TREE, no_class_def_found_type_node);
-
-  /* We start by building the try block. We need to build:
-       return (java.lang.Class.forName (type)); */
-  stmt = build_method_invocation (tmp, 
-                                 build_tree_list (NULL_TREE, type_parm_wfl));
-  stmt = build_return (0, stmt);
-
-  /* Now onto the catch block. We start by building the expression
-     throwing a new exception: throw new NoClassDefFoundError (_.getMessage) */
-  throw_stmt = make_qualified_name (build_wfl_node (wpv_id), 
-                                   get_message_wfl, 0);
-  throw_stmt = build_method_invocation (throw_stmt, NULL_TREE);
-  
-  /* Build new NoClassDefFoundError (_.getMessage) */
-  throw_stmt = build_new_invocation 
-    (build_wfl_node (get_identifier ("NoClassDefFoundError")),
-     build_tree_list (build_pointer_type (string_type_node), throw_stmt));
-
-  /* Build the throw, (it's too early to use BUILD_THROW) */
-  throw_stmt = build1 (THROW_EXPR, NULL_TREE, throw_stmt);
-
-  /* Encapsulate STMT in a try block. The catch clause executes THROW_STMT */
-  stmt = encapsulate_with_try_catch (0, class_not_found_type_node,
-                                    stmt, throw_stmt);
-
-  fix_method_argument_names (args, mdecl);
-  layout_class_method (class, NULL_TREE, mdecl, NULL_TREE);
-  saved_current_function_decl = current_function_decl;
-  start_artificial_method_body (mdecl);
-  java_method_add_stmt (mdecl, stmt);
-  end_artificial_method_body (mdecl);
-  current_function_decl = saved_current_function_decl;
-  TYPE_DOT_CLASS (class) = mdecl;
-
-  return mdecl;
-}
-
-static tree
-build_dot_class_method_invocation (type)
-     tree type;
-{
-  tree sig_id, s;
-
-  if (TYPE_ARRAY_P (type))
-    sig_id = build_java_signature (type);
-  else
-    sig_id = DECL_NAME (TYPE_NAME (type));
-
-  /* Ensure that the proper name separator is used */
-  sig_id = unmangle_classname (IDENTIFIER_POINTER (sig_id),
-                              IDENTIFIER_LENGTH (sig_id));
-
-  s = build_string (IDENTIFIER_LENGTH (sig_id), 
-                   IDENTIFIER_POINTER (sig_id));
-  return build_method_invocation (build_wfl_node (classdollar_identifier_node),
-                                 build_tree_list (NULL_TREE, s));
-}
-
-/* This section of the code deals with constructor.  */
-
-/* Craft a body for default constructor. Patch existing constructor
-   bodies with call to super() and field initialization statements if
-   necessary.  */
-
-static void
-fix_constructors (mdecl)
-     tree mdecl;
-{
-  tree iii;                    /* Instance Initializer Invocation */
-  tree body = DECL_FUNCTION_BODY (mdecl);
-  tree thisn_assign, compound = NULL_TREE;
-  tree class_type = DECL_CONTEXT (mdecl);
-
-  if (DECL_FIXED_CONSTRUCTOR_P (mdecl))
-    return;
-  DECL_FIXED_CONSTRUCTOR_P (mdecl) = 1;
-
-  if (!body)
-    {
-      /* It is an error for the compiler to generate a default
-        constructor if the superclass doesn't have a constructor that
-        takes no argument, or the same args for an anonymous class */
-      if (verify_constructor_super (mdecl))
-       {
-         tree sclass_decl = TYPE_NAME (CLASSTYPE_SUPER (class_type));
-         tree save = DECL_NAME (mdecl);
-         const char *n = IDENTIFIER_POINTER (DECL_NAME (sclass_decl));
-         DECL_NAME (mdecl) = DECL_NAME (sclass_decl);
-         parse_error_context
-           (lookup_cl (TYPE_NAME (class_type)), 
-            "No constructor matching `%s' found in class `%s'",
-            lang_printable_name (mdecl, 0), n);
-         DECL_NAME (mdecl) = save;
-       }
-      
-      /* The constructor body must be crafted by hand. It's the
-        constructor we defined when we realize we didn't have the
-        CLASSNAME() constructor */
-      start_artificial_method_body (mdecl);
-      
-      /* Insert an assignment to the this$<n> hidden field, if
-         necessary */
-      if ((thisn_assign = build_thisn_assign ()))
-       java_method_add_stmt (mdecl, thisn_assign);
-
-      /* We don't generate a super constructor invocation if we're
-        compiling java.lang.Object. build_super_invocation takes care
-        of that. */
-      java_method_add_stmt (mdecl, build_super_invocation (mdecl));
-
-      /* FIXME */
-      if ((iii = build_instinit_invocation (class_type)))
-       java_method_add_stmt (mdecl, iii);
-
-      end_artificial_method_body (mdecl);
-    }
-  /* Search for an explicit constructor invocation */
-  else 
-    {
-      int found = 0;
-      int invokes_this = 0;
-      tree found_call = NULL_TREE;
-      tree main_block = BLOCK_EXPR_BODY (body);
-      
-      while (body)
-       switch (TREE_CODE (body))
-         {
-         case CALL_EXPR:
-           found = CALL_EXPLICIT_CONSTRUCTOR_P (body);
-           if (CALL_THIS_CONSTRUCTOR_P (body))
-             invokes_this = 1;
-           body = NULL_TREE;
-           break;
-         case COMPOUND_EXPR:
-         case EXPR_WITH_FILE_LOCATION:
-           found_call = body;
-           body = TREE_OPERAND (body, 0);
-           break;
-         case BLOCK:
-           found_call = body;
-           body = BLOCK_EXPR_BODY (body);
-           break;
-         default:
-           found = 0;
-           body = NULL_TREE;
-         }
-
-      /* Generate the assignment to this$<n>, if necessary */
-      if ((thisn_assign = build_thisn_assign ()))
-        compound = add_stmt_to_compound (compound, NULL_TREE, thisn_assign);
-
-      /* The constructor is missing an invocation of super() */
-      if (!found)
-       compound = add_stmt_to_compound (compound, NULL_TREE,
-                                         build_super_invocation (mdecl));
-      /* Explicit super() invokation should take place before the
-         instance initializer blocks. */
-      else
-       {
-         compound = add_stmt_to_compound (compound, NULL_TREE,
-                                          TREE_OPERAND (found_call, 0));
-         TREE_OPERAND (found_call, 0) = empty_stmt_node;
-       }
-      
-      DECL_INIT_CALLS_THIS (mdecl) = invokes_this;
-
-      /* Insert the instance initializer block right after. */
-      if (!invokes_this && (iii = build_instinit_invocation (class_type)))
-       compound = add_stmt_to_compound (compound, NULL_TREE, iii);
-
-      /* Fix the constructor main block if we're adding extra stmts */
-      if (compound)
-       {
-         compound = add_stmt_to_compound (compound, NULL_TREE,
-                                          BLOCK_EXPR_BODY (main_block));
-         BLOCK_EXPR_BODY (main_block) = compound;
-       }
-    }
-}
-
-/* Browse constructors in the super class, searching for a constructor
-   that doesn't take any argument. Return 0 if one is found, 1
-   otherwise.  If the current class is an anonymous inner class, look
-   for something that has the same signature. */
-
-static int
-verify_constructor_super (mdecl)
-     tree mdecl;
-{
-  tree class = CLASSTYPE_SUPER (current_class);
-  int super_inner = PURE_INNER_CLASS_TYPE_P (class);
-  tree sdecl;
-
-  if (!class)
-    return 0;
-
-  if (ANONYMOUS_CLASS_P (current_class))
-    {
-      tree mdecl_arg_type;
-      SKIP_THIS_AND_ARTIFICIAL_PARMS (mdecl_arg_type, mdecl);
-      for (sdecl = TYPE_METHODS (class); sdecl; sdecl = TREE_CHAIN (sdecl))
-       if (DECL_CONSTRUCTOR_P (sdecl))
-         {
-           tree m_arg_type;
-           tree arg_type = TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (sdecl)));
-           if (super_inner)
-             arg_type = TREE_CHAIN (arg_type);
-           for (m_arg_type = mdecl_arg_type; 
-                (arg_type != end_params_node 
-                 && m_arg_type != end_params_node);
-                arg_type = TREE_CHAIN (arg_type), 
-                  m_arg_type = TREE_CHAIN (m_arg_type))
-             if (!valid_method_invocation_conversion_p 
-                    (TREE_VALUE (arg_type),
-                     TREE_VALUE (m_arg_type)))
-               break;
-
-           if (arg_type == end_params_node && m_arg_type == end_params_node)
-             return 0;
-         }
-    }
-  else
-    {
-      for (sdecl = TYPE_METHODS (class); sdecl; sdecl = TREE_CHAIN (sdecl))
-       {
-         tree arg = TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (sdecl)));
-         if (super_inner)
-           arg = TREE_CHAIN (arg);
-         if (DECL_CONSTRUCTOR_P (sdecl) && arg == end_params_node)
-           return 0;
-       }
-    }
-  return 1;
-}
-
-/* Generate code for all context remembered for code generation.  */
-
-void
-java_expand_classes ()
-{
-  int save_error_count = 0;
-  static struct parser_ctxt *cur_ctxp = NULL;
-
-  java_parse_abort_on_error ();
-  if (!(ctxp = ctxp_for_generation))
-    return;
-  java_layout_classes ();
-  java_parse_abort_on_error ();
-
-  for (cur_ctxp = ctxp_for_generation; cur_ctxp; cur_ctxp = cur_ctxp->next)
-    {
-      ctxp = cur_ctxp;
-      input_filename = ctxp->filename;
-      lang_init_source (2);           /* Error msgs have method prototypes */
-      java_complete_expand_classes (); /* Complete and expand classes */
-      java_parse_abort_on_error ();
-    }
-  input_filename = main_input_filename;
-
-
-  /* Find anonymous classes and expand their constructor. This extra pass is
-     neccessary because the constructor itself is only generated when the
-     method in which it is defined is expanded. */
-  for (cur_ctxp = ctxp_for_generation; cur_ctxp; cur_ctxp = cur_ctxp->next)
-    {
-      tree current;
-      ctxp = cur_ctxp;
-      for (current = ctxp->class_list; current; current = TREE_CHAIN (current))
-       {
-         current_class = TREE_TYPE (current);
-         if (ANONYMOUS_CLASS_P (current_class))
-           {
-             tree d;
-             for (d = TYPE_METHODS (current_class); d; d = TREE_CHAIN (d))
-               {
-                 if (DECL_CONSTRUCTOR_P (d))
-                   {
-                     restore_line_number_status (1);
-                     java_complete_expand_method (d);
-                     restore_line_number_status (0);
-                     break;    /* There is only one constructor. */
-                   }
-               }
-           }
-       }
-    }
-
-  /* If we've found error at that stage, don't try to generate
-     anything, unless we're emitting xrefs or checking the syntax only
-     (but not using -fsyntax-only for the purpose of generating
-     bytecode. */
-  if (java_error_count && !flag_emit_xref 
-      && (!flag_syntax_only && !flag_emit_class_files))
-    return;
-
-  /* Now things are stable, go for generation of the class data. */
-
-  /* We pessimistically marked all fields external until we knew
-     what set of classes we were planning to compile.  Now mark
-     those that will be generated locally as not external.  */
-  for (cur_ctxp = ctxp_for_generation; cur_ctxp; cur_ctxp = cur_ctxp->next)
-    {
-      tree current;
-      ctxp = cur_ctxp;
-      for (current = ctxp->class_list; current; current = TREE_CHAIN (current))
-       {
-         tree class = TREE_TYPE (current);
-         tree field;
-         for (field = TYPE_FIELDS (class); field ; field = TREE_CHAIN (field))
-           if (FIELD_STATIC (field))
-             DECL_EXTERNAL (field) = 0;
-       }
-    }
-
-  /* Compile the classes.  */
-  for (cur_ctxp = ctxp_for_generation; cur_ctxp; cur_ctxp = cur_ctxp->next)
-    {
-      tree current;
-      tree reversed_class_list = NULL;
-
-      ctxp = cur_ctxp;
-
-      /* We write out the classes in reverse order.  This ensures that
-        inner classes are written before their containing classes,
-        which is important for parallel builds.  Otherwise, the
-        class file for the outer class may be found, but the class
-        file for the inner class may not be present.  In that
-        situation, the compiler cannot fall back to the original
-        source, having already read the outer class, so we must
-        prevent that situation.  */
-      for (current = ctxp->class_list; 
-          current; 
-          current = TREE_CHAIN (current))
-       reversed_class_list
-         = tree_cons (NULL_TREE, current, reversed_class_list);
-      ggc_add_tree_root (&reversed_class_list, 1);
-
-      for (current = reversed_class_list; 
-          current; 
-          current = TREE_CHAIN (current))
-       {
-         current_class = TREE_TYPE (TREE_VALUE (current));
-         outgoing_cpool = TYPE_CPOOL (current_class);
-         if (flag_emit_class_files)
-           write_classfile (current_class);
-         if (flag_emit_xref)
-           expand_xref (current_class);
-         else if (! flag_syntax_only)
-           {
-             java_expand_method_bodies (current_class);
-             finish_class ();
-           }
-       }
-
-      ggc_del_root (&reversed_class_list);
-    }
-}
-
-/* Wrap non WFL PRIMARY around a WFL and set EXPR_WFL_QUALIFICATION to
-   a tree list node containing RIGHT. Fore coming RIGHTs will be
-   chained to this hook. LOCATION contains the location of the
-   separating `.' operator.  */
-
-static tree
-make_qualified_primary (primary, right, location)
-     tree primary, right;
-     int location;
-{
-  tree wfl;
-
-  if (TREE_CODE (primary) != EXPR_WITH_FILE_LOCATION)
-    wfl = build_wfl_wrap (primary, location);
-  else
-    {
-      wfl = primary;
-      /* If wfl wasn't qualified, we build a first anchor */
-      if (!EXPR_WFL_QUALIFICATION (wfl))
-       EXPR_WFL_QUALIFICATION (wfl) = build_tree_list (wfl, NULL_TREE);
-    }
-
-  /* And chain them */
-  EXPR_WFL_LINECOL (right) = location;
-  chainon (EXPR_WFL_QUALIFICATION (wfl), build_tree_list (right, NULL_TREE));
-  PRIMARY_P (wfl) =  1;
-  return wfl;
-}
-
-/* Simple merge of two name separated by a `.' */
-
-static tree
-merge_qualified_name (left, right)
-     tree left, right;
-{
-  tree node;
-  if (!left && !right)
-    return NULL_TREE;
-
-  if (!left)
-    return right;
-
-  if (!right)
-    return left;
-
-  obstack_grow (&temporary_obstack, IDENTIFIER_POINTER (left),
-               IDENTIFIER_LENGTH (left));
-  obstack_1grow (&temporary_obstack, '.');
-  obstack_grow0 (&temporary_obstack, IDENTIFIER_POINTER (right),
-                IDENTIFIER_LENGTH (right));
-  node =  get_identifier (obstack_base (&temporary_obstack));
-  obstack_free (&temporary_obstack, obstack_base (&temporary_obstack));
-  QUALIFIED_P (node) = 1;
-  return node;
-}
-
-/* Merge the two parts of a qualified name into LEFT.  Set the
-   location information of the resulting node to LOCATION, usually
-   inherited from the location information of the `.' operator. */
-
-static tree
-make_qualified_name (left, right, location)
-     tree left, right;
-     int location;
-{
-#ifdef USE_COMPONENT_REF
-  tree node = build (COMPONENT_REF, NULL_TREE, left, right);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-#else
-  tree left_id = EXPR_WFL_NODE (left);
-  tree right_id = EXPR_WFL_NODE (right);
-  tree wfl, merge;
-
-  merge = merge_qualified_name (left_id, right_id);
-
-  /* Left wasn't qualified and is now qualified */
-  if (!QUALIFIED_P (left_id))
-    {
-      tree wfl = build_expr_wfl (left_id, ctxp->filename, 0, 0);
-      EXPR_WFL_LINECOL (wfl) = EXPR_WFL_LINECOL (left);
-      EXPR_WFL_QUALIFICATION (left) = build_tree_list (wfl, NULL_TREE);
-    }
-  
-  wfl = build_expr_wfl (right_id, ctxp->filename, 0, 0);
-  EXPR_WFL_LINECOL (wfl) = location;
-  chainon (EXPR_WFL_QUALIFICATION (left), build_tree_list (wfl, NULL_TREE));
-
-  EXPR_WFL_NODE (left) = merge;
-  return left;
-#endif
-}
-
-/* Extract the last identifier component of the qualified in WFL. The
-   last identifier is removed from the linked list */
-
-static tree
-cut_identifier_in_qualified (wfl)
-     tree wfl;
-{
-  tree q;
-  tree previous = NULL_TREE;
-  for (q = EXPR_WFL_QUALIFICATION (wfl); ; previous = q, q = TREE_CHAIN (q))
-    if (!TREE_CHAIN (q))
-      {
-       if (!previous)
-         /* Operating on a non qualified qualified WFL.  */
-         abort ();
-
-       TREE_CHAIN (previous) = NULL_TREE;
-       return TREE_PURPOSE (q);
-      }
-}
-
-/* Resolve the expression name NAME. Return its decl.  */
-
-static tree
-resolve_expression_name (id, orig)
-     tree id;
-     tree *orig;
-{
-  tree name = EXPR_WFL_NODE (id);
-  tree decl;
-
-  /* 6.5.5.1: Simple expression names */
-  if (!PRIMARY_P (id) && !QUALIFIED_P (name))
-    {
-      /* 15.13.1: NAME can appear within the scope of a local variable
-         declaration */
-      if ((decl = IDENTIFIER_LOCAL_VALUE (name)))
-        return decl;
-
-      /* 15.13.1: NAME can appear within a class declaration */
-      else 
-        {
-         decl = lookup_field_wrapper (current_class, name);
-         if (decl)
-           {
-             tree access = NULL_TREE;
-             int fs = FIELD_STATIC (decl);
-
-             /* If we're accessing an outer scope local alias, make
-                sure we change the name of the field we're going to
-                build access to. */
-             if (FIELD_LOCAL_ALIAS_USED (decl))
-               name = DECL_NAME (decl);
-
-             /* Instance variable (8.3.1.1) can't appear within
-                static method, static initializer or initializer for
-                a static variable. */
-             if (!fs && METHOD_STATIC (current_function_decl))
-               {
-                 static_ref_err (id, name, current_class);
-                 return error_mark_node;
-               }
-             /* Instance variables can't appear as an argument of
-                an explicit constructor invocation */
-             if (!fs && ctxp->explicit_constructor_p
-                 && !enclosing_context_p (DECL_CONTEXT (decl), current_class))
-               {
-                 parse_error_context
-                   (id, "Can't reference `%s' before the superclass constructor has been called", IDENTIFIER_POINTER (name));
-                 return error_mark_node;
-               }
-
-             /* If we're processing an inner class and we're trying
-                to access a field belonging to an outer class, build
-                the access to the field */
-             if (!fs && outer_field_access_p (current_class, decl))
-               {
-                 if (CLASS_STATIC (TYPE_NAME (current_class)))
-                   {
-                     static_ref_err (id, DECL_NAME (decl), current_class);
-                     return error_mark_node;
-                   }
-                 access = build_outer_field_access (id, decl);
-                 if (orig)
-                   *orig = access;
-                 return access;
-               }
-
-             /* Otherwise build what it takes to access the field */
-             access = build_field_ref ((fs ? NULL_TREE : current_this),
-                                       DECL_CONTEXT (decl), name);
-             if (fs)
-               access = maybe_build_class_init_for_field (decl, access);
-             /* We may be asked to save the real field access node */
-             if (orig)
-               *orig = access;
-             /* And we return what we got */
-             return access;
-           }
-         /* Fall down to error report on undefined variable */
-       }
-    }
-  /* 6.5.5.2 Qualified Expression Names */
-  else
-    {
-      if (orig)
-       *orig = NULL_TREE;
-      qualify_ambiguous_name (id);
-      /* 15.10.1 Field Access Using a Primary and/or Expression Name */
-      /* 15.10.2: Accessing Superclass Members using super */
-      return resolve_field_access (id, orig, NULL);
-    }
-
-  /* We've got an error here */
-  if (INNER_CLASS_TYPE_P (current_class))
-    parse_error_context (id, 
-                        "Local variable `%s' can't be accessed from within the inner class `%s' unless it is declared final",
-                        IDENTIFIER_POINTER (name),
-                        IDENTIFIER_POINTER (DECL_NAME
-                                            (TYPE_NAME (current_class))));
-  else
-    parse_error_context (id, "Undefined variable `%s'", 
-                        IDENTIFIER_POINTER (name));
-
-  return error_mark_node;
-}
-
-static void
-static_ref_err (wfl, field_id, class_type)
-    tree wfl, field_id, class_type;
-{
-  parse_error_context 
-    (wfl, 
-     "Can't make a static reference to nonstatic variable `%s' in class `%s'",
-     IDENTIFIER_POINTER (field_id), 
-     IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (class_type))));
-}
-
-/* 15.10.1 Field Access Using a Primary and/or Expression Name.
-   We return something suitable to generate the field access. We also
-   return the field decl in FIELD_DECL and its type in FIELD_TYPE.  If
-   recipient's address can be null. */
-
-static tree
-resolve_field_access (qual_wfl, field_decl, field_type)
-     tree qual_wfl;
-     tree *field_decl, *field_type;
-{
-  int is_static = 0;
-  tree field_ref;
-  tree decl, where_found, type_found;
-
-  if (resolve_qualified_expression_name (qual_wfl, &decl,
-                                        &where_found, &type_found))
-    return error_mark_node;
-
-  /* Resolve the LENGTH field of an array here */
-  if (DECL_P (decl) && DECL_NAME (decl) == length_identifier_node 
-      && type_found && TYPE_ARRAY_P (type_found) 
-      && ! flag_emit_class_files && ! flag_emit_xref)
-    {
-      tree length = build_java_array_length_access (where_found);
-      field_ref = length;
-
-      /* In case we're dealing with a static array, we need to
-        initialize its class before the array length can be fetched.
-        It's also a good time to create a DECL_RTL for the field if
-        none already exists, otherwise if the field was declared in a
-        class found in an external file and hasn't been (and won't
-        be) accessed for its value, none will be created. */
-      if (TREE_CODE (where_found) == VAR_DECL && FIELD_STATIC (where_found))
-       {
-         build_static_field_ref (where_found);
-         field_ref = build_class_init (DECL_CONTEXT (where_found), field_ref);
-       }
-    }
-  /* We might have been trying to resolve field.method(). In which
-     case, the resolution is over and decl is the answer */
-  else if (JDECL_P (decl) && IDENTIFIER_LOCAL_VALUE (DECL_NAME (decl)) == decl)
-    field_ref = decl;
-  else if (JDECL_P (decl))
-    {
-      if (!type_found)
-       type_found = DECL_CONTEXT (decl);
-      is_static = FIELD_STATIC (decl);
-      field_ref = build_field_ref ((is_static && !flag_emit_xref? 
-                                   NULL_TREE : where_found), 
-                                  type_found, DECL_NAME (decl));
-      if (field_ref == error_mark_node)
-       return error_mark_node;
-      if (is_static)
-       field_ref = maybe_build_class_init_for_field (decl, field_ref);
-    }
-  else
-    field_ref = decl;
-
-  if (field_decl)
-    *field_decl = decl;
-  if (field_type)
-    *field_type = (QUAL_DECL_TYPE (decl) ? 
-                  QUAL_DECL_TYPE (decl) : TREE_TYPE (decl));
-  return field_ref;
-}
-
-/* If NODE is an access to f static field, strip out the class
-   initialization part and return the field decl, otherwise, return
-   NODE. */
-
-static tree
-strip_out_static_field_access_decl (node)
-    tree node;
-{
-  if (TREE_CODE (node) == COMPOUND_EXPR)
-    {
-      tree op1 = TREE_OPERAND (node, 1);
-      if (TREE_CODE (op1) == COMPOUND_EXPR)
-        {
-          tree call = TREE_OPERAND (op1, 0);
-          if (TREE_CODE (call) == CALL_EXPR
-              && TREE_CODE (TREE_OPERAND (call, 0)) == ADDR_EXPR
-              && TREE_OPERAND (TREE_OPERAND (call, 0), 0)
-              == soft_initclass_node)
-            return TREE_OPERAND (op1, 1);
-        }
-      else if (JDECL_P (op1))
-       return op1;
-    }
-  return node;
-}
-
-/* 6.5.5.2: Qualified Expression Names */
-
-static int
-resolve_qualified_expression_name (wfl, found_decl, where_found, type_found)
-     tree wfl;
-     tree *found_decl, *type_found, *where_found;
-{
-  int from_type = 0;           /* Field search initiated from a type */
-  int from_super = 0, from_cast = 0, from_qualified_this = 0;
-  int previous_call_static = 0;
-  int is_static;
-  tree decl = NULL_TREE, type = NULL_TREE, q;
-  /* For certain for of inner class instantiation */
-  tree saved_current, saved_this;              
-#define RESTORE_THIS_AND_CURRENT_CLASS                                 \
-  { current_class = saved_current; current_this = saved_this;}
-
-  *type_found = *where_found = NULL_TREE;
-
-  for (q = EXPR_WFL_QUALIFICATION (wfl); q; q = TREE_CHAIN (q))
-    {
-      tree qual_wfl = QUAL_WFL (q);
-      tree ret_decl;           /* for EH checking */
-      int location;            /* for EH checking */
-
-      /* 15.10.1 Field Access Using a Primary */
-      switch (TREE_CODE (qual_wfl))
-       {
-       case CALL_EXPR:
-       case NEW_CLASS_EXPR:
-         /* If the access to the function call is a non static field,
-            build the code to access it. */
-         if (JDECL_P (decl) && !FIELD_STATIC (decl))
-           {
-             decl = maybe_access_field (decl, *where_found, 
-                                        DECL_CONTEXT (decl));
-             if (decl == error_mark_node)
-               return 1;
-           }
-
-         /* And code for the function call */
-         if (complete_function_arguments (qual_wfl))
-           return 1;
-
-         /* We might have to setup a new current class and a new this
-            for the search of an inner class, relative to the type of
-            a expression resolved as `decl'. The current values are
-            saved and restored shortly after */
-         saved_current = current_class;
-         saved_this = current_this;
-         if (decl 
-             && (TREE_CODE (qual_wfl) == NEW_CLASS_EXPR
-                 || from_qualified_this))
-           {
-             /* If we still have `from_qualified_this', we have the form
-                <T>.this.f() and we need to build <T>.this */
-             if (from_qualified_this)
-               {
-                 decl = build_access_to_thisn (current_class, type, 0);
-                 decl = java_complete_tree (decl);
-                 type = TREE_TYPE (TREE_TYPE (decl));
-               }
-             current_class = type;
-             current_this = decl;
-             from_qualified_this = 0;
-           }
-
-         if (from_super && TREE_CODE (qual_wfl) == CALL_EXPR)
-           CALL_USING_SUPER (qual_wfl) = 1;
-         location = (TREE_CODE (qual_wfl) == CALL_EXPR ?
-                     EXPR_WFL_LINECOL (TREE_OPERAND (qual_wfl, 0)) : 0);
-         *where_found = patch_method_invocation (qual_wfl, decl, type,
-                                                 from_super,
-                                                 &is_static, &ret_decl);
-         from_super = 0;
-         if (*where_found == error_mark_node)
-           {
-             RESTORE_THIS_AND_CURRENT_CLASS;
-             return 1;
-           }
-         *type_found = type = QUAL_DECL_TYPE (*where_found);
-
-         /* If we're creating an inner class instance, check for that
-            an enclosing instance is in scope */
-         if (TREE_CODE (qual_wfl) == NEW_CLASS_EXPR
-             && INNER_ENCLOSING_SCOPE_CHECK (type))
-           {
-             parse_error_context 
-               (qual_wfl, "No enclosing instance for inner class `%s' is in scope%s",
-                lang_printable_name (type, 0),
-                (!current_this ? "" :
-                 "; an explicit one must be provided when creating this inner class"));
-             RESTORE_THIS_AND_CURRENT_CLASS;
-             return 1;
-           }
-
-         /* In case we had to change then to resolve a inner class
-            instantiation using a primary qualified by a `new' */
-         RESTORE_THIS_AND_CURRENT_CLASS;
-
-         /* EH check. No check on access$<n> functions */
-         if (location 
-             && !OUTER_FIELD_ACCESS_IDENTIFIER_P 
-                   (DECL_NAME (current_function_decl)))
-           check_thrown_exceptions (location, ret_decl);
-
-         /* If the previous call was static and this one is too,
-            build a compound expression to hold the two (because in
-            that case, previous function calls aren't transported as
-            forcoming function's argument. */
-         if (previous_call_static && is_static)
-           {
-             decl = build (COMPOUND_EXPR, TREE_TYPE (*where_found),
-                           decl, *where_found);
-             TREE_SIDE_EFFECTS (decl) = 1;
-           }
-         else
-           {
-             previous_call_static = is_static;
-             decl = *where_found;
-           }
-         from_type = 0;
-         continue;
-
-       case NEW_ARRAY_EXPR:
-       case NEW_ANONYMOUS_ARRAY_EXPR:
-         *where_found = decl = java_complete_tree (qual_wfl);
-         if (decl == error_mark_node)
-           return 1;
-         *type_found = type = QUAL_DECL_TYPE (decl);
-         continue;
-
-       case CONVERT_EXPR:
-         *where_found = decl = java_complete_tree (qual_wfl);
-         if (decl == error_mark_node)
-           return 1;
-         *type_found = type = QUAL_DECL_TYPE (decl);
-         from_cast = 1;
-         continue;
-
-       case CONDITIONAL_EXPR:
-       case STRING_CST:
-       case MODIFY_EXPR:
-         *where_found = decl = java_complete_tree (qual_wfl);
-         if (decl == error_mark_node)
-           return 1;
-         *type_found = type = QUAL_DECL_TYPE (decl);
-         continue;
-
-       case ARRAY_REF:
-         /* If the access to the function call is a non static field,
-            build the code to access it. */
-         if (JDECL_P (decl) && !FIELD_STATIC (decl))
-           {
-             decl = maybe_access_field (decl, *where_found, type);
-             if (decl == error_mark_node)
-               return 1;
-           }
-         /* And code for the array reference expression */
-         decl = java_complete_tree (qual_wfl);
-         if (decl == error_mark_node)
-           return 1;
-         type = QUAL_DECL_TYPE (decl);
-         continue;
-
-       case PLUS_EXPR:
-         if ((decl = java_complete_tree (qual_wfl)) == error_mark_node)
-           return 1;
-         if ((type = patch_string (decl)))
-           decl = type;
-         *where_found = QUAL_RESOLUTION (q) = decl;
-         *type_found = type = TREE_TYPE (decl);
-         break;
-
-       case CLASS_LITERAL:
-         if ((decl = java_complete_tree (qual_wfl)) == error_mark_node)
-           return 1;
-         *where_found = QUAL_RESOLUTION (q) = decl;
-         *type_found = type = TREE_TYPE (decl);
-         break;
-
-       default:
-         /* Fix for -Wall Just go to the next statement. Don't
-             continue */
-         break;
-       }
-
-      /* If we fall here, we weren't processing a (static) function call. */
-      previous_call_static = 0;
-
-      /* It can be the keyword THIS */
-      if (TREE_CODE (qual_wfl) == EXPR_WITH_FILE_LOCATION
-         && EXPR_WFL_NODE (qual_wfl) == this_identifier_node)
-       {
-         if (!current_this)
-           {
-             parse_error_context 
-               (wfl, "Keyword `this' used outside allowed context");
-             return 1;
-           }
-         if (ctxp->explicit_constructor_p
-             && type == current_class)
-           {
-             parse_error_context (wfl, "Can't reference `this' before the superclass constructor has been called");
-             return 1;
-           }
-         /* We have to generate code for intermediate access */
-         if (!from_type || TREE_TYPE (TREE_TYPE (current_this)) == type)
-           {
-             *where_found = decl = current_this;
-             *type_found = type = QUAL_DECL_TYPE (decl);
-           }
-         /* We're trying to access the this from somewhere else. Make sure
-            it's allowed before doing so. */
-         else
-           {
-             if (!enclosing_context_p (type, current_class))
-               {
-                 char *p  = xstrdup (lang_printable_name (type, 0));
-                 parse_error_context (qual_wfl, "Can't use variable `%s.this': type `%s' isn't an outer type of type `%s'", 
-                                      p, p, 
-                                      lang_printable_name (current_class, 0));
-                 free (p);
-                 return 1;
-               }
-             from_qualified_this = 1;
-             /* If there's nothing else after that, we need to
-                 produce something now, otherwise, the section of the
-                 code that needs to produce <T>.this will generate
-                 what is necessary. */
-             if (!TREE_CHAIN (q))
-               {
-                 decl = build_access_to_thisn (current_class, type, 0);
-                 *where_found = decl = java_complete_tree (decl);
-                 *type_found = type = TREE_TYPE (decl);
-               }
-           }
-
-         from_type = 0;
-         continue;
-       }
-
-      /* 15.10.2 Accessing Superclass Members using SUPER */
-      if (TREE_CODE (qual_wfl) == EXPR_WITH_FILE_LOCATION
-         && EXPR_WFL_NODE (qual_wfl) == super_identifier_node)
-       {
-         tree node;
-         /* Check on the restricted use of SUPER */
-         if (METHOD_STATIC (current_function_decl)
-             || current_class == object_type_node)
-           {
-             parse_error_context 
-               (wfl, "Keyword `super' used outside allowed context");
-             return 1;
-           }
-         /* Otherwise, treat SUPER as (SUPER_CLASS)THIS */
-         node = build_cast (EXPR_WFL_LINECOL (qual_wfl), 
-                            CLASSTYPE_SUPER (current_class),
-                            build_this (EXPR_WFL_LINECOL (qual_wfl)));
-         *where_found = decl = java_complete_tree (node);
-         if (decl == error_mark_node)
-           return 1;
-         *type_found = type = QUAL_DECL_TYPE (decl);
-         from_super = from_type = 1;
-         continue;
-       }
-
-      /* 15.13.1: Can't search for field name in packages, so we
-        assume a variable/class name was meant. */
-      if (RESOLVE_PACKAGE_NAME_P (qual_wfl))
-       {
-         tree name;
-         if ((decl = resolve_package (wfl, &q, &name)))
-           {
-             tree list;
-             *where_found = decl;
-
-             /* We want to be absolutely sure that the class is laid
-                 out. We're going to search something inside it. */
-             *type_found = type = TREE_TYPE (decl);
-             layout_class (type);
-             from_type = 1;
-
-             /* Fix them all the way down, if any are left. */
-             if (q)
-               {
-                 list = TREE_CHAIN (q);
-                 while (list)
-                   {
-                     RESOLVE_EXPRESSION_NAME_P (QUAL_WFL (list)) = 1;
-                     RESOLVE_PACKAGE_NAME_P (QUAL_WFL (list)) = 0;
-                     list = TREE_CHAIN (list);
-                   }
-               }
-           }
-         else
-           {
-             if (from_super || from_cast)
-               parse_error_context 
-                 ((from_cast ? qual_wfl : wfl),
-                  "No variable `%s' defined in class `%s'",
-                  IDENTIFIER_POINTER (EXPR_WFL_NODE (qual_wfl)),
-                  lang_printable_name (type, 0));
-             else
-               parse_error_context
-                 (qual_wfl, "Undefined variable or class name: `%s'",
-                  IDENTIFIER_POINTER (name));
-             return 1;
-           }
-       }
-
-      /* We have a type name. It's been already resolved when the
-        expression was qualified. */
-      else if (RESOLVE_TYPE_NAME_P (qual_wfl) && QUAL_RESOLUTION (q))
-       {
-         decl = QUAL_RESOLUTION (q);
-
-         /* Sneak preview. If next we see a `new', we're facing a
-            qualification with resulted in a type being selected
-            instead of a field.  Report the error */
-         if(TREE_CHAIN (q) 
-            && TREE_CODE (TREE_PURPOSE (TREE_CHAIN (q))) == NEW_CLASS_EXPR)
-           {
-             parse_error_context (qual_wfl, "Undefined variable `%s'",
-                                  IDENTIFIER_POINTER (EXPR_WFL_NODE (wfl)));
-             return 1;
-           }
-
-         if (not_accessible_p (TREE_TYPE (decl), decl, type, 0))
-           {
-             parse_error_context 
-               (qual_wfl, "Can't access %s field `%s.%s' from `%s'",
-                java_accstring_lookup (get_access_flags_from_decl (decl)),
-                GET_TYPE_NAME (type),
-                IDENTIFIER_POINTER (DECL_NAME (decl)),
-                IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (current_class))));
-             return 1;
-           }
-         check_deprecation (qual_wfl, decl);
-
-         type = TREE_TYPE (decl);
-         from_type = 1;
-       }
-      /* We resolve an expression name */
-      else 
-       {
-         tree field_decl = NULL_TREE;
-
-         /* If there exists an early resolution, use it. That occurs
-            only once and we know that there are more things to
-            come. Don't do that when processing something after SUPER
-            (we need more thing to be put in place below */
-         if (!from_super && QUAL_RESOLUTION (q))
-           {
-             decl = QUAL_RESOLUTION (q);
-             if (!type)
-               {
-                 if (TREE_CODE (decl) == FIELD_DECL && !FIELD_STATIC (decl))
-                   {
-                     if (current_this)
-                       *where_found = current_this;
-                     else
-                       {
-                         static_ref_err (qual_wfl, DECL_NAME (decl),
-                                         current_class);
-                         return 1;
-                       }
-                      if (outer_field_access_p (current_class, decl))
-                        decl = build_outer_field_access (qual_wfl, decl);
-                   }
-                 else
-                   {
-                     *where_found = TREE_TYPE (decl);
-                     if (TREE_CODE (*where_found) == POINTER_TYPE)
-                       *where_found = TREE_TYPE (*where_found);
-                   }
-               }
-           }
-
-         /* Report and error if we're using a numerical litteral as a
-             qualifier. It can only be an INTEGER_CST. */
-         else if (TREE_CODE (qual_wfl) == INTEGER_CST)
-           {
-             parse_error_context
-               (wfl, "Can't use type `%s' as a qualifier",
-                lang_printable_name (TREE_TYPE (qual_wfl), 0));
-             return 1;
-           }
-
-         /* We have to search for a field, knowing the type of its
-             container. The flag FROM_TYPE indicates that we resolved
-             the last member of the expression as a type name, which
-             means that for the resolution of this field, we'll look
-             for other errors than if it was resolved as a member of
-             an other field. */
-         else
-           {
-             int is_static;
-             tree field_decl_type; /* For layout */
-
-             if (!from_type && !JREFERENCE_TYPE_P (type))
-               {
-                 parse_error_context 
-                   (qual_wfl, "Attempt to reference field `%s' in `%s %s'",
-                    IDENTIFIER_POINTER (EXPR_WFL_NODE (qual_wfl)),
-                    lang_printable_name (type, 0),
-                    IDENTIFIER_POINTER (DECL_NAME (decl)));
-                 return 1;
-               }
-             
-             field_decl = lookup_field_wrapper (type,
-                                                EXPR_WFL_NODE (qual_wfl));
-
-             /* Maybe what we're trying to access to is an inner
-                class, only if decl is a TYPE_DECL. */
-             if (!field_decl && TREE_CODE (decl) == TYPE_DECL)
-               {
-                 tree ptr, inner_decl;
-
-                 BUILD_PTR_FROM_NAME (ptr, EXPR_WFL_NODE (qual_wfl));
-                 inner_decl = resolve_class (decl, ptr, NULL_TREE, qual_wfl);
-                 if (inner_decl)
-                   {
-                     check_inner_class_access (inner_decl, decl, qual_wfl); 
-                     type = TREE_TYPE (inner_decl);
-                     decl = inner_decl;
-                     from_type = 1;
-                     continue;
-                   }
-               }
-
-             if (field_decl == NULL_TREE)
-               {
-                 parse_error_context 
-                   (qual_wfl, "No variable `%s' defined in type `%s'",
-                    IDENTIFIER_POINTER (EXPR_WFL_NODE (qual_wfl)), 
-                    GET_TYPE_NAME (type));
-                 return 1;
-               }
-             if (field_decl == error_mark_node)
-               return 1;
-
-             /* Layout the type of field_decl, since we may need
-                 it. Don't do primitive types or loaded classes. The
-                 situation of non primitive arrays may not handled
-                 properly here. FIXME */
-             if (TREE_CODE (TREE_TYPE (field_decl)) == POINTER_TYPE)
-               field_decl_type = TREE_TYPE (TREE_TYPE (field_decl));
-             else
-               field_decl_type = TREE_TYPE (field_decl);
-             if (!JPRIMITIVE_TYPE_P (field_decl_type) 
-                 && !CLASS_LOADED_P (field_decl_type)
-                 && !TYPE_ARRAY_P (field_decl_type))
-               resolve_and_layout (field_decl_type, NULL_TREE);
-             
-             /* Check on accessibility here */
-             if (not_accessible_p (current_class, field_decl,
-                                   DECL_CONTEXT (field_decl), from_super))
-               {
-                 parse_error_context 
-                   (qual_wfl,
-                    "Can't access %s field `%s.%s' from `%s'",
-                    java_accstring_lookup 
-                      (get_access_flags_from_decl (field_decl)),
-                    GET_TYPE_NAME (type),
-                    IDENTIFIER_POINTER (DECL_NAME (field_decl)),
-                    IDENTIFIER_POINTER 
-                      (DECL_NAME (TYPE_NAME (current_class))));
-                 return 1;
-               }
-             check_deprecation (qual_wfl, field_decl);
-             
-             /* There are things to check when fields are accessed
-                from type. There are no restrictions on a static
-                declaration of the field when it is accessed from an
-                interface */
-             is_static = FIELD_STATIC (field_decl);
-             if (!from_super && from_type 
-                 && !TYPE_INTERFACE_P (type) 
-                 && !is_static 
-                 && (current_function_decl 
-                     && METHOD_STATIC (current_function_decl)))
-               {
-                 static_ref_err (qual_wfl, EXPR_WFL_NODE (qual_wfl), type);
-                 return 1;
-               }
-             from_cast = from_super = 0;
-
-             /* It's an access from a type but it isn't static, we
-                make it relative to `this'. */
-             if (!is_static && from_type)
-               decl = current_this;
-
-             /* If we need to generate something to get a proper
-                handle on what this field is accessed from, do it
-                now. */
-             if (!is_static)
-               {
-                 decl = maybe_access_field (decl, *where_found, *type_found);
-                 if (decl == error_mark_node)
-                   return 1;
-               }
-
-             /* We want to keep the location were found it, and the type
-                we found. */
-             *where_found = decl;
-             *type_found = type;
-
-             /* Generate the correct expression for field access from
-                qualified this */
-             if (from_qualified_this)
-               {
-                 field_decl = build_outer_field_access (qual_wfl, field_decl);
-                 from_qualified_this = 0;
-               }
-
-             /* This is the decl found and eventually the next one to
-                search from */
-             decl = field_decl;
-           }
-         from_type = 0;
-         type = QUAL_DECL_TYPE (decl);
-
-         /* Sneak preview. If decl is qualified by a `new', report
-             the error here to be accurate on the peculiar construct */
-         if (TREE_CHAIN (q) 
-             && TREE_CODE (TREE_PURPOSE (TREE_CHAIN (q))) == NEW_CLASS_EXPR
-             && !JREFERENCE_TYPE_P (type))
-           {
-             parse_error_context (qual_wfl, "Attempt to reference field `new' in a `%s'", 
-                                  lang_printable_name (type, 0));
-             return 1;
-           }
-       }
-      /* `q' might have changed due to a after package resolution
-         re-qualification */
-      if (!q)
-       break;
-    }
-  *found_decl = decl;
-  return 0;
-}
-
-/* 6.6 Qualified name and access control. Returns 1 if MEMBER (a decl)
-   can't be accessed from REFERENCE (a record type). If MEMBER
-   features a protected access, we then use WHERE which, if non null,
-   holds the type of MEMBER's access that is checked against
-   6.6.2.1. This function should be used when decl is a field or a
-   method.  */
-
-static int
-not_accessible_p (reference, member, where, from_super)
-     tree reference, member;
-     tree where;
-     int from_super;
-{
-  int access_flag = get_access_flags_from_decl (member);
-
-  /* Inner classes are processed by check_inner_class_access */
-  if (INNER_CLASS_TYPE_P (reference))
-    return 0;
-
-  /* Access always granted for members declared public */
-  if (access_flag & ACC_PUBLIC)
-    return 0;
-  
-  /* Check access on protected members */
-  if (access_flag & ACC_PROTECTED)
-    {
-      /* Access granted if it occurs from within the package
-         containing the class in which the protected member is
-         declared */
-      if (class_in_current_package (DECL_CONTEXT (member)))
-       return 0;
-
-      /* If accessed with the form `super.member', then access is granted */
-      if (from_super)
-       return 0;
-
-      /* If where is active, access was made through a
-        qualifier. Access is granted if the type of the qualifier is
-        or is a sublass of the type the access made from (6.6.2.1.)  */
-      if (where && !inherits_from_p (reference, where))
-       return 1;
-
-      /* Otherwise, access is granted if occurring from the class where
-        member is declared or a subclass of it. Find the right
-        context to perform the check */
-      if (PURE_INNER_CLASS_TYPE_P (reference))
-        {
-          while (INNER_CLASS_TYPE_P (reference))
-            {
-              if (inherits_from_p (reference, DECL_CONTEXT (member)))
-                return 0;
-              reference = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (reference)));
-            }
-        }
-      if (inherits_from_p (reference, DECL_CONTEXT (member)))
-       return 0;
-      return 1;
-    }
-
-  /* Check access on private members. Access is granted only if it
-     occurs from within the class in which it is declared -- that does
-     it for innerclasses too. */
-  if (access_flag & ACC_PRIVATE)
-    {
-      if (reference == DECL_CONTEXT (member))
-       return 0;
-      if (enclosing_context_p (reference, DECL_CONTEXT (member)))
-       return 0;
-      return 1;
-    }
-
-  /* Default access are permitted only when occurring within the
-     package in which the type (REFERENCE) is declared. In other words,
-     REFERENCE is defined in the current package */
-  if (ctxp->package)
-    return !class_in_current_package (reference);
-
-  /* Otherwise, access is granted */
-  return 0;
-}
-
-/* Test deprecated decl access.  */
-static void
-check_deprecation (wfl, decl)
-     tree wfl, decl;
-{
-  const char *file = DECL_SOURCE_FILE (decl);
-  /* Complain if the field is deprecated and the file it was defined
-     in isn't compiled at the same time the file which contains its
-     use is */
-  if (DECL_DEPRECATED (decl) 
-      && !IS_A_COMMAND_LINE_FILENAME_P (get_identifier (file)))
-    {
-      char the [20];
-      switch (TREE_CODE (decl))
-       {
-       case FUNCTION_DECL:
-         strcpy (the, "method");
-         break;
-       case FIELD_DECL:
-       case VAR_DECL:
-         strcpy (the, "field");
-         break;
-       case TYPE_DECL:
-         parse_warning_context (wfl, "The class `%s' has been deprecated",
-                                IDENTIFIER_POINTER (DECL_NAME (decl)));
-         return;
-       default:
-         abort ();
-       }
-      /* Don't issue a message if the context as been deprecated as a
-         whole. */
-      if (! CLASS_DEPRECATED (TYPE_NAME (DECL_CONTEXT (decl))))
-       parse_warning_context 
-         (wfl, "The %s `%s' in class `%s' has been deprecated", 
-          the, lang_printable_name (decl, 0),
-          IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (DECL_CONTEXT (decl)))));
-    }
-}
-
-/* Returns 1 if class was declared in the current package, 0 otherwise */
-
-static int
-class_in_current_package (class)
-     tree class;
-{
-  static tree cache = NULL_TREE;
-  int qualified_flag;
-  tree left;
-
-  if (cache == class)
-    return 1;
-
-  qualified_flag = QUALIFIED_P (DECL_NAME (TYPE_NAME (class)));
-
-  /* If the current package is empty and the name of CLASS is
-     qualified, class isn't in the current package.  If there is a
-     current package and the name of the CLASS is not qualified, class
-     isn't in the current package */
-  if ((!ctxp->package && qualified_flag) || (ctxp->package && !qualified_flag))
-    return 0;
-
-  /* If there is not package and the name of CLASS isn't qualified,
-     they belong to the same unnamed package */
-  if (!ctxp->package && !qualified_flag)
-    return 1;
-
-  /* Compare the left part of the name of CLASS with the package name */
-  breakdown_qualified (&left, NULL, DECL_NAME (TYPE_NAME (class)));
-  if (ctxp->package == left)
-    {
-      static int initialized_p;
-      /* Register CACHE with the garbage collector.  */
-      if (!initialized_p)
-       {
-         ggc_add_tree_root (&cache, 1);
-         initialized_p = 1;
-       }
-
-      cache = class;
-      return 1;
-    }
-  return 0;
-}
-
-/* This function may generate code to access DECL from WHERE. This is
-   done only if certain conditions meet.  */
-
-static tree
-maybe_access_field (decl, where, type)
-  tree decl, where, type;
-{
-  if (TREE_CODE (decl) == FIELD_DECL && decl != current_this
-      && !FIELD_STATIC (decl))
-    decl = build_field_ref (where ? where : current_this, 
-                           (type ? type : DECL_CONTEXT (decl)),
-                           DECL_NAME (decl));
-  return decl;
-}
-
-/* Build a method invocation, by patching PATCH. If non NULL
-   and according to the situation, PRIMARY and WHERE may be
-   used. IS_STATIC is set to 1 if the invoked function is static. */
-
-static tree
-patch_method_invocation (patch, primary, where, from_super,
-                        is_static, ret_decl)
-     tree patch, primary, where;
-     int from_super;
-     int *is_static;
-     tree *ret_decl;
-{
-  tree wfl = TREE_OPERAND (patch, 0);
-  tree args = TREE_OPERAND (patch, 1);
-  tree name = EXPR_WFL_NODE (wfl);
-  tree list;
-  int is_static_flag = 0;
-  int is_super_init = 0;
-  tree this_arg = NULL_TREE;
-  int is_array_clone_call = 0;
-  
-  /* Should be overriden if everything goes well. Otherwise, if
-     something fails, it should keep this value. It stop the
-     evaluation of a bogus assignment. See java_complete_tree,
-     MODIFY_EXPR: for the reasons why we sometimes want to keep on
-     evaluating an assignment */
-  TREE_TYPE (patch) = error_mark_node;
-
-  /* Since lookup functions are messing with line numbers, save the
-     context now.  */
-  java_parser_context_save_global ();
-
-  /* 15.11.1: Compile-Time Step 1: Determine Class or Interface to Search */
-
-  /* Resolution of qualified name, excluding constructors */
-  if (QUALIFIED_P (name) && !CALL_CONSTRUCTOR_P (patch))
-    {
-      tree identifier, identifier_wfl, type, resolved;
-      /* Extract the last IDENTIFIER of the qualified
-        expression. This is a wfl and we will use it's location
-        data during error report. */
-      identifier_wfl = cut_identifier_in_qualified (wfl);
-      identifier = EXPR_WFL_NODE (identifier_wfl);
-      
-      /* Given the context, IDENTIFIER is syntactically qualified
-        as a MethodName. We need to qualify what's before */
-      qualify_ambiguous_name (wfl);
-      resolved = resolve_field_access (wfl, NULL, NULL);
-
-      if (TREE_CODE (resolved) == VAR_DECL && FIELD_STATIC (resolved)
-         && FIELD_FINAL (resolved) 
-         && !inherits_from_p (DECL_CONTEXT (resolved), current_class)
-         && !flag_emit_class_files && !flag_emit_xref)
-       resolved = build_class_init (DECL_CONTEXT (resolved), resolved);
-
-      if (resolved == error_mark_node)
-       PATCH_METHOD_RETURN_ERROR ();
-
-      type = GET_SKIP_TYPE (resolved);
-      resolve_and_layout (type, NULL_TREE);
-      
-      if (JPRIMITIVE_TYPE_P (type))
-        {
-         parse_error_context
-           (identifier_wfl,
-            "Can't invoke a method on primitive type `%s'",
-            IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (type))));
-         PATCH_METHOD_RETURN_ERROR ();         
-       }
-
-      list = lookup_method_invoke (0, identifier_wfl, type, identifier, args);
-      args = nreverse (args);
-
-      /* We're resolving a call from a type */
-      if (TREE_CODE (resolved) == TYPE_DECL)
-       {
-         if (CLASS_INTERFACE (resolved))
-           {
-             parse_error_context
-               (identifier_wfl,
-               "Can't make static reference to method `%s' in interface `%s'",
-                IDENTIFIER_POINTER (identifier), 
-                IDENTIFIER_POINTER (name));
-             PATCH_METHOD_RETURN_ERROR ();
-           }
-         if (list && !METHOD_STATIC (list))
-           {
-             char *fct_name = xstrdup (lang_printable_name (list, 0));
-             parse_error_context 
-               (identifier_wfl,
-                "Can't make static reference to method `%s %s' in class `%s'",
-                lang_printable_name (TREE_TYPE (TREE_TYPE (list)), 0), 
-                fct_name, IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (type))));
-             free (fct_name);
-             PATCH_METHOD_RETURN_ERROR ();
-           }
-       }
-      else
-       this_arg = primary = resolved;
-      
-      if (TYPE_ARRAY_P (type) && identifier == get_identifier ("clone"))
-        is_array_clone_call = 1;
-      
-      /* IDENTIFIER_WFL will be used to report any problem further */
-      wfl = identifier_wfl;
-    }
-  /* Resolution of simple names, names generated after a primary: or
-     constructors */
-  else
-    {
-      tree class_to_search = NULL_TREE;
-      int lc;                  /* Looking for Constructor */
-      
-      /* We search constructor in their target class */
-      if (CALL_CONSTRUCTOR_P (patch))
-       {
-         if (TREE_CODE (patch) == NEW_CLASS_EXPR)
-           class_to_search = EXPR_WFL_NODE (wfl);
-         else if (EXPR_WFL_NODE (TREE_OPERAND (patch, 0)) == 
-                  this_identifier_node)
-           class_to_search = NULL_TREE;
-         else if (EXPR_WFL_NODE (TREE_OPERAND (patch, 0)) ==
-                  super_identifier_node)
-           {
-             is_super_init = 1;
-             if (CLASSTYPE_SUPER (current_class))
-               class_to_search = 
-                 DECL_NAME (TYPE_NAME (CLASSTYPE_SUPER (current_class)));
-             else
-               {
-                 parse_error_context (wfl, "Can't invoke super constructor on java.lang.Object");
-                 PATCH_METHOD_RETURN_ERROR ();
-               }
-           }
-
-         /* Class to search is NULL if we're searching the current one */
-         if (class_to_search)
-           {
-             class_to_search = resolve_and_layout (class_to_search, wfl);
-
-             if (!class_to_search)
-               {
-                 parse_error_context 
-                   (wfl, "Class `%s' not found in type declaration",
-                    IDENTIFIER_POINTER (EXPR_WFL_NODE (wfl)));
-                 PATCH_METHOD_RETURN_ERROR ();
-               }
-             
-             /* Can't instantiate an abstract class, but we can
-                invoke it's constructor. It's use within the `new'
-                context is denied here. */
-             if (CLASS_ABSTRACT (class_to_search) 
-                 && TREE_CODE (patch) == NEW_CLASS_EXPR)
-               {
-                 parse_error_context 
-                   (wfl, "Class `%s' is an abstract class. It can't be instantiated",
-                    IDENTIFIER_POINTER (EXPR_WFL_NODE (wfl)));
-                 PATCH_METHOD_RETURN_ERROR ();
-               }
-
-             class_to_search = TREE_TYPE (class_to_search);
-           }
-         else
-           class_to_search = current_class;
-         lc = 1;
-       }
-      /* This is a regular search in the local class, unless an
-         alternate class is specified. */
-      else
-       {
-         if (where != NULL_TREE)
-           class_to_search = where;
-         else if (QUALIFIED_P (name))
-           class_to_search = current_class;
-         else
-           {
-             class_to_search = current_class;
-
-             for (;;)
-               {
-                 if (has_method (class_to_search, name))
-                   break;
-                 if (! INNER_CLASS_TYPE_P (class_to_search))
-                   {
-                     parse_error_context (wfl,
-                                          "No method named `%s' in scope",
-                                          IDENTIFIER_POINTER (name));
-                     PATCH_METHOD_RETURN_ERROR ();
-                   }
-                 class_to_search
-                   = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (class_to_search)));
-               }
-           }
-         lc = 0;
-       }
-
-      /* NAME is a simple identifier or comes from a primary. Search
-        in the class whose declaration contain the method being
-        invoked. */
-      resolve_and_layout (class_to_search, NULL_TREE);
-
-      list = lookup_method_invoke (lc, wfl, class_to_search, name, args);
-      /* Don't continue if no method were found, as the next statement
-         can't be executed then. */
-      if (!list)
-       PATCH_METHOD_RETURN_ERROR ();
-      
-      if (TYPE_ARRAY_P (class_to_search)
-          && DECL_NAME (list) == get_identifier ("clone"))
-        is_array_clone_call = 1;
-
-      /* Check for static reference if non static methods */
-      if (check_for_static_method_reference (wfl, patch, list, 
-                                            class_to_search, primary))
-       PATCH_METHOD_RETURN_ERROR ();
-
-      /* Check for inner classes creation from illegal contexts */
-      if (lc && (INNER_CLASS_TYPE_P (class_to_search)
-                && !CLASS_STATIC (TYPE_NAME (class_to_search)))
-         && INNER_ENCLOSING_SCOPE_CHECK (class_to_search)
-         && !DECL_INIT_P (current_function_decl))
-       {
-         parse_error_context 
-           (wfl, "No enclosing instance for inner class `%s' is in scope%s",
-            lang_printable_name (class_to_search, 0),
-            (!current_this ? "" :
-             "; an explicit one must be provided when creating this inner class"));
-         PATCH_METHOD_RETURN_ERROR ();
-       }
-
-      /* Non static methods are called with the current object extra
-        argument. If patch a `new TYPE()', the argument is the value
-        returned by the object allocator. If method is resolved as a
-        primary, use the primary otherwise use the current THIS. */
-      args = nreverse (args);
-      if (TREE_CODE (patch) != NEW_CLASS_EXPR)
-       {
-         this_arg = primary ? primary : current_this;
-
-         /* If we're using an access method, things are different.
-            There are two familly of cases:
-
-            1) We're not generating bytecodes:
-
-            - LIST is non static. It's invocation is transformed from
-              x(a1,...,an) into this$<n>.x(a1,....an).
-            - LIST is static. It's invocation is transformed from
-              x(a1,...,an) into TYPE_OF(this$<n>).x(a1,....an)
-
-            2) We're generating bytecodes:
-            
-            - LIST is non static. It's invocation is transformed from
-              x(a1,....,an) into access$<n>(this$<n>,a1,...,an).
-            - LIST is static. It's invocation is transformed from
-              x(a1,....,an) into TYPE_OF(this$<n>).x(a1,....an).
-
-            Of course, this$<n> can be abitrary complex, ranging from
-            this$0 (the immediate outer context) to 
-            access$0(access$0(...(this$0))). 
-            
-            maybe_use_access_method returns a non zero value if the
-            this_arg has to be moved into the (then generated) stub
-            argument list. In the meantime, the selected function
-            might have be replaced by a generated stub. */
-         if (!primary &&
-             maybe_use_access_method (is_super_init, &list, &this_arg))
-           {
-             args = tree_cons (NULL_TREE, this_arg, args);
-             this_arg = NULL_TREE; /* So it doesn't get chained twice */
-           }
-       }
-    }
-
-  /* Merge point of all resolution schemes. If we have nothing, this
-     is an error, already signaled */
-  if (!list) 
-    PATCH_METHOD_RETURN_ERROR ();
-
-  /* Check accessibility, position the is_static flag, build and
-     return the call */
-  if (not_accessible_p (DECL_CONTEXT (current_function_decl), list,
-                       (primary ? TREE_TYPE (TREE_TYPE (primary)) : 
-                        NULL_TREE), from_super)
-      /* Calls to clone() on array types are permitted as a special-case. */
-      && !is_array_clone_call)
-    {
-      const char *const fct_name = IDENTIFIER_POINTER (DECL_NAME (list));
-      const char *const access =
-       java_accstring_lookup (get_access_flags_from_decl (list));
-      const char *const klass =
-       IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (DECL_CONTEXT (list))));
-      const char *const refklass =
-       IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (current_class)));
-      const char *const what = (DECL_CONSTRUCTOR_P (list)
-                               ? "constructor" : "method");
-      /* FIXME: WFL yields the wrong message here but I don't know
-        what else to use.  */
-      parse_error_context (wfl,
-                          "Can't access %s %s `%s.%s' from `%s'",
-                          access, what, klass, fct_name, refklass);
-      PATCH_METHOD_RETURN_ERROR ();
-    }
-
-  /* Deprecation check: check whether the method being invoked or the
-     instance-being-created's type are deprecated. */
-  if (TREE_CODE (patch) == NEW_CLASS_EXPR)
-    check_deprecation (wfl, TYPE_NAME (DECL_CONTEXT (list)));
-  else
-    check_deprecation (wfl, list);
-
-  /* If invoking a innerclass constructor, there are hidden parameters
-     to pass */
-  if (TREE_CODE (patch) == NEW_CLASS_EXPR 
-      && PURE_INNER_CLASS_TYPE_P (DECL_CONTEXT (list)))
-    {
-      /* And make sure we add the accessed local variables to be saved
-        in field aliases. */
-      args = build_alias_initializer_parameter_list
-       (AIPL_FUNCTION_CTOR_INVOCATION, DECL_CONTEXT (list), args, NULL);
-
-      /* Secretly pass the current_this/primary as a second argument */
-      if (primary || current_this)
-       {
-         tree extra_arg;
-         tree this_type = (current_this ?
-                           TREE_TYPE (TREE_TYPE (current_this)) : NULL_TREE);
-         /* Method's (list) enclosing context */
-         tree mec = DECL_CONTEXT (TYPE_NAME (DECL_CONTEXT (list)));
-         /* If we have a primary, use it. */
-         if (primary)
-           extra_arg = primary;
-         /* The current `this' is an inner class but isn't a direct
-            enclosing context for the inner class we're trying to
-            create. Build an access to the proper enclosing context
-            and use it. */
-         else if (current_this && PURE_INNER_CLASS_TYPE_P (this_type)
-                  && this_type != TREE_TYPE (mec))
-           {
-
-             extra_arg = build_access_to_thisn (current_class,
-                                                TREE_TYPE (mec), 0);
-             extra_arg = java_complete_tree (extra_arg);
-           }
-         /* Otherwise, just use the current `this' as an enclosing
-             context. */
-         else
-           extra_arg = current_this;
-         args = tree_cons (NULL_TREE, extra_arg, args);
-       }
-      else
-       args = tree_cons (NULL_TREE, integer_zero_node, args);
-    }
-
-  /* This handles the situation where a constructor invocation needs
-     to have an enclosing context passed as a second parameter (the
-     constructor is one of an inner class). */
-  if ((is_super_init || 
-       (TREE_CODE (patch) == CALL_EXPR && name == this_identifier_node))
-      && PURE_INNER_CLASS_TYPE_P (DECL_CONTEXT (list)))
-    {
-      tree dest = TYPE_NAME (DECL_CONTEXT (list));
-      tree extra_arg = 
-       build_access_to_thisn (current_class, DECL_CONTEXT (dest), 0);
-      extra_arg = java_complete_tree (extra_arg);
-      args = tree_cons (NULL_TREE, extra_arg, args);
-    }
-
-  is_static_flag = METHOD_STATIC (list);
-  if (! is_static_flag && this_arg != NULL_TREE)
-    args = tree_cons (NULL_TREE, this_arg, args);
-
-  /* In the context of an explicit constructor invocation, we can't
-     invoke any method relying on `this'. Exceptions are: we're
-     invoking a static function, primary exists and is not the current
-     this, we're creating a new object. */
-  if (ctxp->explicit_constructor_p 
-      && !is_static_flag 
-      && (!primary || primary == current_this)
-      && (TREE_CODE (patch) != NEW_CLASS_EXPR))
-    {
-      parse_error_context (wfl, "Can't reference `this' before the superclass constructor has been called");
-      PATCH_METHOD_RETURN_ERROR ();
-    }
-  java_parser_context_restore_global ();
-  if (is_static) 
-    *is_static = is_static_flag;
-  /* Sometimes, we want the decl of the selected method. Such as for
-     EH checking */
-  if (ret_decl)
-    *ret_decl = list;
-  patch = patch_invoke (patch, list, args);
-
-  /* Now is a good time to insert the call to finit$ */
-  if (is_super_init && CLASS_HAS_FINIT_P (current_class))
-    {
-      tree finit_parms, finit_call;
-      
-      /* Prepare to pass hidden parameters to finit$, if any. */
-      finit_parms = build_alias_initializer_parameter_list 
-       (AIPL_FUNCTION_FINIT_INVOCATION, current_class, NULL_TREE, NULL);
-      
-      finit_call = 
-       build_method_invocation (build_wfl_node (finit_identifier_node),
-                                finit_parms);
-
-      /* Generate the code used to initialize fields declared with an
-        initialization statement and build a compound statement along
-        with the super constructor invocation. */
-      CAN_COMPLETE_NORMALLY (patch) = 1;
-      patch = build (COMPOUND_EXPR, void_type_node, patch,
-                    java_complete_tree (finit_call));
-    }
-  return patch;
-}
-
-/* Check that we're not trying to do a static reference to a method in
-   non static method. Return 1 if it's the case, 0 otherwise. */
-
-static int
-check_for_static_method_reference (wfl, node, method, where, primary)
-     tree wfl, node, method, where, primary;
-{
-  if (METHOD_STATIC (current_function_decl) 
-      && !METHOD_STATIC (method) && !primary && !CALL_CONSTRUCTOR_P (node))
-    {
-      char *fct_name = xstrdup (lang_printable_name (method, 0));
-      parse_error_context 
-       (wfl, "Can't make static reference to method `%s %s' in class `%s'", 
-        lang_printable_name (TREE_TYPE (TREE_TYPE (method)), 0), fct_name,
-        IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (where))));
-      free (fct_name);
-      return 1;
-    }
-  return 0;
-}
-
-/* Fix the invocation of *MDECL if necessary in the case of a
-   invocation from an inner class. *THIS_ARG might be modified
-   appropriately and an alternative access to *MDECL might be
-   returned.  */
-
-static int
-maybe_use_access_method (is_super_init, mdecl, this_arg)
-     int is_super_init;
-     tree *mdecl, *this_arg;
-{
-  tree ctx;
-  tree md = *mdecl, ta = *this_arg;
-  int to_return = 0;
-  int non_static_context = !METHOD_STATIC (md);
-
-  if (is_super_init 
-      || DECL_CONTEXT (md) == current_class
-      || !PURE_INNER_CLASS_TYPE_P (current_class) 
-      || DECL_FINIT_P (md)
-      || DECL_INSTINIT_P (md))
-    return 0;
-  
-  /* If we're calling a method found in an enclosing class, generate
-     what it takes to retrieve the right this. Don't do that if we're
-     invoking a static method. Note that if MD's type is unrelated to
-     CURRENT_CLASS, then the current this can be used. */
-
-  if (non_static_context && DECL_CONTEXT (md) != object_type_node)
-    {
-      ctx = TREE_TYPE (DECL_CONTEXT (TYPE_NAME (current_class)));
-      if (inherits_from_p (ctx, DECL_CONTEXT (md)))
-       {
-         ta = build_current_thisn (current_class);
-         ta = build_wfl_node (ta);
-       }
-      else
-       {
-         tree type = ctx;
-         while (type)
-           {
-             maybe_build_thisn_access_method (type);
-             if (inherits_from_p (type, DECL_CONTEXT (md)))
-               {
-                 ta = build_access_to_thisn (ctx, type, 0);
-                 break;
-               }
-             type = (DECL_CONTEXT (TYPE_NAME (type)) ? 
-                     TREE_TYPE (DECL_CONTEXT (TYPE_NAME (type))) : NULL_TREE);
-           }
-       }
-      ta = java_complete_tree (ta);
-    }
-
-  /* We might have to use an access method to get to MD. We can
-     break the method access rule as far as we're not generating
-     bytecode */
-  if (METHOD_PRIVATE (md) && flag_emit_class_files)
-    {
-      md = build_outer_method_access_method (md);
-      to_return = 1;
-    }
-
-  *mdecl = md;
-  *this_arg = ta;
-
-  /* Returnin a non zero value indicates we were doing a non static
-     method invokation that is now a static invocation. It will have
-     callee displace `this' to insert it in the regular argument
-     list. */
-  return (non_static_context && to_return);
-}
-
-/* Patch an invoke expression METHOD and ARGS, based on its invocation
-   mode.  */
-
-static tree
-patch_invoke (patch, method, args)
-     tree patch, method, args;
-{
-  tree dtable, func;
-  tree original_call, t, ta;
-  tree check = NULL_TREE;
-
-  /* Last step for args: convert build-in types. If we're dealing with
-     a new TYPE() type call, the first argument to the constructor
-     isn't found in the incoming argument list, but delivered by
-     `new' */
-  t = TYPE_ARG_TYPES (TREE_TYPE (method));
-  if (TREE_CODE (patch) == NEW_CLASS_EXPR)
-    t = TREE_CHAIN (t);
-  for (ta = args; t != end_params_node && ta; 
-       t = TREE_CHAIN (t), ta = TREE_CHAIN (ta))
-    if (JPRIMITIVE_TYPE_P (TREE_TYPE (TREE_VALUE (ta))) &&
-       TREE_TYPE (TREE_VALUE (ta)) != TREE_VALUE (t))
-      TREE_VALUE (ta) = convert (TREE_VALUE (t), TREE_VALUE (ta));
-
-  /* Resolve unresolved returned type isses */
-  t = TREE_TYPE (TREE_TYPE (method));
-  if (TREE_CODE (t) == POINTER_TYPE && !CLASS_LOADED_P (TREE_TYPE (t)))
-    resolve_and_layout (TREE_TYPE (t), NULL);
-
-  if (flag_emit_class_files || flag_emit_xref)
-    func = method;
-  else
-    {
-      switch (invocation_mode (method, CALL_USING_SUPER (patch)))
-       {
-       case INVOKE_VIRTUAL:
-         dtable = invoke_build_dtable (0, args);
-         func = build_invokevirtual (dtable, method);
-         break;
-
-       case INVOKE_NONVIRTUAL:
-         /* If the object for the method call is null, we throw an
-            exception.  We don't do this if the object is the current
-            method's `this'.  In other cases we just rely on an
-            optimization pass to eliminate redundant checks.  */
-         if (TREE_VALUE (args) != current_this)
-           {
-             /* We use a save_expr here to make sure we only evaluate
-                the new `self' expression once.  */
-             tree save_arg = save_expr (TREE_VALUE (args));
-             TREE_VALUE (args) = save_arg;
-             check = java_check_reference (save_arg, 1);
-           }
-         /* Fall through.  */
-
-       case INVOKE_SUPER:
-       case INVOKE_STATIC:
-         {
-           tree signature = build_java_signature (TREE_TYPE (method));
-           func = build_known_method_ref (method, TREE_TYPE (method),
-                                          DECL_CONTEXT (method),
-                                          signature, args);
-         }
-         break;
-
-       case INVOKE_INTERFACE:
-         dtable = invoke_build_dtable (1, args);
-         func = build_invokeinterface (dtable, method);
-         break;
-
-       default:
-         abort ();
-       }
-
-      /* Ensure self_type is initialized, (invokestatic). FIXME */
-      func = build1 (NOP_EXPR, build_pointer_type (TREE_TYPE (method)), func);
-    }
-
-  TREE_TYPE (patch) = TREE_TYPE (TREE_TYPE (method));
-  TREE_OPERAND (patch, 0) = func;
-  TREE_OPERAND (patch, 1) = args;
-  patch = check_for_builtin (method, patch);
-  original_call = patch;
-
-  /* We're processing a `new TYPE ()' form. New is called and its
-     returned value is the first argument to the constructor. We build
-     a COMPOUND_EXPR and use saved expression so that the overall NEW
-     expression value is a pointer to a newly created and initialized
-     class. */
-  if (TREE_CODE (original_call) == NEW_CLASS_EXPR)
-    {
-      tree class = DECL_CONTEXT (method);
-      tree c1, saved_new, size, new;
-      tree alloc_node;
-
-      if (flag_emit_class_files || flag_emit_xref)
-       {
-         TREE_TYPE (patch) = build_pointer_type (class);
-         return patch;
-       }
-      if (!TYPE_SIZE (class))
-       safe_layout_class (class);
-      size = size_in_bytes (class);
-      alloc_node =
-       (class_has_finalize_method (class) ? alloc_object_node
-                                          : alloc_no_finalizer_node);
-      new = build (CALL_EXPR, promote_type (class),
-                  build_address_of (alloc_node),
-                  tree_cons (NULL_TREE, build_class_ref (class),
-                             build_tree_list (NULL_TREE, 
-                                              size_in_bytes (class))),
-                  NULL_TREE);
-      saved_new = save_expr (new);
-      c1 = build_tree_list (NULL_TREE, saved_new);
-      TREE_CHAIN (c1) = TREE_OPERAND (original_call, 1);
-      TREE_OPERAND (original_call, 1) = c1;
-      TREE_SET_CODE (original_call, CALL_EXPR);
-      patch = build (COMPOUND_EXPR, TREE_TYPE (new), patch, saved_new);
-    }
-
-  /* If CHECK is set, then we are building a check to see if the object
-     is NULL.  */
-  if (check != NULL_TREE)
-    {
-      patch = build (COMPOUND_EXPR, TREE_TYPE (patch), check, patch);
-      TREE_SIDE_EFFECTS (patch) = 1;
-    }
-
-  /* In order to be able to modify PATCH later, we SAVE_EXPR it and
-     put it as the first expression of a COMPOUND_EXPR. The second
-     expression being an empty statement to be later patched if
-     necessary. We remember a TREE_LIST (the PURPOSE is the method,
-     the VALUE is the compound) in a hashtable and return a
-     COMPOUND_EXPR built so that the result of the evaluation of the
-     original PATCH node is returned. */
-  if (STATIC_CLASS_INIT_OPT_P ()
-      && current_function_decl && METHOD_STATIC (method))
-    {
-      tree list;
-      tree fndecl = current_function_decl;
-      tree save = save_expr (patch);
-      tree type = TREE_TYPE (patch);
-
-      patch = build (COMPOUND_EXPR, type, save, empty_stmt_node);
-      list = tree_cons (method, patch,
-                       DECL_FUNCTION_STATIC_METHOD_INVOCATION_COMPOUND (fndecl));
-
-      DECL_FUNCTION_STATIC_METHOD_INVOCATION_COMPOUND (fndecl) = list;
-
-      patch = build (COMPOUND_EXPR, type, patch, save);
-    }
-
-  return patch;
-}
-
-static int
-invocation_mode (method, super)
-     tree method;
-     int super;
-{
-  int access = get_access_flags_from_decl (method);
-
-  if (super)
-    return INVOKE_SUPER;
-
-  if (access & ACC_STATIC)
-    return INVOKE_STATIC;
-
-  /* We have to look for a constructor before we handle nonvirtual
-     calls; otherwise the constructor will look nonvirtual.  */
-  if (DECL_CONSTRUCTOR_P (method))
-    return INVOKE_STATIC;
-
-  if (access & ACC_FINAL || access & ACC_PRIVATE)
-    return INVOKE_NONVIRTUAL;
-
-  if (CLASS_FINAL (TYPE_NAME (DECL_CONTEXT (method))))
-    return INVOKE_NONVIRTUAL;
-
-  if (CLASS_INTERFACE (TYPE_NAME (DECL_CONTEXT (method))))
-    return INVOKE_INTERFACE;
-
-  return INVOKE_VIRTUAL;
-}
-
-/* Retrieve a refined list of matching methods. It covers the step
-   15.11.2 (Compile-Time Step 2) */
-
-static tree
-lookup_method_invoke (lc, cl, class, name, arg_list)
-     int lc;
-     tree cl;
-     tree class, name, arg_list;
-{
-  tree atl = end_params_node;          /* Arg Type List */
-  tree method, signature, list, node;
-  const char *candidates;              /* Used for error report */
-  char *dup;
-
-  /* Fix the arguments */
-  for (node = arg_list; node; node = TREE_CHAIN (node))
-    {
-      tree current_arg = TREE_TYPE (TREE_VALUE (node));
-      /* Non primitive type may have to be resolved */
-      if (!JPRIMITIVE_TYPE_P (current_arg))
-       resolve_and_layout (current_arg, NULL_TREE);
-      /* And promoted */
-      if (TREE_CODE (current_arg) == RECORD_TYPE)
-        current_arg = promote_type (current_arg);
-      atl = tree_cons (NULL_TREE, current_arg, atl);
-    }
-
-  /* Presto. If we're dealing with an anonymous class and a
-     constructor call, generate the right constructor now, since we
-     know the arguments' types. */
-
-  if (lc && ANONYMOUS_CLASS_P (class))
-    {
-      tree saved_current_class;
-      tree mdecl = craft_constructor (TYPE_NAME (class), atl);
-      saved_current_class = current_class;
-      current_class = class;
-      fix_constructors (mdecl);
-      current_class = saved_current_class;
-    }
-
-  /* Find all candidates and then refine the list, searching for the
-     most specific method. */
-  list = find_applicable_accessible_methods_list (lc, class, name, atl);
-  list = find_most_specific_methods_list (list);
-  if (list && !TREE_CHAIN (list))
-    return TREE_VALUE (list);
-
-  /* Issue an error. List candidates if any. Candidates are listed
-     only if accessible (non accessible methods may end-up here for
-     the sake of a better error report). */
-  candidates = NULL;
-  if (list)
-    {
-      tree current;
-      obstack_grow (&temporary_obstack, ". Candidates are:\n", 18);
-      for (current = list; current; current = TREE_CHAIN (current))
-       {
-         tree cm = TREE_VALUE (current);
-         char string [4096];
-         if (!cm || not_accessible_p (class, cm, NULL_TREE, 0))
-           continue;
-         sprintf 
-           (string, "  `%s' in `%s'%s",
-            get_printable_method_name (cm),
-            IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (DECL_CONTEXT (cm)))),
-            (TREE_CHAIN (current) ? "\n" : ""));
-         obstack_grow (&temporary_obstack, string, strlen (string));
-       }
-      obstack_1grow (&temporary_obstack, '\0');
-      candidates = obstack_finish (&temporary_obstack);
-    }
-  /* Issue the error message */
-  method = make_node (FUNCTION_TYPE);
-  TYPE_ARG_TYPES (method) = atl;
-  signature = build_java_argument_signature (method);
-  dup = xstrdup (lang_printable_name (class, 0));
-  parse_error_context (cl, "Can't find %s `%s(%s)' in type `%s'%s",
-                      (lc ? "constructor" : "method"),
-                      (lc ? dup : IDENTIFIER_POINTER (name)),
-                      IDENTIFIER_POINTER (signature), dup,
-                      (candidates ? candidates : ""));
-  free (dup);
-  return NULL_TREE;
-}
-
-/* 15.11.2.1: Find Methods that are Applicable and Accessible. LC is 1
-   when we're looking for a constructor. */
-
-static tree
-find_applicable_accessible_methods_list (lc, class, name, arglist)
-     int lc;
-     tree class, name, arglist;
-{
-  static struct hash_table t, *searched_classes = NULL;
-  static int search_not_done = 0;
-  tree list = NULL_TREE, all_list = NULL_TREE;
-
-  /* Check the hash table to determine if this class has been searched 
-     already. */
-  if (searched_classes)
-    {
-      if (hash_lookup (searched_classes, 
-                      (const hash_table_key) class, FALSE, NULL))
-       return NULL;
-    }
-  else
-    {
-      hash_table_init (&t, hash_newfunc, java_hash_hash_tree_node,
-                      java_hash_compare_tree_node);
-      searched_classes = &t;
-    }
-    
-  search_not_done++;
-  hash_lookup (searched_classes, 
-              (const hash_table_key) class, TRUE, NULL);
-
-  if (!CLASS_LOADED_P (class) && !CLASS_FROM_SOURCE_P (class))
-    {
-      load_class (class, 1);
-      safe_layout_class (class);
-    }
-
-  /* Search interfaces */
-  if (TREE_CODE (TYPE_NAME (class)) == TYPE_DECL 
-      && CLASS_INTERFACE (TYPE_NAME (class)))
-    {
-      int i, n;
-      tree basetype_vec = TYPE_BINFO_BASETYPES (class);
-      search_applicable_methods_list (lc, TYPE_METHODS (class), 
-                                     name, arglist, &list, &all_list);
-      n = TREE_VEC_LENGTH (basetype_vec);
-      for (i = 1; i < n; i++)
-       {
-         tree t = BINFO_TYPE (TREE_VEC_ELT (basetype_vec, i));
-         tree rlist;
-
-         rlist = find_applicable_accessible_methods_list (lc,  t, name, 
-                                                          arglist);
-         list = chainon (rlist, list);
-       }
-    }
-  /* Search classes */
-  else
-    {
-      search_applicable_methods_list (lc, TYPE_METHODS (class), 
-                                     name, arglist, &list, &all_list);
-
-      /* When looking finit$, class$ or instinit$, we turn LC to 1 so
-        that we only search in class. Note that we should have found
-        something at this point. */
-      if (ID_FINIT_P (name) || ID_CLASSDOLLAR_P (name) || ID_INSTINIT_P (name))
-       {
-         lc = 1;
-         if (!list)
-           abort ();
-       }
-
-      /* We must search all interfaces of this class */
-      if (!lc)
-      {
-       tree basetype_vec = TYPE_BINFO_BASETYPES (class);
-       int n = TREE_VEC_LENGTH (basetype_vec), i;
-       for (i = 1; i < n; i++)
-         {
-           tree t = BINFO_TYPE (TREE_VEC_ELT (basetype_vec, i));
-           if (t != object_type_node)
-             {
-               tree rlist
-                 = find_applicable_accessible_methods_list (lc, t,
-                                                            name, arglist);
-               list = chainon (rlist, list);
-             }
-         }
-      }
-
-      /* Search superclass */
-      if (!lc && CLASSTYPE_SUPER (class) != NULL_TREE)
-       {
-          tree rlist;
-          class = CLASSTYPE_SUPER (class);
-          rlist = find_applicable_accessible_methods_list (lc, class, 
-                                                           name, arglist);
-          list = chainon (rlist, list);
-        }
-    }
-
-  search_not_done--;
-
-  /* We're done. Reset the searched classes list and finally search
-     java.lang.Object if it wasn't searched already. */
-  if (!search_not_done)
-    {
-      if (!lc
-         && TYPE_METHODS (object_type_node)
-         && !hash_lookup (searched_classes, 
-                           (const hash_table_key) object_type_node, 
-                           FALSE, NULL))
-       {
-          search_applicable_methods_list (lc, 
-                                          TYPE_METHODS (object_type_node),
-                                          name, arglist, &list, &all_list);
-        }
-      hash_table_free (searched_classes);
-      searched_classes = NULL;
-    }
-
-  /* Either return the list obtained or all selected (but
-     inaccessible) methods for better error report. */
-  return (!list ? all_list : list);
-}
-
-/* Effectively search for the appropriate method in method */
-
-static void 
-search_applicable_methods_list (lc, method, name, arglist, list, all_list)
-     int lc;
-     tree method, name, arglist;
-     tree *list, *all_list;
-{
-  for (; method; method = TREE_CHAIN (method))
-    {
-      /* When dealing with constructor, stop here, otherwise search
-         other classes */
-      if (lc && !DECL_CONSTRUCTOR_P (method))
-       continue;
-      else if (!lc && (DECL_CONSTRUCTOR_P (method) 
-                      || (DECL_NAME (method) != name)))
-       continue;
-
-      if (argument_types_convertible (method, arglist))
-       {
-         /* Retain accessible methods only */
-         if (!not_accessible_p (DECL_CONTEXT (current_function_decl), 
-                                method, NULL_TREE, 0))
-           *list = tree_cons (NULL_TREE, method, *list);
-         else
-           /* Also retain all selected method here */
-           *all_list = tree_cons (NULL_TREE, method, *list);
-       }
-    }
-}
-
-/* 15.11.2.2 Choose the Most Specific Method */
-
-static tree
-find_most_specific_methods_list (list)
-     tree list;
-{
-  int max = 0;
-  int abstract, candidates;
-  tree current, new_list = NULL_TREE;
-  for (current = list; current; current = TREE_CHAIN (current))
-    {
-      tree method;
-      DECL_SPECIFIC_COUNT (TREE_VALUE (current)) = 0;
-
-      for (method = list; method; method = TREE_CHAIN (method))
-       {
-         tree method_v, current_v;
-         /* Don't test a method against itself */
-         if (method == current)
-           continue;
-
-         method_v = TREE_VALUE (method);
-         current_v = TREE_VALUE (current);
-
-         /* Compare arguments and location where methods where declared */
-         if (argument_types_convertible (method_v, current_v))
-           {
-             if (valid_method_invocation_conversion_p 
-                 (DECL_CONTEXT (method_v), DECL_CONTEXT (current_v))
-                 || (INNER_CLASS_TYPE_P (DECL_CONTEXT (current_v))
-                     && enclosing_context_p (DECL_CONTEXT (method_v),
-                                             DECL_CONTEXT (current_v))))
-               {
-                 int v = (DECL_SPECIFIC_COUNT (current_v) += 
-                   (INNER_CLASS_TYPE_P (DECL_CONTEXT (current_v)) ? 2 : 1));
-                 max = (v > max ? v : max);
-               }
-           }
-       }
-    }
-
-  /* Review the list and select the maximally specific methods */
-  for (current = list, abstract = -1, candidates = -1;
-       current; current = TREE_CHAIN (current))
-    if (DECL_SPECIFIC_COUNT (TREE_VALUE (current)) == max)
-      {
-       new_list = tree_cons (NULL_TREE, TREE_VALUE (current), new_list);
-       abstract += (METHOD_ABSTRACT (TREE_VALUE (current)) ? 1 : 0);
-       candidates++;
-      }
-
-  /* If we have several and they're all abstract, just pick the
-     closest one. */
-  if (candidates > 0 && (candidates == abstract))
-    {
-      new_list = nreverse (new_list);
-      TREE_CHAIN (new_list) = NULL_TREE;
-    }
-
-  /* We have several (we couldn't find a most specific), all but one
-     are abstract, we pick the only non abstract one. */
-  if (candidates > 0 && (candidates == abstract+1))
-    {
-      for (current = new_list; current; current = TREE_CHAIN (current))
-       if (!METHOD_ABSTRACT (TREE_VALUE (current)))
-         {
-           TREE_CHAIN (current) = NULL_TREE;
-           new_list = current;
-         }
-    }
-
-  /* If we can't find one, lower expectations and try to gather multiple
-     maximally specific methods */
-  while (!new_list && max)
-    {
-      while (--max > 0)
-       {
-         if (DECL_SPECIFIC_COUNT (TREE_VALUE (current)) == max)
-           new_list = tree_cons (NULL_TREE, TREE_VALUE (current), new_list);
-       }
-    }
-
-  return new_list;
-}
-
-/* Make sure that the type of each M2_OR_ARGLIST arguments can be
-   converted by method invocation conversion (5.3) to the type of the
-   corresponding parameter of M1. Implementation expects M2_OR_ARGLIST
-   to change less often than M1. */
-
-static int
-argument_types_convertible (m1, m2_or_arglist)
-    tree m1, m2_or_arglist;
-{
-  static tree m2_arg_value = NULL_TREE;
-  static tree m2_arg_cache = NULL_TREE;
-  static int initialized_p;
-
-  register tree m1_arg, m2_arg;
-
-  /* Register M2_ARG_VALUE and M2_ARG_CACHE with the garbage
-     collector.  */
-  if (!initialized_p)
-    {
-      ggc_add_tree_root (&m2_arg_value, 1);
-      ggc_add_tree_root (&m2_arg_cache, 1);
-      initialized_p = 1;
-    }
-
-  SKIP_THIS_AND_ARTIFICIAL_PARMS (m1_arg, m1)
-
-  if (m2_arg_value == m2_or_arglist)
-    m2_arg = m2_arg_cache;
-  else
-    {
-      /* M2_OR_ARGLIST can be a function DECL or a raw list of
-         argument types */
-      if (m2_or_arglist && TREE_CODE (m2_or_arglist) == FUNCTION_DECL)
-       {
-         m2_arg = TYPE_ARG_TYPES (TREE_TYPE (m2_or_arglist));
-         if (!METHOD_STATIC (m2_or_arglist))
-           m2_arg = TREE_CHAIN (m2_arg);
-       }
-      else
-       m2_arg = m2_or_arglist;
-
-      m2_arg_value = m2_or_arglist;
-      m2_arg_cache = m2_arg;
-    }
-
-  while (m1_arg != end_params_node && m2_arg != end_params_node)
-    {
-      resolve_and_layout (TREE_VALUE (m1_arg), NULL_TREE);
-      if (!valid_method_invocation_conversion_p (TREE_VALUE (m1_arg),
-                                                TREE_VALUE (m2_arg)))
-       break;
-      m1_arg = TREE_CHAIN (m1_arg);
-      m2_arg = TREE_CHAIN (m2_arg);
-    }
-  return m1_arg == end_params_node && m2_arg == end_params_node;
-}
-
-/* Qualification routines */
-
-static void
-qualify_ambiguous_name (id)
-     tree id;
-{
-  tree qual, qual_wfl, name = NULL_TREE, decl, ptr_type = NULL_TREE,
-    saved_current_class;
-  int again, super_found = 0, this_found = 0, new_array_found = 0;
-  int code;
-
-  /* We first qualify the first element, then derive qualification of
-     others based on the first one. If the first element is qualified
-     by a resolution (field or type), this resolution is stored in the
-     QUAL_RESOLUTION of the qual element being examined. We need to
-     save the current_class since the use of SUPER might change the
-     its value. */
-  saved_current_class = current_class;
-  qual = EXPR_WFL_QUALIFICATION (id);
-  do {
-
-    /* Simple qualified expression feature a qual_wfl that is a
-       WFL. Expression derived from a primary feature more complicated
-       things like a CALL_EXPR. Expression from primary need to be
-       worked out to extract the part on which the qualification will
-       take place. */
-    qual_wfl = QUAL_WFL (qual);
-    switch (TREE_CODE (qual_wfl))
-      {
-      case CALL_EXPR:
-       qual_wfl = TREE_OPERAND (qual_wfl, 0);
-       if (TREE_CODE (qual_wfl) != EXPR_WITH_FILE_LOCATION
-           || (EXPR_WFL_QUALIFICATION (qual_wfl)
-               && TREE_CODE (EXPR_WFL_QUALIFICATION (qual_wfl)) == TREE_LIST))
-         {
-           qual = EXPR_WFL_QUALIFICATION (qual_wfl);
-           qual_wfl = QUAL_WFL (qual);
-         }
-       break;
-      case NEW_ARRAY_EXPR:
-      case NEW_ANONYMOUS_ARRAY_EXPR:
-       qual = TREE_CHAIN (qual);
-       again = new_array_found = 1;
-       continue;
-      case CONVERT_EXPR:
-       break;
-      case NEW_CLASS_EXPR:
-       qual_wfl = TREE_OPERAND (qual_wfl, 0);
-       break;
-      case ARRAY_REF:
-       while (TREE_CODE (qual_wfl) == ARRAY_REF)
-         qual_wfl = TREE_OPERAND (qual_wfl, 0);
-       break;
-      case STRING_CST:
-       qual = TREE_CHAIN (qual);
-       qual_wfl = QUAL_WFL (qual);
-       break;
-      case CLASS_LITERAL:
-       qual = TREE_CHAIN (qual);
-       qual_wfl = QUAL_WFL (qual);
-      break;
-      default:
-       /* Fix for -Wall. Just break doing nothing */
-       break;
-      }
-
-    ptr_type = current_class;
-    again = 0;
-    code = TREE_CODE (qual_wfl);
-
-    /* Pos evaluation: non WFL leading expression nodes */
-    if (code == CONVERT_EXPR
-       && TREE_CODE (TREE_TYPE (qual_wfl)) == EXPR_WITH_FILE_LOCATION)
-      name = EXPR_WFL_NODE (TREE_TYPE (qual_wfl));
-
-    else if (code == INTEGER_CST)
-      name = qual_wfl;
-
-    else if (code == CONVERT_EXPR &&
-            TREE_CODE (TREE_OPERAND (qual_wfl, 0)) == EXPR_WITH_FILE_LOCATION)
-      name = TREE_OPERAND (qual_wfl, 0);
-
-    else if (code == CONVERT_EXPR
-            && TREE_CODE (TREE_OPERAND (qual_wfl, 0)) == CALL_EXPR
-            && (TREE_CODE (TREE_OPERAND (TREE_OPERAND (qual_wfl, 0), 0))
-                == EXPR_WITH_FILE_LOCATION))
-      name = TREE_OPERAND (TREE_OPERAND (qual_wfl, 0), 0);
-
-    else if ((code == ARRAY_REF || code == CALL_EXPR || code == MODIFY_EXPR) &&
-            TREE_CODE (TREE_OPERAND (qual_wfl, 0)) == EXPR_WITH_FILE_LOCATION)
-      name = EXPR_WFL_NODE (TREE_OPERAND (qual_wfl, 0));
-
-    else if (code == TREE_LIST)
-      name = EXPR_WFL_NODE (TREE_PURPOSE (qual_wfl));
-
-    else if (code == STRING_CST || code == CONDITIONAL_EXPR 
-            || code == PLUS_EXPR)
-      {
-       qual = TREE_CHAIN (qual);
-       qual_wfl = QUAL_WFL (qual);
-       again = 1;
-      }
-    else
-      {
-       name = EXPR_WFL_NODE (qual_wfl);
-       if (!name)
-         {
-           qual = EXPR_WFL_QUALIFICATION (qual_wfl);
-           again = 1;
-         }
-      }
-
-    /* If we have a THIS (from a primary), we set the context accordingly */
-    if (name == this_identifier_node)
-      {
-       /* This isn't really elegant. One more added irregularity
-          before I start using COMPONENT_REF (hopefully very soon.)  */
-       if (TREE_CODE (TREE_PURPOSE (qual)) == ARRAY_REF
-           && TREE_CODE (TREE_OPERAND (TREE_PURPOSE (qual), 0)) ==
-              EXPR_WITH_FILE_LOCATION
-           && EXPR_WFL_NODE (TREE_OPERAND (TREE_PURPOSE (qual), 0)) == 
-              this_identifier_node)
-           {
-             qual = TREE_OPERAND (TREE_PURPOSE (qual), 0);
-             qual = EXPR_WFL_QUALIFICATION (qual);
-           }
-       qual = TREE_CHAIN (qual);
-       qual_wfl = QUAL_WFL (qual);
-       if (TREE_CODE (qual_wfl) == CALL_EXPR)
-         again = 1;
-       else if (TREE_CODE (qual_wfl) == EXPR_WITH_FILE_LOCATION)
-         name = EXPR_WFL_NODE (qual_wfl);
-       else if (TREE_CODE (qual_wfl) == NEW_CLASS_EXPR)
-         name = TREE_OPERAND (qual_wfl, 0);
-       this_found = 1;
-      }
-    /* If we have a SUPER, we set the context accordingly */
-    if (name == super_identifier_node)
-      {
-       current_class = CLASSTYPE_SUPER (ptr_type);
-       /* Check that there is such a thing as a super class. If not,
-          return.  The error will be caught later on, during the
-          resolution */
-       if (!current_class)
-         {
-           current_class = saved_current_class;
-           return;
-         }
-       qual = TREE_CHAIN (qual);
-       /* Do one more interation to set things up */
-       super_found = again = 1;
-      }
-  } while (again);
-  
-  /* If name appears within the scope of a local variable declaration
-     or parameter declaration, then it is an expression name. We don't
-     carry this test out if we're in the context of the use of SUPER
-     or THIS */
-  if (!this_found && !super_found 
-      && TREE_CODE (name) != STRING_CST && TREE_CODE (name) != INTEGER_CST
-      && (decl = IDENTIFIER_LOCAL_VALUE (name)))
-    {
-      RESOLVE_EXPRESSION_NAME_P (qual_wfl) = 1;
-      QUAL_RESOLUTION (qual) = decl;
-    }
-
-  /* If within the class/interface NAME was found to be used there
-     exists a (possibly inherited) field named NAME, then this is an
-     expression name. If we saw a NEW_ARRAY_EXPR before and want to
-     address length, it is OK. */
-  else if ((decl = lookup_field_wrapper (ptr_type, name))
-          || name == length_identifier_node)
-    {
-      RESOLVE_EXPRESSION_NAME_P (qual_wfl) = 1;
-      QUAL_RESOLUTION (qual) = (new_array_found ? NULL_TREE : decl);
-    }
-
-  /* We reclassify NAME as yielding to a type name resolution if:
-     - NAME is a class/interface declared within the compilation
-       unit containing NAME,
-     - NAME is imported via a single-type-import declaration,
-     - NAME is declared in an another compilation unit of the package
-       of the compilation unit containing NAME,
-     - NAME is declared by exactly on type-import-on-demand declaration
-     of the compilation unit containing NAME. 
-     - NAME is actually a STRING_CST.
-     This can't happen if the expression was qualified by `this.' */
-  else if (! this_found &&
-          (TREE_CODE (name) == STRING_CST ||
-           TREE_CODE (name) == INTEGER_CST ||
-           (decl = resolve_and_layout (name, NULL_TREE))))
-    {
-      RESOLVE_TYPE_NAME_P (qual_wfl) = 1;
-      QUAL_RESOLUTION (qual) = decl;
-    }
-
-  /* Method call, array references and cast are expression name */
-  else if (TREE_CODE (QUAL_WFL (qual)) == CALL_EXPR
-          || TREE_CODE (QUAL_WFL (qual)) == ARRAY_REF
-          || TREE_CODE (QUAL_WFL (qual)) == CONVERT_EXPR
-          || TREE_CODE (QUAL_WFL (qual)) == MODIFY_EXPR)
-    RESOLVE_EXPRESSION_NAME_P (qual_wfl) = 1;
-
-  /* Check here that NAME isn't declared by more than one
-     type-import-on-demand declaration of the compilation unit
-     containing NAME. FIXME */
-
-  /* Otherwise, NAME is reclassified as a package name */
-  else 
-    RESOLVE_PACKAGE_NAME_P (qual_wfl) = 1;
-
-  /* Propagate the qualification accross other components of the
-     qualified name */
-  for (qual = TREE_CHAIN (qual); qual;
-       qual_wfl = QUAL_WFL (qual), qual = TREE_CHAIN (qual))
-    {
-      if (RESOLVE_PACKAGE_NAME_P (qual_wfl))
-       RESOLVE_PACKAGE_NAME_P (QUAL_WFL (qual)) = 1;
-      else 
-       RESOLVE_EXPRESSION_NAME_P (QUAL_WFL (qual)) = 1;
-    }
-
-  /* Store the global qualification for the ambiguous part of ID back
-     into ID fields */
-  if (RESOLVE_EXPRESSION_NAME_P (qual_wfl))
-    RESOLVE_EXPRESSION_NAME_P (id) = 1;
-  else if (RESOLVE_TYPE_NAME_P (qual_wfl))
-    RESOLVE_TYPE_NAME_P (id) = 1;
-  else if (RESOLVE_PACKAGE_NAME_P (qual_wfl))
-    RESOLVE_PACKAGE_NAME_P (id) = 1;
-
-  /* Restore the current class */
-  current_class = saved_current_class;
-}
-
-static int
-breakdown_qualified (left, right, source)
-    tree *left, *right, source;
-{
-  char *p, *base;
-  int   l = IDENTIFIER_LENGTH (source);
-
-  base = alloca (l + 1);
-  memcpy (base, IDENTIFIER_POINTER (source), l + 1);
-
-  /* Breakdown NAME into REMAINDER . IDENTIFIER */
-  p = base + l - 1;
-  while (*p != '.' && p != base)
-    p--;
-
-  /* We didn't find a '.'. Return an error */
-  if (p == base)
-    return 1;
-
-  *p = '\0';
-  if (right)
-    *right = get_identifier (p+1);
-  *left = get_identifier (base);
-  
-  return 0;
-}
-
-/* Return TRUE if two classes are from the same package. */
-
-static int
-in_same_package (name1, name2)
-  tree name1, name2;
-{
-  tree tmp;
-  tree pkg1;
-  tree pkg2;
-  
-  if (TREE_CODE (name1) == TYPE_DECL)
-    name1 = DECL_NAME (name1);
-  if (TREE_CODE (name2) == TYPE_DECL)
-    name2 = DECL_NAME (name2);
-
-  if (QUALIFIED_P (name1) != QUALIFIED_P (name2))
-    /* One in empty package. */
-    return 0;
-
-  if (QUALIFIED_P (name1) == 0 && QUALIFIED_P (name2) == 0)
-    /* Both in empty package. */
-    return 1;
-
-  breakdown_qualified (&pkg1, &tmp, name1);
-  breakdown_qualified (&pkg2, &tmp, name2);
-  
-  return (pkg1 == pkg2);
-}
-
-/* Patch tree nodes in a function body. When a BLOCK is found, push
-   local variable decls if present.
-   Same as java_complete_lhs, but does resolve static finals to values. */
-
-static tree
-java_complete_tree (node)
-     tree node;
-{
-  node = java_complete_lhs (node);
-  if (JDECL_P (node) && CLASS_FINAL_VARIABLE_P (node)
-      && DECL_INITIAL (node) != NULL_TREE
-      && !flag_emit_xref)
-    {
-      tree value = DECL_INITIAL (node);
-      DECL_INITIAL (node) = NULL_TREE;
-      value = fold_constant_for_init (value, node);
-      DECL_INITIAL (node) = value;
-      if (value != NULL_TREE)
-       {
-         /* fold_constant_for_init sometimes widens the original type
-             of the constant (i.e. byte to int). It's not desirable,
-             especially if NODE is a function argument. */
-         if ((TREE_CODE (value) == INTEGER_CST
-              || TREE_CODE (value) == REAL_CST)
-             && TREE_TYPE (node) != TREE_TYPE (value))
-           return convert (TREE_TYPE (node), value);
-         else
-           return value;
-       }
-    }
-  return node;
-}
-
-static tree
-java_stabilize_reference (node)
-     tree node;
-{
-  if (TREE_CODE (node) == COMPOUND_EXPR)
-    {
-      tree op0 = TREE_OPERAND (node, 0);
-      tree op1 = TREE_OPERAND (node, 1);
-      TREE_OPERAND (node, 0) = save_expr (op0);
-      TREE_OPERAND (node, 1) = java_stabilize_reference (op1);
-      return node;
-    }
-  return stabilize_reference (node);
-}
-
-/* Patch tree nodes in a function body. When a BLOCK is found, push
-   local variable decls if present.
-   Same as java_complete_tree, but does not resolve static finals to values. */
-
-static tree
-java_complete_lhs (node)
-     tree node;
-{
-  tree nn, cn, wfl_op1, wfl_op2, wfl_op3;
-  int flag;
-
-  /* CONVERT_EXPR always has its type set, even though it needs to be
-     worked out. */
-  if (TREE_TYPE (node) && TREE_CODE (node) != CONVERT_EXPR)
-    return node;
-
-  /* The switch block implements cases processing container nodes
-     first.  Contained nodes are always written back. Leaves come
-     next and return a value. */
-  switch (TREE_CODE (node))
-    {
-    case BLOCK:
-
-      /* 1- Block section.
-        Set the local values on decl names so we can identify them
-        faster when they're referenced. At that stage, identifiers
-        are legal so we don't check for declaration errors. */
-      for (cn = BLOCK_EXPR_DECLS (node); cn; cn = TREE_CHAIN (cn))
-       {
-         DECL_CONTEXT (cn) = current_function_decl;
-         IDENTIFIER_LOCAL_VALUE (DECL_NAME (cn)) = cn;
-       }
-      if (BLOCK_EXPR_BODY (node) == NULL_TREE)
-         CAN_COMPLETE_NORMALLY (node) = 1;
-      else
-       {
-         tree stmt = BLOCK_EXPR_BODY (node);
-         tree *ptr;
-         int error_seen = 0;
-         if (TREE_CODE (stmt) == COMPOUND_EXPR)
-           {
-             /* Re-order from (((A; B); C); ...; Z) to 
-                (A; (B; (C ; (...; Z)))).
-                This makes it easier to scan the statements left-to-right
-                without using recursion (which might overflow the stack
-                if the block has many statements. */
-             for (;;)
-               {
-                 tree left = TREE_OPERAND (stmt, 0);
-                 if (TREE_CODE (left) != COMPOUND_EXPR)
-                   break;
-                 TREE_OPERAND (stmt, 0) = TREE_OPERAND (left, 1);
-                 TREE_OPERAND (left, 1) = stmt;
-                 stmt = left;
-               }
-             BLOCK_EXPR_BODY (node) = stmt;
-           }
-
-         /* Now do the actual complete, without deep recursion for
-             long blocks. */
-         ptr = &BLOCK_EXPR_BODY (node);
-         while (TREE_CODE (*ptr) == COMPOUND_EXPR
-                && TREE_OPERAND (*ptr, 1) != empty_stmt_node)
-           {
-             tree cur = java_complete_tree (TREE_OPERAND (*ptr, 0));
-             tree *next = &TREE_OPERAND (*ptr, 1);
-             TREE_OPERAND (*ptr, 0) = cur;
-             if (cur == empty_stmt_node)
-               {
-                 /* Optimization;  makes it easier to detect empty bodies.
-                    Most useful for <clinit> with all-constant initializer. */
-                 *ptr = *next;
-                 continue;
-               }
-             if (TREE_CODE (cur) == ERROR_MARK)
-               error_seen++;
-             else if (! CAN_COMPLETE_NORMALLY (cur))
-               {
-                 wfl_op2 = *next;
-                 for (;;)
-                   {
-                     if (TREE_CODE (wfl_op2) == BLOCK)
-                       wfl_op2 = BLOCK_EXPR_BODY (wfl_op2);
-                     else if (TREE_CODE (wfl_op2) == COMPOUND_EXPR)
-                       wfl_op2 = TREE_OPERAND (wfl_op2, 0);
-                     else
-                       break;
-                   }
-                 if (TREE_CODE (wfl_op2) != CASE_EXPR
-                     && TREE_CODE (wfl_op2) != DEFAULT_EXPR)
-                   unreachable_stmt_error (*ptr);
-               }
-             ptr = next;
-           }
-         *ptr = java_complete_tree (*ptr);
-
-         if (TREE_CODE (*ptr) == ERROR_MARK || error_seen > 0)
-           return error_mark_node;
-         CAN_COMPLETE_NORMALLY (node) = CAN_COMPLETE_NORMALLY (*ptr);
-       }
-      /* Turn local bindings to null */
-      for (cn = BLOCK_EXPR_DECLS (node); cn; cn = TREE_CHAIN (cn))
-       IDENTIFIER_LOCAL_VALUE (DECL_NAME (cn)) = NULL_TREE;
-
-      TREE_TYPE (node) = void_type_node;
-      break;
-
-      /* 2- They are expressions but ultimately deal with statements */
-
-    case THROW_EXPR:
-      wfl_op1 = TREE_OPERAND (node, 0);
-      COMPLETE_CHECK_OP_0 (node);
-      /* 14.19 A throw statement cannot complete normally. */
-      CAN_COMPLETE_NORMALLY (node) = 0;
-      return patch_throw_statement (node, wfl_op1);
-
-    case SYNCHRONIZED_EXPR:
-      wfl_op1 = TREE_OPERAND (node, 0);
-      return patch_synchronized_statement (node, wfl_op1);
-
-    case TRY_EXPR:
-      return patch_try_statement (node);
-
-    case TRY_FINALLY_EXPR:
-      COMPLETE_CHECK_OP_0 (node);
-      COMPLETE_CHECK_OP_1 (node);
-      if (TREE_OPERAND (node, 0) == empty_stmt_node)
-       return TREE_OPERAND (node, 1);
-      if (TREE_OPERAND (node, 1) == empty_stmt_node)
-       return TREE_OPERAND (node, 0);
-      CAN_COMPLETE_NORMALLY (node)
-       = (CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 0))
-          && CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 1)));
-      TREE_TYPE (node) = TREE_TYPE (TREE_OPERAND (node, 0));
-      return node;
-
-    case LABELED_BLOCK_EXPR:
-      PUSH_LABELED_BLOCK (node);
-      if (LABELED_BLOCK_BODY (node))
-       COMPLETE_CHECK_OP_1 (node);
-      TREE_TYPE (node) = void_type_node;
-      POP_LABELED_BLOCK ();
-
-      if (LABELED_BLOCK_BODY (node) == empty_stmt_node)
-       {
-         LABELED_BLOCK_BODY (node) = NULL_TREE;
-         CAN_COMPLETE_NORMALLY (node) = 1;
-       }
-      else if (CAN_COMPLETE_NORMALLY (LABELED_BLOCK_BODY (node)))
-       CAN_COMPLETE_NORMALLY (node) = 1;
-      return node;
-
-    case EXIT_BLOCK_EXPR:
-      /* We don't complete operand 1, because it's the return value of
-         the EXIT_BLOCK_EXPR which doesn't exist it Java */
-      return patch_bc_statement (node);
-
-    case CASE_EXPR:
-      cn = java_complete_tree (TREE_OPERAND (node, 0));
-      if (cn == error_mark_node)
-       return cn;
-
-      /* First, the case expression must be constant. Values of final
-         fields are accepted. */
-      cn = fold (cn);
-      if ((TREE_CODE (cn) == COMPOUND_EXPR || TREE_CODE (cn) == COMPONENT_REF)
-         && JDECL_P (TREE_OPERAND (cn, 1))
-         && FIELD_FINAL (TREE_OPERAND (cn, 1))
-         && DECL_INITIAL (TREE_OPERAND (cn, 1)))
-       {
-         cn = fold_constant_for_init (DECL_INITIAL (TREE_OPERAND (cn, 1)),
-                                      TREE_OPERAND (cn, 1));
-       }
-      /* Accept final locals too. */
-      else if (TREE_CODE (cn) == VAR_DECL && DECL_FINAL (cn))
-       cn = fold_constant_for_init (DECL_INITIAL (cn), cn);
-
-      if (!TREE_CONSTANT (cn) && !flag_emit_xref)
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-         parse_error_context (node, "Constant expression required");
-         return error_mark_node;
-       }
-
-      nn = ctxp->current_loop;
-
-      /* It must be assignable to the type of the switch expression. */
-      if (!try_builtin_assignconv (NULL_TREE, 
-                                  TREE_TYPE (TREE_OPERAND (nn, 0)), cn))
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-         parse_error_context 
-           (wfl_operator,
-            "Incompatible type for case. Can't convert `%s' to `int'",
-            lang_printable_name (TREE_TYPE (cn), 0));
-         return error_mark_node;
-       }
-
-      cn = fold (convert (int_type_node, cn));
-      TREE_CONSTANT_OVERFLOW (cn) = 0;
-      CAN_COMPLETE_NORMALLY (cn) = 1;
-
-      /* Save the label on a list so that we can later check for
-        duplicates.  */
-      case_label_list = tree_cons (node, cn, case_label_list);
-
-      /* Multiple instance of a case label bearing the same value is
-        checked later. The case expression is all right so far. */
-      if (TREE_CODE (cn) == VAR_DECL)
-       cn = DECL_INITIAL (cn);
-      TREE_OPERAND (node, 0) = cn;
-      TREE_TYPE (node) = void_type_node;
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      TREE_SIDE_EFFECTS (node) = 1;
-      break;
-
-    case DEFAULT_EXPR:
-      nn = ctxp->current_loop;
-      /* Only one default label is allowed per switch statement */
-      if (SWITCH_HAS_DEFAULT (nn))
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-         parse_error_context (wfl_operator, 
-                              "Duplicate case label: `default'");
-         return error_mark_node;
-       }
-      else
-       SWITCH_HAS_DEFAULT (nn) = 1;
-      TREE_TYPE (node) = void_type_node;
-      TREE_SIDE_EFFECTS (node) = 1;
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      break;
-
-    case SWITCH_EXPR:
-    case LOOP_EXPR:
-      PUSH_LOOP (node);
-      /* Check whether the loop was enclosed in a labeled
-         statement. If not, create one, insert the loop in it and
-         return the node */
-      nn = patch_loop_statement (node);
-
-      /* Anyways, walk the body of the loop */
-      if (TREE_CODE (node) == LOOP_EXPR)
-       TREE_OPERAND (node, 0) = java_complete_tree (TREE_OPERAND (node, 0));
-      /* Switch statement: walk the switch expression and the cases */
-      else
-       node = patch_switch_statement (node);
-
-      if (node == error_mark_node || TREE_OPERAND (node, 0) == error_mark_node)
-       nn = error_mark_node;
-      else
-       {
-         TREE_TYPE (nn) = TREE_TYPE (node) = void_type_node;
-         /* If we returned something different, that's because we
-            inserted a label. Pop the label too. */
-         if (nn != node)
-           {
-             if (CAN_COMPLETE_NORMALLY (node))
-               CAN_COMPLETE_NORMALLY (nn) = 1;
-             POP_LABELED_BLOCK ();
-           }
-       }
-      POP_LOOP ();
-      return nn;
-
-    case EXIT_EXPR:
-      TREE_OPERAND (node, 0) = java_complete_tree (TREE_OPERAND (node, 0));
-      return patch_exit_expr (node);
-
-    case COND_EXPR:
-      /* Condition */
-      TREE_OPERAND (node, 0) = java_complete_tree (TREE_OPERAND (node, 0));
-      if (TREE_OPERAND (node, 0) == error_mark_node)
-       return error_mark_node;
-      /* then-else branches */
-      TREE_OPERAND (node, 1) = java_complete_tree (TREE_OPERAND (node, 1));
-      if (TREE_OPERAND (node, 1) == error_mark_node)
-       return error_mark_node;
-      TREE_OPERAND (node, 2) = java_complete_tree (TREE_OPERAND (node, 2));
-      if (TREE_OPERAND (node, 2) == error_mark_node)
-       return error_mark_node;
-      return patch_if_else_statement (node);
-      break;
-
-    case CONDITIONAL_EXPR:
-      /* Condition */
-      wfl_op1 = TREE_OPERAND (node, 0);
-      COMPLETE_CHECK_OP_0 (node);
-      wfl_op2 = TREE_OPERAND (node, 1);
-      COMPLETE_CHECK_OP_1 (node);
-      wfl_op3 = TREE_OPERAND (node, 2);
-      COMPLETE_CHECK_OP_2 (node);
-      return patch_conditional_expr (node, wfl_op1, wfl_op2);
-
-      /* 3- Expression section */
-    case COMPOUND_EXPR:
-      wfl_op2 = TREE_OPERAND (node, 1);
-      TREE_OPERAND (node, 0) = nn = 
-       java_complete_tree (TREE_OPERAND (node, 0));
-      if (wfl_op2 == empty_stmt_node)
-       CAN_COMPLETE_NORMALLY (node) = CAN_COMPLETE_NORMALLY (nn);
-      else
-       {
-         if (! CAN_COMPLETE_NORMALLY (nn) && TREE_CODE (nn) != ERROR_MARK)
-           {
-             /* An unreachable condition in a do-while statement
-                is *not* (technically) an unreachable statement. */
-             nn = wfl_op2;
-             if (TREE_CODE (nn) == EXPR_WITH_FILE_LOCATION)
-               nn = EXPR_WFL_NODE (nn);
-             if (TREE_CODE (nn) != EXIT_EXPR)
-               {
-                 SET_WFL_OPERATOR (wfl_operator, node, wfl_op2);
-                 parse_error_context (wfl_operator, "Unreachable statement");
-               }
-           }
-         TREE_OPERAND (node, 1) = java_complete_tree (TREE_OPERAND (node, 1));
-         if (TREE_OPERAND (node, 1) == error_mark_node)
-           return error_mark_node;
-         /* Even though we might allow the case where the first
-            operand doesn't return normally, we still should compute
-            CAN_COMPLETE_NORMALLY correctly.  */
-         CAN_COMPLETE_NORMALLY (node)
-           = (CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 0))
-              && CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 1)));
-       }
-      TREE_TYPE (node) = TREE_TYPE (TREE_OPERAND (node, 1));
-      break;
-
-    case RETURN_EXPR:
-      /* CAN_COMPLETE_NORMALLY (node) = 0; */
-      return patch_return (node);
-
-    case EXPR_WITH_FILE_LOCATION:
-      if (!EXPR_WFL_NODE (node) /* Or a PRIMARY flag ? */
-         || TREE_CODE (EXPR_WFL_NODE (node)) == IDENTIFIER_NODE)
-       {
-         tree wfl = node;
-         node = resolve_expression_name (node, NULL);
-         if (node == error_mark_node)
-           return node;
-         /* Keep line number information somewhere were it doesn't
-            disrupt the completion process. */
-         if (flag_emit_xref && TREE_CODE (node) != CALL_EXPR)
-           {
-             EXPR_WFL_NODE (wfl) = TREE_OPERAND (node, 1);
-             TREE_OPERAND (node, 1) = wfl;
-           }
-         CAN_COMPLETE_NORMALLY (node) = 1;
-       }
-      else
-       {
-         tree body;
-         int save_lineno = lineno;
-         lineno = EXPR_WFL_LINENO (node);
-         body = java_complete_tree (EXPR_WFL_NODE (node));
-         lineno = save_lineno;
-         EXPR_WFL_NODE (node) = body;
-         TREE_SIDE_EFFECTS (node) = TREE_SIDE_EFFECTS (body);
-         CAN_COMPLETE_NORMALLY (node) = CAN_COMPLETE_NORMALLY (body);
-         if (body == empty_stmt_node || TREE_CONSTANT (body))
-           {
-             /* Makes it easier to constant fold, detect empty bodies. */
-             return body;
-           }
-         if (body == error_mark_node)
-           {
-             /* Its important for the evaluation of assignment that
-                this mark on the TREE_TYPE is propagated. */
-             TREE_TYPE (node) = error_mark_node;
-             return error_mark_node;
-           }
-         else
-           TREE_TYPE (node) = TREE_TYPE (EXPR_WFL_NODE (node));
-         
-       }
-      break;
-
-    case NEW_ARRAY_EXPR:
-      /* Patch all the dimensions */
-      flag = 0;
-      for (cn = TREE_OPERAND (node, 1); cn; cn = TREE_CHAIN (cn))
-       {
-         int location = EXPR_WFL_LINECOL (TREE_VALUE (cn));
-         tree dim = convert (int_type_node, 
-                             java_complete_tree (TREE_VALUE (cn)));
-         if (dim == error_mark_node)
-           {
-             flag = 1;
-             continue;
-           }
-         else
-           {
-             TREE_VALUE (cn) = dim;
-             /* Setup the location of the current dimension, for
-                later error report. */
-             TREE_PURPOSE (cn) = 
-               build_expr_wfl (NULL_TREE, input_filename, 0, 0);
-             EXPR_WFL_LINECOL (TREE_PURPOSE (cn)) = location;
-           }
-       }
-      /* They complete the array creation expression, if no errors
-         were found. */
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      return (flag ? error_mark_node
-             : force_evaluation_order (patch_newarray (node)));
-
-    case NEW_ANONYMOUS_ARRAY_EXPR:
-      /* Create the array type if necessary. */
-      if (ANONYMOUS_ARRAY_DIMS_SIG (node))
-       {
-         tree type = ANONYMOUS_ARRAY_BASE_TYPE (node);
-         if (!(type = resolve_type_during_patch (type)))
-           return error_mark_node;
-         type = build_array_from_name (type, NULL_TREE,
-                                       ANONYMOUS_ARRAY_DIMS_SIG (node), NULL);
-         ANONYMOUS_ARRAY_BASE_TYPE (node) = build_pointer_type (type);
-       }
-      node = patch_new_array_init (ANONYMOUS_ARRAY_BASE_TYPE (node),
-                                  ANONYMOUS_ARRAY_INITIALIZER (node));
-      if (node == error_mark_node)
-       return error_mark_node;
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      return node;
-
-    case NEW_CLASS_EXPR:
-    case CALL_EXPR:
-      /* Complete function's argument(s) first */
-      if (complete_function_arguments (node))
-       return error_mark_node;
-      else
-       {
-         tree decl, wfl = TREE_OPERAND (node, 0);
-         int in_this = CALL_THIS_CONSTRUCTOR_P (node);
-         int from_super = (EXPR_WFL_NODE (TREE_OPERAND (node, 0)) ==
-                           super_identifier_node);
-
-         node = patch_method_invocation (node, NULL_TREE, NULL_TREE,
-                                         from_super, 0, &decl);
-         if (node == error_mark_node)
-           return error_mark_node;
-
-         check_thrown_exceptions (EXPR_WFL_LINECOL (node), decl);
-         /* If we call this(...), register signature and positions */
-         if (in_this)
-           DECL_CONSTRUCTOR_CALLS (current_function_decl) = 
-             tree_cons (wfl, decl, 
-                        DECL_CONSTRUCTOR_CALLS (current_function_decl));
-         CAN_COMPLETE_NORMALLY (node) = 1;
-         return force_evaluation_order (node);
-       }
-
-    case MODIFY_EXPR:
-      /* Save potential wfls */
-      wfl_op1 = TREE_OPERAND (node, 0);
-      TREE_OPERAND (node, 0) = nn = java_complete_lhs (wfl_op1);
-      
-      if (MODIFY_EXPR_FROM_INITIALIZATION_P (node)
-         && TREE_CODE (nn) == VAR_DECL && TREE_STATIC (nn)
-         && DECL_INITIAL (nn) != NULL_TREE)
-       {
-         tree value;
-         
-         value = fold_constant_for_init (nn, nn);
-
-         /* When we have a primitype type, or a string and we're not
-             emitting a class file, we actually don't want to generate
-             anything for the assignment. */
-         if (value != NULL_TREE &&
-             (JPRIMITIVE_TYPE_P (TREE_TYPE (value)) || 
-              (TREE_TYPE (value) == string_ptr_type_node &&
-               ! flag_emit_class_files)))
-           {
-             /* Prepare node for patch_assignment */
-             TREE_OPERAND (node, 1) = value;
-             /* Call patch assignment to verify the assignment */
-             if (patch_assignment (node, wfl_op1) == error_mark_node)
-               return error_mark_node;
-             /* Set DECL_INITIAL properly (a conversion might have
-                 been decided by patch_assignment) and return the
-                 empty statement. */
-             else
-               {
-                 tree patched = patch_string (TREE_OPERAND (node, 1));
-                 if (patched)
-                   DECL_INITIAL (nn) = patched;
-                 else
-                   DECL_INITIAL (nn) = TREE_OPERAND (node, 1);
-                 DECL_FIELD_FINAL_IUD (nn) = 1;
-                 return empty_stmt_node;
-               }
-           }
-         if (! flag_emit_class_files)
-           DECL_INITIAL (nn) = NULL_TREE;
-       }
-      wfl_op2 = TREE_OPERAND (node, 1);
-
-      if (TREE_OPERAND (node, 0) == error_mark_node)
-       return error_mark_node;
-
-      flag = COMPOUND_ASSIGN_P (wfl_op2);
-      if (flag)
-       {
-         /* This might break when accessing outer field from inner
-             class. TESTME, FIXME */
-         tree lvalue = java_stabilize_reference (TREE_OPERAND (node, 0)); 
-
-         /* Hand stabilize the lhs on both places */
-         TREE_OPERAND (node, 0) = lvalue;
-         TREE_OPERAND (TREE_OPERAND (node, 1), 0) = 
-           (flag_emit_class_files ? lvalue : save_expr (lvalue));
-
-         /* 15.25.2.a: Left hand is not an array access. FIXME */
-         /* Now complete the RHS. We write it back later on. */
-         nn = java_complete_tree (TREE_OPERAND (node, 1));
-
-         if ((cn = patch_string (nn)))
-           nn = cn;
-
-         /* The last part of the rewrite for E1 op= E2 is to have 
-            E1 = (T)(E1 op E2), with T being the type of E1. */
-         nn = java_complete_tree (build_cast (EXPR_WFL_LINECOL (wfl_op2), 
-                                              TREE_TYPE (lvalue), nn));
-
-         /* If the assignment is compound and has reference type,
-            then ensure the LHS has type String and nothing else.  */
-         if (JREFERENCE_TYPE_P (TREE_TYPE (lvalue))
-             && ! JSTRING_TYPE_P (TREE_TYPE (lvalue)))
-           parse_error_context (wfl_op2,
-                                "Incompatible type for `+='. Can't convert `%s' to `java.lang.String'",
-                                lang_printable_name (TREE_TYPE (lvalue), 0));
-
-         /* 15.25.2.b: Left hand is an array access. FIXME */
-       }
-
-      /* If we're about to patch a NEW_ARRAY_INIT, we call a special
-        function to complete this RHS. Note that a NEW_ARRAY_INIT
-        might have been already fully expanded if created as a result
-        of processing an anonymous array initializer. We avoid doing
-        the operation twice by testing whether the node already bears
-        a type. */
-      else if (TREE_CODE (wfl_op2) == NEW_ARRAY_INIT && !TREE_TYPE (wfl_op2))
-       nn = patch_new_array_init (TREE_TYPE (TREE_OPERAND (node, 0)),
-                                  TREE_OPERAND (node, 1));
-      /* Otherwise we simply complete the RHS */
-      else
-       nn = java_complete_tree (TREE_OPERAND (node, 1));
-
-      if (nn == error_mark_node)
-       return error_mark_node;
-
-      /* Write back the RHS as we evaluated it. */
-      TREE_OPERAND (node, 1) = nn;
-
-      /* In case we're handling = with a String as a RHS, we need to
-        produce a String out of the RHS (it might still be a
-        STRING_CST or a StringBuffer at this stage */
-      if ((nn = patch_string (TREE_OPERAND (node, 1))))
-       TREE_OPERAND (node, 1) = nn;
-
-      if ((nn = outer_field_access_fix (wfl_op1, TREE_OPERAND (node, 0),
-                                       TREE_OPERAND (node, 1))))
-       {
-         /* We return error_mark_node if outer_field_access_fix
-            detects we write into a final. */
-         if (nn == error_mark_node)
-           return error_mark_node;
-         node = nn;
-       }
-      else
-       {
-         node = patch_assignment (node, wfl_op1);
-         if (node == error_mark_node)
-           return error_mark_node;
-         /* Reorganize the tree if necessary. */
-         if (flag && (!JREFERENCE_TYPE_P (TREE_TYPE (node)) 
-                      || JSTRING_P (TREE_TYPE (node))))
-           node = java_refold (node);
-       }
-
-      /* Seek to set DECL_INITIAL to a proper value, since it might have
-        undergone a conversion in patch_assignment. We do that only when
-        it's necessary to have DECL_INITIAL properly set. */
-      nn = TREE_OPERAND (node, 0);
-      if (TREE_CODE (nn) == VAR_DECL 
-         && DECL_INITIAL (nn) && CONSTANT_VALUE_P (DECL_INITIAL (nn))
-         && FIELD_STATIC (nn) && FIELD_FINAL (nn) 
-         && (JPRIMITIVE_TYPE_P (TREE_TYPE (nn))
-             || TREE_TYPE (nn) == string_ptr_type_node))
-       DECL_INITIAL (nn) = TREE_OPERAND (node, 1);
-
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      return node;
-
-    case MULT_EXPR:
-    case PLUS_EXPR:
-    case MINUS_EXPR:
-    case LSHIFT_EXPR:
-    case RSHIFT_EXPR:
-    case URSHIFT_EXPR:
-    case BIT_AND_EXPR:
-    case BIT_XOR_EXPR:
-    case BIT_IOR_EXPR:
-    case TRUNC_MOD_EXPR:
-    case TRUNC_DIV_EXPR:
-    case RDIV_EXPR:
-    case TRUTH_ANDIF_EXPR:
-    case TRUTH_ORIF_EXPR:
-    case EQ_EXPR: 
-    case NE_EXPR:
-    case GT_EXPR:
-    case GE_EXPR:
-    case LT_EXPR:
-    case LE_EXPR:
-      /* Operands 0 and 1 are WFL in certain cases only. patch_binop
-        knows how to handle those cases. */
-      wfl_op1 = TREE_OPERAND (node, 0);
-      wfl_op2 = TREE_OPERAND (node, 1);
-
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      /* Don't complete string nodes if dealing with the PLUS operand. */
-      if (TREE_CODE (node) != PLUS_EXPR || !JSTRING_P (wfl_op1))
-        {
-          nn = java_complete_tree (wfl_op1);
-          if (nn == error_mark_node)
-            return error_mark_node;
-
-          TREE_OPERAND (node, 0) = nn;
-        }
-      if (TREE_CODE (node) != PLUS_EXPR || !JSTRING_P (wfl_op2))
-        {
-          nn = java_complete_tree (wfl_op2);
-          if (nn == error_mark_node)
-            return error_mark_node;
-
-          TREE_OPERAND (node, 1) = nn;
-        }
-      return force_evaluation_order (patch_binop (node, wfl_op1, wfl_op2));
-
-    case INSTANCEOF_EXPR:
-      wfl_op1 = TREE_OPERAND (node, 0);
-      COMPLETE_CHECK_OP_0 (node);
-      if (flag_emit_xref)
-       {
-         TREE_TYPE (node) = boolean_type_node;
-         return node;
-       }
-      return patch_binop (node, wfl_op1, TREE_OPERAND (node, 1));
-
-    case UNARY_PLUS_EXPR:
-    case NEGATE_EXPR:
-    case TRUTH_NOT_EXPR:
-    case BIT_NOT_EXPR:
-    case PREDECREMENT_EXPR:
-    case PREINCREMENT_EXPR:
-    case POSTDECREMENT_EXPR:
-    case POSTINCREMENT_EXPR:
-    case CONVERT_EXPR:
-      /* There are cases were wfl_op1 is a WFL. patch_unaryop knows
-        how to handle those cases. */
-      wfl_op1 = TREE_OPERAND (node, 0);
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      TREE_OPERAND (node, 0) = java_complete_tree (wfl_op1);
-      if (TREE_OPERAND (node, 0) == error_mark_node)
-       return error_mark_node;
-      node = patch_unaryop (node, wfl_op1);
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      break;
-
-    case ARRAY_REF:
-      /* There are cases were wfl_op1 is a WFL. patch_array_ref knows
-        how to handle those cases. */
-      wfl_op1 = TREE_OPERAND (node, 0);
-      TREE_OPERAND (node, 0) = java_complete_tree (wfl_op1);
-      if (TREE_OPERAND (node, 0) == error_mark_node)
-       return error_mark_node;
-      if (!flag_emit_class_files && !flag_emit_xref)
-       TREE_OPERAND (node, 0) = save_expr (TREE_OPERAND (node, 0));
-      /* The same applies to wfl_op2 */
-      wfl_op2 = TREE_OPERAND (node, 1);
-      TREE_OPERAND (node, 1) = java_complete_tree (wfl_op2);
-      if (TREE_OPERAND (node, 1) == error_mark_node)
-       return error_mark_node;
-      if (!flag_emit_class_files && !flag_emit_xref)
-       TREE_OPERAND (node, 1) = save_expr (TREE_OPERAND (node, 1));
-      return patch_array_ref (node);
-
-    case RECORD_TYPE:
-      return node;;
-
-    case COMPONENT_REF:
-      /* The first step in the re-write of qualified name handling.  FIXME.
-        So far, this is only to support PRIMTYPE.class -> PRIMCLASS.TYPE. */
-      TREE_OPERAND (node, 0) = java_complete_tree (TREE_OPERAND (node, 0));
-      if (TREE_CODE (TREE_OPERAND (node, 0)) == RECORD_TYPE)
-       {
-         tree name = TREE_OPERAND (node, 1);
-         tree field = lookup_field_wrapper (TREE_OPERAND (node, 0), name);
-         if (field == NULL_TREE)
-           {
-             error ("missing static field `%s'", IDENTIFIER_POINTER (name));
-             return error_mark_node;
-           }
-         if (! FIELD_STATIC (field))
-           {
-             error ("not a static field `%s'", IDENTIFIER_POINTER (name));
-             return error_mark_node;
-           }
-         return field;
-       }
-      else
-       abort ();
-      break;
-
-    case THIS_EXPR:
-      /* Can't use THIS in a static environment */
-      if (!current_this)
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-         parse_error_context (wfl_operator,
-                              "Keyword `this' used outside allowed context");
-         TREE_TYPE (node) = error_mark_node;
-         return error_mark_node;
-       }
-      if (ctxp->explicit_constructor_p)
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-         parse_error_context 
-           (wfl_operator, "Can't reference `this' or `super' before the superclass constructor has been called");
-         TREE_TYPE (node) = error_mark_node;
-         return error_mark_node;
-       }
-      return current_this;
-      
-    case CLASS_LITERAL:
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      node = patch_incomplete_class_ref (node);
-      if (node == error_mark_node)
-       return error_mark_node;
-      break;
-
-    default:
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      /* Ok: may be we have a STRING_CST or a crafted `StringBuffer'
-        and it's time to turn it into the appropriate String object */
-      if ((nn = patch_string (node)))
-       node = nn;
-      else
-       internal_error ("No case for %s", tree_code_name [TREE_CODE (node)]);
-    }
-  return node;
-}
-
-/* Complete function call's argument. Return a non zero value is an
-   error was found.  */
-
-static int
-complete_function_arguments (node)
-     tree node;
-{
-  int flag = 0;
-  tree cn;
-
-  ctxp->explicit_constructor_p += (CALL_EXPLICIT_CONSTRUCTOR_P (node) ? 1 : 0);
-  for (cn = TREE_OPERAND (node, 1); cn; cn = TREE_CHAIN (cn))
-    {
-      tree wfl = TREE_VALUE (cn), parm, temp;
-      parm = java_complete_tree (wfl);
-
-      if (parm == error_mark_node)
-       {
-         flag = 1;
-         continue;
-       }
-      /* If have a string literal that we haven't transformed yet or a
-        crafted string buffer, as a result of use of the the String
-        `+' operator. Build `parm.toString()' and expand it. */
-      if ((temp = patch_string (parm)))
-       parm = temp;
-
-      TREE_VALUE (cn) = parm;
-    }
-  ctxp->explicit_constructor_p -= (CALL_EXPLICIT_CONSTRUCTOR_P (node) ? 1 : 0);
-  return flag;
-}
-
-/* Sometimes (for loops and variable initialized during their
-   declaration), we want to wrap a statement around a WFL and turn it
-   debugable.  */
-
-static tree
-build_debugable_stmt (location, stmt)
-    int location;
-    tree stmt;
-{
-  if (TREE_CODE (stmt) != EXPR_WITH_FILE_LOCATION)
-    {
-      stmt = build_expr_wfl (stmt, input_filename, 0, 0);
-      EXPR_WFL_LINECOL (stmt) = location;
-    }
-  JAVA_MAYBE_GENERATE_DEBUG_INFO (stmt);
-  return stmt;
-}
-
-static tree
-build_expr_block (body, decls)
-     tree body, decls;
-{
-  tree node = make_node (BLOCK);
-  BLOCK_EXPR_DECLS (node) = decls;
-  BLOCK_EXPR_BODY (node) = body;
-  if (body)
-    TREE_TYPE (node) = TREE_TYPE (body);
-  TREE_SIDE_EFFECTS (node) = 1;
-  return node;
-}
-
-/* Create a new function block and link it appropriately to current
-   function block chain */
-
-static tree
-enter_block ()
-{
-  tree b = build_expr_block (NULL_TREE, NULL_TREE);
-
-  /* Link block B supercontext to the previous block. The current
-     function DECL is used as supercontext when enter_a_block is called
-     for the first time for a given function. The current function body
-     (DECL_FUNCTION_BODY) is set to be block B.  */
-
-  tree fndecl = current_function_decl; 
-
-  if (!fndecl) {
-    BLOCK_SUPERCONTEXT (b) = current_static_block;
-    current_static_block = b;
-  }
-
-  else if (!DECL_FUNCTION_BODY (fndecl))
-    {
-      BLOCK_SUPERCONTEXT (b) = fndecl;
-      DECL_FUNCTION_BODY (fndecl) = b;
-    }
-  else
-    {
-      BLOCK_SUPERCONTEXT (b) = DECL_FUNCTION_BODY (fndecl);
-      DECL_FUNCTION_BODY (fndecl) = b;
-    }
-  return b;
-}
-
-/* Exit a block by changing the current function body
-   (DECL_FUNCTION_BODY) to the current block super context, only if
-   the block being exited isn't the method's top level one.  */
-
-static tree
-exit_block ()
-{
-  tree b;
-  if (current_function_decl)
-    {
-      b = DECL_FUNCTION_BODY (current_function_decl);
-      if (BLOCK_SUPERCONTEXT (b) != current_function_decl)
-       DECL_FUNCTION_BODY (current_function_decl) = BLOCK_SUPERCONTEXT (b);
-    }
-  else
-    {
-      b = current_static_block;
-
-      if (BLOCK_SUPERCONTEXT (b))
-       current_static_block = BLOCK_SUPERCONTEXT (b);
-    }
-  return b;
-}
-
-/* Lookup for NAME in the nested function's blocks, all the way up to
-   the current toplevel one. It complies with Java's local variable
-   scoping rules.  */
-
-static tree
-lookup_name_in_blocks (name)
-     tree name;
-{
-  tree b = GET_CURRENT_BLOCK (current_function_decl);
-
-  while (b != current_function_decl)
-    {
-      tree current;
-
-      /* Paranoid sanity check. To be removed */
-      if (TREE_CODE (b) != BLOCK)
-       abort ();
-
-      for (current = BLOCK_EXPR_DECLS (b); current; 
-          current = TREE_CHAIN (current))
-       if (DECL_NAME (current) == name)
-         return current;
-      b = BLOCK_SUPERCONTEXT (b);
-    }
-  return NULL_TREE;
-}
-
-static void
-maybe_absorb_scoping_blocks ()
-{
-  while (BLOCK_IS_IMPLICIT (GET_CURRENT_BLOCK (current_function_decl)))
-    {
-      tree b = exit_block ();
-      java_method_add_stmt (current_function_decl, b);
-      SOURCE_FRONTEND_DEBUG (("Absorbing scoping block at line %d", lineno));
-    }
-}
-
-\f
-/* This section of the source is reserved to build_* functions that
-   are building incomplete tree nodes and the patch_* functions that
-   are completing them.  */
-
-/* Wrap a non WFL node around a WFL.  */
-
-static tree
-build_wfl_wrap (node, location)
-    tree node;
-    int location;
-{
-  tree wfl, node_to_insert = node;
-  
-  /* We want to process THIS . xxx symbolicaly, to keep it consistent
-     with the way we're processing SUPER. A THIS from a primary as a
-     different form than a SUPER. Turn THIS into something symbolic */
-  if (TREE_CODE (node) == THIS_EXPR)
-    node_to_insert = wfl = build_wfl_node (this_identifier_node);
-  else
-    wfl = build_expr_wfl (NULL_TREE, ctxp->filename, 0, 0);
-
-  EXPR_WFL_LINECOL (wfl) = location;
-  EXPR_WFL_QUALIFICATION (wfl) = build_tree_list (node_to_insert, NULL_TREE);
-  return wfl;
-}
-
-/* Build a super() constructor invocation. Returns empty_stmt_node if
-   we're currently dealing with the class java.lang.Object. */
-
-static tree
-build_super_invocation (mdecl)
-     tree mdecl;
-{
-  if (DECL_CONTEXT (mdecl) == object_type_node)
-    return empty_stmt_node;
-  else
-    {
-      tree super_wfl = build_wfl_node (super_identifier_node);
-      tree a = NULL_TREE, t;
-      /* If we're dealing with an anonymous class, pass the arguments
-         of the crafted constructor along. */
-      if (ANONYMOUS_CLASS_P (DECL_CONTEXT (mdecl)))
-       {
-         SKIP_THIS_AND_ARTIFICIAL_PARMS (t, mdecl);
-         for (; t != end_params_node; t = TREE_CHAIN (t))
-           a = tree_cons (NULL_TREE, build_wfl_node (TREE_PURPOSE (t)), a);
-       }
-      return build_method_invocation (super_wfl, a);
-    }
-}
-
-/* Build a SUPER/THIS qualified method invocation.  */
-
-static tree
-build_this_super_qualified_invocation (use_this, name, args, lloc, rloc)
-     int use_this;
-     tree name, args;
-     int lloc, rloc;
-{
-  tree invok;
-  tree wfl = 
-    build_wfl_node (use_this ? this_identifier_node : super_identifier_node);
-  EXPR_WFL_LINECOL (wfl) = lloc;
-  invok = build_method_invocation (name, args);
-  return make_qualified_primary (wfl, invok, rloc);
-}
-
-/* Build an incomplete CALL_EXPR node. */
-
-static tree
-build_method_invocation (name, args)
-    tree name;
-    tree args;
-{
-  tree call = build (CALL_EXPR, NULL_TREE, name, args, NULL_TREE);
-  TREE_SIDE_EFFECTS (call) = 1;
-  EXPR_WFL_LINECOL (call) = EXPR_WFL_LINECOL (name);
-  return call;
-}
-
-/* Build an incomplete new xxx(...) node. */
-
-static tree
-build_new_invocation (name, args)
-    tree name, args;
-{
-  tree call = build (NEW_CLASS_EXPR, NULL_TREE, name, args, NULL_TREE);
-  TREE_SIDE_EFFECTS (call) = 1;
-  EXPR_WFL_LINECOL (call) = EXPR_WFL_LINECOL (name);
-  return call;
-}
-
-/* Build an incomplete assignment expression. */
-
-static tree
-build_assignment (op, op_location, lhs, rhs)
-     int op, op_location;
-     tree lhs, rhs;
-{
-  tree assignment;
-  /* Build the corresponding binop if we deal with a Compound
-     Assignment operator. Mark the binop sub-tree as part of a
-     Compound Assignment expression */
-  if (op != ASSIGN_TK)
-    {
-      rhs = build_binop (BINOP_LOOKUP (op), op_location, lhs, rhs);
-      COMPOUND_ASSIGN_P (rhs) = 1;
-    }
-  assignment = build (MODIFY_EXPR, NULL_TREE, lhs, rhs);
-  TREE_SIDE_EFFECTS (assignment) = 1;
-  EXPR_WFL_LINECOL (assignment) = op_location;
-  return assignment;
-}
-
-/* Print an INTEGER_CST node in a static buffer, and return the buffer. */
-
-char *
-print_int_node (node)
-    tree node;
-{
-  static char buffer [80];
-  if (TREE_CONSTANT_OVERFLOW (node))
-    sprintf (buffer, "<overflow>");
-    
-  if (TREE_INT_CST_HIGH (node) == 0)
-    sprintf (buffer, HOST_WIDE_INT_PRINT_UNSIGNED,
-            TREE_INT_CST_LOW (node));
-  else if (TREE_INT_CST_HIGH (node) == -1
-          && TREE_INT_CST_LOW (node) != 0)
-    {
-      buffer [0] = '-';
-      sprintf (&buffer [1], HOST_WIDE_INT_PRINT_UNSIGNED,
-              -TREE_INT_CST_LOW (node));
-    }
-  else
-    sprintf (buffer, HOST_WIDE_INT_PRINT_DOUBLE_HEX,
-            TREE_INT_CST_HIGH (node), TREE_INT_CST_LOW (node));
-
-  return buffer;
-}
-
-\f
-/* Return 1 if an assignment to a FINAL is attempted in a non suitable
-   context.  */
-
-/* 15.25 Assignment operators. */
-
-static tree
-patch_assignment (node, wfl_op1)
-     tree node;
-     tree wfl_op1;
-{
-  tree rhs = TREE_OPERAND (node, 1);
-  tree lvalue = TREE_OPERAND (node, 0), llvalue;
-  tree lhs_type = NULL_TREE, rhs_type, new_rhs = NULL_TREE;
-  int error_found = 0;
-  int lvalue_from_array = 0;
-  int is_return = 0;
-
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  /* Lhs can be a named variable */
-  if (JDECL_P (lvalue))
-    {
-      lhs_type = TREE_TYPE (lvalue);
-    }
-  /* Or Lhs can be an array access. */
-  else if (TREE_CODE (lvalue) == ARRAY_REF)
-    {
-      lhs_type = TREE_TYPE (lvalue);
-      lvalue_from_array = 1;
-    }
-  /* Or a field access */
-  else if (TREE_CODE (lvalue) == COMPONENT_REF)
-    lhs_type = TREE_TYPE (lvalue);
-  /* Or a function return slot */
-  else if (TREE_CODE (lvalue) == RESULT_DECL)
-    {
-      /* If the return type is an integral type, then we create the
-        RESULT_DECL with a promoted type, but we need to do these
-        checks against the unpromoted type to ensure type safety.  So
-        here we look at the real type, not the type of the decl we
-        are modifying.  */
-      lhs_type = TREE_TYPE (TREE_TYPE (current_function_decl));
-      is_return = 1;
-    }
-  /* Otherwise, we might want to try to write into an optimized static
-     final, this is an of a different nature, reported further on. */
-  else if (TREE_CODE (wfl_op1) == EXPR_WITH_FILE_LOCATION
-          && resolve_expression_name (wfl_op1, &llvalue))
-    {
-      lhs_type = TREE_TYPE (lvalue);
-    }
-  else 
-    {
-      parse_error_context (wfl_op1, "Invalid left hand side of assignment");
-      error_found = 1;
-    }
-
-  rhs_type = TREE_TYPE (rhs);
-
-  /* 5.1 Try the assignment conversion for builtin type. */
-  new_rhs = try_builtin_assignconv (wfl_op1, lhs_type, rhs);
-
-  /* 5.2 If it failed, try a reference conversion */
-  if (!new_rhs && (new_rhs = try_reference_assignconv (lhs_type, rhs)))
-    lhs_type = promote_type (rhs_type);
-
-  /* 15.25.2 If we have a compound assignment, convert RHS into the
-     type of the LHS */
-  else if (COMPOUND_ASSIGN_P (TREE_OPERAND (node, 1)))
-    new_rhs = convert (lhs_type, rhs);
-
-  /* Explicit cast required. This is an error */
-  if (!new_rhs)
-    {
-      char *t1 = xstrdup (lang_printable_name (TREE_TYPE (rhs), 0));
-      char *t2 = xstrdup (lang_printable_name (lhs_type, 0));
-      tree wfl;
-      char operation [32];     /* Max size known */
-
-      /* If the assignment is part of a declaration, we use the WFL of
-        the declared variable to point out the error and call it a
-        declaration problem. If the assignment is a genuine =
-        operator, we call is a operator `=' problem, otherwise we
-        call it an assignment problem. In both of these last cases,
-        we use the WFL of the operator to indicate the error. */
-
-      if (MODIFY_EXPR_FROM_INITIALIZATION_P (node))
-       {
-         wfl = wfl_op1;
-         strcpy (operation, "declaration");
-       }
-      else
-       {
-         wfl = wfl_operator;
-         if (COMPOUND_ASSIGN_P (TREE_OPERAND (node, 1)))
-           strcpy (operation, "assignment");
-         else if (is_return)
-           strcpy (operation, "`return'");
-         else
-           strcpy (operation, "`='");
-       }
-
-      if (!valid_cast_to_p (rhs_type, lhs_type))
-       parse_error_context
-         (wfl, "Incompatible type for %s. Can't convert `%s' to `%s'",
-          operation, t1, t2);
-      else
-       parse_error_context (wfl, "Incompatible type for %s. Explicit cast needed to convert `%s' to `%s'",
-                            operation, t1, t2);
-      free (t1); free (t2);
-      error_found = 1;
-    }
-
-  if (error_found)
-    return error_mark_node;
-
-  /* If we're processing a `return' statement, promote the actual type
-     to the promoted type.  */
-  if (is_return)
-    new_rhs = convert (TREE_TYPE (lvalue), new_rhs);
-
-  /* 10.10: Array Store Exception runtime check */
-  if (!flag_emit_class_files
-      && !flag_emit_xref
-      && lvalue_from_array 
-      && JREFERENCE_TYPE_P (TYPE_ARRAY_ELEMENT (lhs_type)))
-    {
-      tree array, store_check, base, index_expr;
-      
-      /* Save RHS so that it doesn't get re-evaluated by the store check. */ 
-      new_rhs = save_expr (new_rhs);
-
-      /* Get the INDIRECT_REF. */
-      array = TREE_OPERAND (TREE_OPERAND (lvalue, 0), 0);
-      /* Get the array pointer expr. */
-      array = TREE_OPERAND (array, 0);
-      store_check = build_java_arraystore_check (array, new_rhs);
-      
-      index_expr = TREE_OPERAND (lvalue, 1);
-      
-      if (TREE_CODE (index_expr) == COMPOUND_EXPR)
-       {
-         /* A COMPOUND_EXPR here is a bounds check. The bounds check must 
-            happen before the store check, so prepare to insert the store
-            check within the second operand of the existing COMPOUND_EXPR. */
-         base = index_expr;
-       }
-      else
-        base = lvalue;
-      
-      index_expr = TREE_OPERAND (base, 1);
-      TREE_OPERAND (base, 1) = build (COMPOUND_EXPR, TREE_TYPE (index_expr), 
-                                     store_check, index_expr);
-    }
-
-  /* Final locals can be used as case values in switch
-     statement. Prepare them for this eventuality. */
-  if (TREE_CODE (lvalue) == VAR_DECL 
-      && DECL_FINAL (lvalue)
-      && TREE_CONSTANT (new_rhs)
-      && IDENTIFIER_LOCAL_VALUE (DECL_NAME (lvalue))
-      && JINTEGRAL_TYPE_P (TREE_TYPE (lvalue))
-      )
-    {
-      TREE_CONSTANT (lvalue) = 1;
-      DECL_INITIAL (lvalue) = new_rhs;
-    }
-
-  TREE_OPERAND (node, 0) = lvalue;
-  TREE_OPERAND (node, 1) = new_rhs;
-  TREE_TYPE (node) = lhs_type;
-  return node;
-}
-
-/* Check that type SOURCE can be cast into type DEST. If the cast
-   can't occur at all, return NULL; otherwise, return a possibly
-   modified rhs.  */
-
-static tree
-try_reference_assignconv (lhs_type, rhs)
-     tree lhs_type, rhs;
-{
-  tree new_rhs = NULL_TREE;
-  tree rhs_type = TREE_TYPE (rhs);
-
-  if (!JPRIMITIVE_TYPE_P (rhs_type) && JREFERENCE_TYPE_P (lhs_type))
-    {
-      /* `null' may be assigned to any reference type */
-      if (rhs == null_pointer_node)
-        new_rhs = null_pointer_node;
-      /* Try the reference assignment conversion */
-      else if (valid_ref_assignconv_cast_p (rhs_type, lhs_type, 0))
-       new_rhs = rhs;
-      /* This is a magic assignment that we process differently */
-      else if (TREE_CODE (rhs) == JAVA_EXC_OBJ_EXPR)
-       new_rhs = rhs;
-    }
-  return new_rhs;
-}
-
-/* Check that RHS can be converted into LHS_TYPE by the assignment
-   conversion (5.2), for the cases of RHS being a builtin type. Return
-   NULL_TREE if the conversion fails or if because RHS isn't of a
-   builtin type. Return a converted RHS if the conversion is possible.  */
-
-static tree
-try_builtin_assignconv (wfl_op1, lhs_type, rhs)
-     tree wfl_op1, lhs_type, rhs;
-{
-  tree new_rhs = NULL_TREE;
-  tree rhs_type = TREE_TYPE (rhs);
-
-  /* Handle boolean specially.  */
-  if (TREE_CODE (rhs_type) == BOOLEAN_TYPE
-      || TREE_CODE (lhs_type) == BOOLEAN_TYPE)
-    {
-      if (TREE_CODE (rhs_type) == BOOLEAN_TYPE
-         && TREE_CODE (lhs_type) == BOOLEAN_TYPE)
-       new_rhs = rhs;
-    }
-
-  /* 5.1.1 Try Identity Conversion,
-     5.1.2 Try Widening Primitive Conversion */
-  else if (valid_builtin_assignconv_identity_widening_p (lhs_type, rhs_type))
-    new_rhs = convert (lhs_type, rhs);
-
-  /* Try a narrowing primitive conversion (5.1.3): 
-       - expression is a constant expression of type int AND
-       - variable is byte, short or char AND
-       - The value of the expression is representable in the type of the 
-         variable */
-  else if (rhs_type == int_type_node && TREE_CONSTANT (rhs)
-          && (lhs_type == byte_type_node || lhs_type == char_type_node
-              || lhs_type == short_type_node))
-    {
-      if (int_fits_type_p (rhs, lhs_type))
-        new_rhs = convert (lhs_type, rhs);
-      else if (wfl_op1)                /* Might be called with a NULL */
-       parse_warning_context 
-         (wfl_op1, "Constant expression `%s' too wide for narrowing primitive conversion to `%s'", 
-          print_int_node (rhs), lang_printable_name (lhs_type, 0));
-      /* Reported a warning that will turn into an error further
-        down, so we don't return */
-    }
-
-  return new_rhs;
-}
-
-/* Return 1 if RHS_TYPE can be converted to LHS_TYPE by identity
-   conversion (5.1.1) or widening primitive conversion (5.1.2).  Return
-   0 is the conversion test fails.  This implements parts the method
-   invocation convertion (5.3).  */
-
-static int
-valid_builtin_assignconv_identity_widening_p (lhs_type, rhs_type)
-     tree lhs_type, rhs_type;
-{
-  /* 5.1.1: This is the identity conversion part. */
-  if (lhs_type == rhs_type)
-    return 1;
-
-  /* Reject non primitive types and boolean conversions.  */
-  if (!JNUMERIC_TYPE_P (lhs_type) || !JNUMERIC_TYPE_P (rhs_type))
-    return 0;
-
-  /* 5.1.2: widening primitive conversion. byte, even if it's smaller
-     than a char can't be converted into a char. Short can't too, but
-     the < test below takes care of that */
-  if (lhs_type == char_type_node && rhs_type == byte_type_node)
-    return 0;
-
-  /* Accept all promoted type here. Note, we can't use <= in the test
-     below, because we still need to bounce out assignments of short
-     to char and the likes */
-  if (lhs_type == int_type_node
-      && (rhs_type == promoted_byte_type_node
-         || rhs_type == promoted_short_type_node
-         || rhs_type == promoted_char_type_node
-         || rhs_type == promoted_boolean_type_node))
-    return 1;
-
-  /* From here, an integral is widened if its precision is smaller
-     than the precision of the LHS or if the LHS is a floating point
-     type, or the RHS is a float and the RHS a double. */
-  if ((JINTEGRAL_TYPE_P (rhs_type) && JINTEGRAL_TYPE_P (lhs_type) 
-       && (TYPE_PRECISION (rhs_type) < TYPE_PRECISION (lhs_type)))
-      || (JINTEGRAL_TYPE_P (rhs_type) && JFLOAT_TYPE_P (lhs_type))
-      || (rhs_type == float_type_node && lhs_type == double_type_node))
-    return 1;
-
-  return 0;
-}
-
-/* Check that something of SOURCE type can be assigned or cast to
-   something of DEST type at runtime. Return 1 if the operation is
-   valid, 0 otherwise. If CAST is set to 1, we're treating the case
-   were SOURCE is cast into DEST, which borrows a lot of the
-   assignment check. */
-
-static int
-valid_ref_assignconv_cast_p (source, dest, cast)
-     tree source;
-     tree dest;
-     int cast;
-{
-  /* SOURCE or DEST might be null if not from a declared entity. */
-  if (!source || !dest)
-    return 0;
-  if (JNULLP_TYPE_P (source))
-    return 1;
-  if (TREE_CODE (source) == POINTER_TYPE)
-    source = TREE_TYPE (source);
-  if (TREE_CODE (dest) == POINTER_TYPE)
-    dest = TREE_TYPE (dest);
-
-  /* If source and dest are being compiled from bytecode, they may need to
-     be loaded. */
-  if (CLASS_P (source) && !CLASS_LOADED_P (source))
-    {
-      load_class (source, 1);
-      safe_layout_class (source);
-    }
-  if (CLASS_P (dest) && !CLASS_LOADED_P (dest))
-    {
-      load_class (dest, 1);
-      safe_layout_class (dest);
-    }
-
-  /* Case where SOURCE is a class type */
-  if (TYPE_CLASS_P (source))
-    {
-      if (TYPE_CLASS_P (dest))
-       return  (source == dest 
-                || inherits_from_p (source, dest)
-                || (cast && inherits_from_p (dest, source)));
-      if (TYPE_INTERFACE_P (dest))
-       {
-         /* If doing a cast and SOURCE is final, the operation is
-             always correct a compile time (because even if SOURCE
-             does not implement DEST, a subclass of SOURCE might). */
-         if (cast && !CLASS_FINAL (TYPE_NAME (source)))
-           return 1;
-         /* Otherwise, SOURCE must implement DEST */
-         return interface_of_p (dest, source);
-       }
-      /* DEST is an array, cast permited if SOURCE is of Object type */
-      return (cast && source == object_type_node ? 1 : 0);
-    }
-  if (TYPE_INTERFACE_P (source))
-    {
-      if (TYPE_CLASS_P (dest))
-       {
-         /* If not casting, DEST must be the Object type */
-         if (!cast)
-           return dest == object_type_node;
-         /* We're doing a cast. The cast is always valid is class
-            DEST is not final, otherwise, DEST must implement SOURCE */
-         else if (!CLASS_FINAL (TYPE_NAME (dest)))
-           return 1;
-         else
-           return interface_of_p (source, dest);
-       }
-      if (TYPE_INTERFACE_P (dest))
-       {
-         /* If doing a cast, then if SOURCE and DEST contain method
-             with the same signature but different return type, then
-             this is a (compile time) error */
-         if (cast)
-           {
-             tree method_source, method_dest;
-             tree source_type;
-             tree source_sig;
-             tree source_name;
-             for (method_source = TYPE_METHODS (source); method_source; 
-                  method_source = TREE_CHAIN (method_source))
-               {
-                 source_sig = 
-                   build_java_argument_signature (TREE_TYPE (method_source));
-                 source_type = TREE_TYPE (TREE_TYPE (method_source));
-                 source_name = DECL_NAME (method_source);
-                 for (method_dest = TYPE_METHODS (dest);
-                      method_dest; method_dest = TREE_CHAIN (method_dest))
-                   if (source_sig == 
-                       build_java_argument_signature (TREE_TYPE (method_dest))
-                       && source_name == DECL_NAME (method_dest)
-                       && source_type != TREE_TYPE (TREE_TYPE (method_dest)))
-                     return 0;
-               }
-             return 1;
-           }
-         else
-           return source == dest || interface_of_p (dest, source);
-       }
-      else
-       {
-         /* Array */
-         return (cast
-                 && (DECL_NAME (TYPE_NAME (source)) == java_lang_cloneable
-                     || (DECL_NAME (TYPE_NAME (source))
-                         == java_io_serializable)));
-       }
-    }
-  if (TYPE_ARRAY_P (source))
-    {
-      if (TYPE_CLASS_P (dest))
-       return dest == object_type_node;
-      /* Can't cast an array to an interface unless the interface is
-        java.lang.Cloneable or java.io.Serializable.  */
-      if (TYPE_INTERFACE_P (dest))
-       return (DECL_NAME (TYPE_NAME (dest)) == java_lang_cloneable
-               || DECL_NAME (TYPE_NAME (dest)) == java_io_serializable);
-      else                     /* Arrays */
-       {
-         tree source_element_type = TYPE_ARRAY_ELEMENT (source);
-         tree dest_element_type = TYPE_ARRAY_ELEMENT (dest);
-         
-         /* In case of severe errors, they turn out null */
-         if (!dest_element_type || !source_element_type)
-           return 0;
-         if (source_element_type == dest_element_type)
-           return 1;
-         return valid_ref_assignconv_cast_p (source_element_type,
-                                             dest_element_type, cast);
-       }
-      return 0;
-    }
-  return 0;
-}
-
-static int
-valid_cast_to_p (source, dest)
-     tree source;
-     tree dest;
-{
-  if (TREE_CODE (source) == POINTER_TYPE)
-    source = TREE_TYPE (source);
-  if (TREE_CODE (dest) == POINTER_TYPE)
-    dest = TREE_TYPE (dest);
-
-  if (TREE_CODE (source) == RECORD_TYPE && TREE_CODE (dest) == RECORD_TYPE)
-    return valid_ref_assignconv_cast_p (source, dest, 1);
-
-  else if (JNUMERIC_TYPE_P (source) && JNUMERIC_TYPE_P (dest))
-    return 1;
-
-  else if (TREE_CODE (source) == BOOLEAN_TYPE
-          && TREE_CODE (dest) == BOOLEAN_TYPE)
-    return 1;
-
-  return 0;
-}
-
-static tree
-do_unary_numeric_promotion (arg)
-     tree arg;
-{
-  tree type = TREE_TYPE (arg);
-  if ((TREE_CODE (type) == INTEGER_TYPE && TYPE_PRECISION (type) < 32)
-      || TREE_CODE (type) == CHAR_TYPE)
-    arg = convert (int_type_node, arg);
-  return arg;
-}
-
-/* Return a non zero value if SOURCE can be converted into DEST using
-   the method invocation conversion rule (5.3).  */
-static int
-valid_method_invocation_conversion_p (dest, source)
-     tree dest, source;
-{
-  return ((JPRIMITIVE_TYPE_P (source) && JPRIMITIVE_TYPE_P (dest)
-          && valid_builtin_assignconv_identity_widening_p (dest, source))
-         || ((JREFERENCE_TYPE_P (source) || JNULLP_TYPE_P (source))
-             && (JREFERENCE_TYPE_P (dest) || JNULLP_TYPE_P (dest))
-             && valid_ref_assignconv_cast_p (source, dest, 0)));
-}
-
-/* Build an incomplete binop expression. */
-
-static tree
-build_binop (op, op_location, op1, op2)
-     enum tree_code op;
-     int op_location;
-     tree op1, op2;
-{
-  tree binop = build (op, NULL_TREE, op1, op2);
-  TREE_SIDE_EFFECTS (binop) = 1;
-  /* Store the location of the operator, for better error report. The
-     string of the operator will be rebuild based on the OP value. */
-  EXPR_WFL_LINECOL (binop) = op_location;
-  return binop;
-}
-
-/* Build the string of the operator retained by NODE. If NODE is part
-   of a compound expression, add an '=' at the end of the string. This
-   function is called when an error needs to be reported on an
-   operator. The string is returned as a pointer to a static character
-   buffer. */
-
-static char *
-operator_string (node)
-     tree node;
-{
-#define BUILD_OPERATOR_STRING(S)                                       \
-  {                                                                    \
-    sprintf (buffer, "%s%s", S, (COMPOUND_ASSIGN_P (node) ? "=" : ""));        \
-    return buffer;                                                     \
-  }
-  
-  static char buffer [10];
-  switch (TREE_CODE (node))
-    {
-    case MULT_EXPR: BUILD_OPERATOR_STRING ("*");
-    case RDIV_EXPR: BUILD_OPERATOR_STRING ("/");
-    case TRUNC_MOD_EXPR: BUILD_OPERATOR_STRING ("%");
-    case PLUS_EXPR: BUILD_OPERATOR_STRING ("+");
-    case MINUS_EXPR: BUILD_OPERATOR_STRING ("-");
-    case LSHIFT_EXPR: BUILD_OPERATOR_STRING ("<<");
-    case RSHIFT_EXPR: BUILD_OPERATOR_STRING (">>");
-    case URSHIFT_EXPR: BUILD_OPERATOR_STRING (">>>");
-    case BIT_AND_EXPR: BUILD_OPERATOR_STRING ("&");
-    case BIT_XOR_EXPR: BUILD_OPERATOR_STRING ("^");
-    case BIT_IOR_EXPR: BUILD_OPERATOR_STRING ("|");
-    case TRUTH_ANDIF_EXPR: BUILD_OPERATOR_STRING ("&&");
-    case TRUTH_ORIF_EXPR: BUILD_OPERATOR_STRING ("||");
-    case EQ_EXPR: BUILD_OPERATOR_STRING ("==");
-    case NE_EXPR: BUILD_OPERATOR_STRING ("!=");
-    case GT_EXPR: BUILD_OPERATOR_STRING (">");
-    case GE_EXPR: BUILD_OPERATOR_STRING (">=");
-    case LT_EXPR: BUILD_OPERATOR_STRING ("<");
-    case LE_EXPR: BUILD_OPERATOR_STRING ("<=");
-    case UNARY_PLUS_EXPR: BUILD_OPERATOR_STRING ("+");
-    case NEGATE_EXPR: BUILD_OPERATOR_STRING ("-");
-    case TRUTH_NOT_EXPR: BUILD_OPERATOR_STRING ("!");
-    case BIT_NOT_EXPR: BUILD_OPERATOR_STRING ("~");
-    case PREINCREMENT_EXPR:    /* Fall through */
-    case POSTINCREMENT_EXPR: BUILD_OPERATOR_STRING ("++");
-    case PREDECREMENT_EXPR:    /* Fall through */
-    case POSTDECREMENT_EXPR: BUILD_OPERATOR_STRING ("--");
-    default:
-      internal_error ("unregistered operator %s",
-                     tree_code_name [TREE_CODE (node)]);
-    }
-  return NULL;
-#undef BUILD_OPERATOR_STRING
-}
-
-/* Return 1 if VAR_ACCESS1 is equivalent to VAR_ACCESS2.  */
-
-static int
-java_decl_equiv (var_acc1, var_acc2)
-     tree var_acc1, var_acc2;
-{
-  if (JDECL_P (var_acc1))
-    return (var_acc1 == var_acc2);
-  
-  return (TREE_CODE (var_acc1) == COMPONENT_REF
-         && TREE_CODE (var_acc2) == COMPONENT_REF
-         && TREE_OPERAND (TREE_OPERAND (var_acc1, 0), 0)
-            == TREE_OPERAND (TREE_OPERAND (var_acc2, 0), 0)
-         && TREE_OPERAND (var_acc1, 1) == TREE_OPERAND (var_acc2, 1));
-}
-
-/* Return a non zero value if CODE is one of the operators that can be
-   used in conjunction with the `=' operator in a compound assignment.  */
-
-static int
-binop_compound_p (code)
-    enum tree_code code;
-{
-  int i;
-  for (i = 0; i < BINOP_COMPOUND_CANDIDATES; i++)
-    if (binop_lookup [i] == code)
-      break;
-
-  return i < BINOP_COMPOUND_CANDIDATES;
-}
-
-/* Reorganize after a fold to get SAVE_EXPR to generate what we want.  */
-
-static tree
-java_refold (t)
-     tree t;
-{
-  tree c, b, ns, decl;
-
-  if (TREE_CODE (t) != MODIFY_EXPR)
-    return t;
-
-  c = TREE_OPERAND (t, 1);
-  if (! (c && TREE_CODE (c) == COMPOUND_EXPR
-        && TREE_CODE (TREE_OPERAND (c, 0)) == MODIFY_EXPR
-        && binop_compound_p (TREE_CODE (TREE_OPERAND (c, 1)))))
-    return t;
-
-  /* Now the left branch of the binary operator. */
-  b = TREE_OPERAND (TREE_OPERAND (c, 1), 0);
-  if (! (b && TREE_CODE (b) == NOP_EXPR 
-        && TREE_CODE (TREE_OPERAND (b, 0)) == SAVE_EXPR))
-    return t;
-
-  ns = TREE_OPERAND (TREE_OPERAND (b, 0), 0);
-  if (! (ns && TREE_CODE (ns) == NOP_EXPR
-        && TREE_CODE (TREE_OPERAND (ns, 0)) == SAVE_EXPR))
-    return t;
-
-  decl = TREE_OPERAND (TREE_OPERAND (ns, 0), 0);
-  if ((JDECL_P (decl) || TREE_CODE (decl) == COMPONENT_REF)
-      /* It's got to be the an equivalent decl */
-      && java_decl_equiv (decl, TREE_OPERAND (TREE_OPERAND (c, 0), 0)))
-    {
-      /* Shorten the NOP_EXPR/SAVE_EXPR path. */
-      TREE_OPERAND (TREE_OPERAND (c, 1), 0) = TREE_OPERAND (ns, 0);
-      /* Substitute the COMPOUND_EXPR by the BINOP_EXPR */
-      TREE_OPERAND (t, 1) = TREE_OPERAND (c, 1);
-      /* Change the right part of the BINOP_EXPR */
-      TREE_OPERAND (TREE_OPERAND (t, 1), 1) = TREE_OPERAND (c, 0);
-    }
-
-  return t;
-}
-
-/* Binary operators (15.16 up to 15.18). We return error_mark_node on
-   errors but we modify NODE so that it contains the type computed
-   according to the expression, when it's fixed. Otherwise, we write
-   error_mark_node as the type. It allows us to further the analysis
-   of remaining nodes and detects more errors in certain cases.  */
-
-static tree
-patch_binop (node, wfl_op1, wfl_op2)
-     tree node;
-     tree wfl_op1;
-     tree wfl_op2;
-{
-  tree op1 = TREE_OPERAND (node, 0);
-  tree op2 = TREE_OPERAND (node, 1);
-  tree op1_type = TREE_TYPE (op1);
-  tree op2_type = TREE_TYPE (op2);
-  tree prom_type = NULL_TREE, cn;
-  enum tree_code code = TREE_CODE (node);
-
-  /* If 1, tell the routine that we have to return error_mark_node
-     after checking for the initialization of the RHS */
-  int error_found = 0;
-
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  /* If either op<n>_type are NULL, this might be early signs of an
-     error situation, unless it's too early to tell (in case we're
-     handling a `+', `==', `!=' or `instanceof'.) We want to set op<n>_type
-     correctly so the error can be later on reported accurately. */
-  if (! (code == PLUS_EXPR || code == NE_EXPR 
-        || code == EQ_EXPR || code == INSTANCEOF_EXPR))
-    {
-      tree n;
-      if (! op1_type)
-       {
-         n = java_complete_tree (op1);
-         op1_type = TREE_TYPE (n);
-       }
-      if (! op2_type)
-       {
-         n = java_complete_tree (op2);
-         op2_type = TREE_TYPE (n);
-       }
-    }
-
-  switch (code)
-    {
-    /* 15.16 Multiplicative operators */
-    case MULT_EXPR:            /* 15.16.1 Multiplication Operator * */
-    case RDIV_EXPR:            /* 15.16.2 Division Operator / */
-    case TRUNC_DIV_EXPR:       /* 15.16.2 Integral type Division Operator / */
-    case TRUNC_MOD_EXPR:       /* 15.16.3 Remainder operator % */
-      if (!JNUMERIC_TYPE_P (op1_type) || !JNUMERIC_TYPE_P (op2_type))
-       {
-         if (!JNUMERIC_TYPE_P (op1_type))
-           ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op1_type);
-         if (!JNUMERIC_TYPE_P (op2_type) && (op1_type != op2_type))
-           ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op2_type);
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-         break;
-       }
-      prom_type = binary_numeric_promotion (op1_type, op2_type, &op1, &op2);
-
-      /* Detect integral division by zero */
-      if ((code == RDIV_EXPR || code == TRUNC_MOD_EXPR)
-         && TREE_CODE (prom_type) == INTEGER_TYPE
-         && (op2 == integer_zero_node || op2 == long_zero_node ||
-             (TREE_CODE (op2) == INTEGER_CST &&
-              ! TREE_INT_CST_LOW (op2)  && ! TREE_INT_CST_HIGH (op2))))
-       {
-         parse_warning_context (wfl_operator, "Evaluating this expression will result in an arithmetic exception being thrown");
-         TREE_CONSTANT (node) = 0;
-       }
-         
-      /* Change the division operator if necessary */
-      if (code == RDIV_EXPR && TREE_CODE (prom_type) == INTEGER_TYPE)
-       TREE_SET_CODE (node, TRUNC_DIV_EXPR);
-
-      /* Before divisions as is disapear, try to simplify and bail if
-         applicable, otherwise we won't perform even simple
-         simplifications like (1-1)/3. We can't do that with floating
-         point number, folds can't handle them at this stage. */
-      if (code == RDIV_EXPR && TREE_CONSTANT (op1) && TREE_CONSTANT (op2)
-         && JINTEGRAL_TYPE_P (op1) && JINTEGRAL_TYPE_P (op2))
-       {
-         TREE_TYPE (node) = prom_type;
-         node = fold (node);
-         if (TREE_CODE (node) != code)
-           return node;
-       }
-
-      if (TREE_CODE (prom_type) == INTEGER_TYPE
-         && flag_use_divide_subroutine
-         && ! flag_emit_class_files
-         && (code == RDIV_EXPR || code == TRUNC_MOD_EXPR))
-       return build_java_soft_divmod (TREE_CODE (node), prom_type, op1, op2);
-      /* This one is more complicated. FLOATs are processed by a
-        function call to soft_fmod. Duplicate the value of the
-        COMPOUND_ASSIGN_P flag. */
-      if (code == TRUNC_MOD_EXPR)
-       {
-         tree mod = build_java_binop (TRUNC_MOD_EXPR, prom_type, op1, op2);
-         COMPOUND_ASSIGN_P (mod) = COMPOUND_ASSIGN_P (node);
-         TREE_SIDE_EFFECTS (mod)
-           = TREE_SIDE_EFFECTS (op1) | TREE_SIDE_EFFECTS (op2);
-         return mod;
-       }
-      break;
-
-    /* 15.17 Additive Operators */
-    case PLUS_EXPR:            /* 15.17.1 String Concatenation Operator + */
-
-      /* Operation is valid if either one argument is a string
-        constant, a String object or a StringBuffer crafted for the
-        purpose of the a previous usage of the String concatenation
-        operator */
-
-      if (TREE_CODE (op1) == STRING_CST 
-         || TREE_CODE (op2) == STRING_CST
-         || JSTRING_TYPE_P (op1_type)
-         || JSTRING_TYPE_P (op2_type)
-         || IS_CRAFTED_STRING_BUFFER_P (op1)
-         || IS_CRAFTED_STRING_BUFFER_P (op2))
-       return build_string_concatenation (op1, op2);
-
-    case MINUS_EXPR:           /* 15.17.2 Additive Operators (+ and -) for
-                                  Numeric Types */
-      if (!JNUMERIC_TYPE_P (op1_type) || !JNUMERIC_TYPE_P (op2_type))
-       {
-         if (!JNUMERIC_TYPE_P (op1_type))
-           ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op1_type);
-         if (!JNUMERIC_TYPE_P (op2_type) && (op1_type != op2_type))
-           ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op2_type);
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-         break;
-       }
-      prom_type = binary_numeric_promotion (op1_type, op2_type, &op1, &op2);
-      break;
-
-    /* 15.18 Shift Operators */
-    case LSHIFT_EXPR:
-    case RSHIFT_EXPR:
-    case URSHIFT_EXPR:
-      if (!JINTEGRAL_TYPE_P (op1_type) || !JINTEGRAL_TYPE_P (op2_type))
-       {
-         if (!JINTEGRAL_TYPE_P (op1_type))
-           ERROR_CAST_NEEDED_TO_INTEGRAL (wfl_operator, node, op1_type);
-         else
-           {
-             if (JNUMERIC_TYPE_P (op2_type))
-               parse_error_context (wfl_operator,
-                                    "Incompatible type for `%s'. Explicit cast needed to convert shift distance from `%s' to integral",
-                                    operator_string (node),
-                                    lang_printable_name (op2_type, 0));
-             else
-               parse_error_context (wfl_operator,
-                                    "Incompatible type for `%s'. Can't convert shift distance from `%s' to integral", 
-                                    operator_string (node),
-                                    lang_printable_name (op2_type, 0));
-           }
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-         break;
-       }
-
-      /* Unary numeric promotion (5.6.1) is performed on each operand
-         separately */
-      op1 = do_unary_numeric_promotion (op1);
-      op2 = do_unary_numeric_promotion (op2);
-
-      /* The type of the shift expression is the type of the promoted
-         type of the left-hand operand */
-      prom_type = TREE_TYPE (op1);
-
-      /* Shift int only up to 0x1f and long up to 0x3f */
-      if (prom_type == int_type_node)
-       op2 = fold (build (BIT_AND_EXPR, int_type_node, op2, 
-                          build_int_2 (0x1f, 0)));
-      else
-       op2 = fold (build (BIT_AND_EXPR, int_type_node, op2, 
-                          build_int_2 (0x3f, 0)));
-
-      /* The >>> operator is a >> operating on unsigned quantities */
-      if (code == URSHIFT_EXPR && ! flag_emit_class_files)
-       {
-         tree to_return;
-          tree utype = unsigned_type (prom_type);
-          op1 = convert (utype, op1);
-         TREE_SET_CODE (node, RSHIFT_EXPR);
-          TREE_OPERAND (node, 0) = op1;
-          TREE_OPERAND (node, 1) = op2;
-          TREE_TYPE (node) = utype;
-         to_return = convert (prom_type, node);
-         /* Copy the original value of the COMPOUND_ASSIGN_P flag */
-         COMPOUND_ASSIGN_P (to_return) = COMPOUND_ASSIGN_P (node);
-         TREE_SIDE_EFFECTS (to_return)
-           = TREE_SIDE_EFFECTS (op1) | TREE_SIDE_EFFECTS (op2);
-         return to_return;
-       }
-      break;
-
-      /* 15.19.1 Type Comparison Operator instaceof */
-    case INSTANCEOF_EXPR:
-
-      TREE_TYPE (node) = boolean_type_node;
-
-      if (!(op2_type = resolve_type_during_patch (op2)))
-       return error_mark_node;
-
-      /* The first operand must be a reference type or the null type */
-      if (!JREFERENCE_TYPE_P (op1_type) && op1 != null_pointer_node)
-       error_found = 1;        /* Error reported further below */
-
-      /* The second operand must be a reference type */
-      if (!JREFERENCE_TYPE_P (op2_type))
-       {
-         SET_WFL_OPERATOR (wfl_operator, node, wfl_op2);
-         parse_error_context
-           (wfl_operator, "Invalid argument `%s' for `instanceof'",
-            lang_printable_name (op2_type, 0));
-         error_found = 1;
-       }
-
-      if (!error_found && valid_ref_assignconv_cast_p (op1_type, op2_type, 1))
-       {
-         /* If the first operand is null, the result is always false */
-         if (op1 == null_pointer_node)
-           return boolean_false_node;
-         else if (flag_emit_class_files)
-           {
-             TREE_OPERAND (node, 1) = op2_type;
-             TREE_SIDE_EFFECTS (node) = TREE_SIDE_EFFECTS (op1);
-             return node;
-           }
-         /* Otherwise we have to invoke instance of to figure it out */
-         else
-           return build_instanceof (op1, op2_type);
-       }
-      /* There is no way the expression operand can be an instance of
-        the type operand. This is a compile time error. */
-      else
-       {
-         char *t1 = xstrdup (lang_printable_name (op1_type, 0));
-         SET_WFL_OPERATOR (wfl_operator, node, wfl_op1);
-         parse_error_context 
-           (wfl_operator, "Impossible for `%s' to be instance of `%s'",
-            t1, lang_printable_name (op2_type, 0));
-         free (t1);
-         error_found = 1;
-       }
-      
-      break;
-
-      /* 15.21 Bitwise and Logical Operators */
-    case BIT_AND_EXPR:
-    case BIT_XOR_EXPR:
-    case BIT_IOR_EXPR:
-      if (JINTEGRAL_TYPE_P (op1_type) && JINTEGRAL_TYPE_P (op2_type))
-       /* Binary numeric promotion is performed on both operand and the
-          expression retain that type */
-       prom_type = binary_numeric_promotion (op1_type, op2_type, &op1, &op2);
-
-      else if (TREE_CODE (op1_type) == BOOLEAN_TYPE 
-              && TREE_CODE (op1_type) == BOOLEAN_TYPE)
-       /* The type of the bitwise operator expression is BOOLEAN */
-       prom_type = boolean_type_node;
-      else
-       {
-         if (!JINTEGRAL_TYPE_P (op1_type))
-           ERROR_CAST_NEEDED_TO_INTEGRAL (wfl_operator, node, op1_type);
-         if (!JINTEGRAL_TYPE_P (op2_type) && (op1_type != op2_type))
-           ERROR_CAST_NEEDED_TO_INTEGRAL (wfl_operator, node, op2_type);
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-         /* Insert a break here if adding thing before the switch's
-             break for this case */
-       }
-      break;
-
-      /* 15.22 Conditional-And Operator */
-    case TRUTH_ANDIF_EXPR:
-      /* 15.23 Conditional-Or Operator */
-    case TRUTH_ORIF_EXPR:
-      /* Operands must be of BOOLEAN type */
-      if (TREE_CODE (op1_type) != BOOLEAN_TYPE || 
-         TREE_CODE (op2_type) != BOOLEAN_TYPE)
-       {
-         if (TREE_CODE (op1_type) != BOOLEAN_TYPE)
-           ERROR_CANT_CONVERT_TO_BOOLEAN (wfl_operator, node, op1_type);
-         if (TREE_CODE (op2_type) != BOOLEAN_TYPE && (op1_type != op2_type))
-           ERROR_CANT_CONVERT_TO_BOOLEAN (wfl_operator, node, op2_type);
-         TREE_TYPE (node) = boolean_type_node;
-         error_found = 1;
-         break;
-       }
-      else if (integer_zerop (op1))
-       {
-         return code == TRUTH_ANDIF_EXPR ? op1 : op2;
-       }
-      else if (integer_onep (op1))
-       {
-         return code == TRUTH_ANDIF_EXPR ? op2 : op1;
-       }
-      /* The type of the conditional operators is BOOLEAN */
-      prom_type = boolean_type_node;
-      break;
-
-      /* 15.19.1 Numerical Comparison Operators <, <=, >, >= */
-    case LT_EXPR:
-    case GT_EXPR:
-    case LE_EXPR:
-    case GE_EXPR:
-      /* The type of each of the operands must be a primitive numeric
-         type */
-      if (!JNUMERIC_TYPE_P (op1_type) || ! JNUMERIC_TYPE_P (op2_type))
-       {
-         if (!JNUMERIC_TYPE_P (op1_type))
-           ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op1_type);
-         if (!JNUMERIC_TYPE_P (op2_type) && (op1_type != op2_type))
-           ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op2_type);
-         TREE_TYPE (node) = boolean_type_node;
-         error_found = 1;
-         break;
-       }
-      /* Binary numeric promotion is performed on the operands */
-      binary_numeric_promotion (op1_type, op2_type, &op1, &op2);
-      /* The type of the relation expression is always BOOLEAN */
-      prom_type = boolean_type_node;
-      break;
-
-      /* 15.20 Equality Operator */
-    case EQ_EXPR:
-    case NE_EXPR:
-      /* It's time for us to patch the strings. */
-      if ((cn = patch_string (op1))) 
-       {
-         op1 = cn;
-         op1_type = TREE_TYPE (op1);
-       }
-      if ((cn = patch_string (op2))) 
-       {
-         op2 = cn;
-         op2_type = TREE_TYPE (op2);
-       }
-      
-      /* 15.20.1 Numerical Equality Operators == and != */
-      /* Binary numeric promotion is performed on the operands */
-      if (JNUMERIC_TYPE_P (op1_type) && JNUMERIC_TYPE_P (op2_type))
-       binary_numeric_promotion (op1_type, op2_type, &op1, &op2);
-      
-      /* 15.20.2 Boolean Equality Operators == and != */
-      else if (TREE_CODE (op1_type) == BOOLEAN_TYPE &&
-         TREE_CODE (op2_type) == BOOLEAN_TYPE)
-       ;                       /* Nothing to do here */
-      
-      /* 15.20.3 Reference Equality Operators == and != */
-      /* Types have to be either references or the null type. If
-         they're references, it must be possible to convert either
-         type to the other by casting conversion. */
-      else if (op1 == null_pointer_node || op2 == null_pointer_node 
-              || (JREFERENCE_TYPE_P (op1_type) && JREFERENCE_TYPE_P (op2_type)
-                  && (valid_ref_assignconv_cast_p (op1_type, op2_type, 1)
-                      || valid_ref_assignconv_cast_p (op2_type, 
-                                                      op1_type, 1))))
-       ;                       /* Nothing to do here */
-         
-      /* Else we have an error figure what can't be converted into
-        what and report the error */
-      else
-       {
-         char *t1;
-         t1 = xstrdup (lang_printable_name (op1_type, 0));
-         parse_error_context 
-           (wfl_operator,
-            "Incompatible type for `%s'. Can't convert `%s' to `%s'",
-            operator_string (node), t1, 
-            lang_printable_name (op2_type, 0));
-         free (t1);
-         TREE_TYPE (node) = boolean_type_node;
-         error_found = 1;
-         break;
-       }
-      prom_type = boolean_type_node;
-      break;
-    default:
-      abort ();
-    }
-
-  if (error_found)
-    return error_mark_node;
-
-  TREE_OPERAND (node, 0) = op1;
-  TREE_OPERAND (node, 1) = op2;
-  TREE_TYPE (node) = prom_type;
-  TREE_SIDE_EFFECTS (node) = TREE_SIDE_EFFECTS (op1) | TREE_SIDE_EFFECTS (op2);
-  
-  if (flag_emit_xref)
-    return node;
-
-  /* fold does not respect side-effect order as required for Java but not C.
-   * Also, it sometimes create SAVE_EXPRs which are bad when emitting
-   * bytecode.
-   */
-  if (flag_emit_class_files ? (TREE_CONSTANT (op1) && TREE_CONSTANT (op2))
-      : ! TREE_SIDE_EFFECTS (node))
-    node = fold (node);
-  return node;
-}
-
-/* Concatenate the STRING_CST CSTE and STRING. When AFTER is a non
-   zero value, the value of CSTE comes after the valude of STRING */
-
-static tree
-do_merge_string_cste (cste, string, string_len, after)
-     tree cste;
-     const char *string;
-     int string_len, after;
-{
-  const char *old = TREE_STRING_POINTER (cste);
-  int old_len = TREE_STRING_LENGTH (cste);
-  int len = old_len + string_len;
-  char *new = alloca (len+1);
-
-  if (after)
-    {
-      memcpy (new, string, string_len);
-      memcpy (&new [string_len], old, old_len);
-    }
-  else
-    {
-      memcpy (new, old, old_len);
-      memcpy (&new [old_len], string, string_len);
-    }
-  new [len] = '\0';
-  return build_string (len, new);
-}
-
-/* Tries to merge OP1 (a STRING_CST) and OP2 (if suitable). Return a
-   new STRING_CST on success, NULL_TREE on failure */
-
-static tree
-merge_string_cste (op1, op2, after)
-     tree op1, op2;
-     int after;
-{
-  /* Handle two string constants right away */
-  if (TREE_CODE (op2) == STRING_CST)
-    return do_merge_string_cste (op1, TREE_STRING_POINTER (op2), 
-                                TREE_STRING_LENGTH (op2), after);
-  
-  /* Reasonable integer constant can be treated right away */
-  if (TREE_CODE (op2) == INTEGER_CST && !TREE_CONSTANT_OVERFLOW (op2))
-    {
-      static const char *const boolean_true = "true";
-      static const char *const boolean_false = "false";
-      static const char *const null_pointer = "null";
-      char ch[3];
-      const char *string;
-      
-      if (op2 == boolean_true_node)
-       string = boolean_true;
-      else if (op2 == boolean_false_node)
-       string = boolean_false;
-      else if (op2 == null_pointer_node)
-       string = null_pointer;
-      else if (TREE_TYPE (op2) == char_type_node)
-       {
-         ch[0] = (char )TREE_INT_CST_LOW (op2);
-         ch[1] = '\0';
-         string = ch;
-       }
-      else
-         string = print_int_node (op2);
-      
-      return do_merge_string_cste (op1, string, strlen (string), after);
-    }
-  return NULL_TREE;
-}
-
-/* Tries to statically concatenate OP1 and OP2 if possible. Either one
-   has to be a STRING_CST and the other part must be a STRING_CST or a
-   INTEGRAL constant. Return a new STRING_CST if the operation
-   succeed, NULL_TREE otherwise.
-
-   If the case we want to optimize for space, we might want to return
-   NULL_TREE for each invocation of this routine. FIXME */
-
-static tree
-string_constant_concatenation (op1, op2)
-     tree op1, op2;
-{
-  if (TREE_CODE (op1) == STRING_CST || (TREE_CODE (op2) == STRING_CST))
-    {
-      tree string, rest;
-      int invert;
-      
-      string = (TREE_CODE (op1) == STRING_CST ? op1 : op2);
-      rest   = (string == op1 ? op2 : op1);
-      invert = (string == op1 ? 0 : 1 );
-      
-      /* Walk REST, only if it looks reasonable */
-      if (TREE_CODE (rest) != STRING_CST
-         && !IS_CRAFTED_STRING_BUFFER_P (rest)
-         && !JSTRING_TYPE_P (TREE_TYPE (rest))
-         && TREE_CODE (rest) == EXPR_WITH_FILE_LOCATION)
-       {
-         rest = java_complete_tree (rest);
-         if (rest == error_mark_node)
-           return error_mark_node;
-         rest = fold (rest);
-       }
-      return merge_string_cste (string, rest, invert);
-    }
-  return NULL_TREE;
-}
-
-/* Implement the `+' operator. Does static optimization if possible,
-   otherwise create (if necessary) and append elements to a
-   StringBuffer. The StringBuffer will be carried around until it is
-   used for a function call or an assignment. Then toString() will be
-   called on it to turn it into a String object. */
-
-static tree
-build_string_concatenation (op1, op2)
-     tree op1, op2;
-{
-  tree result;
-  int side_effects = TREE_SIDE_EFFECTS (op1) | TREE_SIDE_EFFECTS (op2);
-
-  if (flag_emit_xref)
-    return build (PLUS_EXPR, string_type_node, op1, op2);
-  
-  /* Try to do some static optimization */
-  if ((result = string_constant_concatenation (op1, op2)))
-    return result;
-
-  /* Discard empty strings on either side of the expression */
-  if (TREE_CODE (op1) == STRING_CST && TREE_STRING_LENGTH (op1) == 0)
-    {
-      op1 = op2;
-      op2 = NULL_TREE;
-    }
-  else if (TREE_CODE (op2) == STRING_CST && TREE_STRING_LENGTH (op2) == 0)
-    op2 = NULL_TREE;
-
-  /* If operands are string constant, turn then into object references */
-  if (TREE_CODE (op1) == STRING_CST)
-    op1 = patch_string_cst (op1);
-  if (op2 && TREE_CODE (op2) == STRING_CST)
-    op2 = patch_string_cst (op2);
-
-  /* If either one of the constant is null and the other non null
-     operand is a String object, return it. */
-  if (JSTRING_TYPE_P (TREE_TYPE (op1)) && !op2)
-    return op1;
-
-  /* If OP1 isn't already a StringBuffer, create and
-     initialize a new one */
-  if (!IS_CRAFTED_STRING_BUFFER_P (op1))
-    {
-      /* Two solutions here: 
-        1) OP1 is a constant string reference, we call new StringBuffer(OP1)
-        2) OP1 is something else, we call new StringBuffer().append(OP1).  */
-      if (TREE_CONSTANT (op1) && JSTRING_TYPE_P (TREE_TYPE (op1)))
-       op1 = BUILD_STRING_BUFFER (op1);
-      else
-       {
-         tree aNew = BUILD_STRING_BUFFER (NULL_TREE);
-         op1 = make_qualified_primary (aNew, BUILD_APPEND (op1), 0);
-       }
-    }
-
-  if (op2)
-    {
-      /* OP1 is no longer the last node holding a crafted StringBuffer */
-      IS_CRAFTED_STRING_BUFFER_P (op1) = 0;
-      /* Create a node for `{new...,xxx}.append (op2)' */
-      if (op2)
-       op1 = make_qualified_primary (op1, BUILD_APPEND (op2), 0);
-    }
-
-  /* Mark the last node holding a crafted StringBuffer */
-  IS_CRAFTED_STRING_BUFFER_P (op1) = 1;
-
-  TREE_SIDE_EFFECTS (op1) = side_effects;
-  return op1;
-}
-
-/* Patch the string node NODE. NODE can be a STRING_CST of a crafted
-   StringBuffer. If no string were found to be patched, return
-   NULL. */
-
-static tree
-patch_string (node)
-    tree node;
-{
-  if (node == error_mark_node)
-    return error_mark_node;
-  if (TREE_CODE (node) == STRING_CST)
-    return patch_string_cst (node);
-  else if (IS_CRAFTED_STRING_BUFFER_P (node))
-    {
-      int saved = ctxp->explicit_constructor_p;
-      tree invoke = build_method_invocation (wfl_to_string, NULL_TREE);
-      tree ret;
-      /* Temporary disable forbid the use of `this'. */
-      ctxp->explicit_constructor_p = 0;
-      ret = java_complete_tree (make_qualified_primary (node, invoke, 0));
-      /* String concatenation arguments must be evaluated in order too. */
-      ret = force_evaluation_order (ret);
-      /* Restore it at its previous value */
-      ctxp->explicit_constructor_p = saved;
-      return ret;
-    }
-  return NULL_TREE;
-}
-
-/* Build the internal representation of a string constant.  */
-
-static tree
-patch_string_cst (node)
-     tree node;
-{
-  int location;
-  if (! flag_emit_class_files)
-    {
-      node = get_identifier (TREE_STRING_POINTER (node));
-      location = alloc_name_constant (CONSTANT_String, node);
-      node = build_ref_from_constant_pool (location);
-    }
-  TREE_TYPE (node) = string_ptr_type_node;
-  TREE_CONSTANT (node) = 1;
-  return node;
-}
-
-/* Build an incomplete unary operator expression. */
-
-static tree
-build_unaryop (op_token, op_location, op1)
-     int op_token, op_location;
-     tree op1;
-{
-  enum tree_code op;
-  tree unaryop;
-  switch (op_token)
-    {
-    case PLUS_TK: op = UNARY_PLUS_EXPR; break;
-    case MINUS_TK: op = NEGATE_EXPR; break;
-    case NEG_TK: op = TRUTH_NOT_EXPR; break;
-    case NOT_TK: op = BIT_NOT_EXPR; break;
-    default: abort ();
-    }
-
-  unaryop = build1 (op, NULL_TREE, op1);
-  TREE_SIDE_EFFECTS (unaryop) = 1;
-  /* Store the location of the operator, for better error report. The
-     string of the operator will be rebuild based on the OP value. */
-  EXPR_WFL_LINECOL (unaryop) = op_location;
-  return unaryop;
-}
-
-/* Special case for the ++/-- operators, since they require an extra
-   argument to build, which is set to NULL and patched
-   later. IS_POST_P is 1 if the operator, 0 otherwise.  */
-
-static tree
-build_incdec (op_token, op_location, op1, is_post_p)
-     int op_token, op_location;
-     tree op1;
-     int is_post_p;
-{
-  static const enum tree_code lookup [2][2] = 
-    {
-      { PREDECREMENT_EXPR, PREINCREMENT_EXPR, },
-      { POSTDECREMENT_EXPR, POSTINCREMENT_EXPR, },
-    };
-  tree node = build (lookup [is_post_p][(op_token - DECR_TK)], 
-                    NULL_TREE, op1, NULL_TREE);
-  TREE_SIDE_EFFECTS (node) = 1;
-  /* Store the location of the operator, for better error report. The
-     string of the operator will be rebuild based on the OP value. */
-  EXPR_WFL_LINECOL (node) = op_location;
-  return node;
-}     
-
-/* Build an incomplete cast operator, based on the use of the
-   CONVERT_EXPR. Note that TREE_TYPE of the constructed node is
-   set. java_complete_tree is trained to walk a CONVERT_EXPR even
-   though its type is already set.  */
-
-static tree
-build_cast (location, type, exp)
-     int location;
-     tree type, exp;
-{
-  tree node = build1 (CONVERT_EXPR, type, exp);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-}
-
-/* Build an incomplete class reference operator.  */
-static tree
-build_incomplete_class_ref (location, class_name)
-    int location;
-    tree class_name;
-{
-  tree node = build1 (CLASS_LITERAL, NULL_TREE, class_name);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-}
-
-/* Complete an incomplete class reference operator.  */
-static tree
-patch_incomplete_class_ref (node)
-    tree node;
-{
-  tree type = TREE_OPERAND (node, 0);
-  tree ref_type;
-
-  if (!(ref_type = resolve_type_during_patch (type)))
-    return error_mark_node;
-
-  if (!flag_emit_class_files || JPRIMITIVE_TYPE_P (ref_type))
-    {
-      tree dot = build_class_ref (ref_type);
-      /* A class referenced by `foo.class' is initialized.  */
-      if (!flag_emit_class_files)
-       dot = build_class_init (ref_type, dot);
-      return java_complete_tree (dot);
-    }
-
-  /* If we're emitting class files and we have to deal with non
-     primitive types, we invoke (and consider generating) the
-     synthetic static method `class$'. */
-  if (!TYPE_DOT_CLASS (current_class))
-      build_dot_class_method (current_class);
-  ref_type = build_dot_class_method_invocation (ref_type);
-  return java_complete_tree (ref_type);
-}
-
-/* 15.14 Unary operators. We return error_mark_node in case of error,
-   but preserve the type of NODE if the type is fixed.  */
-
-static tree
-patch_unaryop (node, wfl_op)
-     tree node;
-     tree wfl_op;
-{
-  tree op = TREE_OPERAND (node, 0);
-  tree op_type = TREE_TYPE (op);
-  tree prom_type = NULL_TREE, value, decl;
-  int outer_field_flag = 0;
-  int code = TREE_CODE (node);
-  int error_found = 0;
-
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  switch (code)
-    {
-      /* 15.13.2 Postfix Increment Operator ++ */
-    case POSTINCREMENT_EXPR:
-      /* 15.13.3 Postfix Increment Operator -- */
-    case POSTDECREMENT_EXPR:
-      /* 15.14.1 Prefix Increment Operator ++ */
-    case PREINCREMENT_EXPR:
-      /* 15.14.2 Prefix Decrement Operator -- */
-    case PREDECREMENT_EXPR:
-      op = decl = strip_out_static_field_access_decl (op);
-      outer_field_flag = outer_field_expanded_access_p (op, NULL, NULL, NULL);
-      /* We might be trying to change an outer field accessed using
-         access method. */
-      if (outer_field_flag)
-       {
-         /* Retrieve the decl of the field we're trying to access. We
-             do that by first retrieving the function we would call to
-             access the field. It has been already verified that this
-             field isn't final */
-         if (flag_emit_class_files)
-           decl = TREE_OPERAND (op, 0);
-         else
-           decl = TREE_OPERAND (TREE_OPERAND (TREE_OPERAND (op, 0), 0), 0);
-         decl = DECL_FUNCTION_ACCESS_DECL (decl);
-       }
-      /* We really should have a JAVA_ARRAY_EXPR to avoid this */
-      else if (!JDECL_P (decl) 
-         && TREE_CODE (decl) != COMPONENT_REF
-         && !(flag_emit_class_files && TREE_CODE (decl) == ARRAY_REF)
-         && TREE_CODE (decl) != INDIRECT_REF
-         && !(TREE_CODE (decl) == COMPOUND_EXPR
-              && TREE_OPERAND (decl, 1)
-              && (TREE_CODE (TREE_OPERAND (decl, 1)) == INDIRECT_REF)))
-       {
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-       }
-      
-      /* From now on, we know that op if a variable and that it has a
-         valid wfl. We use wfl_op to locate errors related to the
-         ++/-- operand. */
-      if (!JNUMERIC_TYPE_P (op_type))
-       {
-         parse_error_context
-           (wfl_op, "Invalid argument type `%s' to `%s'",
-            lang_printable_name (op_type, 0), operator_string (node));
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-       }
-      else
-       {
-         /* Before the addition, binary numeric promotion is performed on
-            both operands, if really necessary */
-         if (JINTEGRAL_TYPE_P (op_type))
-           {
-             value = build_int_2 (1, 0);
-             TREE_TYPE (value) = TREE_TYPE (node) = op_type;
-           }
-         else
-           {
-             value = build_int_2 (1, 0);
-             TREE_TYPE (node) = 
-               binary_numeric_promotion (op_type, 
-                                         TREE_TYPE (value), &op, &value);
-           }
-
-         /* We remember we might be accessing an outer field */
-         if (outer_field_flag)
-           {
-             /* We re-generate an access to the field */
-             value = build (PLUS_EXPR, TREE_TYPE (op), 
-                            build_outer_field_access (wfl_op, decl), value);
-                                                   
-             /* And we patch the original access$() into a write 
-                 with plus_op as a rhs */
-             return outer_field_access_fix (node, op, value);
-           }
-
-         /* And write back into the node. */
-         TREE_OPERAND (node, 0) = op;
-         TREE_OPERAND (node, 1) = value;
-         /* Convert the overall back into its original type, if
-             necessary, and return */
-         if (JINTEGRAL_TYPE_P (op_type))
-           return fold (node);
-         else
-           return fold (convert (op_type, node));
-       }
-      break;
-
-      /* 15.14.3 Unary Plus Operator + */
-    case UNARY_PLUS_EXPR:
-      /* 15.14.4 Unary Minus Operator - */
-    case NEGATE_EXPR:
-      if (!JNUMERIC_TYPE_P (op_type))
-       {
-         ERROR_CANT_CONVERT_TO_NUMERIC (wfl_operator, node, op_type);
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-       }
-      /* Unary numeric promotion is performed on operand */
-      else
-       {
-         op = do_unary_numeric_promotion (op);
-         prom_type = TREE_TYPE (op);
-         if (code == UNARY_PLUS_EXPR)
-           return fold (op);
-       }
-      break;
-
-      /* 15.14.5 Bitwise Complement Operator ~ */
-    case BIT_NOT_EXPR:
-      if (!JINTEGRAL_TYPE_P (op_type))
-       {
-         ERROR_CAST_NEEDED_TO_INTEGRAL (wfl_operator, node, op_type);
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-       }
-      else
-       {
-         op = do_unary_numeric_promotion (op);
-         prom_type = TREE_TYPE (op);
-       }
-      break;
-
-      /* 15.14.6 Logical Complement Operator ! */
-    case TRUTH_NOT_EXPR:
-      if (TREE_CODE (op_type) != BOOLEAN_TYPE)
-       {
-         ERROR_CANT_CONVERT_TO_BOOLEAN (wfl_operator, node, op_type);
-         /* But the type is known. We will report an error if further
-            attempt of a assignment is made with this rhs */
-         TREE_TYPE (node) = boolean_type_node;
-         error_found = 1;
-       }
-      else
-       prom_type = boolean_type_node;
-      break;
-
-      /* 15.15 Cast Expression */
-    case CONVERT_EXPR:
-      value = patch_cast (node, wfl_operator);
-      if (value == error_mark_node)
-       {
-         /* If this cast is part of an assignment, we tell the code
-            that deals with it not to complain about a mismatch,
-            because things have been cast, anyways */
-         TREE_TYPE (node) = error_mark_node;
-         error_found = 1;
-       }
-      else
-       {
-         value = fold (value);
-         TREE_SIDE_EFFECTS (value) = TREE_SIDE_EFFECTS (op);
-         return value;
-       }
-      break;
-    }
-  
-  if (error_found)
-    return error_mark_node;
-
-  /* There are cases where node has been replaced by something else
-     and we don't end up returning here: UNARY_PLUS_EXPR,
-     CONVERT_EXPR, {POST,PRE}{INCR,DECR}EMENT_EXPR. */
-  TREE_OPERAND (node, 0) = fold (op);
-  TREE_TYPE (node) = prom_type;
-  TREE_SIDE_EFFECTS (node) = TREE_SIDE_EFFECTS (op);
-  return fold (node);
-}
-
-/* Generic type resolution that sometimes takes place during node
-   patching. Returned the resolved type or generate an error
-   message. Return the resolved type or NULL_TREE.  */
-
-static tree
-resolve_type_during_patch (type)
-     tree type;
-{
-  if (unresolved_type_p (type, NULL))
-    {
-      tree type_decl = resolve_and_layout (EXPR_WFL_NODE (type), type);
-      if (!type_decl)
-       {
-         parse_error_context (type, 
-                              "Class `%s' not found in type declaration",
-                              IDENTIFIER_POINTER (EXPR_WFL_NODE (type)));
-         return NULL_TREE;
-       }
-      return TREE_TYPE (type_decl);
-    }
-  return type;
-}
-/* 5.5 Casting Conversion. error_mark_node is returned if an error is
-   found. Otherwise NODE or something meant to replace it is returned.  */
-
-static tree
-patch_cast (node, wfl_op)
-     tree node;
-     tree wfl_op;
-{
-  tree op = TREE_OPERAND (node, 0);
-  tree cast_type = TREE_TYPE (node);
-  tree patched, op_type;
-  char *t1;
-
-  /* Some string patching might be necessary at this stage */
-  if ((patched = patch_string (op)))
-    TREE_OPERAND (node, 0) = op = patched;
-  op_type = TREE_TYPE (op);
-
-  /* First resolve OP_TYPE if unresolved */
-  if (!(cast_type = resolve_type_during_patch (cast_type)))
-    return error_mark_node;
-
-  /* Check on cast that are proven correct at compile time */
-  if (JNUMERIC_TYPE_P (cast_type) && JNUMERIC_TYPE_P (op_type))
-    {
-      /* Same type */
-      if (cast_type == op_type)
-       return node;
-
-      /* float and double type are converted to the original type main
-        variant and then to the target type. */
-      if (JFLOAT_TYPE_P (op_type) && TREE_CODE (cast_type) == CHAR_TYPE)
-       op = convert (integer_type_node, op);
-
-      /* Try widening/narowwing convertion. Potentially, things need
-        to be worked out in gcc so we implement the extreme cases
-        correctly. fold_convert() needs to be fixed. */
-      return convert (cast_type, op);
-    }
-
-  /* It's also valid to cast a boolean into a boolean */
-  if (op_type == boolean_type_node && cast_type == boolean_type_node)
-    return node;
-
-  /* null can be casted to references */
-  if (op == null_pointer_node && JREFERENCE_TYPE_P (cast_type))
-    return build_null_of_type (cast_type);
-
-  /* The remaining legal casts involve conversion between reference
-     types. Check for their compile time correctness. */
-  if (JREFERENCE_TYPE_P (op_type) && JREFERENCE_TYPE_P (cast_type) 
-      && valid_ref_assignconv_cast_p (op_type, cast_type, 1))
-    {
-      TREE_TYPE (node) = promote_type (cast_type);
-      /* Now, the case can be determined correct at compile time if
-         OP_TYPE can be converted into CAST_TYPE by assignment
-         conversion (5.2) */
-
-      if (valid_ref_assignconv_cast_p (op_type, cast_type, 0))
-       {
-         TREE_SET_CODE (node, NOP_EXPR);
-         return node;
-       }
-
-      if (flag_emit_class_files)
-       {
-         TREE_SET_CODE (node, CONVERT_EXPR);
-         return node;
-       }
-
-      /* The cast requires a run-time check */
-      return build (CALL_EXPR, promote_type (cast_type),
-                   build_address_of (soft_checkcast_node),
-                   tree_cons (NULL_TREE, build_class_ref (cast_type),
-                              build_tree_list (NULL_TREE, op)),
-                   NULL_TREE);
-    }
-
-  /* Any other casts are proven incorrect at compile time */
-  t1 = xstrdup (lang_printable_name (op_type, 0));
-  parse_error_context (wfl_op, "Invalid cast from `%s' to `%s'",
-                      t1, lang_printable_name (cast_type, 0));
-  free (t1);
-  return error_mark_node;
-}
-
-/* Build a null constant and give it the type TYPE.  */
-
-static tree
-build_null_of_type (type)
-     tree type;
-{
-  tree node = build_int_2 (0, 0);
-  TREE_TYPE (node) = promote_type (type);
-  return node;
-}
-
-/* Build an ARRAY_REF incomplete tree node. Note that operand 1 isn't
-   a list of indices. */
-static tree
-build_array_ref (location, array, index)
-     int location;
-     tree array, index;
-{
-  tree node = build (ARRAY_REF, NULL_TREE, array, index);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-}
-
-/* 15.12 Array Access Expression */
-
-static tree
-patch_array_ref (node)
-     tree node;
-{
-  tree array = TREE_OPERAND (node, 0);
-  tree array_type  = TREE_TYPE (array);
-  tree index = TREE_OPERAND (node, 1);
-  tree index_type = TREE_TYPE (index);
-  int error_found = 0;
-
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  if (TREE_CODE (array_type) == POINTER_TYPE)
-    array_type = TREE_TYPE (array_type);
-
-  /* The array reference must be an array */
-  if (!TYPE_ARRAY_P (array_type))
-    {
-      parse_error_context 
-       (wfl_operator,
-        "`[]' can only be applied to arrays. It can't be applied to `%s'",
-        lang_printable_name (array_type, 0));
-      TREE_TYPE (node) = error_mark_node;
-      error_found = 1;
-    }
-
-  /* The array index undergoes unary numeric promotion. The promoted
-     type must be int */
-  index = do_unary_numeric_promotion (index);
-  if (TREE_TYPE (index) != int_type_node)
-    {
-      if (valid_cast_to_p (index_type, int_type_node))
-       parse_error_context (wfl_operator,
-   "Incompatible type for `[]'. Explicit cast needed to convert `%s' to `int'",
-                            lang_printable_name (index_type, 0));
-      else
-       parse_error_context (wfl_operator,
-          "Incompatible type for `[]'. Can't convert `%s' to `int'",
-                            lang_printable_name (index_type, 0));
-      TREE_TYPE (node) = error_mark_node;
-      error_found = 1;
-    }
-
-  if (error_found)
-    return error_mark_node;
-
-  array_type = TYPE_ARRAY_ELEMENT (array_type);
-
-  if (flag_emit_class_files || flag_emit_xref)
-    {
-      TREE_OPERAND (node, 0) = array;
-      TREE_OPERAND (node, 1) = index;
-    }
-  else
-    node = build_java_arrayaccess (array, array_type, index);
-  TREE_TYPE (node) = array_type;
-  return node;
-}
-
-/* 15.9 Array Creation Expressions */
-
-static tree
-build_newarray_node (type, dims, extra_dims)
-     tree type;
-     tree dims;
-     int extra_dims;
-{
-  tree node =
-    build (NEW_ARRAY_EXPR, NULL_TREE, type, nreverse (dims), 
-          build_int_2 (extra_dims, 0));
-  return node;
-}
-
-static tree
-patch_newarray (node)
-     tree node;
-{
-  tree type = TREE_OPERAND (node, 0);
-  tree dims = TREE_OPERAND (node, 1);
-  tree cdim, array_type;
-  int error_found = 0;
-  int ndims = 0;
-  int xdims = TREE_INT_CST_LOW (TREE_OPERAND (node, 2));
-
-  /* Dimension types are verified. It's better for the types to be
-     verified in order. */
-  for (cdim = dims, ndims = 0; cdim; cdim = TREE_CHAIN (cdim), ndims++ )
-    {
-      int dim_error = 0;
-      tree dim = TREE_VALUE (cdim);
-
-      /* Dim might have been saved during its evaluation */
-      dim = (TREE_CODE (dim) == SAVE_EXPR ? TREE_OPERAND (dim, 0) : dim);
-
-      /* The type of each specified dimension must be an integral type. */
-      if (!JINTEGRAL_TYPE_P (TREE_TYPE (dim)))
-       dim_error = 1;
-
-      /* Each expression undergoes an unary numeric promotion (5.6.1) and the
-        promoted type must be int. */
-      else
-       {
-         dim = do_unary_numeric_promotion (dim);
-         if (TREE_TYPE (dim) != int_type_node)
-           dim_error = 1;
-       }
-
-      /* Report errors on types here */
-      if (dim_error)
-       {
-         parse_error_context 
-           (TREE_PURPOSE (cdim), 
-            "Incompatible type for dimension in array creation expression. %s convert `%s' to `int'", 
-            (valid_cast_to_p (TREE_TYPE (dim), int_type_node) ?
-             "Explicit cast needed to" : "Can't"),
-            lang_printable_name (TREE_TYPE (dim), 0));
-         error_found = 1;
-       }
-
-      TREE_PURPOSE (cdim) = NULL_TREE;
-    }
-
-  /* Resolve array base type if unresolved */
-  if (!(type = resolve_type_during_patch (type)))
-    error_found = 1;
-
-  if (error_found)
-    {
-      /* We don't want further evaluation of this bogus array creation
-         operation */
-      TREE_TYPE (node) = error_mark_node;
-      return error_mark_node;
-    }
-
-  /* Set array_type to the actual (promoted) array type of the result. */
-  if (TREE_CODE (type) == RECORD_TYPE)
-    type = build_pointer_type (type);
-  while (--xdims >= 0)
-    {
-      type = promote_type (build_java_array_type (type, -1));
-    }
-  dims = nreverse (dims);
-  array_type = type;
-  for (cdim = dims; cdim; cdim = TREE_CHAIN (cdim))
-    {
-      type = array_type;
-      array_type
-       = build_java_array_type (type,
-                                TREE_CODE (cdim) == INTEGER_CST
-                                ? (HOST_WIDE_INT) TREE_INT_CST_LOW (cdim)
-                                : -1);
-      array_type = promote_type (array_type);
-    }
-  dims = nreverse (dims);
-
-  /* The node is transformed into a function call. Things are done
-     differently according to the number of dimensions. If the number
-     of dimension is equal to 1, then the nature of the base type
-     (primitive or not) matters. */
-  if (ndims == 1)
-    return build_new_array (type, TREE_VALUE (dims));
-  
-  /* Can't reuse what's already written in expr.c because it uses the
-     JVM stack representation. Provide a build_multianewarray. FIXME */
-  return build (CALL_EXPR, array_type,
-               build_address_of (soft_multianewarray_node),
-               tree_cons (NULL_TREE, build_class_ref (TREE_TYPE (array_type)),
-                          tree_cons (NULL_TREE, 
-                                     build_int_2 (ndims, 0), dims )),
-               NULL_TREE);
-}
-
-/* 10.6 Array initializer.  */
-
-/* Build a wfl for array element that don't have one, so we can
-   pin-point errors.  */
-
-static tree
-maybe_build_array_element_wfl (node)
-     tree node;
-{
-  if (TREE_CODE (node) != EXPR_WITH_FILE_LOCATION)
-    return build_expr_wfl (NULL_TREE, ctxp->filename,
-                          ctxp->elc.line, ctxp->elc.prev_col);
-  else
-    return NULL_TREE;
-}
-
-/* Build a NEW_ARRAY_INIT that features a CONSTRUCTOR node. This makes
-   identification of initialized arrays easier to detect during walk
-   and expansion.  */
-
-static tree
-build_new_array_init (location, values)
-     int location;
-     tree values;
-{
-  tree constructor = build (CONSTRUCTOR, NULL_TREE, NULL_TREE, values);
-  tree to_return = build1 (NEW_ARRAY_INIT, NULL_TREE, constructor);
-  EXPR_WFL_LINECOL (to_return) = location;
-  return to_return;
-}
-
-/* Expand a NEW_ARRAY_INIT node. Return error_mark_node if an error
-   occurred.  Otherwise return NODE after having set its type
-   appropriately.  */
-
-static tree
-patch_new_array_init (type, node)
-     tree type, node;
-{
-  int error_seen = 0;
-  tree current, element_type;
-  HOST_WIDE_INT length;
-  int all_constant = 1;
-  tree init = TREE_OPERAND (node, 0);
-
-  if (TREE_CODE (type) != POINTER_TYPE || ! TYPE_ARRAY_P (TREE_TYPE (type)))
-    {
-      parse_error_context (node,
-                          "Invalid array initializer for non-array type `%s'",
-                          lang_printable_name (type, 1));
-      return error_mark_node;
-    }
-  type = TREE_TYPE (type);
-  element_type = TYPE_ARRAY_ELEMENT (type);
-
-  CONSTRUCTOR_ELTS (init) = nreverse (CONSTRUCTOR_ELTS (init));
-
-  for (length = 0, current = CONSTRUCTOR_ELTS (init);
-       current;  length++, current = TREE_CHAIN (current))
-    {
-      tree elt = TREE_VALUE (current);
-      if (elt == NULL_TREE || TREE_CODE (elt) != NEW_ARRAY_INIT)
-       {
-         error_seen |= array_constructor_check_entry (element_type, current);
-         elt = TREE_VALUE (current);
-         /* When compiling to native code, STRING_CST is converted to
-            INDIRECT_REF, but still with a TREE_CONSTANT flag. */
-         if (! TREE_CONSTANT (elt) || TREE_CODE (elt) == INDIRECT_REF)
-           all_constant = 0;
-       }
-      else
-       {
-         TREE_VALUE (current) = patch_new_array_init (element_type, elt);
-         TREE_PURPOSE (current) = NULL_TREE;
-         all_constant = 0;
-       }
-      if (elt && TREE_CODE (elt) == TREE_LIST 
-         && TREE_VALUE (elt) == error_mark_node)
-       error_seen = 1;
-    }
-
-  if (error_seen)
-    return error_mark_node;
-
-  /* Create a new type. We can't reuse the one we have here by
-     patching its dimension because it originally is of dimension -1
-     hence reused by gcc. This would prevent triangular arrays. */
-  type = build_java_array_type (element_type, length);
-  TREE_TYPE (init) = TREE_TYPE (TREE_CHAIN (TREE_CHAIN (TYPE_FIELDS (type))));
-  TREE_TYPE (node) = promote_type (type);
-  TREE_CONSTANT (init) = all_constant;
-  TREE_CONSTANT (node) = all_constant;
-  return node;
-}
-
-/* Verify that one entry of the initializer element list can be
-   assigned to the array base type. Report 1 if an error occurred, 0
-   otherwise.  */
-
-static int
-array_constructor_check_entry (type, entry)
-     tree type, entry;
-{
-  char *array_type_string = NULL;      /* For error reports */
-  tree value, type_value, new_value, wfl_value, patched;
-  int error_seen = 0;
-
-  new_value = NULL_TREE;
-  wfl_value = TREE_VALUE (entry);
-
-  value = java_complete_tree (TREE_VALUE (entry));
-  /* patch_string return error_mark_node if arg is error_mark_node */
-  if ((patched = patch_string (value)))
-    value = patched;
-  if (value == error_mark_node)
-    return 1;
-  
-  type_value = TREE_TYPE (value);
-  
-  /* At anytime, try_builtin_assignconv can report a warning on
-     constant overflow during narrowing. */
-  SET_WFL_OPERATOR (wfl_operator, TREE_PURPOSE (entry), wfl_value);
-  new_value = try_builtin_assignconv (wfl_operator, type, value);
-  if (!new_value && (new_value = try_reference_assignconv (type, value)))
-    type_value = promote_type (type);
-
-  /* Check and report errors */
-  if (!new_value)
-    {
-      const char *const msg = (!valid_cast_to_p (type_value, type) ?
-                  "Can't" : "Explicit cast needed to");
-      if (!array_type_string)
-       array_type_string = xstrdup (lang_printable_name (type, 1));
-      parse_error_context 
-       (wfl_operator, "Incompatible type for array. %s convert `%s' to `%s'",
-        msg, lang_printable_name (type_value, 1), array_type_string);
-      error_seen = 1;
-    }
-  
-  if (new_value)
-    TREE_VALUE (entry) = new_value;
-
-  if (array_type_string)
-    free (array_type_string);
-
-  TREE_PURPOSE (entry) = NULL_TREE;
-  return error_seen;
-}
-
-static tree
-build_this (location)
-     int location;
-{
-  tree node = build_wfl_node (this_identifier_node);
-  TREE_SET_CODE (node, THIS_EXPR);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-}
-
-/* 14.15 The return statement. It builds a modify expression that
-   assigns the returned value to the RESULT_DECL that hold the value
-   to be returned. */
-
-static tree
-build_return (location, op)
-     int location;
-     tree op;
-{
-  tree node = build1 (RETURN_EXPR, NULL_TREE, op);
-  EXPR_WFL_LINECOL (node) = location;
-  node = build_debugable_stmt (location, node);
-  return node;
-}
-
-static tree
-patch_return (node)
-     tree node;
-{
-  tree return_exp = TREE_OPERAND (node, 0);
-  tree meth = current_function_decl;
-  tree mtype = TREE_TYPE (TREE_TYPE (current_function_decl));
-  int error_found = 0;
-
-  TREE_TYPE (node) = error_mark_node;
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  /* It's invalid to have a return value within a function that is
-     declared with the keyword void or that is a constructor */
-  if (return_exp && (mtype == void_type_node || DECL_CONSTRUCTOR_P (meth)))
-    error_found = 1;
-
-  /* It's invalid to use a return statement in a static block */
-  if (DECL_CLINIT_P (current_function_decl))
-    error_found = 1;
-
-  /* It's invalid to have a no return value within a function that
-     isn't declared with the keyword `void' */
-  if (!return_exp && (mtype != void_type_node && !DECL_CONSTRUCTOR_P (meth)))
-    error_found = 2;
-  
-  if (DECL_INSTINIT_P (current_function_decl))
-    error_found = 1;
-
-  if (error_found)
-    {
-      if (DECL_INSTINIT_P (current_function_decl))
-       parse_error_context (wfl_operator,
-                            "`return' inside instance initializer");
-       
-      else if (DECL_CLINIT_P (current_function_decl))
-       parse_error_context (wfl_operator,
-                            "`return' inside static initializer");
-
-      else if (!DECL_CONSTRUCTOR_P (meth))
-       {
-         char *t = xstrdup (lang_printable_name (mtype, 0));
-         parse_error_context (wfl_operator, 
-                              "`return' with%s value from `%s %s'",
-                              (error_found == 1 ? "" : "out"), 
-                              t, lang_printable_name (meth, 0));
-         free (t);
-       }
-      else
-       parse_error_context (wfl_operator, 
-                            "`return' with value from constructor `%s'",
-                            lang_printable_name (meth, 0));
-      return error_mark_node;
-    }
-
-  /* If we have a return_exp, build a modify expression and expand
-     it. Note: at that point, the assignment is declared valid, but we
-     may want to carry some more hacks */
-  if (return_exp)
-    {
-      tree exp = java_complete_tree (return_exp);
-      tree modify, patched;
-
-      if ((patched = patch_string (exp)))
-       exp = patched;
-      
-      modify = build (MODIFY_EXPR, NULL_TREE, DECL_RESULT (meth), exp);
-      EXPR_WFL_LINECOL (modify) = EXPR_WFL_LINECOL (node);
-      modify = java_complete_tree (modify);
-
-      if (modify != error_mark_node)
-       {
-         TREE_SIDE_EFFECTS (modify) = 1;
-         TREE_OPERAND (node, 0) = modify;
-       }
-      else
-       return error_mark_node;
-    }
-  TREE_TYPE (node) = void_type_node;
-  TREE_SIDE_EFFECTS (node) = 1;
-  return node;
-}
-
-/* 14.8 The if Statement */
-
-static tree
-build_if_else_statement (location, expression, if_body, else_body)
-     int location;
-     tree expression, if_body, else_body;
-{
-  tree node;
-  if (!else_body)
-    else_body = empty_stmt_node;
-  node = build (COND_EXPR, NULL_TREE, expression, if_body, else_body);
-  EXPR_WFL_LINECOL (node) = location;
-  node = build_debugable_stmt (location, node);
-  return node;
-}
-
-static tree
-patch_if_else_statement (node)
-     tree node;
-{
-  tree expression = TREE_OPERAND (node, 0);
-  int can_complete_normally
-    = (CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 1))
-       | CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 2)));
-
-  TREE_TYPE (node) = error_mark_node;
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  /* The type of expression must be boolean */
-  if (TREE_TYPE (expression) != boolean_type_node
-      && TREE_TYPE (expression) != promoted_boolean_type_node)
-    {
-      parse_error_context 
-       (wfl_operator, 
-        "Incompatible type for `if'. Can't convert `%s' to `boolean'", 
-        lang_printable_name (TREE_TYPE (expression), 0));
-      return error_mark_node;
-    }
-  
-  if (TREE_CODE (expression) == INTEGER_CST)
-    {
-      if (integer_zerop (expression))
-       node = TREE_OPERAND (node, 2);
-      else
-       node = TREE_OPERAND (node, 1);
-      if (CAN_COMPLETE_NORMALLY (node) != can_complete_normally)
-       {
-         node = build (COMPOUND_EXPR, void_type_node, node, empty_stmt_node);
-         CAN_COMPLETE_NORMALLY (node) = can_complete_normally;
-       }
-      return node;
-    }
-  TREE_TYPE (node) = void_type_node;
-  TREE_SIDE_EFFECTS (node) = 1;
-  CAN_COMPLETE_NORMALLY (node) = can_complete_normally;
-  return node;
-}
-
-/* 14.6 Labeled Statements */
-
-/* Action taken when a lableled statement is parsed. a new
-   LABELED_BLOCK_EXPR is created. No statement is attached to the
-   label, yet.  LABEL can be NULL_TREE for artificially-generated blocks. */
-
-static tree
-build_labeled_block (location, label)
-     int location;
-     tree label;
-{
-  tree label_name ;
-  tree label_decl, node;
-  if (label == NULL_TREE || label == continue_identifier_node)
-    label_name = label;
-  else
-    {
-      label_name = merge_qualified_name (label_id, label);
-      /* Issue an error if we try to reuse a label that was previously
-        declared */
-      if (IDENTIFIER_LOCAL_VALUE (label_name))
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = location;
-         parse_error_context (wfl_operator,
-            "Declaration of `%s' shadows a previous label declaration",
-                              IDENTIFIER_POINTER (label));
-         EXPR_WFL_LINECOL (wfl_operator) = 
-           EXPR_WFL_LINECOL (IDENTIFIER_LOCAL_VALUE (label_name));
-         parse_error_context (wfl_operator,
-            "This is the location of the previous declaration of label `%s'",
-                              IDENTIFIER_POINTER (label));
-         java_error_count--;
-       }
-    }
-
-  label_decl = create_label_decl (label_name);
-  node = build (LABELED_BLOCK_EXPR, NULL_TREE, label_decl, NULL_TREE);
-  EXPR_WFL_LINECOL (node) = location;
-  TREE_SIDE_EFFECTS (node) = 1;
-  return node;
-}
-
-/* A labeled statement LBE is attached a statement.  */
-
-static tree
-finish_labeled_statement (lbe, statement)
-     tree lbe;                 /* Labeled block expr */
-     tree statement;
-{
-  /* In anyways, tie the loop to its statement */
-  LABELED_BLOCK_BODY (lbe) = statement;
-  pop_labeled_block ();
-  POP_LABELED_BLOCK ();
-  return lbe;
-}
-
-/* 14.10, 14.11, 14.12 Loop Statements */
-
-/* Create an empty LOOP_EXPR and make it the last in the nested loop
-   list. */
-
-static tree
-build_new_loop (loop_body)
-     tree loop_body;
-{
-  tree loop =  build (LOOP_EXPR, NULL_TREE, loop_body);
-  TREE_SIDE_EFFECTS (loop) = 1;
-  PUSH_LOOP (loop);
-  return loop;
-}
-
-/* Create a loop body according to the following structure:
-     COMPOUND_EXPR
-       COMPOUND_EXPR           (loop main body)
-         EXIT_EXPR             (this order is for while/for loops.
-         LABELED_BLOCK_EXPR      the order is reversed for do loops)
-           LABEL_DECL           (a continue occurring here branches at the 
-           BODY                         end of this labeled block)
-       INCREMENT               (if any)
-
-  REVERSED, if non zero, tells that the loop condition expr comes
-  after the body, like in the do-while loop.
-
-  To obtain a loop, the loop body structure described above is
-  encapsulated within a LOOP_EXPR surrounded by a LABELED_BLOCK_EXPR:
-
-   LABELED_BLOCK_EXPR
-     LABEL_DECL                   (use this label to exit the loop)
-     LOOP_EXPR
-       <structure described above> */
-
-static tree
-build_loop_body (location, condition, reversed)
-     int location;
-     tree condition;
-     int reversed;
-{
-  tree first, second, body;
-
-  condition = build (EXIT_EXPR, NULL_TREE, condition); /* Force walk */
-  EXPR_WFL_LINECOL (condition) = location; /* For accurate error report */
-  condition = build_debugable_stmt (location, condition);
-  TREE_SIDE_EFFECTS (condition) = 1;
-
-  body = build_labeled_block (0, continue_identifier_node);
-  first = (reversed ? body : condition);
-  second = (reversed ? condition : body);
-  return 
-    build (COMPOUND_EXPR, NULL_TREE, 
-          build (COMPOUND_EXPR, NULL_TREE, first, second), empty_stmt_node);
-}
-
-/* Install CONDITION (if any) and loop BODY (using REVERSED to tell
-   their order) on the current loop. Unlink the current loop from the
-   loop list.  */
-
-static tree
-finish_loop_body (location, condition, body, reversed)
-     int location;
-     tree condition, body;
-     int reversed;
-{
-  tree to_return = ctxp->current_loop;
-  tree loop_body = LOOP_EXPR_BODY (to_return);
-  if (condition)
-    {
-      tree cnode = LOOP_EXPR_BODY_CONDITION_EXPR (loop_body, reversed);
-      /* We wrapped the EXIT_EXPR around a WFL so we can debug it.
-         The real EXIT_EXPR is one operand further. */
-      EXPR_WFL_LINECOL (cnode) = location;
-      /* This one is for accurate error reports */
-      EXPR_WFL_LINECOL (TREE_OPERAND (cnode, 0)) = location;
-      TREE_OPERAND (TREE_OPERAND (cnode, 0), 0) = condition;
-    }
-  LOOP_EXPR_BODY_BODY_EXPR (loop_body, reversed) = body;
-  POP_LOOP ();
-  return to_return;
-}
-
-/* Tailored version of finish_loop_body for FOR loops, when FOR
-   loops feature the condition part */
-
-static tree
-finish_for_loop (location, condition, update, body)
-    int location;
-    tree condition, update, body;
-{
-  /* Put the condition and the loop body in place */
-  tree loop = finish_loop_body (location, condition, body, 0);
-  /* LOOP is the current loop which has been now popped of the loop
-     stack. Install the update block */
-  LOOP_EXPR_BODY_UPDATE_BLOCK (LOOP_EXPR_BODY (loop)) = update;
-  return loop;
-}
-
-/* Try to find the loop a block might be related to. This comprises
-   the case where the LOOP_EXPR is found as the second operand of a
-   COMPOUND_EXPR, because the loop happens to have an initialization
-   part, then expressed as the first operand of the COMPOUND_EXPR. If
-   the search finds something, 1 is returned. Otherwise, 0 is
-   returned. The search is assumed to start from a
-   LABELED_BLOCK_EXPR's block.  */
-
-static tree
-search_loop (statement)
-    tree statement;
-{
-  if (TREE_CODE (statement) == LOOP_EXPR)
-    return statement;
-
-  if (TREE_CODE (statement) == BLOCK)
-    statement = BLOCK_SUBBLOCKS (statement);
-  else
-    return NULL_TREE;
-
-  if (statement && TREE_CODE (statement) == COMPOUND_EXPR)
-    while (statement && TREE_CODE (statement) == COMPOUND_EXPR)
-      statement = TREE_OPERAND (statement, 1);
-
-  return (TREE_CODE (statement) == LOOP_EXPR
-         && FOR_LOOP_P (statement) ? statement : NULL_TREE);
-}
-
-/* Return 1 if LOOP can be found in the labeled block BLOCK. 0 is
-   returned otherwise.  */
-
-static int
-labeled_block_contains_loop_p (block, loop)
-    tree block, loop;
-{
-  if (!block)
-    return 0;
-
-  if (LABELED_BLOCK_BODY (block) == loop)
-    return 1;
-
-  if (FOR_LOOP_P (loop) && search_loop (LABELED_BLOCK_BODY (block)) == loop)
-    return 1;
-
-  return 0;
-}
-
-/* If the loop isn't surrounded by a labeled statement, create one and
-   insert LOOP as its body.  */
-
-static tree
-patch_loop_statement (loop)
-     tree loop;
-{
-  tree loop_label;
-
-  TREE_TYPE (loop) = void_type_node;
-  if (labeled_block_contains_loop_p (ctxp->current_labeled_block, loop))
-    return loop;
-
-  loop_label = build_labeled_block (0, NULL_TREE);
-  /* LOOP is an EXPR node, so it should have a valid EXPR_WFL_LINECOL
-     that LOOP_LABEL could enquire about, for a better accuracy. FIXME */
-  LABELED_BLOCK_BODY (loop_label) = loop;
-  PUSH_LABELED_BLOCK (loop_label);
-  return loop_label;
-}
-
-/* 14.13, 14.14: break and continue Statements */
-
-/* Build a break or a continue statement. a null NAME indicates an
-   unlabeled break/continue statement.  */
-
-static tree
-build_bc_statement (location, is_break, name)
-     int location, is_break;
-     tree name;
-{
-  tree break_continue, label_block_expr = NULL_TREE;
-
-  if (name)
-    {
-      if (!(label_block_expr = IDENTIFIER_LOCAL_VALUE 
-           (merge_qualified_name (label_id, EXPR_WFL_NODE (name)))))
-       /* Null means that we don't have a target for this named
-          break/continue. In this case, we make the target to be the
-          label name, so that the error can be reported accuratly in
-          patch_bc_statement. */
-       label_block_expr = EXPR_WFL_NODE (name);
-    }
-  /* Unlabeled break/continue will be handled during the
-     break/continue patch operation */
-  break_continue 
-    = build (EXIT_BLOCK_EXPR, NULL_TREE, label_block_expr, NULL_TREE);
-
-  IS_BREAK_STMT_P (break_continue) = is_break;
-  TREE_SIDE_EFFECTS (break_continue) = 1;
-  EXPR_WFL_LINECOL (break_continue) = location;
-  break_continue = build_debugable_stmt (location, break_continue);
-  return break_continue;
-}
-
-/* Verification of a break/continue statement. */
-
-static tree
-patch_bc_statement (node)
-     tree node;
-{
-  tree bc_label = EXIT_BLOCK_LABELED_BLOCK (node), target_stmt;
-  tree labeled_block = ctxp->current_labeled_block;
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-  /* Having an identifier here means that the target is unknown. */
-  if (bc_label != NULL_TREE && TREE_CODE (bc_label) == IDENTIFIER_NODE)
-    {
-      parse_error_context (wfl_operator, "No label definition found for `%s'",
-                          IDENTIFIER_POINTER (bc_label));
-      return error_mark_node;
-    }
-  if (! IS_BREAK_STMT_P (node))
-    {
-      /* It's a continue statement. */
-      for (;; labeled_block = TREE_CHAIN (labeled_block))
-       {
-         if (labeled_block == NULL_TREE)
-           {
-             if (bc_label == NULL_TREE)
-               parse_error_context (wfl_operator,
-                                    "`continue' must be in loop");
-             else
-               parse_error_context 
-                 (wfl_operator, "continue label `%s' does not name a loop",
-                  IDENTIFIER_POINTER (bc_label));
-             return error_mark_node;
-           }
-         if ((DECL_NAME (LABELED_BLOCK_LABEL (labeled_block))
-              == continue_identifier_node)
-             && (bc_label == NULL_TREE
-                 || TREE_CHAIN (labeled_block) == bc_label))
-           {
-             bc_label = labeled_block;
-             break;
-           }
-       }
-    }
-  else if (!bc_label)
-    { 
-      for (;; labeled_block = TREE_CHAIN (labeled_block))
-       {
-         if (labeled_block == NULL_TREE)
-           {
-             parse_error_context (wfl_operator,
-                                    "`break' must be in loop or switch");
-             return error_mark_node;
-           }
-         target_stmt = LABELED_BLOCK_BODY (labeled_block);
-         if (TREE_CODE (target_stmt) == SWITCH_EXPR
-             || search_loop (target_stmt))
-           {
-             bc_label = labeled_block;
-             break;
-           }
-       }
-    }
-
-  EXIT_BLOCK_LABELED_BLOCK (node) = bc_label;
-  CAN_COMPLETE_NORMALLY (bc_label) = 1;
-
-  /* Our break/continue don't return values. */
-  TREE_TYPE (node) = void_type_node;
-  /* Encapsulate the break within a compound statement so that it's
-     expanded all the times by expand_expr (and not clobbered
-     sometimes, like after a if statement) */
-  node = add_stmt_to_compound (NULL_TREE, void_type_node, node);
-  TREE_SIDE_EFFECTS (node) = 1;
-  return node;
-}
-
-/* Process the exit expression belonging to a loop. Its type must be
-   boolean.  */
-
-static tree
-patch_exit_expr (node)
-     tree node;
-{
-  tree expression = TREE_OPERAND (node, 0);
-  TREE_TYPE (node) = error_mark_node;
-  EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-
-  /* The type of expression must be boolean */
-  if (TREE_TYPE (expression) != boolean_type_node)
-    {
-      parse_error_context 
-       (wfl_operator, 
-    "Incompatible type for loop conditional. Can't convert `%s' to `boolean'", 
-        lang_printable_name (TREE_TYPE (expression), 0));
-      return error_mark_node;
-    }
-  /* Now we know things are allright, invert the condition, fold and
-     return */
-  TREE_OPERAND (node, 0) = 
-    fold (build1 (TRUTH_NOT_EXPR, boolean_type_node, expression));
-
-  if (! integer_zerop (TREE_OPERAND (node, 0))
-      && ctxp->current_loop != NULL_TREE
-      && TREE_CODE (ctxp->current_loop) == LOOP_EXPR)
-    CAN_COMPLETE_NORMALLY (ctxp->current_loop) = 1;
-  if (! integer_onep (TREE_OPERAND (node, 0)))
-    CAN_COMPLETE_NORMALLY (node) = 1;
-
-
-  TREE_TYPE (node) = void_type_node;
-  return node;
-}
-
-/* 14.9 Switch statement */
-
-static tree
-patch_switch_statement (node)
-     tree node;
-{
-  tree se = TREE_OPERAND (node, 0), se_type;
-  tree save, iter;
-
-  /* Complete the switch expression */
-  se = TREE_OPERAND (node, 0) = java_complete_tree (se);
-  se_type = TREE_TYPE (se);
-  /* The type of the switch expression must be char, byte, short or
-     int */
-  if (! JINTEGRAL_TYPE_P (se_type) || se_type == long_type_node)
-    {
-      EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (node);
-      parse_error_context (wfl_operator,
-         "Incompatible type for `switch'. Can't convert `%s' to `int'",
-                          lang_printable_name (se_type, 0));
-      /* This is what java_complete_tree will check */
-      TREE_OPERAND (node, 0) = error_mark_node;
-      return error_mark_node;
-    }
-
-  /* Save and restore the outer case label list.  */
-  save = case_label_list;
-  case_label_list = NULL_TREE;
-
-  TREE_OPERAND (node, 1) = java_complete_tree (TREE_OPERAND (node, 1));
-
-  /* See if we've found a duplicate label.  We can't leave this until
-     code generation, because in `--syntax-only' and `-C' modes we
-     don't do ordinary code generation.  */
-  for (iter = case_label_list; iter != NULL_TREE; iter = TREE_CHAIN (iter))
-    {
-      HOST_WIDE_INT val = TREE_INT_CST_LOW (TREE_VALUE (iter));
-      tree subiter;
-      for (subiter = TREE_CHAIN (iter);
-          subiter != NULL_TREE;
-          subiter = TREE_CHAIN (subiter))
-       {
-         HOST_WIDE_INT subval = TREE_INT_CST_LOW (TREE_VALUE (subiter));
-         if (val == subval)
-           {
-             EXPR_WFL_LINECOL (wfl_operator)
-               = EXPR_WFL_LINECOL (TREE_PURPOSE (iter));
-             /* The case_label_list is in reverse order, so print the
-                outer label first.  */
-             parse_error_context (wfl_operator, "duplicate case label: `"
-                                  HOST_WIDE_INT_PRINT_DEC "'", subval);
-             EXPR_WFL_LINECOL (wfl_operator)
-               = EXPR_WFL_LINECOL (TREE_PURPOSE (subiter));
-             parse_error_context (wfl_operator, "original label is here");
-
-             break;
-           }
-       }
-    }
-
-  case_label_list = save;
-
-  /* Ready to return */
-  if (TREE_CODE (TREE_OPERAND (node, 1)) == ERROR_MARK)
-    {
-      TREE_TYPE (node) = error_mark_node;
-      return error_mark_node;
-    }
-  TREE_TYPE (node) = void_type_node;
-  TREE_SIDE_EFFECTS (node) = 1;
-  CAN_COMPLETE_NORMALLY (node)
-    = CAN_COMPLETE_NORMALLY (TREE_OPERAND (node, 1)) 
-      || ! SWITCH_HAS_DEFAULT (node);
-  return node;
-}
-
-/* 14.18 The try/catch statements */
-
-/* Encapsulate TRY_STMTS' in a try catch sequence. The catch clause
-   catches TYPE and executes CATCH_STMTS.  */
-
-static tree
-encapsulate_with_try_catch (location, type, try_stmts, catch_stmts)
-     int location;
-     tree type, try_stmts, catch_stmts;
-{
-  tree try_block, catch_clause_param, catch_block, catch;
-
-  /* First build a try block */
-  try_block = build_expr_block (try_stmts, NULL_TREE);
-
-  /* Build a catch block: we need a catch clause parameter */
-  catch_clause_param = build_decl (VAR_DECL, 
-                                  wpv_id, build_pointer_type (type));
-  /* And a block */
-  catch_block = build_expr_block (NULL_TREE, catch_clause_param);
-  
-  /* Initialize the variable and store in the block */
-  catch = build (MODIFY_EXPR, NULL_TREE, catch_clause_param,
-                build (JAVA_EXC_OBJ_EXPR, ptr_type_node));
-  add_stmt_to_block (catch_block, NULL_TREE, catch);
-
-  /* Add the catch statements */
-  add_stmt_to_block (catch_block, NULL_TREE, catch_stmts);
-
-  /* Now we can build a CATCH_EXPR */
-  catch_block = build1 (CATCH_EXPR, NULL_TREE, catch_block);
-
-  return build_try_statement (location, try_block, catch_block);
-}
-
-static tree
-build_try_statement (location, try_block, catches)
-     int location;
-     tree try_block, catches;
-{
-  tree node = build (TRY_EXPR, NULL_TREE, try_block, catches);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-}
-
-static tree
-build_try_finally_statement (location, try_block, finally)
-     int location;
-     tree try_block, finally;
-{
-  tree node = build (TRY_FINALLY_EXPR, NULL_TREE, try_block, finally);
-  EXPR_WFL_LINECOL (node) = location;
-  return node;
-}
-
-static tree
-patch_try_statement (node)
-     tree node;
-{
-  int error_found = 0;
-  tree try = TREE_OPERAND (node, 0);
-  /* Exception handlers are considered in left to right order */
-  tree catch = nreverse (TREE_OPERAND (node, 1));
-  tree current, caught_type_list = NULL_TREE;
-
-  /* Check catch clauses, if any. Every time we find an error, we try
-     to process the next catch clause. We process the catch clause before
-     the try block so that when processing the try block we can check thrown
-     exceptions againts the caught type list. */
-  for (current = catch; current; current = TREE_CHAIN (current))
-    {
-      tree carg_decl, carg_type;
-      tree sub_current, catch_block, catch_clause;
-      int unreachable;
-
-      /* At this point, the structure of the catch clause is
-          CATCH_EXPR           (catch node)
-            BLOCK              (with the decl of the parameter)
-               COMPOUND_EXPR
-                 MODIFY_EXPR   (assignment of the catch parameter)
-                BLOCK          (catch clause block)
-       */
-      catch_clause = TREE_OPERAND (current, 0);
-      carg_decl = BLOCK_EXPR_DECLS (catch_clause);
-      carg_type = TREE_TYPE (TREE_TYPE (carg_decl));
-
-      /* Catch clauses can't have more than one parameter declared,
-        but it's already enforced by the grammar. Make sure that the
-        only parameter of the clause statement in of class Throwable
-        or a subclass of Throwable, but that was done earlier. The
-        catch clause parameter type has also been resolved. */
-      
-      /* Just make sure that the catch clause parameter type inherits
-        from java.lang.Throwable */
-      if (!inherits_from_p (carg_type, throwable_type_node))
-       {
-         EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (current);
-         parse_error_context (wfl_operator,
-                              "Can't catch class `%s'. Catch clause parameter type must be a subclass of class `java.lang.Throwable'",
-                              lang_printable_name (carg_type, 0));
-         error_found = 1;
-         continue;
-       }
-      
-      /* Partial check for unreachable catch statement: The catch
-        clause is reachable iff is no earlier catch block A in
-        the try statement such that the type of the catch
-        clause's parameter is the same as or a subclass of the
-        type of A's parameter */
-      unreachable = 0;
-      for (sub_current = catch;
-          sub_current != current; sub_current = TREE_CHAIN (sub_current))
-       {
-         tree sub_catch_clause, decl;
-         sub_catch_clause = TREE_OPERAND (sub_current, 0);
-         decl = BLOCK_EXPR_DECLS (sub_catch_clause);
-
-         if (inherits_from_p (carg_type, TREE_TYPE (TREE_TYPE (decl))))
-           {
-             EXPR_WFL_LINECOL (wfl_operator) = EXPR_WFL_LINECOL (current);
-             parse_error_context 
-               (wfl_operator,
-                "`catch' not reached because of the catch clause at line %d",
-                EXPR_WFL_LINENO (sub_current));
-             unreachable = error_found = 1;
-             break;
-           }
-       }
-      /* Complete the catch clause block */
-      catch_block = java_complete_tree (TREE_OPERAND (current, 0));
-      if (catch_block == error_mark_node)
-       {
-         error_found = 1;
-         continue;
-       }
-      if (CAN_COMPLETE_NORMALLY (catch_block))
-       CAN_COMPLETE_NORMALLY (node) = 1;
-      TREE_OPERAND (current, 0) = catch_block;
-
-      if (unreachable)
-       continue;
-
-      /* Things to do here: the exception must be thrown */
-
-      /* Link this type to the caught type list */
-      caught_type_list = tree_cons (NULL_TREE, carg_type, caught_type_list);
-    }
-
-  PUSH_EXCEPTIONS (caught_type_list);
-  if ((try = java_complete_tree (try)) == error_mark_node)
-    error_found = 1;
-  if (CAN_COMPLETE_NORMALLY (try))
-    CAN_COMPLETE_NORMALLY (node) = 1;
-  POP_EXCEPTIONS ();
-
-  /* Verification ends here */
-  if (error_found) 
-    return error_mark_node;
-
-  TREE_OPERAND (node, 0) = try;
-  TREE_OPERAND (node, 1) = catch;
-  TREE_TYPE (node) = void_type_node;
-  return node;
-}
-
-/* 14.17 The synchronized Statement */
-
-static tree
-patch_synchronized_statement (node, wfl_op1)
-    tree node, wfl_op1;
-{
-  tree expr = java_complete_tree (TREE_OPERAND (node, 0));
-  tree block = TREE_OPERAND (node, 1);
-
-  tree tmp, enter, exit, expr_decl, assignment;
-
-  if (expr == error_mark_node)
-    {
-      block = java_complete_tree (block);
-      return expr;
-    }
-
-  /* We might be trying to synchronize on a STRING_CST */
-  if ((tmp = patch_string (expr)))
-    expr = tmp;
-
-  /* The TYPE of expr must be a reference type */
-  if (!JREFERENCE_TYPE_P (TREE_TYPE (expr)))
-    {
-      SET_WFL_OPERATOR (wfl_operator, node, wfl_op1);
-      parse_error_context (wfl_operator, "Incompatible type for `synchronized'. Can't convert `%s' to `java.lang.Object'",
-                          lang_printable_name (TREE_TYPE (expr), 0));
-      return error_mark_node;
-    }
-
-  if (flag_emit_xref)
-    {
-      TREE_OPERAND (node, 0) = expr;
-      TREE_OPERAND (node, 1) = java_complete_tree (block);
-      CAN_COMPLETE_NORMALLY (node) = 1;
-      return node;
-    }
-
-  /* Generate a try-finally for the synchronized statement, except
-     that the handler that catches all throw exception calls
-     _Jv_MonitorExit and then rethrow the exception.
-     The synchronized statement is then implemented as:
-     TRY 
-       {
-         _Jv_MonitorEnter (expression)
-        synchronized_block
-         _Jv_MonitorExit (expression)
-       }
-     CATCH_ALL
-       {
-         e = _Jv_exception_info ();
-        _Jv_MonitorExit (expression)
-        Throw (e);
-       } */
-
-  expr_decl = build_decl (VAR_DECL, generate_name (), TREE_TYPE (expr));
-  BUILD_MONITOR_ENTER (enter, expr_decl);
-  BUILD_MONITOR_EXIT (exit, expr_decl);
-  CAN_COMPLETE_NORMALLY (enter) = 1;
-  CAN_COMPLETE_NORMALLY (exit) = 1;
-  assignment = build (MODIFY_EXPR, NULL_TREE, expr_decl, expr);
-  TREE_SIDE_EFFECTS (assignment) = 1;
-  node = build (COMPOUND_EXPR, NULL_TREE,
-               build (COMPOUND_EXPR, NULL_TREE, assignment, enter),
-               build (TRY_FINALLY_EXPR, NULL_TREE, block, exit));
-  node = build_expr_block (node, expr_decl);
-
-  return java_complete_tree (node);
-}
-
-/* 14.16 The throw Statement */
-
-static tree
-patch_throw_statement (node, wfl_op1)
-    tree node, wfl_op1;
-{
-  tree expr = TREE_OPERAND (node, 0);
-  tree type = TREE_TYPE (expr);
-  int unchecked_ok = 0, tryblock_throws_ok = 0;
-
-  /* Thrown expression must be assignable to java.lang.Throwable */
-  if (!try_reference_assignconv (throwable_type_node, expr))
-    {
-      SET_WFL_OPERATOR (wfl_operator, node, wfl_op1);
-      parse_error_context (wfl_operator,
-    "Can't throw `%s'; it must be a subclass of class `java.lang.Throwable'",
-                          lang_printable_name (type, 0));
-      /* If the thrown expression was a reference, we further the
-         compile-time check. */
-      if (!JREFERENCE_TYPE_P (type))
-       return error_mark_node;
-    }
-
-  /* At least one of the following must be true */
-
-  /* The type of the throw expression is a not checked exception,
-     i.e. is a unchecked expression. */
-  unchecked_ok = IS_UNCHECKED_EXCEPTION_P (TREE_TYPE (type));
-
-  SET_WFL_OPERATOR (wfl_operator, node, wfl_op1);
-  /* An instance can't throw a checked exception unless that exception
-     is explicitly declared in the `throws' clause of each
-     constructor. This doesn't apply to anonymous classes, since they
-     don't have declared constructors. */
-  if (!unchecked_ok 
-      && DECL_INSTINIT_P (current_function_decl)
-      && !ANONYMOUS_CLASS_P (current_class))
-    {
-      tree current;
-      for (current = TYPE_METHODS (current_class); current; 
-          current = TREE_CHAIN (current))
-       if (DECL_CONSTRUCTOR_P (current) 
-           && !check_thrown_exceptions_do (TREE_TYPE (expr)))
-         {
-           parse_error_context (wfl_operator, "Checked exception `%s' can't be thrown in instance initializer (not all declared constructor are declaring it in their `throws' clause)", 
-                                lang_printable_name (TREE_TYPE (expr), 0));
-           return error_mark_node;
-         }
-    }
-
-  /* Throw is contained in a try statement and at least one catch
-     clause can receive the thrown expression or the current method is
-     declared to throw such an exception. Or, the throw statement is
-     contained in a method or constructor declaration and the type of
-     the Expression is assignable to at least one type listed in the
-     throws clause the declaration. */
-  if (!unchecked_ok)
-    tryblock_throws_ok = check_thrown_exceptions_do (TREE_TYPE (expr));
-  if (!(unchecked_ok || tryblock_throws_ok))
-    {
-      /* If there is a surrounding try block that has no matching
-        clatch clause, report it first. A surrounding try block exits
-        only if there is something after the list of checked
-        exception thrown by the current function (if any). */
-      if (IN_TRY_BLOCK_P ())
-       parse_error_context (wfl_operator, "Checked exception `%s' can't be caught by any of the catch clause(s) of the surrounding `try' block",
-                            lang_printable_name (type, 0));
-      /* If we have no surrounding try statement and the method doesn't have
-        any throws, report it now. FIXME */
-
-      /* We report that the exception can't be throw from a try block
-         in all circumstances but when the `throw' is inside a static
-         block. */
-      else if (!EXCEPTIONS_P (currently_caught_type_list) 
-              && !tryblock_throws_ok)
-       {
-         if (DECL_CLINIT_P (current_function_decl))
-           parse_error_context (wfl_operator,
-                   "Checked exception `%s' can't be thrown in initializer",
-                                lang_printable_name (type, 0));
-         else
-           parse_error_context (wfl_operator,
-                   "Checked exception `%s' isn't thrown from a `try' block", 
-                                lang_printable_name (type, 0));
-       }
-      /* Otherwise, the current method doesn't have the appropriate
-         throws declaration */
-      else
-       parse_error_context (wfl_operator, "Checked exception `%s' doesn't match any of current method's `throws' declaration(s)", 
-                            lang_printable_name (type, 0));
-      return error_mark_node;
-    }
-
-  if (! flag_emit_class_files && ! flag_emit_xref)
-    BUILD_THROW (node, expr);
-
-  /* If doing xrefs, keep the location where the `throw' was seen. */
-  if (flag_emit_xref)
-    EXPR_WFL_LINECOL (node) = EXPR_WFL_LINECOL (wfl_op1);
-  return node;
-}
-
-/* Check that exception said to be thrown by method DECL can be
-   effectively caught from where DECL is invoked.  */
-
-static void
-check_thrown_exceptions (location, decl)
-     int location;
-     tree decl;
-{
-  tree throws;
-  /* For all the unchecked exceptions thrown by DECL */
-  for (throws = DECL_FUNCTION_THROWS (decl); throws; 
-       throws = TREE_CHAIN (throws)) 
-    if (!check_thrown_exceptions_do (TREE_VALUE (throws)))
-      {
-#if 1
-       /* Temporary hack to suppresses errors about cloning arrays. FIXME */
-       if (DECL_NAME (decl) == get_identifier ("clone"))
-         continue;
-#endif
-       EXPR_WFL_LINECOL (wfl_operator) = location;
-       if (DECL_FINIT_P (current_function_decl))
-         parse_error_context
-            (wfl_operator, "Exception `%s' can't be thrown in initializer",
-            lang_printable_name (TREE_VALUE (throws), 0));
-       else 
-         {
-           parse_error_context 
-             (wfl_operator, "Exception `%s' must be caught, or it must be declared in the `throws' clause of `%s'", 
-              lang_printable_name (TREE_VALUE (throws), 0),
-              (DECL_INIT_P (current_function_decl) ?
-               IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (current_class))) :
-               IDENTIFIER_POINTER (DECL_NAME (current_function_decl))));
-         }
-      }
-}
-
-/* Return 1 if checked EXCEPTION is caught at the current nesting level of
-   try-catch blocks, OR is listed in the `throws' clause of the
-   current method.  */
-
-static int
-check_thrown_exceptions_do (exception)
-     tree exception;
-{
-  tree list = currently_caught_type_list;
-  resolve_and_layout (exception, NULL_TREE);
-  /* First, all the nested try-catch-finally at that stage. The
-     last element contains `throws' clause exceptions, if any. */
-  if (IS_UNCHECKED_EXCEPTION_P (exception))
-    return 1;
-  while (list)
-    {
-      tree caught;
-      for (caught = TREE_VALUE (list); caught; caught = TREE_CHAIN (caught))
-       if (valid_ref_assignconv_cast_p (exception, TREE_VALUE (caught), 0))
-         return 1;
-      list = TREE_CHAIN (list);
-    }
-  return 0;
-}
-
-static void
-purge_unchecked_exceptions (mdecl)
-     tree mdecl;
-{
-  tree throws = DECL_FUNCTION_THROWS (mdecl);
-  tree new = NULL_TREE;
-
-  while (throws)
-    {
-      tree next = TREE_CHAIN (throws);
-      if (!IS_UNCHECKED_EXCEPTION_P (TREE_VALUE (throws)))
-       {
-         TREE_CHAIN (throws) = new;
-         new = throws;
-       }
-      throws = next;
-    }
-  /* List is inverted here, but it doesn't matter */
-  DECL_FUNCTION_THROWS (mdecl) = new;
-}
-
-/* This function goes over all of CLASS_TYPE ctors and checks whether
-   each of them features at least one unchecked exception in its
-   `throws' clause. If it's the case, it returns `true', `false'
-   otherwise.  */
-
-static bool
-ctors_unchecked_throws_clause_p (class_type)
-     tree class_type;
-{
-  tree current;
-
-  for (current = TYPE_METHODS (class_type); current;
-       current = TREE_CHAIN (current))
-    {
-      bool ctu = false;        /* Ctor Throws Unchecked */
-      if (DECL_CONSTRUCTOR_P (current))
-       {
-         tree throws;
-         for (throws = DECL_FUNCTION_THROWS (current); throws && !ctu;
-              throws = TREE_CHAIN (throws))
-           if (inherits_from_p (TREE_VALUE (throws), exception_type_node))
-             ctu = true;
-       }
-      /* We return false as we found one ctor that is unfit. */
-      if (!ctu && DECL_CONSTRUCTOR_P (current))
-       return false;
-    }
-  /* All ctors feature at least one unchecked exception in their
-     `throws' clause. */
-  return true;
-}
-
-/* 15.24 Conditional Operator ?: */
-
-static tree
-patch_conditional_expr (node, wfl_cond, wfl_op1)
-     tree node, wfl_cond, wfl_op1;
-{
-  tree cond = TREE_OPERAND (node, 0);
-  tree op1 = TREE_OPERAND (node, 1);
-  tree op2 = TREE_OPERAND (node, 2);
-  tree resulting_type = NULL_TREE;
-  tree t1, t2, patched;
-  int error_found = 0;
-
-  /* Operands of ?: might be StringBuffers crafted as a result of a
-     string concatenation. Obtain a descent operand here.  */
-  if ((patched = patch_string (op1)))
-    TREE_OPERAND (node, 1) = op1 = patched;
-  if ((patched = patch_string (op2)))
-    TREE_OPERAND (node, 2) = op2 = patched;
-
-  t1 = TREE_TYPE (op1);
-  t2 = TREE_TYPE (op2);
-
-  /* The first expression must be a boolean */
-  if (TREE_TYPE (cond) != boolean_type_node)
-    {
-      SET_WFL_OPERATOR (wfl_operator, node, wfl_cond);
-      parse_error_context (wfl_operator,
-               "Incompatible type for `?:'. Can't convert `%s' to `boolean'",
-                          lang_printable_name (TREE_TYPE (cond), 0));
-      error_found = 1;
-    }
-
-  /* Second and third can be numeric, boolean (i.e. primitive),
-     references or null. Anything else results in an error */
-  if (!((JNUMERIC_TYPE_P (t1) && JNUMERIC_TYPE_P (t2))
-       || ((JREFERENCE_TYPE_P (t1) || op1 == null_pointer_node) 
-           && (JREFERENCE_TYPE_P (t2) || op2 == null_pointer_node))
-       || (t1 == boolean_type_node && t2 == boolean_type_node)))
-    error_found = 1;
-
-  /* Determine the type of the conditional expression. Same types are
-     easy to deal with */
-  else if (t1 == t2)
-    resulting_type = t1;
-
-  /* There are different rules for numeric types */
-  else if (JNUMERIC_TYPE_P (t1))
-    {
-      /* if byte/short found, the resulting type is short */
-      if ((t1 == byte_type_node && t2 == short_type_node)
-         || (t1 == short_type_node && t2 == byte_type_node))
-       resulting_type = short_type_node;
-
-      /* If t1 is a constant int and t2 is of type byte, short or char
-        and t1's value fits in t2, then the resulting type is t2 */
-      else if ((t1 == int_type_node && TREE_CONSTANT (TREE_OPERAND (node, 1)))
-         && JBSC_TYPE_P (t2) && int_fits_type_p (TREE_OPERAND (node, 1), t2))
-       resulting_type = t2;
-
-      /* If t2 is a constant int and t1 is of type byte, short or char
-        and t2's value fits in t1, then the resulting type is t1 */
-      else if ((t2 == int_type_node && TREE_CONSTANT (TREE_OPERAND (node, 2)))
-         && JBSC_TYPE_P (t1) && int_fits_type_p (TREE_OPERAND (node, 2), t1))
-       resulting_type = t1;
-
-      /* Otherwise, binary numeric promotion is applied and the
-        resulting type is the promoted type of operand 1 and 2 */
-      else 
-       resulting_type = binary_numeric_promotion (t1, t2, 
-                                                  &TREE_OPERAND (node, 1), 
-                                                  &TREE_OPERAND (node, 2));
-    }
-
-  /* Cases of a reference and a null type */
-  else if (JREFERENCE_TYPE_P (t1) && op2 == null_pointer_node)
-    resulting_type = t1;
-
-  else if (JREFERENCE_TYPE_P (t2) && op1 == null_pointer_node)
-    resulting_type = t2;
-
-  /* Last case: different reference types. If a type can be converted
-     into the other one by assignment conversion, the latter
-     determines the type of the expression */
-  else if ((resulting_type = try_reference_assignconv (t1, op2)))
-    resulting_type = promote_type (t1);
-
-  else if ((resulting_type = try_reference_assignconv (t2, op1)))
-    resulting_type = promote_type (t2);
-
-  /* If we don't have any resulting type, we're in trouble */
-  if (!resulting_type)
-    {
-      char *t = xstrdup (lang_printable_name (t1, 0));
-      SET_WFL_OPERATOR (wfl_operator, node, wfl_op1);
-      parse_error_context (wfl_operator,
-                "Incompatible type for `?:'. Can't convert `%s' to `%s'",
-                          t, lang_printable_name (t2, 0));
-      free (t);
-      error_found = 1;
-    }
-
-  if (error_found)
-    {
-      TREE_TYPE (node) = error_mark_node;
-      return error_mark_node;
-    }
-
-  TREE_TYPE (node) = resulting_type;
-  TREE_SET_CODE (node, COND_EXPR);
-  CAN_COMPLETE_NORMALLY (node) = 1;
-  return node;
-}
-
-/* Wrap EXPR with code to initialize DECL's class, if appropriate. */
-
-static tree
-maybe_build_class_init_for_field (decl, expr)
-    tree decl, expr;
-{
-  tree clas = DECL_CONTEXT (decl);
-  if (flag_emit_class_files || flag_emit_xref)
-    return expr;
-
-  if (TREE_CODE (decl) == VAR_DECL && FIELD_STATIC (decl)
-      && FIELD_FINAL (decl))
-    {
-      tree init = DECL_INITIAL (decl);
-      if (init != NULL_TREE)
-       init = fold_constant_for_init (init, decl);
-      if (init != NULL_TREE && CONSTANT_VALUE_P (init))
-       return expr;
-    }
-
-  return build_class_init (clas, expr);
-}
-
-/* Try to constant fold NODE.
-   If NODE is not a constant expression, return NULL_EXPR.
-   CONTEXT is a static final VAR_DECL whose initializer we are folding. */
-
-static tree
-fold_constant_for_init (node, context)
-     tree node;
-     tree context;
-{
-  tree op0, op1, val;
-  enum tree_code code = TREE_CODE (node);
-
-  switch (code)
-    {
-    case STRING_CST:
-    case INTEGER_CST:
-    case REAL_CST:
-      return node;
-
-    case PLUS_EXPR:
-    case MINUS_EXPR:
-    case MULT_EXPR:
-    case TRUNC_MOD_EXPR:
-    case RDIV_EXPR:
-    case LSHIFT_EXPR:
-    case RSHIFT_EXPR:
-    case URSHIFT_EXPR:
-    case BIT_AND_EXPR:
-    case BIT_XOR_EXPR:
-    case BIT_IOR_EXPR:
-    case TRUTH_ANDIF_EXPR:
-    case TRUTH_ORIF_EXPR:
-    case EQ_EXPR: 
-    case NE_EXPR:
-    case GT_EXPR:
-    case GE_EXPR:
-    case LT_EXPR:
-    case LE_EXPR:
-      op0 = TREE_OPERAND (node, 0);
-      op1 = TREE_OPERAND (node, 1);
-      val = fold_constant_for_init (op0, context);
-      if (val == NULL_TREE || ! TREE_CONSTANT (val))
-       return NULL_TREE;
-      TREE_OPERAND (node, 0) = val;
-      val = fold_constant_for_init (op1, context);
-      if (val == NULL_TREE || ! TREE_CONSTANT (val))
-       return NULL_TREE;
-      TREE_OPERAND (node, 1) = val;
-      return patch_binop (node, op0, op1);
-
-    case UNARY_PLUS_EXPR:
-    case NEGATE_EXPR:
-    case TRUTH_NOT_EXPR:
-    case BIT_NOT_EXPR:
-    case CONVERT_EXPR:
-      op0 = TREE_OPERAND (node, 0);
-      val = fold_constant_for_init (op0, context);
-      if (val == NULL_TREE || ! TREE_CONSTANT (val))
-       return NULL_TREE;
-      TREE_OPERAND (node, 0) = val;
-      return patch_unaryop (node, op0);
-      break;
-
-    case COND_EXPR:
-      val = fold_constant_for_init (TREE_OPERAND (node, 0), context);
-      if (val == NULL_TREE || ! TREE_CONSTANT (val))
-       return NULL_TREE;
-      TREE_OPERAND (node, 0) = val;
-      val = fold_constant_for_init (TREE_OPERAND (node, 1), context);
-      if (val == NULL_TREE || ! TREE_CONSTANT (val))
-       return NULL_TREE;
-      TREE_OPERAND (node, 1) = val;
-      val = fold_constant_for_init (TREE_OPERAND (node, 2), context);
-      if (val == NULL_TREE || ! TREE_CONSTANT (val))
-       return NULL_TREE;
-      TREE_OPERAND (node, 2) = val;
-      return integer_zerop (TREE_OPERAND (node, 0)) ? TREE_OPERAND (node, 1)
-       : TREE_OPERAND (node, 2);
-
-    case VAR_DECL:
-    case FIELD_DECL:
-      if (! FIELD_FINAL (node)
-         || DECL_INITIAL (node) == NULL_TREE)
-       return NULL_TREE;
-      val = DECL_INITIAL (node);
-      /* Guard against infinite recursion. */
-      DECL_INITIAL (node) = NULL_TREE;
-      val = fold_constant_for_init (val, node);
-      DECL_INITIAL (node) = val;
-      return val;
-
-    case EXPR_WITH_FILE_LOCATION:
-      /* Compare java_complete_tree and resolve_expression_name. */
-      if (!EXPR_WFL_NODE (node) /* Or a PRIMARY flag ? */
-         || TREE_CODE (EXPR_WFL_NODE (node)) == IDENTIFIER_NODE)
-       {
-         tree name = EXPR_WFL_NODE (node);
-         tree decl;
-         if (PRIMARY_P (node))
-           return NULL_TREE;
-         else if (! QUALIFIED_P (name))
-           {
-             decl = lookup_field_wrapper (DECL_CONTEXT (context), name);
-             if (decl == NULL_TREE 
-                 || (! FIELD_STATIC (decl) && ! FIELD_FINAL (decl)))
-               return NULL_TREE;
-             return fold_constant_for_init (decl, decl);
-           }
-         else
-           {
-             /* Install the proper context for the field resolution.
-                The prior context is restored once the name is
-                properly qualified. */
-             tree saved_current_class = current_class;
-             /* Wait until the USE_COMPONENT_REF re-write.  FIXME. */
-             current_class = DECL_CONTEXT (context);
-             qualify_ambiguous_name (node);
-             current_class = saved_current_class;
-             if (resolve_field_access (node, &decl, NULL)
-                 && decl != NULL_TREE)
-               return fold_constant_for_init (decl, decl);
-             return NULL_TREE;
-           }
-       }
-      else
-       {
-         op0 = TREE_OPERAND (node, 0);
-         val = fold_constant_for_init (op0, context);
-         if (val == NULL_TREE || ! TREE_CONSTANT (val))
-           return NULL_TREE;
-         TREE_OPERAND (node, 0) = val;
-         return val;
-       }
-
-#ifdef USE_COMPONENT_REF
-    case IDENTIFIER:
-    case COMPONENT_REF:
-      ?;
-#endif
-
-    default:
-      return NULL_TREE;
-    }
-}
-
-#ifdef USE_COMPONENT_REF
-/* Context is 'T' for TypeName, 'P' for PackageName,
-   'M' for MethodName, 'E' for ExpressionName, and 'A' for AmbiguousName. */
-
-tree
-resolve_simple_name (name, context)
-     tree name;
-     int context;
-{
-}
-
-tree
-resolve_qualified_name (name, context)
-     tree name;
-     int context;
-{
-}
-#endif
-
-/* Mark P, which is really a `struct parser_ctxt **' for GC.  */
-
-static void
-mark_parser_ctxt (p)
-     void *p;
-{
-  struct parser_ctxt *pc = *((struct parser_ctxt **) p);
-  int i;
-
-  if (!pc)
-    return;
-
-#ifndef JC1_LITE
-  for (i = 0; i < 11; ++i)
-    ggc_mark_tree (pc->modifier_ctx[i]);
-  ggc_mark_tree (pc->class_type);
-  ggc_mark_tree (pc->function_decl);
-  ggc_mark_tree (pc->package);
-  ggc_mark_tree (pc->class_list);
-  ggc_mark_tree (pc->current_parsed_class);
-  ggc_mark_tree (pc->current_parsed_class_un);
-  ggc_mark_tree (pc->non_static_initialized);
-  ggc_mark_tree (pc->static_initialized);
-  ggc_mark_tree (pc->instance_initializers);
-  ggc_mark_tree (pc->import_list);
-  ggc_mark_tree (pc->import_demand_list);
-  ggc_mark_tree (pc->current_loop);
-  ggc_mark_tree (pc->current_labeled_block);
-#endif /* JC1_LITE */
-
-  if (pc->next)
-    mark_parser_ctxt (&pc->next);
-}
-
-void
-init_src_parse ()
-{
-  /* Register roots with the garbage collector.  */
-  ggc_add_tree_root (src_parse_roots, sizeof (src_parse_roots) / sizeof(tree));
-
-  /* Sanity check; we've been bit by this before.  */
-  if (sizeof (ctxp->modifier_ctx) / sizeof (tree) != 
-      MODIFIER_TK - PUBLIC_TK)
-    abort ();
-}
-
-\f
-
-/* This section deals with the functions that are called when tables
-   recording class initialization information are traversed.  */
-
-/* Attach to PTR (a block) the declaration found in ENTRY. */
-
-static bool
-attach_init_test_initialization_flags (entry, ptr)
-     struct hash_entry *entry;
-     PTR ptr;
-{
-  tree block = (tree)ptr;
-  struct init_test_hash_entry *ite = (struct init_test_hash_entry *) entry;
-  
-  TREE_CHAIN (ite->init_test_decl) = BLOCK_EXPR_DECLS (block);
-  BLOCK_EXPR_DECLS (block) = ite->init_test_decl;
-  return true;
-}
-
-/* This function is called for each classes that is known definitely
-   assigned when a given static method was called. This function
-   augments a compound expression (INFO) storing all assignment to
-   initialized static class flags if a flag already existed, otherwise
-   a new one is created.  */
-
-static bool
-emit_test_initialization (entry, info)
-     struct hash_entry *entry;
-     PTR info;
-{
-  tree l = (tree) info;
-  tree decl, init;
-
-  struct init_test_hash_entry *ite = (struct init_test_hash_entry *)
-    hash_lookup (&DECL_FUNCTION_INIT_TEST_TABLE (current_function_decl),
-                entry->key,
-                current_function_decl != TREE_PURPOSE (l), NULL);
-
-  /* If we haven't found a flag and we're dealing with self registered
-     with current_function_decl, then don't do anything. Self is
-     always added as definitely initialized but this information is
-     valid only if used outside the current function. */
-  if (! ite)
-    return true;
-
-  /* If we don't have a variable, create one and install it. */
-  if (! ite->init_test_decl)
-    {
-      tree block;
-      
-      decl = build_decl (VAR_DECL, NULL_TREE, boolean_type_node);
-      MAYBE_CREATE_VAR_LANG_DECL_SPECIFIC (decl);
-      LOCAL_CLASS_INITIALIZATION_FLAG (decl) = 1;
-      DECL_CONTEXT (decl) = current_function_decl;
-      DECL_INITIAL (decl) = boolean_true_node;
-
-      /* The trick is to find the right context for it. */
-      block = BLOCK_SUBBLOCKS (GET_CURRENT_BLOCK (current_function_decl));
-      TREE_CHAIN (decl) = BLOCK_EXPR_DECLS (block);
-      BLOCK_EXPR_DECLS (block) = decl;
-      ite->init_test_decl = decl;
-    }
-  else
-    decl = ite->init_test_decl;
-
-  /* Now simply augment the compound that holds all the assignments
-     pertaining to this method invocation. */
-  init = build (MODIFY_EXPR, boolean_type_node, decl, boolean_true_node);
-  TREE_SIDE_EFFECTS (init) = 1;
-  TREE_VALUE (l) = add_stmt_to_compound (TREE_VALUE (l), void_type_node, init);
-  TREE_SIDE_EFFECTS (TREE_VALUE (l)) = 1;
-
-  return true;
-}
-
-