#include <stdio.h>
#include "prescheme.h"
long goto_arg1K0;
long goto_arg1K4;
long goto_arg1K3;
long goto_arg1K2;
long goto_arg1K1;
unsigned char goto_arg0K0;
long Sminimum_recovered_spaceS;
long Sinterrupt_templateS;
long Spending_interruptsS;
long Sdynamic_stateS;
long Sinterrupt_handlersS;
long Sexception_handlerS;
long Senabled_interruptsS;
long SvalS;
long SnargsS;
long Scode_pointerS;
long StemplateS;
long SenvS;
unsigned char Sexception_space_usedPS;
long ScontS;
long Sbottom_of_stackS;
long Sstack_limitS;
long SstackS;
long Sstack_endS;
long Sstack_beginS;
long *Sopen_vm_portsS;
FILE * *Sopen_portsS;
long Snumber_of_portsS;
long Sweak_pointer_limitS;
long Sweak_pointer_hpS;
long Ssaved_limitS;
long Ssaved_hpS;
long Sgc_countS;
unsigned char Simpure_area_countS;
unsigned char Spure_area_countS;
long *Simpure_sizesS;
long *Spure_sizesS;
long *Simpure_areasS;
long *Spure_areasS;
long Soldspace_endS;
long Soldspace_beginS;
long Snewspace_endS;
long Snewspace_beginS;
long SlimitS;
long ShpS;
FILE * Scurrent_output_portS;
FILE * Scurrent_input_portS;

unsigned char hoistD0(long start_0X, long end_1X, long type_2X)
{
  extern FILE * Scurrent_output_portS;
  extern long SlimitS;
  extern long ShpS;
  long arg1K0;
  long addr_3X;
  long d_4X;

 {arg1K0 = start_0X;
  goto L10156;}
 L10156: {
  addr_3X = arg1K0;
  if ((addr_3X < end_1X)) {
    d_4X = *((long *) addr_3X);
    if ((2 == (3 & d_4X))) {
      if ((type_2X == (31 & (((d_4X)>>2))))) {
        if (((16 + (ShpS)) < (SlimitS))) {
          *((long *) (ShpS)) = (7 + addr_3X);
          ShpS = (4 + (ShpS));
          arg1K0 = (4 + (addr_3X + (-4 & (3 + ((long)(((unsigned long)d_4X)>>8))))));
          goto L10156;}
        else {
          return(0);}}
      else {
        arg1K0 = (4 + (addr_3X + (-4 & (3 + ((long)(((unsigned long)d_4X)>>8))))));
        goto L10156;}}
    else {
      fputs("heap is in an inconsistent state.", (Scurrent_output_portS));
      return(0);}}
  else {
    return(1);}}}

unsigned char hoistD1(long start_5X, long end_6X, long x_7X)
{
  extern FILE * Scurrent_output_portS;
  extern long SlimitS;
  extern long ShpS;
  long arg1K1;
  long arg1K0;
  long i_8X;
  long h_9X;
  long bucket_10X;
  long index_11X;
  long b_12X;
  long new_13X;
  long addr_14X;
  long d_15X;
  long obj_16X;
  long v_17X;
  long s_18X;
  long n_19X;

 {arg1K0 = start_5X;
  goto L17328;}
 L13673: {
  i_8X = arg1K0;
  h_9X = arg1K1;
  if ((i_8X < n_19X)) {
    arg1K0 = (1 + i_8X);
    arg1K1 = (h_9X + ((long)((((long)(*((unsigned char *) ((-3 + s_18X) + i_8X))))))));
    goto L13673;}
  else {
    index_11X = h_9X & (-1 + v_17X);
    bucket_10X = *((long *) ((-3 + x_7X) + (((index_11X)<<2))));
    arg1K0 = bucket_10X;
    goto L13571;}}
 L13571: {
  b_12X = arg1K0;
  if ((25 == b_12X)) {
    *((long *) (ShpS)) = 2050;
    ShpS = (4 + (ShpS));
    new_13X = 3 + (ShpS);
    ShpS = (8 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_13X)) = obj_16X;
    *((long *) (1 + new_13X)) = bucket_10X;
    *((long *) ((-3 + x_7X) + (((index_11X)<<2)))) = new_13X;
    arg1K0 = (4 + (addr_14X + (-4 & (3 + ((long)(((unsigned long)d_15X)>>8))))));
    goto L17328;}
  else {
    if ((obj_16X == (*((long *) (-3 + b_12X))))) {
      arg1K0 = (4 + (addr_14X + (-4 & (3 + ((long)(((unsigned long)d_15X)>>8))))));
      goto L17328;}
    else {
      arg1K0 = (*((long *) (1 + b_12X)));
      goto L13571;}}}
 L17328: {
  addr_14X = arg1K0;
  if ((addr_14X < end_6X)) {
    d_15X = *((long *) addr_14X);
    if ((2 == (3 & d_15X))) {
      if ((1 == (31 & (((d_15X)>>2))))) {
        if (((12 + (ShpS)) < (SlimitS))) {
          obj_16X = 7 + addr_14X;
          v_17X = (((3 + ((long)(((unsigned long)(*((long *) (-7 + x_7X))))>>8))))>>2);
          s_18X = *((long *) (-3 + obj_16X));
          n_19X = -1 + ((long)(((unsigned long)(*((long *) (-7 + s_18X))))>>8));
          arg1K0 = 0;
          arg1K1 = 0;
          goto L13673;}
        else {
          return(0);}}
      else {
        arg1K0 = (4 + (addr_14X + (-4 & (3 + ((long)(((unsigned long)d_15X)>>8))))));
        goto L17328;}}
    else {
      fputs("heap is in an inconsistent state.", (Scurrent_output_portS));
      return(0);}}
  else {
    return(1);}}}

long Tinterpret()
{
  extern void really_write_number(long, FILE *);
  extern FILE * Scurrent_output_portS;
  extern long copy_weak_pointer(long);
  extern long Sinterrupt_templateS;
  extern unsigned char Sexception_space_usedPS;
  extern long extended_vm(long, long);
  extern long ps_real_time();
  extern long ps_run_time();
  extern long ps_ticks_per_second();
  extern unsigned char lookup_external_name(long, long);
  extern long ps_schedule_interrupt(long);
  extern long Sinterrupt_handlersS;
  extern long Sexception_handlerS;
  extern long Sdynamic_stateS;
  extern long *Simpure_sizesS;
  extern long *Simpure_areasS;
  extern unsigned char hoistD0(long, long, long);
  extern long *Spure_sizesS;
  extern long *Spure_areasS;
  extern unsigned char hoistD1(long, long, long);
  extern long Sgc_countS;
  extern long Sminimum_recovered_spaceS;
  extern unsigned char Spure_area_countS;
  extern unsigned char Simpure_area_countS;
  extern long Sweak_pointer_hpS;
  extern void do_gc();
  extern long Snewspace_endS;
  extern long Ssaved_limitS;
  extern long Ssaved_hpS;
  extern long Snewspace_beginS;
  extern long Soldspace_beginS;
  extern long Soldspace_endS;
  extern FILE * *Sopen_portsS;
  extern long Snumber_of_portsS;
  extern long *Sopen_vm_portsS;
  extern long Senabled_interruptsS;
  extern long Spending_interruptsS;
  extern long Sbottom_of_stackS;
  extern long ScontS;
  extern long Sstack_beginS;
  extern long StemplateS;
  extern long SenvS;
  extern long Sstack_limitS;
  extern long SstackS;
  extern long Sstack_endS;
  extern long SlimitS;
  extern long ShpS;
  extern long SvalS;
  extern long Scode_pointerS;
  extern long SnargsS;
  extern long Tinterpret();
  unsigned char arg3K3;
  unsigned char arg3K0;
  FILE * arg2K0;
  unsigned char arg0K0;
  long arg1K2;
  long arg1K1;
  long arg1K0;
  unsigned char merged_arg0K0;
  unsigned char merged_arg0K1;
  unsigned char merged_arg0K3;
  FILE * merged_arg2K1;
  long merged_arg1K4;
  long merged_arg1K3;
  long merged_arg1K2;
  long merged_arg1K1;
  long merged_arg1K0;
  long RSenvS = SenvS;
  long RSstackS = SstackS;
  long RSvalS = SvalS;
  long RScode_pointerS = Scode_pointerS;

  int extract_string_return_tag;
  unsigned char *extract_string_return_value;
  int stob_equalP_return_tag;
  unsigned char stob_equalP_return_value;
  int write_number_return_tag;
  int close_port_return_tag;
  int close_untraced_portsB_return_tag;
  unsigned char close_untraced_portsB_return_value;
  int copy_object_return_tag;
  long copy_object_return_value;
  int copy_next_return_tag;
  long copy_next_return_value;
  int collect_saving_temp_return_tag;
  long collect_saving_temp_return_value;
  int pop_args_list_return_tag;
  long pop_args_list_return_value;
  int push_continuationB_return_tag;
  int push_exception_continuationB_return_tag;
  int copy_stob_return_tag;
  long copy_stob_return_value;
  int save_env_in_heap_return_tag;
  long save_env_in_heap_return_value;
  int copy_continuation_from_heap_return_tag;
  long copy_continuation_from_heap_return_value;
  int preserve_continuation_return_tag;
  long preserve_continuation_return_value;
  int copy_stack_into_heap_return_tag;
  unsigned char b_20X;
  unsigned char b_21X;
  long space_22X;
  long v_23X;
  unsigned char b_24X;
  long env_25X;
  unsigned char b_26X;
  long location_27X;
  unsigned char b_28X;
  long location_29X;
  unsigned char b_30X;
  unsigned char b_31X;
  long space_32X;
  long v_33X;
  long cont_34X;
  long list_35X;
  long proc_36X;
  long v_37X;
  long cont_38X;
  long pc_39X;
  long tem_40X;
  long cont_41X;
  long tem_42X;
  unsigned char b_43X;
  long tem_44X;
  unsigned char b_45X;
  unsigned char b_46X;
  unsigned char b_47X;
  unsigned char b_48X;
  unsigned char b_49X;
  long val_50X;
  long z_51X;
  long x_52X;
  long arg2_53X;
  long arg2_54X;
  long arg2_55X;
  long x_56X;
  long arg2_57X;
  long arg2_58X;
  long arg2_59X;
  long x_60X;
  long arg2_61X;
  long arg2_62X;
  long arg2_63X;
  long arg2_64X;
  long arg2_65X;
  long arg2_66X;
  long x_67X;
  long result_68X;
  long x_69X;
  long value_70X;
  long count_71X;
  long x_72X;
  long x_73X;
  unsigned char b_74X;
  long x_75X;
  long space_76X;
  unsigned char b_77X;
  unsigned char b_78X;
  long x_79X;
  long arg2_80X;
  long temp_81X;
  long size_82X;
  unsigned char b_83X;
  long len_84X;
  long x_85X;
  long len_86X;
  unsigned char b_87X;
  long index_88X;
  long len_89X;
  unsigned char b_90X;
  long index_91X;
  long x_92X;
  long size_93X;
  long len_94X;
  long init_95X;
  long obj_96X;
  long arg2_97X;
  long arg3_98X;
  long arg2_99X;
  long obj_100X;
  long arg2_101X;
  long descriptor_102X;
  long x_103X;
  long obj_104X;
  long x_105X;
  long p_106X;
  unsigned char Kchar_107X;
  long c_108X;
  long x_109X;
  unsigned char b_110X;
  long p_111X;
  long arg2_112X;
  long p_113X;
  long a_114X;
  long old_115X;
  long arg2_116X;
  unsigned char v_117X;
  long start_hp_118X;
  long x_119X;
  long obj_120X;
  unsigned char v_121X;
  long start_hp_122X;
  long type_123X;
  long obj_124X;
  long obj_125X;
  long tem_126X;
  unsigned char v_127X;
  long name_128X;
  long value_129X;
  long x_130X;
  long obj_131X;
  long n_132X;
  long n_133X;
  long arg2_134X;
  long return_value_135X;
  long key_136X;
  long x_137X;
  long n_138X;
  long x_139X;
  long obj_140X;
  unsigned char b_141X;
  long space_142X;
  long arg2_143X;
  long obj_144X;
  unsigned char x_145X;
  long arg2_146X;
  long arg2_147X;
  long x_148X;
  long key_149X;
  long n_150X;
  long proc_151X;
  long p_152X;
  long n_153X;
  long temp_154X;
  long *areas_155X;
  long *sizes_156X;
  unsigned char count_157X;
  long *areas_158X;
  long *sizes_159X;
  unsigned char count_160X;
  long x_161X;
  long key_162X;
  long arg2_163X;
  long arg3_164X;
  long obj_165X;
  long x_166X;
  unsigned char *spec_167X;
  FILE * port_168X;
  long b_169X;
  long e_170X;
  long v_171X;
  long arg2_172X;
  long p_173X;
  long p_174X;
  long x_175X;
  long x_176X;
  long p_177X;
  FILE * v_178X;
  long x_179X;
  long c_180X;
  unsigned char Kchar_181X;
  long x_182X;
  long x_183X;
  long obj_184X;
  long x_185X;
  long arg2_186X;
  long x_187X;
  long arg2_188X;
  long arg3_189X;
  unsigned char Kchar_190X;
  long index_191X;
  long len_192X;
  long index_193X;
  long len_194X;
  long arg2_195X;
  unsigned char init_196X;
  long len_197X;
  long size_198X;
  long value_199X;
  long index_200X;
  long len_201X;
  long index_202X;
  long len_203X;
  long arg2_204X;
  long arg2_205X;
  long arg3_206X;
  long arg2_207X;
  long arg2_208X;
  long x_209X;
  unsigned char b_210X;
  unsigned char b_211X;
  long x_212X;
  unsigned char b_213X;
  long x_214X;
  long arg2_215X;
  long x_216X;
  long arg2_217X;
  long x_218X;
  long x_219X;
  long arg2_220X;
  long x_221X;
  long x_222X;
  long x_223X;
  long a_224X;
  long b_225X;
  long x_226X;
  long a_227X;
  long b_228X;
  long x_229X;
  long arg2_230X;
  long x_231X;
  long a_232X;
  long b_233X;
  long x_234X;
  long z_235X;
  long x_236X;
  long a_237X;
  long b_238X;
  long arg2_239X;
  long x_240X;
  long x_241X;
  long x_242X;
  long x_243X;
  long x_244X;
  long arg2_245X;
  long x_246X;
  unsigned char b_247X;
  unsigned char b_248X;
  unsigned char b_249X;
  unsigned char b_250X;
  long consumer_251X;
  long start_arg_252X;
  long start_loc_253X;
  unsigned char b_254X;
  unsigned char b_255X;
  unsigned char b_256X;
  long space_257X;
  unsigned char b_258X;
  long p_259X;
  long env_260X;
  unsigned char b_261X;
  long env_262X;
  unsigned char b_263X;
  long env_264X;
  unsigned char b_265X;
  unsigned char b_266X;
  long env_267X;
  unsigned char b_268X;
  long v_269X;
  unsigned char count_270X;
  long space_271X;
  long vector_272X;
  long i_273X;
  unsigned char v_274X;
  long *areas_275X;
  long *sizes_276X;
  unsigned char count_277X;
  long i_278X;
  unsigned char v_279X;
  long h_280X;
  long addr_281X;
  long h_282X;
  long d_283X;
  long sym_284X;
  long v_285X;
  long val_286X;
  long i_287X;
  long h_288X;
  long bucket_289X;
  long index_290X;
  long new_291X;
  long new_292X;
  long b_293X;
  unsigned char v_294X;
  long new_295X;
  long stob_296X;
  long from_297X;
  long from_298X;
  long to_299X;
  long arg2_300X;
  long obj_301X;
  long table_302X;
  long v_303X;
  long n_304X;
  long arg2_305X;
  long n_306X;
  long new_307X;
  long len_308X;
  long obj_309X;
  long l_310X;
  long i_311X;
  long i_312X;
  long h_313X;
  unsigned char v_314X;
  long i_315X;
  unsigned char v_316X;
  long resume_proc_317X;
  long size_318X;
  long b_319X;
  long e_320X;
  unsigned char v_321X;
  long val_322X;
  long c_323X;
  long val_324X;
  long key_325X;
  long arg2_326X;
  long mode_327X;
  long i_328X;
  long i_329X;
  long i_330X;
  long i_331X;
  long index_332X;
  long new_count_333X;
  long old_count_334X;
  FILE * *new_ports_335X;
  long *new_vm_ports_336X;
  FILE * port_337X;
  long new_338X;
  long index_339X;
  long filename_340X;
  unsigned char *spec_341X;
  unsigned char *spec_342X;
  long filename_343X;
  unsigned char v_344X;
  long new_345X;
  long len_346X;
  long string_347X;
  long i_348X;
  long new_349X;
  long code_vector_350X;
  long i_351X;
  long val_352X;
  long i_353X;
  unsigned char okayP_354X;
  long init_355X;
  long new_356X;
  long len_357X;
  long new_358X;
  long len_359X;
  unsigned char b_360X;
  unsigned char b_361X;
  long new_362X;
  long i_363X;
  long n_364X;
  long b_365X;
  long c_366X;
  long a_367X;
  long b_368X;
  long c_369X;
  long a_370X;
  long n_371X;
  long b_372X;
  long c_373X;
  long a_374X;
  long q_375X;
  long a_376X;
  long b_377X;
  long b_378X;
  long c_379X;
  long a_380X;
  long b_381X;
  long lo_a_382X;
  long lo_b_383X;
  long hi_a_384X;
  long hi_b_385X;
  long lo_c_386X;
  long mid_c_387X;
  long c_388X;
  long a_389X;
  long offset_390X;
  long list_391X;
  long a_392X;
  long new_393X;
  long l_394X;
  long last_395X;
  long new_396X;
  long a_397X;
  long i_398X;
  long l_399X;
  long space_400X;
  long overflow_401X;
  long args_402X;
  long fast_403X;
  long len_404X;
  long slow_405X;
  unsigned char move_slowP_406X;
  long nargs_407X;
  long args_408X;
  long args_409X;
  long loc_410X;
  long arg_411X;
  long v_412X;
  long key_413X;
  long v_414X;
  long space_415X;
  long key_416X;
  long p_417X;
  long v_418X;
  long env_419X;
  unsigned char b_420X;
  long a_421X;
  long new_422X;
  long env_423X;
  long i_424X;
  unsigned char b_425X;
  long env_426X;
  long i_427X;
  unsigned char b_428X;
  long args_429X;
  long new_430X;
  long len_431X;
  unsigned char b_432X;
  unsigned char b_433X;
  long v_434X;
  unsigned char v_435X;
  unsigned char v_436X;
  unsigned char v_437X;
  unsigned char v_438X;
  unsigned char v_439X;
  unsigned char v_440X;
  unsigned char v_441X;
  unsigned char v_442X;
  long r_443X;
  unsigned char v_444X;
  unsigned char v_445X;
  unsigned char v_446X;
  unsigned char v_447X;
  long v_448X;
  long key_449X;
  long v_450X;
  long cont_451X;
  long tem_452X;
  long pc_453X;
  long args_454X;
  long v_455X;
  long v_456X;
  long cont_457X;
  long v_458X;
  unsigned char next_op_459X;
  long v_460X;
  long next_461X;
  long cont_462X;
  long tem_463X;
  long pc_464X;
  long args_465X;
  long v_466X;
  long v_467X;
  long args_468X;
  long a1_469X;
  long obj_470X;
  long space_471X;
  long v_472X;
  unsigned char x_473X;
  long tem_474X;
  long obj_475X;
  long space_476X;
  long obj_477X;
  long i_478X;
  long m_479X;
  long obj_480X;
  long tem_481X;
  long v_482X;
  long key_483X;
  long n_484X;
  long i_485X;
  long i_486X;
  long vec_487X;
  long p_488X;
  long i_489X;
  long new_490X;
  long len_491X;
  long p_492X;
  long v_493X;
  long cont_494X;
  long previous_495X;
  long v_496X;
  long cont_497X;
  long p_498X;
  long new_499X;
  long v_500X;
  long end_501X;
  long top_502X;
  long new_cont_503X;
  long v_504X;
  long from_505X;
  long from_506X;
  long to_507X;
  long new_508X;
  long env_509X;
  long p_510X;
  long env_511X;
  long new_512X;
  long cont_513X;
  long env_514X;
  long new_515X;
  long len_516X;
  long from_517X;
  long to_518X;
  long new_519X;
  long bytes_520X;
  long from_521X;
  long p_522X;
  long i_523X;
  long key_524X;
  long pc_525X;
  long template_526X;
  long cont_527X;
  long space_528X;
  long args_529X;
  long count_530X;
  long a_531X;
  long new_532X;
  long v_533X;
  long value_534X;
  long pc_535X;
  long e_536X;
  long b_537X;
  long a_538X;
  long value_539X;
  long i_540X;
  long a_541X;
  long v_542X;
  long start_543X;
  long end_544X;
  long addr_545X;
  long v_546X;
  long cont_547X;
  long last_env_548X;
  long env_549X;
  long end_550X;
  long *areas_551X;
  long *sizes_552X;
  unsigned char count_553X;
  long env_554X;
  long end_555X;
  long addr_556X;
  long v_557X;
  long addr_558X;
  long v_559X;
  long addr_560X;
  long v_561X;
  long env_562X;
  long start_563X;
  long end_564X;
  long v_565X;
  long v_566X;
  long value_567X;
  long a_568X;
  long v_569X;
  long v_570X;
  long value_571X;
  long a_572X;
  long v_573X;
  long v_574X;
  long value_575X;
  long a_576X;
  long v_577X;
  long v_578X;
  long value_579X;
  long a_580X;
  long v_581X;
  long v_582X;
  long value_583X;
  long a_584X;
  long tem_585X;
  long v_586X;
  long value_587X;
  long a_588X;
  long next_589X;
  long thing_590X;
  long value_591X;
  long a_592X;
  long a_593X;
  long h_594X;
  long descriptor_595X;
  long v_596X;
  long o_597X;
  long new_598X;
  long x1_599X;
  long i_600X;
  long port_601X;
  long header_602X;
  long header_603X;
  long new_604X;
  long string_605X;
  FILE * port_606X;
  long mode_607X;
  long index_608X;

  long v_609X;
  long z1_610X;
  long z2_611X;
  long i_612X;
  long z_613X;
  unsigned char *v_614X;
  long i_615X;
  unsigned char *c_616X;
  long string_617X;
  unsigned char c_618X;
  long stob1_619X;
  long stob2_620X;
  long x_621X;
  FILE * port_622X;
  long vm_port_623X;
  unsigned char c_624X;
  long c_625X;
  long thing_626X;
  long c_627X;
  long addr_628X;
  long c_629X;
  long value_630X;
  long c_631X;
  long start_632X;
  long count_633X;
  long code_pointer_634X;
  long size_635X;
  long c_636X;
  long old_stob_637X;
  long c_638X;
  long env_639X;
  long cont_640X;
  long key_641X;
  long c_642X;
  long cont_643X;
  long c_644X;
  long key_645X;
  unsigned char reason_646X;
  long key_647X;
  unsigned char c_648X;
  unsigned char c_649X;
  unsigned char bytes_consumed_650X;
  unsigned char c_651X;
  unsigned char nargs_652X;
  unsigned char c_653X;
  unsigned char byte_args_654X;
  unsigned char c_655X;
  unsigned char args_656X;
  long a1_657X;
  long a2_658X;
  long a3_659X;
  long a4_660X;
  unsigned char c_661X;
  unsigned char args_662X;
  long a1_663X;
  long a2_664X;
  long a3_665X;
  unsigned char c_666X;
  unsigned char args_667X;
  long a1_668X;
  long a2_669X;
  unsigned char c_670X;
  unsigned char args_671X;
  long a1_672X;
  unsigned char c_673X;
  long nargs_674X;
  unsigned char c_675X;
  unsigned char args_676X;
 START: {
  b_141X = *((unsigned char *) (RScode_pointerS));
  RScode_pointerS = (1 + (RScode_pointerS));
  switch (b_141X) {
    case 0 : {
      b_20X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if (((SnargsS) == ((long)b_20X))) {
        goto START;}
      else {
        merged_arg0K0 = 1;
        goto application_exception;}}
      break;
    case 1 : {
      b_21X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if (((SnargsS) < ((long)b_21X))) {
        merged_arg0K0 = 1;
        goto application_exception;}
      else {
        goto START;}}
      break;
    case 2 : {
      RSvalS = ((((SnargsS))<<2));
      goto START;}
      break;
    case 3 : {
      count_270X = *((unsigned char *) (RScode_pointerS));
      if (((Sstack_limitS) < (-8 + ((RSstackS) - (((((long)count_270X))<<2)))))) {
        goto L27800;}
      else {
        space_271X = 1 + (((((Sstack_endS) - (RSstackS)))>>2));
        if ((((ShpS) + (((space_271X)<<2))) < (SlimitS))) {
          arg1K0 = 0;
          goto L27833;}
        else {
          merged_arg1K0 = 0;
          collect_saving_temp_return_tag = 0;
          goto collect_saving_temp;
         collect_saving_temp_return_0:
          if ((((ShpS) + (((space_271X)<<2))) < (SlimitS))) {
            arg1K0 = 0;
            goto L27833;}
          else {
            TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
            arg1K0 = 0;
            goto L27833;}}}}
      break;
    case 4 : {
      space_22X = 2 + ((long)(*((unsigned char *) (RScode_pointerS))));
      if ((((ShpS) + (((space_22X)<<2))) < (SlimitS))) {
        goto L27866;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 1;
        goto collect_saving_temp;
       collect_saving_temp_return_1:
        if ((((ShpS) + (((space_22X)<<2))) < (SlimitS))) {
          goto L27866;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          goto L27866;}}}
      break;
    case 5 : {
      RSenvS = (*((long *) (-3 + (RSenvS))));
      goto START;}
      break;
    case 6 : {
      b_268X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if ((64 == (SnargsS))) {
        RSstackS = (4 + (RSstackS));
        merged_arg1K0 = (*((long *) (RSstackS)));
        merged_arg1K1 = ((-1 + (SnargsS)) - ((long)b_268X));
        pop_args_list_return_tag = 0;
        goto pop_args_list;
       pop_args_list_return_0:
        v_23X = pop_args_list_return_value;
        arg1K0 = v_23X;
        goto L27934;}
      else {
        merged_arg1K0 = 25;
        merged_arg1K1 = ((SnargsS) - ((long)b_268X));
        pop_args_list_return_tag = 1;
        goto pop_args_list;
       pop_args_list_return_1:
        v_269X = pop_args_list_return_value;
        arg1K0 = v_269X;
        goto L27934;}}
      break;
    case 7 : {
      b_24X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      RSvalS = (*((long *) ((-3 + (StemplateS)) + (((((long)b_24X))<<2)))));
      goto START;}
      break;
    case 8 : {
      b_266X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      env_267X = RSenvS;
      arg1K0 = env_267X;
      arg1K1 = ((long)b_266X);
      goto L27698;}
      break;
    case 9 : {
      env_264X = RSenvS;
      b_265X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      RSvalS = (*((long *) ((-3 + env_264X) + (((((long)b_265X))<<2)))));
      if ((529 == (RSvalS))) {
        merged_arg0K0 = 1;
        goto raise_exception;}
      else {
        goto START;}}
      break;
    case 10 : {
      env_262X = *((long *) (-3 + (RSenvS)));
      b_263X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      RSvalS = (*((long *) ((-3 + env_262X) + (((((long)b_263X))<<2)))));
      if ((529 == (RSvalS))) {
        merged_arg0K0 = 1;
        goto raise_exception;}
      else {
        goto START;}}
      break;
    case 11 : {
      env_260X = *((long *) (-3 + (*((long *) (-3 + (RSenvS))))));
      b_261X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      RSvalS = (*((long *) ((-3 + env_260X) + (((((long)b_261X))<<2)))));
      if ((529 == (RSvalS))) {
        merged_arg0K0 = 1;
        goto raise_exception;}
      else {
        goto START;}}
      break;
    case 12 : {
      b_26X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      env_25X = RSenvS;
      arg1K0 = env_25X;
      arg1K1 = ((long)b_26X);
      goto L28006;}
      break;
    case 13 : {
      b_28X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      location_27X = *((long *) ((-3 + (StemplateS)) + (((((long)b_28X))<<2))));
      RSvalS = (*((long *) (-3 + location_27X)));
      if ((17 == (255 & (RSvalS)))) {
        merged_arg0K0 = 1;
        merged_arg1K1 = location_27X;
        goto raise_exception1;}
      else {
        goto START;}}
      break;
    case 14 : {
      b_30X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      location_29X = *((long *) ((-3 + (StemplateS)) + (((((long)b_30X))<<2))));
      if ((273 == (*((long *) (-3 + location_29X))))) {
        merged_arg0K0 = 1;
        merged_arg1K1 = location_29X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}
      else {
        *((long *) (-3 + location_29X)) = (RSvalS);
        RSvalS = 13;
        goto START;}}
      break;
    case 15 : {
      p_259X = RSenvS;
      if ((p_259X < (Sstack_beginS))) {
        arg1K0 = 0;
        goto L28104;}
      else {
        if (((Sstack_endS) < p_259X)) {
          arg1K0 = 0;
          goto L28104;}
        else {
          arg1K0 = ((Sstack_endS) - (Sstack_beginS));
          goto L28104;}}}
      break;
    case 16 : {
      *((long *) (RSstackS)) = (RSvalS);
      RSstackS = (-4 + (RSstackS));
      goto START;}
      break;
    case 17 : {
      RSstackS = (4 + (RSstackS));
      RSvalS = (*((long *) (RSstackS)));
      goto START;}
      break;
    case 18 : {
      b_31X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      RSvalS = (*((long *) (4 + ((RSstackS) + (((((long)b_31X))<<2))))));
      goto START;}
      break;
    case 19 : {
      b_258X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      *((long *) (4 + ((RSstackS) + (((((long)b_258X))<<2))))) = (RSvalS);
      goto START;}
      break;
    case 20 : {
      b_254X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      b_255X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      b_256X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if (((Sstack_limitS) < (-276 + (RSstackS)))) {
        arg1K0 = 0;
        goto L28247;}
      else {
        space_257X = 1 + (((((Sstack_endS) - (RSstackS)))>>2));
        if ((((ShpS) + (((space_257X)<<2))) < (SlimitS))) {
          arg1K0 = 0;
          goto L28264;}
        else {
          merged_arg1K0 = 0;
          collect_saving_temp_return_tag = 2;
          goto collect_saving_temp;
         collect_saving_temp_return_2:
          if ((((ShpS) + (((space_257X)<<2))) < (SlimitS))) {
            arg1K0 = 0;
            goto L28264;}
          else {
            TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
            arg1K0 = 0;
            goto L28264;}}}}
      break;
    case 21 : {
      space_32X = 1 + (((((Sstack_endS) - (RSstackS)))>>2));
      if ((((ShpS) + (((space_32X)<<2))) < (SlimitS))) {
        arg1K0 = 0;
        goto L29948;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 3;
        goto collect_saving_temp;
       collect_saving_temp_return_3:
        if ((((ShpS) + (((space_32X)<<2))) < (SlimitS))) {
          arg1K0 = 0;
          goto L29948;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          arg1K0 = 0;
          goto L29948;}}}
      break;
    case 22 : {
      cont_34X = *((long *) (-3 + (Sbottom_of_stackS)));
      if ((1 == cont_34X)) {
        if ((0 == (3 & (RSvalS)))) {
          RSvalS = ((((RSvalS))>>2));
          SvalS = RSvalS;
          SstackS = RSstackS;
          Scode_pointerS = RScode_pointerS;
          SenvS = RSenvS;
          TTreturn_value = 0;
          return(0L);}
        else {
          RSstackS = (-11 + (Sbottom_of_stackS));
          *((long *) (-3 + (Sbottom_of_stackS))) = 1;
          merged_arg0K0 = 0;
          merged_arg1K1 = (RSvalS);
          goto raise_exception1;}}
      else {
        if ((1 == cont_34X)) {
          RSstackS = (-11 + (Sbottom_of_stackS));
          *((long *) (-3 + (Sbottom_of_stackS))) = 1;
          arg1K0 = (Sbottom_of_stackS);
          goto L28365;}
        else {
          merged_arg1K0 = cont_34X;
          copy_continuation_from_heap_return_tag = 0;
          goto copy_continuation_from_heap;
         copy_continuation_from_heap_return_0:
          v_33X = copy_continuation_from_heap_return_value;
          arg1K0 = v_33X;
          goto L28365;}}}
      break;
    case 23 : {
      SnargsS = ((long)(*((unsigned char *) (RScode_pointerS))));
      merged_arg0K0 = 0;
      goto perform_application;}
      break;
    case 24 : {
      SnargsS = ((long)(*((unsigned char *) (RScode_pointerS))));
      start_arg_252X = (RSstackS) + ((((SnargsS))<<2));
      start_loc_253X = -11 + (ScontS);
      if ((start_arg_252X < start_loc_253X)) {
        arg1K0 = start_loc_253X;
        arg1K1 = start_arg_252X;
        goto L15929;}
      else {
        goto L15912;}}
      break;
    case 25 : {
      RSstackS = (4 + (RSstackS));
      proc_36X = *((long *) (RSstackS));
      list_35X = RSvalS;
      arg1K0 = list_35X;
      arg1K1 = 0;
      arg1K2 = list_35X;
      arg3K3 = 0;
      goto L25376;}
      break;
    case 26 : {
      RSstackS = (4 + (RSstackS));
      cont_38X = *((long *) (RSstackS));
      if ((1 == cont_38X)) {
        RSstackS = (-11 + (Sbottom_of_stackS));
        *((long *) (-3 + (Sbottom_of_stackS))) = 1;
        arg1K0 = (Sbottom_of_stackS);
        goto L29978;}
      else {
        merged_arg1K0 = cont_38X;
        copy_continuation_from_heap_return_tag = 1;
        goto copy_continuation_from_heap;
       copy_continuation_from_heap_return_1:
        v_37X = copy_continuation_from_heap_return_value;
        arg1K0 = v_37X;
        goto L29978;}}
      break;
    case 27 : {
      RSstackS = (4 + (RSstackS));
      consumer_251X = *((long *) (RSstackS));
      *((long *) (RSstackS)) = (RSvalS);
      RSstackS = (-4 + (RSstackS));
      RSvalS = consumer_251X;
      SnargsS = 1;
      merged_arg0K0 = 0;
      goto perform_application;}
      break;
    case 28 : {
      cont_41X = ScontS;
      tem_40X = *((long *) (5 + cont_41X));
      pc_39X = *((long *) (1 + cont_41X));
      StemplateS = tem_40X;
      RScode_pointerS = ((-3 + (*((long *) (-3 + tem_40X)))) + (((pc_39X)>>2)));
      RSenvS = (*((long *) (9 + cont_41X)));
      ScontS = (*((long *) (-3 + cont_41X)));
      RSstackS = (9 + cont_41X);
      goto START;}
      break;
    case 29 : {
      merged_arg1K0 = (SnargsS);
      goto return_values;}
      break;
    case 30 : {
      merged_arg1K0 = ((long)(*((unsigned char *) (RScode_pointerS))));
      goto return_values;}
      break;
    case 31 : {
      goto START;}
      break;
    case 32 : {
      b_43X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      tem_42X = *((long *) ((-3 + (StemplateS)) + (((((long)b_43X))<<2))));
      StemplateS = tem_42X;
      RScode_pointerS = (-3 + (*((long *) (-3 + tem_42X))));
      goto START;}
      break;
    case 33 : {
      b_46X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      SnargsS = ((long)b_46X);
      b_45X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      tem_44X = *((long *) ((-3 + (StemplateS)) + (((((long)b_45X))<<2))));
      StemplateS = tem_44X;
      RScode_pointerS = (-3 + (*((long *) (-3 + tem_44X))));
      if ((0 == ((Spending_interruptsS) & (Senabled_interruptsS)))) {
        goto START;}
      else {
        goto handle_interrupt;}}
      break;
    case 34 : {
      b_48X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      b_47X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if ((1 == (RSvalS))) {
        RScode_pointerS = ((RScode_pointerS) + ((((((long)b_48X))<<8)) + ((long)b_47X)));
        goto START;}
      else {
        goto START;}}
      break;
    case 35 : {
      b_249X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      b_250X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      RScode_pointerS = ((RScode_pointerS) + ((((((long)b_249X))<<8)) + ((long)b_250X)));
      goto START;}
      break;
    case 36 : {
      if ((0 == (3 & (RSvalS)))) {
        val_50X = (((RSvalS))>>2);
        b_49X = *((unsigned char *) (RScode_pointerS));
        RScode_pointerS = (1 + (RScode_pointerS));
        if ((val_50X < 0)) {
          arg1K0 = (((((long)b_49X))<<1));
          goto L28572;}
        else {
          if ((val_50X < ((long)b_49X))) {
            RScode_pointerS = ((RScode_pointerS) + (((val_50X)<<1)));
            b_247X = *((unsigned char *) (RScode_pointerS));
            RScode_pointerS = (1 + (RScode_pointerS));
            b_248X = *((unsigned char *) (RScode_pointerS));
            RScode_pointerS = (1 + (RScode_pointerS));
            arg1K0 = ((((((long)b_247X))<<8)) + ((long)b_248X));
            goto L28572;}
          else {
            arg1K0 = (((((long)b_49X))<<1));
            goto L28572;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 37 : {
      RSstackS = (4 + (RSstackS));
      arg2_245X = *((long *) (RSstackS));
      x_246X = RSvalS;
      if ((arg2_245X == x_246X)) {
        arg0K0 = 5;
        goto L30099;}
      else {
        arg0K0 = 1;
        goto L30099;}}
      break;
    case 38 : {
      x_244X = RSvalS;
      if ((0 == (3 & x_244X))) {
        arg0K0 = 5;
        goto L30113;}
      else {
        if ((3 == (3 & x_244X))) {
          if ((9 == (31 & ((((*((long *) (-7 + x_244X))))>>2))))) {
            arg0K0 = 5;
            goto L30113;}
          else {
            arg0K0 = 1;
            goto L30113;}}
        else {
          arg0K0 = 1;
          goto L30113;}}}
      break;
    case 39 : {
      x_243X = RSvalS;
      if ((0 == (3 & x_243X))) {
        RSvalS = 5;
        goto START;}
      else {
        if ((3 == (3 & x_243X))) {
          if ((9 == (31 & ((((*((long *) (-7 + x_243X))))>>2))))) {
            merged_arg0K0 = 0;
            merged_arg1K1 = x_243X;
            goto raise_exception1;}
          else {
            goto L30131;}}
        else {
          goto L30131;}}}
      break;
    case 40 : {
      x_242X = RSvalS;
      if ((0 == (3 & x_242X))) {
        RSvalS = 5;
        goto START;}
      else {
        if ((3 == (3 & x_242X))) {
          if ((9 == (31 & ((((*((long *) (-7 + x_242X))))>>2))))) {
            merged_arg0K0 = 0;
            merged_arg1K1 = x_242X;
            goto raise_exception1;}
          else {
            goto L30158;}}
        else {
          goto L30158;}}}
      break;
    case 41 : {
      x_241X = RSvalS;
      if ((0 == (3 & x_241X))) {
        RSvalS = 5;
        goto START;}
      else {
        if ((3 == (3 & x_241X))) {
          if ((9 == (31 & ((((*((long *) (-7 + x_241X))))>>2))))) {
            merged_arg0K0 = 0;
            merged_arg1K1 = x_241X;
            goto raise_exception1;}
          else {
            goto L30185;}}
        else {
          goto L30185;}}}
      break;
    case 42 : {
      x_240X = RSvalS;
      if ((0 == (3 & x_240X))) {
        RSvalS = 5;
        goto START;}
      else {
        if ((3 == (3 & x_240X))) {
          if ((9 == (31 & ((((*((long *) (-7 + x_240X))))>>2))))) {
            merged_arg0K0 = 0;
            merged_arg1K1 = x_240X;
            goto raise_exception1;}
          else {
            goto L30212;}}
        else {
          goto L30212;}}}
      break;
    case 43 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = 5;
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 44 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 45 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 46 : {
      RSstackS = (4 + (RSstackS));
      arg2_239X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_239X | (RSvalS))))) {
        x_52X = RSvalS;
        z_51X = (((arg2_239X)>>2)) + (((x_52X)>>2));
        if ((536870911 < z_51X)) {
          goto L24263;}
        else {
          if ((z_51X < -536870912)) {
            goto L24263;}
          else {
            RSvalS = (((z_51X)<<2));
            goto START;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_239X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 47 : {
      RSstackS = (4 + (RSstackS));
      arg2_53X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_53X | (RSvalS))))) {
        x_236X = RSvalS;
        a_237X = ((arg2_53X)>>2);
        b_238X = ((x_236X)>>2);
        if ((a_237X < 0)) {
          arg1K0 = (0 - a_237X);
          goto L24057;}
        else {
          arg1K0 = a_237X;
          goto L24057;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_53X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 48 : {
      RSstackS = (4 + (RSstackS));
      arg2_54X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_54X | (RSvalS))))) {
        x_234X = RSvalS;
        z_235X = (((arg2_54X)>>2)) - (((x_234X)>>2));
        if ((536870911 < z_235X)) {
          goto L23940;}
        else {
          if ((z_235X < -536870912)) {
            goto L23940;}
          else {
            RSvalS = (((z_235X)<<2));
            goto START;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_54X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 49 : {
      RSstackS = (4 + (RSstackS));
      arg2_55X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_55X | (RSvalS))))) {
        x_231X = RSvalS;
        if ((0 == x_231X)) {
          merged_arg0K0 = 0;
          merged_arg1K1 = arg2_55X;
          merged_arg1K2 = x_231X;
          goto raise_exception2;}
        else {
          a_232X = ((arg2_55X)>>2);
          b_233X = ((x_231X)>>2);
          if ((a_232X < 0)) {
            arg1K0 = (0 - a_232X);
            goto L23734;}
          else {
            arg1K0 = a_232X;
            goto L23734;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_55X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 50 : {
      RSstackS = (4 + (RSstackS));
      arg2_230X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_230X | (RSvalS))))) {
        x_56X = RSvalS;
        if ((arg2_230X == x_56X)) {
          arg0K0 = 5;
          goto L30295;}
        else {
          arg0K0 = 1;
          goto L30295;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_230X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 51 : {
      RSstackS = (4 + (RSstackS));
      arg2_57X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_57X | (RSvalS))))) {
        x_229X = RSvalS;
        if ((arg2_57X < x_229X)) {
          arg0K0 = 5;
          goto L30319;}
        else {
          arg0K0 = 1;
          goto L30319;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_57X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 52 : {
      RSstackS = (4 + (RSstackS));
      arg2_58X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_58X | (RSvalS))))) {
        x_226X = RSvalS;
        if ((0 == x_226X)) {
          merged_arg0K0 = 0;
          merged_arg1K1 = arg2_58X;
          merged_arg1K2 = x_226X;
          goto raise_exception2;}
        else {
          a_227X = ((arg2_58X)>>2);
          b_228X = ((x_226X)>>2);
          if ((a_227X < 0)) {
            arg1K0 = (0 - a_227X);
            goto L23399;}
          else {
            arg1K0 = a_227X;
            goto L23399;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_58X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 53 : {
      RSstackS = (4 + (RSstackS));
      arg2_59X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_59X | (RSvalS))))) {
        x_223X = RSvalS;
        if ((0 == x_223X)) {
          merged_arg0K0 = 0;
          merged_arg1K1 = arg2_59X;
          merged_arg1K2 = x_223X;
          goto raise_exception2;}
        else {
          a_224X = ((arg2_59X)>>2);
          b_225X = ((x_223X)>>2);
          if ((a_224X < 0)) {
            arg1K0 = (0 - a_224X);
            goto L23268;}
          else {
            arg1K0 = a_224X;
            goto L23268;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_59X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 54 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = (RSvalS);
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 55 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = (RSvalS);
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 56 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = 4;
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 57 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = (RSvalS);
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 58 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = 0;
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 59 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 60 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 61 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 62 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 63 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 64 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 65 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 66 : {
      if ((0 == (3 & (RSvalS)))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 67 : {
      if ((0 == (3 & (RSvalS)))) {
        x_60X = RSvalS;
        if ((x_60X < 0)) {
          merged_arg0K0 = 0;
          merged_arg1K1 = x_60X;
          goto raise_exception1;}
        else {
          RSvalS = 0;
          goto START;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 68 : {
      if ((0 == (3 & (RSvalS)))) {
        x_222X = RSvalS;
        if ((x_222X < 0)) {
          arg1K0 = (0 - x_222X);
          goto L30507;}
        else {
          arg1K0 = x_222X;
          goto L30507;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 69 : {
      RSstackS = (4 + (RSstackS));
      arg2_61X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_61X | (RSvalS))))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_61X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_61X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 70 : {
      RSstackS = (4 + (RSstackS));
      arg2_62X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_62X | (RSvalS))))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_62X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_62X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 71 : {
      RSstackS = (4 + (RSstackS));
      arg2_63X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_63X | (RSvalS))))) {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_63X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_63X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 72 : {
      if ((0 == (3 & (RSvalS)))) {
        RSvalS = ((((~ ((((RSvalS))>>2))))<<2));
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 73 : {
      RSstackS = (4 + (RSstackS));
      arg2_64X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_64X | (RSvalS))))) {
        RSvalS = (((((((arg2_64X)>>2)) & ((((RSvalS))>>2))))<<2));
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_64X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 74 : {
      RSstackS = (4 + (RSstackS));
      arg2_65X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_65X | (RSvalS))))) {
        RSvalS = (((((((arg2_65X)>>2)) | ((((RSvalS))>>2))))<<2));
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_65X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 75 : {
      RSstackS = (4 + (RSstackS));
      arg2_66X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_66X | (RSvalS))))) {
        RSvalS = (((((((arg2_66X)>>2)) ^ ((((RSvalS))>>2))))<<2));
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_66X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 76 : {
      RSstackS = (4 + (RSstackS));
      arg2_220X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_220X | (RSvalS))))) {
        x_72X = RSvalS;
        count_71X = ((x_72X)>>2);
        value_70X = ((arg2_220X)>>2);
        if ((count_71X < 0)) {
          PS_SHIFT_RIGHT(value_70X, (0 - count_71X), x_221X)
          RSvalS = (((x_221X)<<2));
          goto START;}
        else {
          PS_SHIFT_LEFT(value_70X, count_71X, x_69X)
          result_68X = (((((x_69X)<<2)))>>2);
          PS_SHIFT_RIGHT(result_68X, count_71X, x_67X)
          if ((value_70X == x_67X)) {
            if ((value_70X < 0)) {
              if ((result_68X < 0)) {
                goto L22717;}
              else {
                goto L22714;}}
            else {
              if ((result_68X < 0)) {
                goto L22714;}
              else {
                goto L22717;}}}
          else {
            goto L22714;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_220X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 77 : {
      x_219X = RSvalS;
      if ((9 == (255 & x_219X))) {
        arg0K0 = 5;
        goto L30635;}
      else {
        arg0K0 = 1;
        goto L30635;}}
      break;
    case 78 : {
      RSstackS = (4 + (RSstackS));
      arg2_217X = *((long *) (RSstackS));
      if ((9 == (255 & arg2_217X))) {
        if ((9 == (255 & (RSvalS)))) {
          x_218X = RSvalS;
          if ((arg2_217X == x_218X)) {
            arg0K0 = 5;
            goto L30662;}
          else {
            arg0K0 = 1;
            goto L30662;}}
        else {
          goto L30650;}}
      else {
        goto L30650;}}
      break;
    case 79 : {
      RSstackS = (4 + (RSstackS));
      arg2_215X = *((long *) (RSstackS));
      if ((9 == (255 & arg2_215X))) {
        if ((9 == (255 & (RSvalS)))) {
          x_216X = RSvalS;
          if ((arg2_215X < x_216X)) {
            arg0K0 = 5;
            goto L30691;}
          else {
            arg0K0 = 1;
            goto L30691;}}
        else {
          goto L30679;}}
      else {
        goto L30679;}}
      break;
    case 80 : {
      if ((9 == (255 & (RSvalS)))) {
        RSvalS = (((((long)((((((RSvalS))>>8))))))<<2));
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 81 : {
      if ((0 == (3 & (RSvalS)))) {
        x_73X = (((RSvalS))>>2);
        if ((255 < x_73X)) {
          goto L30722;}
        else {
          if ((x_73X < 0)) {
            goto L30722;}
          else {
            RSvalS = (9 + (((((long)((x_73X))))<<8)));
            goto START;}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 82 : {
      x_214X = RSvalS;
      if ((21 == x_214X)) {
        arg0K0 = 5;
        goto L30744;}
      else {
        arg0K0 = 1;
        goto L30744;}}
      break;
    case 83 : {
      x_75X = RSvalS;
      b_74X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if ((3 == (3 & x_75X))) {
        if (((31 & ((((*((long *) (-7 + x_75X))))>>2))) == ((long)b_74X))) {
          arg0K0 = 5;
          goto L30762;}
        else {
          arg0K0 = 1;
          goto L30762;}}
      else {
        arg0K0 = 1;
        goto L30762;}}
      break;
    case 84 : {
      x_212X = RSvalS;
      b_213X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if ((3 == (3 & x_212X))) {
        if (((31 & ((((*((long *) (-7 + x_212X))))>>2))) == ((long)b_213X))) {
          RSvalS = (-4 & (3 + ((long)(((unsigned long)(*((long *) (-7 + x_212X))))>>8))));
          goto START;}
        else {
          goto L22430;}}
      else {
        goto L22430;}}
      break;
    case 85 : {
      space_76X = 4 + (((((long)(*((unsigned char *) (RScode_pointerS)))))<<2));
      if ((((ShpS) + (((space_76X)<<2))) < (SlimitS))) {
        goto L16631;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 4;
        goto collect_saving_temp;
       collect_saving_temp_return_4:
        if ((((ShpS) + (((space_76X)<<2))) < (SlimitS))) {
          goto L16631;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          goto L16631;}}}
      break;
    case 86 : {
      x_209X = RSvalS;
      b_210X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      b_211X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if ((3 == (3 & x_209X))) {
        if (((31 & ((((*((long *) (-7 + x_209X))))>>2))) == ((long)b_210X))) {
          RSvalS = (*((long *) ((-3 + x_209X) + (((((long)b_211X))<<2)))));
          goto START;}
        else {
          goto L25259;}}
      else {
        goto L25259;}}
      break;
    case 87 : {
      RSstackS = (4 + (RSstackS));
      arg2_80X = *((long *) (RSstackS));
      x_79X = RSvalS;
      b_78X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      b_77X = *((unsigned char *) (RScode_pointerS));
      RScode_pointerS = (1 + (RScode_pointerS));
      if ((3 == (3 & arg2_80X))) {
        if (((31 & ((((*((long *) (-7 + arg2_80X))))>>2))) == ((long)b_78X))) {
          if ((3 == (3 & arg2_80X))) {
            if ((0 == (128 & (*((long *) (-7 + arg2_80X)))))) {
              *((long *) ((-3 + arg2_80X) + (((((long)b_77X))<<2)))) = x_79X;
              RSvalS = 13;
              goto START;}
            else {
              goto L25732;}}
          else {
            goto L25732;}}
        else {
          goto L25732;}}
      else {
        goto L25732;}}
      break;
    case 88 : {
      RSstackS = (4 + (RSstackS));
      arg2_208X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_208X))) {
        x_85X = RSvalS;
        len_84X = ((arg2_208X)>>2);
        b_83X = *((unsigned char *) (RScode_pointerS));
        RScode_pointerS = (1 + (RScode_pointerS));
        size_82X = 1 + len_84X;
        if ((len_84X < 0)) {
          goto L25022;}
        else {
          if ((4194304 < size_82X)) {
            goto L25022;}
          else {
            if ((((ShpS) + (((size_82X)<<2))) < (SlimitS))) {
              arg3K0 = 1;
              arg1K1 = x_85X;
              goto L25027;}
            else {
              merged_arg1K0 = x_85X;
              collect_saving_temp_return_tag = 5;
              goto collect_saving_temp;
             collect_saving_temp_return_5:
              temp_81X = collect_saving_temp_return_value;
              arg3K0 = (((ShpS) + (((size_82X)<<2))) < (SlimitS));
              arg1K1 = temp_81X;
              goto L25027;}}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_208X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 89 : {
      RSstackS = (4 + (RSstackS));
      arg2_207X = *((long *) (RSstackS));
      if ((0 == (3 & (RSvalS)))) {
        index_88X = (((RSvalS))>>2);
        b_87X = *((unsigned char *) (RScode_pointerS));
        RScode_pointerS = (1 + (RScode_pointerS));
        if ((3 == (3 & arg2_207X))) {
          if (((31 & ((((*((long *) (-7 + arg2_207X))))>>2))) == ((long)b_87X))) {
            len_86X = (((3 + ((long)(((unsigned long)(*((long *) (-7 + arg2_207X))))>>8))))>>2);
            if ((index_88X < 0)) {
              goto L24845;}
            else {
              if ((index_88X < len_86X)) {
                RSvalS = (*((long *) ((-3 + arg2_207X) + (((index_88X)<<2)))));
                goto START;}
              else {
                goto L24845;}}}
          else {
            goto L24845;}}
        else {
          goto L24845;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_207X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 90 : {
      RSstackS = (4 + (RSstackS));
      arg2_205X = *((long *) (RSstackS));
      RSstackS = (4 + (RSstackS));
      arg3_206X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_205X))) {
        x_92X = RSvalS;
        index_91X = ((arg2_205X)>>2);
        b_90X = *((unsigned char *) (RScode_pointerS));
        RScode_pointerS = (1 + (RScode_pointerS));
        if ((3 == (3 & arg3_206X))) {
          if (((31 & ((((*((long *) (-7 + arg3_206X))))>>2))) == ((long)b_90X))) {
            len_89X = (((3 + ((long)(((unsigned long)(*((long *) (-7 + arg3_206X))))>>8))))>>2);
            if ((index_91X < 0)) {
              goto L25476;}
            else {
              if ((index_91X < len_89X)) {
                if ((3 == (3 & arg3_206X))) {
                  if ((0 == (128 & (*((long *) (-7 + arg3_206X)))))) {
                    *((long *) ((-3 + arg3_206X) + (((index_91X)<<2)))) = x_92X;
                    RSvalS = 13;
                    goto START;}
                  else {
                    goto L25476;}}
                else {
                  goto L25476;}}
              else {
                goto L25476;}}}
          else {
            goto L25476;}}
        else {
          goto L25476;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg3_206X;
        merged_arg1K2 = arg2_205X;
        merged_arg1K3 = (RSvalS);
        goto raise_exception3;}}
      break;
    case 91 : {
      RSstackS = (4 + (RSstackS));
      arg2_204X = *((long *) (RSstackS));
      if ((0 == (3 & (arg2_204X | (RSvalS))))) {
        init_95X = (((RSvalS))>>2);
        len_94X = ((arg2_204X)>>2);
        size_93X = 1 + ((((3 + len_94X))>>2));
        if ((len_94X < 0)) {
          goto L22178;}
        else {
          if ((4194304 < size_93X)) {
            goto L22178;}
          else {
            if ((((ShpS) + (((size_93X)<<2))) < (SlimitS))) {
              goto L22270;}
            else {
              merged_arg1K0 = 0;
              collect_saving_temp_return_tag = 6;
              goto collect_saving_temp;
             collect_saving_temp_return_6:
              if ((((ShpS) + (((size_93X)<<2))) < (SlimitS))) {
                goto L22270;}
              else {
                merged_arg0K0 = 0;
                merged_arg1K1 = (((len_94X)<<2));
                merged_arg1K2 = (((init_95X)<<2));
                goto raise_exception2;}}}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_204X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 92 : {
      obj_96X = RSvalS;
      if ((3 == (3 & obj_96X))) {
        if ((16 == (31 & ((((*((long *) (-7 + obj_96X))))>>2))))) {
          RSvalS = (((((long)(((unsigned long)(*((long *) (-7 + (RSvalS)))))>>8)))<<2));
          goto START;}
        else {
          goto L30809;}}
      else {
        goto L30809;}}
      break;
    case 93 : {
      RSstackS = (4 + (RSstackS));
      arg2_97X = *((long *) (RSstackS));
      if ((3 == (3 & arg2_97X))) {
        if ((16 == (31 & ((((*((long *) (-7 + arg2_97X))))>>2))))) {
          if ((0 == (3 & (RSvalS)))) {
            index_202X = (((RSvalS))>>2);
            len_203X = (long)(((unsigned long)(*((long *) (-7 + arg2_97X))))>>8);
            if ((index_202X < 0)) {
              goto L22028;}
            else {
              if ((index_202X < len_203X)) {
                RSvalS = (((((long)(*((unsigned char *) ((-3 + arg2_97X) + index_202X)))))<<2));
                goto START;}
              else {
                goto L22028;}}}
          else {
            goto L22033;}}
        else {
          goto L22033;}}
      else {
        goto L22033;}}
      break;
    case 94 : {
      RSstackS = (4 + (RSstackS));
      arg2_99X = *((long *) (RSstackS));
      RSstackS = (4 + (RSstackS));
      arg3_98X = *((long *) (RSstackS));
      if ((3 == (3 & arg3_98X))) {
        if ((16 == (31 & ((((*((long *) (-7 + arg3_98X))))>>2))))) {
          if ((0 == (3 & (arg2_99X | (RSvalS))))) {
            value_199X = (((RSvalS))>>2);
            index_200X = ((arg2_99X)>>2);
            len_201X = (long)(((unsigned long)(*((long *) (-7 + arg3_98X))))>>8);
            if ((index_200X < 0)) {
              goto L24671;}
            else {
              if ((index_200X < len_201X)) {
                *((unsigned char *) ((-3 + arg3_98X) + index_200X)) = ((unsigned char)value_199X);
                RSvalS = 13;
                goto START;}
              else {
                goto L24671;}}}
          else {
            goto L24678;}}
        else {
          goto L24678;}}
      else {
        goto L24678;}}
      break;
    case 95 : {
      RSstackS = (4 + (RSstackS));
      arg2_195X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_195X))) {
        if ((9 == (255 & (RSvalS)))) {
          init_196X = ((((RSvalS))>>8));
          len_197X = ((arg2_195X)>>2);
          size_198X = 1 + ((((4 + len_197X))>>2));
          if ((len_197X < 0)) {
            goto L21763;}
          else {
            if ((4194304 < size_198X)) {
              goto L21763;}
            else {
              if ((((ShpS) + (((size_198X)<<2))) < (SlimitS))) {
                goto L21857;}
              else {
                merged_arg1K0 = 0;
                collect_saving_temp_return_tag = 7;
                goto collect_saving_temp;
               collect_saving_temp_return_7:
                if ((((ShpS) + (((size_198X)<<2))) < (SlimitS))) {
                  goto L21857;}
                else {
                  merged_arg0K0 = 0;
                  merged_arg1K1 = (((len_197X)<<2));
                  merged_arg1K2 = (9 + (((((long)(init_196X)))<<8)));
                  goto raise_exception2;}}}}}
        else {
          goto L21806;}}
      else {
        goto L21806;}}
      break;
    case 96 : {
      obj_100X = RSvalS;
      if ((3 == (3 & obj_100X))) {
        if ((15 == (31 & ((((*((long *) (-7 + obj_100X))))>>2))))) {
          RSvalS = (-4 + (((((long)(((unsigned long)(*((long *) (-7 + (RSvalS)))))>>8)))<<2)));
          goto START;}
        else {
          goto L30840;}}
      else {
        goto L30840;}}
      break;
    case 97 : {
      RSstackS = (4 + (RSstackS));
      arg2_101X = *((long *) (RSstackS));
      if ((3 == (3 & arg2_101X))) {
        if ((15 == (31 & ((((*((long *) (-7 + arg2_101X))))>>2))))) {
          if ((0 == (3 & (RSvalS)))) {
            index_193X = (((RSvalS))>>2);
            len_194X = -1 + ((long)(((unsigned long)(*((long *) (-7 + arg2_101X))))>>8));
            if ((index_193X < 0)) {
              goto L21613;}
            else {
              if ((index_193X < len_194X)) {
                RSvalS = (9 + (((((long)((((long)(*((unsigned char *) ((-3 + arg2_101X) + index_193X))))))))<<8)));
                goto START;}
              else {
                goto L21613;}}}
          else {
            goto L21618;}}
        else {
          goto L21618;}}
      else {
        goto L21618;}}
      break;
    case 98 : {
      RSstackS = (4 + (RSstackS));
      arg2_188X = *((long *) (RSstackS));
      RSstackS = (4 + (RSstackS));
      arg3_189X = *((long *) (RSstackS));
      if ((3 == (3 & arg3_189X))) {
        if ((15 == (31 & ((((*((long *) (-7 + arg3_189X))))>>2))))) {
          if ((0 == (3 & arg2_188X))) {
            if ((9 == (255 & (RSvalS)))) {
              Kchar_190X = ((((RSvalS))>>8));
              index_191X = ((arg2_188X)>>2);
              len_192X = -1 + ((long)(((unsigned long)(*((long *) (-7 + arg3_189X))))>>8));
              if ((index_191X < 0)) {
                goto L24497;}
              else {
                if ((index_191X < len_192X)) {
                  *((unsigned char *) ((-3 + arg3_189X) + index_191X)) = ((unsigned char)((long)(Kchar_190X)));
                  RSvalS = 13;
                  goto START;}
                else {
                  goto L24497;}}}
            else {
              goto L24504;}}
          else {
            goto L24504;}}
        else {
          goto L24504;}}
      else {
        goto L24504;}}
      break;
    case 99 : {
      obj_104X = RSvalS;
      if ((3 == (3 & obj_104X))) {
        if ((4 == (31 & ((((*((long *) (-7 + obj_104X))))>>2))))) {
          x_103X = RSvalS;
          descriptor_102X = *((long *) (-3 + x_103X));
          if ((17 == (255 & descriptor_102X))) {
            if ((529 == (*((long *) (-3 + x_103X))))) {
              arg0K0 = 5;
              goto L18264;}
            else {
              arg0K0 = 1;
              goto L18264;}}
          else {
            arg0K0 = 5;
            goto L18264;}}
        else {
          goto L18255;}}
      else {
        goto L18255;}}
      break;
    case 100 : {
      RSstackS = (4 + (RSstackS));
      arg2_186X = *((long *) (RSstackS));
      if ((3 == (3 & arg2_186X))) {
        if ((4 == (31 & ((((*((long *) (-7 + arg2_186X))))>>2))))) {
          x_187X = RSvalS;
          if ((1 == x_187X)) {
            goto L21413;}
          else {
            if ((5 == x_187X)) {
              goto L21413;}
            else {
              goto L21441;}}}
        else {
          goto L21441;}}
      else {
        goto L21441;}}
      break;
    case 101 : {
      x_105X = RSvalS;
      if ((3 == (3 & x_105X))) {
        if ((0 == (128 & (*((long *) (-7 + x_105X)))))) {
          arg0K0 = 1;
          goto L30876;}
        else {
          arg0K0 = 5;
          goto L30876;}}
      else {
        arg0K0 = 5;
        goto L30876;}}
      break;
    case 102 : {
      x_185X = RSvalS;
      if ((3 == (3 & x_185X))) {
        if ((0 == (128 & (*((long *) (-7 + x_185X)))))) {
          *((long *) (-7 + x_185X)) = (128 | (*((long *) (-7 + x_185X))));
          goto L30891;}
        else {
          goto L30891;}}
      else {
        goto L30891;}}
      break;
    case 103 : {
      if (((20 + (ShpS)) < (SlimitS))) {
        arg1K0 = 0;
        goto L21131;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 8;
        goto collect_saving_temp;
       collect_saving_temp_return_8:
        if (((20 + (ShpS)) < (SlimitS))) {
          arg1K0 = 0;
          goto L21131;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          arg1K0 = 0;
          goto L21131;}}}
      break;
    case 104 : {
      obj_184X = RSvalS;
      if ((3 == (3 & obj_184X))) {
        if ((5 == (31 & ((((*((long *) (-7 + obj_184X))))>>2))))) {
          merged_arg1K0 = (RSvalS);
          close_port_return_tag = 0;
          goto close_port;
         close_port_return_0:
          RSvalS = 13;
          goto START;}
        else {
          goto L30912;}}
      else {
        goto L30912;}}
      break;
    case 105 : {
      x_183X = RSvalS;
      if ((3 == (3 & x_183X))) {
        if ((5 == (31 & ((((*((long *) (-7 + x_183X))))>>2))))) {
          if ((4 == (*((long *) (-3 + x_183X))))) {
            arg0K0 = 5;
            goto L30934;}
          else {
            arg0K0 = 1;
            goto L30934;}}
        else {
          arg0K0 = 1;
          goto L30934;}}
      else {
        arg0K0 = 1;
        goto L30934;}}
      break;
    case 106 : {
      x_182X = RSvalS;
      if ((3 == (3 & x_182X))) {
        if ((5 == (31 & ((((*((long *) (-7 + x_182X))))>>2))))) {
          if ((8 == (*((long *) (-3 + x_182X))))) {
            arg0K0 = 5;
            goto L30952;}
          else {
            arg0K0 = 1;
            goto L30952;}}
        else {
          arg0K0 = 1;
          goto L30952;}}
      else {
        arg0K0 = 1;
        goto L30952;}}
      break;
    case 107 : {
      p_106X = RSvalS;
      if ((3 == (3 & p_106X))) {
        if ((5 == (31 & ((((*((long *) (-7 + p_106X))))>>2))))) {
          if ((4 == (*((long *) (-3 + p_106X))))) {
            if (((*((long *) (1 + p_106X))) < 0)) {
              goto L17836;}
            else {
              x_179X = RSvalS;
              c_180X = *((long *) (5 + x_179X));
              if ((1 == c_180X)) {
                { int TTchar;
                  PS_GETC((*((Sopen_portsS) + ((((*((long *) (1 + x_179X))))>>2)))), TTchar);
                  if (EOF == TTchar) {
                    arg1K0 = 21;
                    goto L17833;}
                  else {
                    unsigned char Kchar_181X = TTchar;
                    arg1K0 = (9 + (((((long)(Kchar_181X)))<<8)));
                    goto L17833;}}}
              else {
                *((long *) (5 + x_179X)) = 1;
                arg1K0 = c_180X;
                goto L17833;}}}
          else {
            goto L17836;}}
        else {
          goto L17836;}}
      else {
        goto L17836;}}
      break;
    case 108 : {
      p_177X = RSvalS;
      if ((3 == (3 & p_177X))) {
        if ((5 == (31 & ((((*((long *) (-7 + p_177X))))>>2))))) {
          if ((4 == (*((long *) (-3 + p_177X))))) {
            if (((*((long *) (1 + p_177X))) < 0)) {
              goto L17718;}
            else {
              x_109X = RSvalS;
              c_108X = *((long *) (5 + x_109X));
              if ((1 == c_108X)) {
                v_178X = *((Sopen_portsS) + ((((*((long *) (1 + x_109X))))>>2)));
                { int TTchar;
                  PS_GETC(v_178X, TTchar);
                  if (EOF == TTchar) {
                    arg1K0 = 21;
                    goto L17710;}
                  else {
                    unsigned char Kchar_107X = TTchar;
                    arg1K0 = (9 + (((((long)(Kchar_107X)))<<8)));
                    goto L17710;}}}
              else {
                arg1K0 = c_108X;
                goto L17715;}}}
          else {
            goto L17718;}}
        else {
          goto L17718;}}
      else {
        goto L17718;}}
      break;
    case 109 : {
      p_111X = RSvalS;
      if ((3 == (3 & p_111X))) {
        if ((5 == (31 & ((((*((long *) (-7 + p_111X))))>>2))))) {
          if ((4 == (*((long *) (-3 + p_111X))))) {
            if (((*((long *) (1 + p_111X))) < 0)) {
              goto L17565;}
            else {
              x_175X = RSvalS;
              x_176X = *((long *) (5 + x_175X));
              if ((1 == x_176X)) {
                b_110X = char_ready_p((*((Sopen_portsS) + ((((*((long *) (1 + x_175X))))>>2)))));
                if (b_110X) {
                  arg0K0 = 5;
                  goto L17562;}
                else {
                  arg0K0 = 1;
                  goto L17562;}}
              else {
                arg0K0 = 5;
                goto L17562;}}}
          else {
            goto L17565;}}
        else {
          goto L17565;}}
      else {
        goto L17565;}}
      break;
    case 110 : {
      RSstackS = (4 + (RSstackS));
      arg2_112X = *((long *) (RSstackS));
      if ((9 == (255 & arg2_112X))) {
        p_174X = RSvalS;
        if ((3 == (3 & p_174X))) {
          if ((5 == (31 & ((((*((long *) (-7 + p_174X))))>>2))))) {
            if ((8 == (*((long *) (-3 + p_174X))))) {
              if (((*((long *) (1 + p_174X))) < 0)) {
                goto L21040;}
              else {
                putc(((((arg2_112X)>>8))), (*((Sopen_portsS) + ((((*((long *) (1 + (RSvalS)))))>>2)))));
                RSvalS = 13;
                goto START;}}
            else {
              goto L21040;}}
          else {
            goto L21040;}}
        else {
          goto L21040;}}
      else {
        goto L21040;}}
      break;
    case 111 : {
      RSstackS = (4 + (RSstackS));
      arg2_172X = *((long *) (RSstackS));
      if ((3 == (3 & arg2_172X))) {
        if ((15 == (31 & ((((*((long *) (-7 + arg2_172X))))>>2))))) {
          p_173X = RSvalS;
          if ((3 == (3 & p_173X))) {
            if ((5 == (31 & ((((*((long *) (-7 + p_173X))))>>2))))) {
              if ((8 == (*((long *) (-3 + p_173X))))) {
                if (((*((long *) (1 + p_173X))) < 0)) {
                  goto L20904;}
                else {
                  fwrite((void *)(-3 + arg2_172X), sizeof(char), (-1 + ((long)(((unsigned long)(*((long *) (-7 + arg2_172X))))>>8))), (*((Sopen_portsS) + ((((*((long *) (1 + (RSvalS)))))>>2)))));
                  RSvalS = 13;
                  goto START;}}
              else {
                goto L20904;}}
            else {
              goto L20904;}}
          else {
            goto L20904;}}
        else {
          goto L20904;}}
      else {
        goto L20904;}}
      break;
    case 112 : {
      p_113X = RSvalS;
      if ((3 == (3 & p_113X))) {
        if ((5 == (31 & ((((*((long *) (-7 + p_113X))))>>2))))) {
          if ((8 == (*((long *) (-3 + p_113X))))) {
            if (((*((long *) (1 + p_113X))) < 0)) {
              goto L17473;}
            else {
              fflush((*((Sopen_portsS) + ((((*((long *) (1 + (RSvalS)))))>>2)))));
              RSvalS = 13;
              goto START;}}
          else {
            goto L17473;}}
        else {
          goto L17473;}}
      else {
        goto L17473;}}
      break;
    case 113 : {
      RSvalS = 529;
      goto START;}
      break;
    case 114 : {
      RSvalS = 13;
      goto START;}
      break;
    case 115 : {
      merged_arg0K0 = 0;
      merged_arg1K1 = (RSvalS);
      goto raise_exception1;}
      break;
    case 116 : {
      RSvalS = 1;
      goto START;}
      break;
    case 117 : {
      RSstackS = (4 + (RSstackS));
      arg2_163X = *((long *) (RSstackS));
      RSstackS = (4 + (RSstackS));
      arg3_164X = *((long *) (RSstackS));
      if ((3 == (3 & arg3_164X))) {
        if ((15 == (31 & ((((*((long *) (-7 + arg3_164X))))>>2))))) {
          obj_165X = RSvalS;
          if ((3 == (3 & obj_165X))) {
            if ((15 == (31 & ((((*((long *) (-7 + obj_165X))))>>2))))) {
              x_166X = RSvalS;
              if ((0 == ((long)(Spure_area_countS)))) {
                if ((0 == ((long)(Simpure_area_countS)))) {
                  merged_arg1K0 = arg3_164X;
                  extract_string_return_tag = 0;
                  goto extract_string;
                 extract_string_return_0:
                  spec_167X = extract_string_return_value;
                  port_168X = ps_open(spec_167X, "w");
                  if ((NULL == port_168X)) {
                    merged_arg0K0 = 0;
                    merged_arg1K1 = arg3_164X;
                    merged_arg1K2 = arg2_163X;
                    goto raise_exception2;}
                  else {
                    fwrite((void *)(-3 + x_166X), sizeof(char), (-1 + ((long)(((unsigned long)(*((long *) (-7 + x_166X))))>>8))), port_168X);
                    b_169X = Snewspace_beginS;
                    Snewspace_beginS = (Soldspace_beginS);
                    Soldspace_beginS = b_169X;
                    e_170X = Snewspace_endS;
                    Snewspace_endS = (Soldspace_endS);
                    Soldspace_endS = e_170X;
                    Ssaved_limitS = (SlimitS);
                    Ssaved_hpS = (ShpS);
                    SlimitS = (Snewspace_endS);
                    ShpS = (Snewspace_beginS);
                    Sweak_pointer_hpS = -1;
                    if ((3 == (3 & arg2_163X))) {
                      a_114X = -3 + arg2_163X;
                      if ((a_114X < (Soldspace_beginS))) {
                        arg1K0 = arg2_163X;
                        goto L28742;}
                      else {
                        if ((a_114X < (Soldspace_endS))) {
                          merged_arg1K0 = arg2_163X;
                          copy_object_return_tag = 0;
                          goto copy_object;
                         copy_object_return_0:
                          v_171X = copy_object_return_value;
                          arg1K0 = v_171X;
                          goto L28742;}
                        else {
                          arg1K0 = arg2_163X;
                          goto L28742;}}}
                    else {
                      arg1K0 = arg2_163X;
                      goto L28742;}}}
                else {
                  goto L28827;}}
              else {
                goto L28827;}}
            else {
              goto L28758;}}
          else {
            goto L28758;}}
        else {
          goto L28758;}}
      else {
        goto L28758;}}
      break;
    case 118 : {
      RSvalS = 13;
      merged_arg1K0 = 0;
      collect_saving_temp_return_tag = 9;
      goto collect_saving_temp;
     collect_saving_temp_return_9:
      RSvalS = 13;
      goto START;}
      break;
    case 119 : {
      RSstackS = (4 + (RSstackS));
      arg2_116X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_116X))) {
        x_161X = RSvalS;
        key_162X = ((arg2_116X)>>2);
        if ((0 == key_162X)) {
          RSvalS = (-4 & ((SlimitS) - (ShpS)));
          goto START;}
        else {
          if ((1 == key_162X)) {
            RSvalS = (-4 & (3 + ((Snewspace_endS) - (Snewspace_beginS))));
            goto START;}
          else {
            if ((2 == key_162X)) {
              RSvalS = (((((Sstack_endS) - (Sstack_beginS)))<<2));
              goto START;}
            else {
              if ((3 == key_162X)) {
                if ((0 == (3 & x_161X))) {
                  old_115X = Sminimum_recovered_spaceS;
                  Sminimum_recovered_spaceS = (((x_161X)>>2));
                  RSvalS = (((old_115X)<<2));
                  goto START;}
                else {
                  merged_arg0K0 = 0;
                  merged_arg1K1 = (((key_162X)<<2));
                  merged_arg1K2 = x_161X;
                  goto raise_exception2;}}
              else {
                if ((4 == key_162X)) {
                  RSvalS = ((((Sgc_countS))<<2));
                  goto START;}
                else {
                  merged_arg0K0 = 0;
                  merged_arg1K1 = (((key_162X)<<2));
                  merged_arg1K2 = x_161X;
                  goto raise_exception2;}}}}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_116X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 120 : {
      obj_120X = RSvalS;
      if ((3 == (3 & obj_120X))) {
        if ((2 == (31 & ((((*((long *) (-7 + obj_120X))))>>2))))) {
          x_119X = RSvalS;
          start_hp_118X = ShpS;
          SvalS = RSvalS;
          SstackS = RSstackS;
          Scode_pointerS = RScode_pointerS;
          SenvS = RSenvS;
          v_117X = hoistD1((Snewspace_beginS), (ShpS), x_119X);
          RSvalS = SvalS;
          RSstackS = SstackS;
          RScode_pointerS = Scode_pointerS;
          RSenvS = SenvS;
          if (v_117X) {
            areas_158X = Spure_areasS;
            sizes_159X = Spure_sizesS;
            count_160X = Spure_area_countS;
            arg1K0 = 0;
            goto L17365;}
          else {
            goto L17350;}}
        else {
          goto L17297;}}
      else {
        goto L17297;}}
      break;
    case 121 : {
      if ((0 == (3 & (RSvalS)))) {
        type_123X = (((RSvalS))>>2);
        start_hp_122X = ShpS;
        *((long *) (ShpS)) = 0;
        ShpS = (4 + (ShpS));
        SvalS = RSvalS;
        SstackS = RSstackS;
        Scode_pointerS = RScode_pointerS;
        SenvS = RSenvS;
        v_121X = hoistD0((Snewspace_beginS), start_hp_122X, type_123X);
        RSvalS = SvalS;
        RSstackS = SstackS;
        RScode_pointerS = Scode_pointerS;
        RSenvS = SenvS;
        if (v_121X) {
          areas_155X = Simpure_areasS;
          sizes_156X = Simpure_sizesS;
          count_157X = Simpure_area_countS;
          arg1K0 = 0;
          goto L10089;}
        else {
          goto L10027;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 122 : {
      RSvalS = (Sdynamic_stateS);
      goto START;}
      break;
    case 123 : {
      Sdynamic_stateS = (RSvalS);
      RSvalS = 13;
      goto START;}
      break;
    case 124 : {
      obj_124X = RSvalS;
      if ((3 == (3 & obj_124X))) {
        if ((3 == (31 & ((((*((long *) (-7 + obj_124X))))>>2))))) {
          Sexception_handlerS = (RSvalS);
          goto START;}
        else {
          goto L31073;}}
      else {
        goto L31073;}}
      break;
    case 125 : {
      obj_125X = RSvalS;
      if ((3 == (3 & obj_125X))) {
        if ((2 == (31 & ((((*((long *) (-7 + obj_125X))))>>2))))) {
          if ((((((3 + ((long)(((unsigned long)(*((long *) (-7 + (RSvalS)))))>>8))))>>2)) < 3)) {
            goto L31092;}
          else {
            Sinterrupt_handlersS = (RSvalS);
            goto START;}}
        else {
          goto L31092;}}
      else {
        goto L31092;}}
      break;
    case 126 : {
      temp_154X = Senabled_interruptsS;
      Senabled_interruptsS = ((((RSvalS))>>2));
      RSvalS = (((temp_154X)<<2));
      goto START;}
      break;
    case 127 : {
      RSstackS = (4 + (RSstackS));
      Senabled_interruptsS = ((((*((long *) (RSstackS))))>>2));
      RSstackS = (4 + (RSstackS));
      SnargsS = ((((*((long *) (RSstackS))))>>2));
      RSstackS = (4 + (RSstackS));
      RSenvS = (*((long *) (RSstackS)));
      RSstackS = (4 + (RSstackS));
      tem_126X = *((long *) (RSstackS));
      StemplateS = tem_126X;
      RScode_pointerS = (-3 + (*((long *) (-3 + tem_126X))));
      RSstackS = (4 + (RSstackS));
      RSvalS = (*((long *) (RSstackS)));
      goto START;}
      break;
    case 128 : {
      if ((0 == (3 & (RSvalS)))) {
        p_152X = RSvalS;
        Spending_interruptsS = (-2 & (Spending_interruptsS));
        SvalS = RSvalS;
        SstackS = RSstackS;
        Scode_pointerS = RScode_pointerS;
        SenvS = RSenvS;
        n_153X = ps_schedule_interrupt((((p_152X)>>2)));
        RSvalS = SvalS;
        RSstackS = SstackS;
        RScode_pointerS = Scode_pointerS;
        RSenvS = SenvS;
        RSvalS = (((n_153X)<<2));
        goto START;}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = (RSvalS);
        goto raise_exception1;}}
      break;
    case 129 : {
      obj_131X = RSvalS;
      if ((3 == (3 & obj_131X))) {
        if ((12 == (31 & ((((*((long *) (-7 + obj_131X))))>>2))))) {
          x_130X = RSvalS;
          value_129X = *((long *) (1 + x_130X));
          name_128X = *((long *) (-3 + x_130X));
          if ((3 == (3 & name_128X))) {
            if ((15 == (31 & ((((*((long *) (-7 + name_128X))))>>2))))) {
              if ((3 == (3 & value_129X))) {
                if ((16 == (31 & ((((*((long *) (-7 + value_129X))))>>2))))) {
                  SvalS = RSvalS;
                  SstackS = RSstackS;
                  Scode_pointerS = RScode_pointerS;
                  SenvS = RSenvS;
                  v_127X = lookup_external_name((-3 + name_128X), (-3 + value_129X));
                  RSvalS = SvalS;
                  RSstackS = SstackS;
                  RScode_pointerS = Scode_pointerS;
                  RSenvS = SenvS;
                  if (v_127X) {
                    RSvalS = 13;
                    goto START;}
                  else {
                    goto L16974;}}
                else {
                  goto L16974;}}
              else {
                goto L16974;}}
            else {
              goto L16974;}}
          else {
            goto L16974;}}
        else {
          goto L16977;}}
      else {
        goto L16977;}}
      break;
    case 130 : {
      proc_151X = *((long *) ((RSstackS) + ((((SnargsS))<<2))));
      if ((3 == (3 & proc_151X))) {
        if ((12 == (31 & ((((*((long *) (-7 + proc_151X))))>>2))))) {
          SnargsS = (-1 + (SnargsS));
          RSvalS = proc_151X;
          SvalS = RSvalS;
          SstackS = RSstackS;
          Scode_pointerS = RScode_pointerS;
          SenvS = RSenvS;
          TTreturn_value = 1;
          return(0L);}
        else {
          goto L31145;}}
      else {
        goto L31145;}}
      break;
    case 131 : {
      RSstackS = (4 + (RSstackS));
      arg2_134X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_134X))) {
        x_148X = RSvalS;
        key_149X = ((arg2_134X)>>2);
        if ((0 == key_149X)) {
          SvalS = RSvalS;
          SstackS = RSstackS;
          Scode_pointerS = RScode_pointerS;
          SenvS = RSenvS;
          n_132X = ps_ticks_per_second();
          RSvalS = SvalS;
          RSstackS = SstackS;
          RScode_pointerS = Scode_pointerS;
          RSenvS = SenvS;
          RSvalS = (((n_132X)<<2));
          goto START;}
        else {
          if ((1 == key_149X)) {
            SvalS = RSvalS;
            SstackS = RSstackS;
            Scode_pointerS = RScode_pointerS;
            SenvS = RSenvS;
            n_150X = ps_run_time();
            RSvalS = SvalS;
            RSstackS = SstackS;
            RScode_pointerS = Scode_pointerS;
            RSenvS = SenvS;
            RSvalS = (((n_150X)<<2));
            goto START;}
          else {
            if ((2 == key_149X)) {
              SvalS = RSvalS;
              SstackS = RSstackS;
              Scode_pointerS = RScode_pointerS;
              SenvS = RSenvS;
              n_133X = ps_real_time();
              RSvalS = SvalS;
              RSstackS = SstackS;
              RScode_pointerS = Scode_pointerS;
              RSenvS = SenvS;
              RSvalS = (((n_133X)<<2));
              goto START;}
            else {
              merged_arg0K0 = 0;
              merged_arg1K1 = (((key_149X)<<2));
              merged_arg1K2 = x_148X;
              goto raise_exception2;}}}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_134X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 132 : {
      RSstackS = (4 + (RSstackS));
      arg2_147X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_147X))) {
        x_137X = RSvalS;
        key_136X = ((arg2_147X)>>2);
        SvalS = RSvalS;
        SstackS = RSstackS;
        Scode_pointerS = RScode_pointerS;
        SenvS = RSenvS;
        return_value_135X = extended_vm(key_136X, x_137X);
        RSvalS = SvalS;
        RSstackS = SstackS;
        RScode_pointerS = Scode_pointerS;
        RSenvS = SenvS;
        if ((17 == (255 & return_value_135X))) {
          merged_arg0K0 = 0;
          merged_arg1K1 = (((key_136X)<<2));
          merged_arg1K2 = x_137X;
          goto raise_exception2;}
        else {
          RSvalS = return_value_135X;
          goto START;}}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_147X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 133 : {
      RSstackS = (4 + (RSstackS));
      arg2_146X = *((long *) (RSstackS));
      if ((0 == (3 & arg2_146X))) {
        RSvalS = (RSvalS);
        SvalS = RSvalS;
        SstackS = RSstackS;
        Scode_pointerS = RScode_pointerS;
        SenvS = RSenvS;
        TTreturn_value = 0;
        return(0L);}
      else {
        merged_arg0K0 = 0;
        merged_arg1K1 = arg2_146X;
        merged_arg1K2 = (RSvalS);
        goto raise_exception2;}}
      break;
    case 134 : {
      RSstackS = (4 + (RSstackS));
      arg2_143X = *((long *) (RSstackS));
      if ((3 == (3 & arg2_143X))) {
        if ((15 == (31 & ((((*((long *) (-7 + arg2_143X))))>>2))))) {
          obj_144X = RSvalS;
          if ((3 == (3 & obj_144X))) {
            if ((15 == (31 & ((((*((long *) (-7 + obj_144X))))>>2))))) {
              merged_arg1K0 = arg2_143X;
              merged_arg1K1 = (RSvalS);
              stob_equalP_return_tag = 0;
              goto stob_equalP;
             stob_equalP_return_0:
              x_145X = stob_equalP_return_value;
              if (x_145X) {
                arg0K0 = 5;
                goto L20298;}
              else {
                arg0K0 = 1;
                goto L20298;}}
            else {
              goto L20289;}}
          else {
            goto L20289;}}
        else {
          goto L20289;}}
      else {
        goto L20289;}}
      break;
    case 135 : {
      obj_140X = RSvalS;
      if ((3 == (3 & obj_140X))) {
        if ((15 == (31 & ((((*((long *) (-7 + obj_140X))))>>2))))) {
          x_139X = RSvalS;
          n_138X = -1 + ((long)(((unsigned long)(*((long *) (-7 + x_139X))))>>8));
          arg1K0 = 0;
          arg1K1 = 0;
          goto L16824;}
        else {
          goto L16802;}}
      else {
        goto L16802;}}
      break;
    case 136 : {
      space_142X = 1 + ((((4 + (RSvalS)))>>2));
      if ((((ShpS) + (((space_142X)<<2))) < (SlimitS))) {
        goto L20018;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 10;
        goto collect_saving_temp;
       collect_saving_temp_return_10:
        if ((((ShpS) + (((space_142X)<<2))) < (SlimitS))) {
          goto L20018;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          goto L20018;}}}
      break;
    case 137 : {
      if (((20 + (ShpS)) < (SlimitS))) {
        goto L19900;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 11;
        goto collect_saving_temp;
       collect_saving_temp_return_11:
        if (((20 + (ShpS)) < (SlimitS))) {
          goto L19900;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          goto L19900;}}}
      break;
  }}
 L31042: {
  vector_272X = arg1K0;
  if ((1 == vector_272X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = (((type_123X)<<2));
    goto raise_exception1;}
  else {
    RSvalS = vector_272X;
    goto START;}}
 L10027: {
  ShpS = start_hp_122X;
  arg1K0 = 1;
  goto L31042;}
 L10089: {
  i_273X = arg1K0;
  if ((i_273X < ((long)count_157X))) {
    SvalS = RSvalS;
    SstackS = RSstackS;
    Scode_pointerS = RScode_pointerS;
    SenvS = RSenvS;
    v_274X = hoistD0((*(areas_155X + i_273X)), ((*(areas_155X + i_273X)) + (*(sizes_156X + i_273X))), type_123X);
    RSvalS = SvalS;
    RSstackS = SstackS;
    RScode_pointerS = Scode_pointerS;
    RSenvS = SenvS;
    if (v_274X) {
      arg1K0 = (1 + i_273X);
      goto L10089;}
    else {
      goto L10027;}}
  else {
    areas_275X = Spure_areasS;
    sizes_276X = Spure_sizesS;
    count_277X = Spure_area_countS;
    arg1K0 = 0;
    goto L10068;}}
 L10068: {
  i_278X = arg1K0;
  if ((i_278X < ((long)count_277X))) {
    SvalS = RSvalS;
    SstackS = RSstackS;
    Scode_pointerS = RScode_pointerS;
    SenvS = RSenvS;
    v_279X = hoistD0((*(areas_275X + i_278X)), ((*(areas_275X + i_278X)) + (*(sizes_276X + i_278X))), type_123X);
    RSvalS = SvalS;
    RSstackS = SstackS;
    RScode_pointerS = Scode_pointerS;
    RSenvS = SenvS;
    if (v_279X) {
      arg1K0 = (1 + i_278X);
      goto L10068;}
    else {
      goto L10027;}}
  else {
    *((long *) start_hp_122X) = (-1014 + (((((ShpS) - start_hp_122X))<<8)));
    arg1K0 = (7 + start_hp_122X);
    goto L31042;}}
 L8859: {
  h_280X = arg1K0;
  arg1K0 = (4 + (addr_281X + (-4 & (3 + ((long)(((unsigned long)h_280X)>>8))))));
  goto L8837;}
 L8837: {
  addr_281X = arg1K0;
  if ((addr_281X < (ShpS))) {
    d_283X = *((long *) addr_281X);
    if ((2 == (3 & d_283X))) {
      arg1K0 = d_283X;
      goto L8859;}
    else {
      h_282X = *((long *) (-7 + d_283X));
      *((long *) addr_281X) = h_282X;
      arg1K0 = h_282X;
      goto L8859;}}
  else {
    RSvalS = (((size_318X)<<2));
    goto START;}}
 L13271: {
  sym_284X = arg1K0;
  if ((3 == (3 & sym_284X))) {
    if ((0 == (128 & (*((long *) (-7 + sym_284X)))))) {
      *((long *) (-7 + sym_284X)) = (128 | (*((long *) (-7 + sym_284X))));
      arg1K0 = sym_284X;
      goto L13213;}
    else {
      arg1K0 = sym_284X;
      goto L13213;}}
  else {
    arg1K0 = sym_284X;
    goto L13213;}}
 L28114: {
  v_285X = arg1K0;
  RSvalS = v_285X;
  goto START;}
 L19922: {
  val_286X = arg1K0;
  RSvalS = val_286X;
  goto START;}
 L13315: {
  i_287X = arg1K0;
  h_288X = arg1K1;
  if ((i_287X < n_304X)) {
    arg1K0 = (1 + i_287X);
    arg1K1 = (h_288X + ((long)((((long)(*((unsigned char *) ((-3 + arg2_300X) + i_287X))))))));
    goto L13315;}
  else {
    index_290X = h_288X & (-1 + v_303X);
    bucket_289X = *((long *) ((-3 + table_302X) + (((index_290X)<<2))));
    arg1K0 = bucket_289X;
    goto L13205;}}
 L13213: {
  new_291X = arg1K0;
  *((long *) (ShpS)) = 2050;
  ShpS = (4 + (ShpS));
  new_292X = 3 + (ShpS);
  ShpS = (8 + (ShpS));
  *((long *) (-4 + (ShpS))) = 0;
  *((long *) (-3 + new_292X)) = new_291X;
  *((long *) (1 + new_292X)) = bucket_289X;
  *((long *) ((-3 + table_302X) + (((index_290X)<<2)))) = new_292X;
  arg1K0 = new_291X;
  goto L19922;}
 L13205: {
  b_293X = arg1K0;
  if ((25 == b_293X)) {
    *((long *) (ShpS)) = 1030;
    ShpS = (4 + (ShpS));
    new_295X = 3 + (ShpS);
    ShpS = (4 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_295X)) = arg2_300X;
    if ((3 == (3 & new_295X))) {
      if ((0 == (128 & (*((long *) (-7 + new_295X)))))) {
        *((long *) (-7 + new_295X)) = (128 | (*((long *) (-7 + new_295X))));
        arg1K0 = new_295X;
        goto L13271;}
      else {
        arg1K0 = new_295X;
        goto L13271;}}
    else {
      arg1K0 = new_295X;
      goto L13271;}}
  else {
    merged_arg1K0 = arg2_300X;
    merged_arg1K1 = (*((long *) (-3 + (*((long *) (-3 + b_293X))))));
    stob_equalP_return_tag = 1;
    goto stob_equalP;
   stob_equalP_return_1:
    v_294X = stob_equalP_return_value;
    if (v_294X) {
      arg1K0 = (*((long *) (-3 + b_293X)));
      goto L19922;}
    else {
      arg1K0 = (*((long *) (1 + b_293X)));
      goto L13205;}}}
 L9754: {
  stob_296X = arg1K0;
  from_297X = 4 + (RSstackS);
  arg1K0 = from_297X;
  arg1K1 = (1 + stob_296X);
  goto L9793;}
 L9793: {
  from_298X = arg1K0;
  to_299X = arg1K1;
  if ((from_298X < (from_297X + (((((long)b_432X))<<2))))) {
    *((long *) to_299X) = (*((long *) from_298X));
    arg1K0 = (4 + from_298X);
    arg1K1 = (4 + to_299X);
    goto L9793;}
  else {
    RSstackS = ((RSstackS) - ((((0 - ((long)b_432X)))<<2)));
    *((long *) (-3 + stob_296X)) = (RSenvS);
    RSenvS = stob_296X;
    goto START;}}
 L19900: {
  RSstackS = (4 + (RSstackS));
  arg2_300X = *((long *) (RSstackS));
  if ((3 == (3 & arg2_300X))) {
    if ((15 == (31 & ((((*((long *) (-7 + arg2_300X))))>>2))))) {
      obj_301X = RSvalS;
      if ((3 == (3 & obj_301X))) {
        if ((2 == (31 & ((((*((long *) (-7 + obj_301X))))>>2))))) {
          table_302X = RSvalS;
          v_303X = (((3 + ((long)(((unsigned long)(*((long *) (-7 + table_302X))))>>8))))>>2);
          n_304X = -1 + ((long)(((unsigned long)(*((long *) (-7 + arg2_300X))))>>8));
          arg1K0 = 0;
          arg1K1 = 0;
          goto L13315;}
        else {
          goto L19925;}}
      else {
        goto L19925;}}
    else {
      goto L19925;}}
  else {
    goto L19925;}}
 L19925: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_300X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L20018: {
  RSstackS = (4 + (RSstackS));
  arg2_305X = *((long *) (RSstackS));
  if ((0 == (3 & (RSvalS)))) {
    n_306X = (((RSvalS))>>2);
    if ((3 == (3 & arg2_305X))) {
      if ((0 == (31 & ((((*((long *) (-7 + arg2_305X))))>>2))))) {
        goto L20144;}
      else {
        goto L20046;}}
    else {
      goto L20046;}}
  else {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_305X;
    merged_arg1K2 = (RSvalS);
    goto raise_exception2;}}
 L20046: {
  if ((25 == arg2_305X)) {
    goto L20144;}
  else {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_305X;
    merged_arg1K2 = (((n_306X)<<2));
    goto raise_exception2;}}
 L20144: {
  len_308X = 1 + n_306X;
  *((long *) (ShpS)) = (62 + (((len_308X)<<8)));
  ShpS = (4 + (ShpS));
  new_307X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_308X)));
  if ((0 < len_308X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_307X;
    goto L20063;}
  else {
    arg1K0 = new_307X;
    goto L20063;}}
 L20063: {
  obj_309X = arg1K0;
  arg1K0 = arg2_305X;
  arg1K1 = (-1 + n_306X);
  goto L20065;}
 L20065: {
  l_310X = arg1K0;
  i_311X = arg1K1;
  if ((i_311X < 0)) {
    RSvalS = obj_309X;
    goto START;}
  else {
    *((unsigned char *) ((-3 + obj_309X) + i_311X)) = ((unsigned char)((long)((((((*((long *) (-3 + l_310X))))>>8))))));
    arg1K0 = (*((long *) (1 + l_310X)));
    arg1K1 = (-1 + i_311X);
    goto L20065;}}
 L16802: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L16824: {
  i_312X = arg1K0;
  h_313X = arg1K1;
  if ((i_312X < n_138X)) {
    arg1K0 = (1 + i_312X);
    arg1K1 = (h_313X + ((long)((((long)(*((unsigned char *) ((-3 + x_139X) + i_312X))))))));
    goto L16824;}
  else {
    RSvalS = (((h_313X)<<2));
    goto START;}}
 L20289: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_143X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L20298: {
  v_314X = arg0K0;
  RSvalS = ((long)v_314X);
  goto START;}
 L16977: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L16974: {
  merged_arg0K0 = 0;
  merged_arg1K1 = x_130X;
  goto raise_exception1;}
 L17297: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L17365: {
  i_315X = arg1K0;
  if ((i_315X < ((long)count_160X))) {
    SvalS = RSvalS;
    SstackS = RSstackS;
    Scode_pointerS = RScode_pointerS;
    SenvS = RSenvS;
    v_316X = hoistD1((*(areas_158X + i_315X)), ((*(areas_158X + i_315X)) + (*(sizes_159X + i_315X))), x_119X);
    RSvalS = SvalS;
    RSstackS = SstackS;
    RScode_pointerS = Scode_pointerS;
    RSenvS = SenvS;
    if (v_316X) {
      arg1K0 = (1 + i_315X);
      goto L17365;}
    else {
      goto L17350;}}
  else {
    RSvalS = 13;
    goto START;}}
 L17350: {
  ShpS = start_hp_118X;
  merged_arg0K0 = 0;
  goto raise_exception;}
 L28758: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg3_164X;
  merged_arg1K2 = arg2_163X;
  merged_arg1K3 = (RSvalS);
  goto raise_exception3;}
 L28827: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg3_164X;
  merged_arg1K2 = arg2_163X;
  goto raise_exception2;}
 L28742: {
  resume_proc_317X = arg1K0;
  SvalS = RSvalS;
  SstackS = RSstackS;
  Scode_pointerS = RScode_pointerS;
  SenvS = RSenvS;
  do_gc();
  RSvalS = SvalS;
  RSstackS = SstackS;
  RScode_pointerS = Scode_pointerS;
  RSenvS = SenvS;
  /* Do NOT put a call to the scsh I/O gc hook post_gc_fdports() here.
  ** This GC is not for real -- it's for writing images, and will be
  ** aborted. But the part of post_gc_fdports that updates the fdports[]
  ** elements to point into new-space *won't* be aborted, and oops, we're
  ** pointing into hyperspace. This whole thing is a mess; we need to port
  ** to a newer Scheme 48 release that gives us structured GC hooks.
  **     -Olin
  */
  close_untraced_portsB_return_tag = 0;
  goto close_untraced_portsB;
 close_untraced_portsB_return_0:
  fputs("This is a Scheme48 heap image file.", port_168X);
  putc(10, port_168X);
  putc(12, port_168X);
  putc(10, port_168X);
  merged_arg1K0 = 15;
  merged_arg2K1 = port_168X;
  write_number_return_tag = 0;
  goto write_number;
 write_number_return_0:
  merged_arg1K0 = 4;
  merged_arg2K1 = port_168X;
  write_number_return_tag = 1;
  goto write_number;
 write_number_return_1:
  merged_arg1K0 = ((((Snewspace_beginS))>>2));
  merged_arg2K1 = port_168X;
  write_number_return_tag = 2;
  goto write_number;
 write_number_return_2:
  merged_arg1K0 = ((((ShpS))>>2));
  merged_arg2K1 = port_168X;
  write_number_return_tag = 3;
  goto write_number;
 write_number_return_3:
  merged_arg1K0 = resume_proc_317X;
  merged_arg2K1 = port_168X;
  write_number_return_tag = 4;
  goto write_number;
 write_number_return_4:
  putc(12, port_168X);
  *((long *) (ShpS)) = 1;
  fwrite((void *)(ShpS), sizeof(char), ((4 + (ShpS)) - (ShpS)), port_168X);
  fwrite((void *)(Snewspace_beginS), sizeof(char), ((ShpS) - (Snewspace_beginS)), port_168X);
  size_318X = (ShpS) - (Snewspace_beginS);
  fclose(port_168X);
  b_319X = Snewspace_beginS;
  Snewspace_beginS = (Soldspace_beginS);
  Soldspace_beginS = b_319X;
  e_320X = Snewspace_endS;
  Snewspace_endS = (Soldspace_endS);
  Soldspace_endS = e_320X;
  SlimitS = (Ssaved_limitS);
  ShpS = (Ssaved_hpS);
  arg1K0 = (Snewspace_beginS);
  goto L8837;}
 L17473: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L20904: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_172X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L21040: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_112X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L17565: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L17562: {
  v_321X = arg0K0;
  RSvalS = ((long)v_321X);
  goto START;}
 L17718: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L17715: {
  val_322X = arg1K0;
  RSvalS = val_322X;
  goto START;}
 L17710: {
  c_323X = arg1K0;
  *((long *) (5 + x_109X)) = c_323X;
  arg1K0 = c_323X;
  goto L17715;}
 L17836: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L17833: {
  val_324X = arg1K0;
  RSvalS = val_324X;
  goto START;}
 L21131: {
  key_325X = arg1K0;
  RSstackS = (4 + (RSstackS));
  arg2_326X = *((long *) (RSstackS));
  if ((3 == (3 & arg2_326X))) {
    if ((15 == (31 & ((((*((long *) (-7 + arg2_326X))))>>2))))) {
      if ((0 == (3 & (RSvalS)))) {
        mode_327X = (((RSvalS))>>2);
        arg1K0 = 0;
        goto L21318;}
      else {
        goto L21169;}}
    else {
      goto L21169;}}
  else {
    goto L21169;}}
 L21169: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_326X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L21318: {
  i_328X = arg1K0;
  if ((i_328X < (Snumber_of_portsS))) {
    if ((1 == (*((Sopen_vm_portsS) + i_328X)))) {
      arg1K0 = i_328X;
      arg1K1 = arg2_326X;
      goto L21205;}
    else {
      arg1K0 = (1 + i_328X);
      goto L21318;}}
  else {
    arg1K0 = -1;
    arg1K1 = arg2_326X;
    goto L21205;}}
 L21307: {
  i_329X = arg1K0;
  if ((i_329X < (Snumber_of_portsS))) {
    if ((1 == (*((Sopen_vm_portsS) + i_329X)))) {
      arg1K0 = i_329X;
      goto L21249;}
    else {
      arg1K0 = (1 + i_329X);
      goto L21307;}}
  else {
    arg1K0 = -1;
    goto L21249;}}
 L21277: {
  i_330X = arg1K0;
  if ((i_330X < (Snumber_of_portsS))) {
    *(new_ports_335X + i_330X) = (*((Sopen_portsS) + i_330X));
    *(new_vm_ports_336X + i_330X) = (*((Sopen_vm_portsS) + i_330X));
    arg1K0 = (1 + i_330X);
    goto L21277;}
  else {
    free((Sopen_portsS));
    free((Sopen_vm_portsS));
    Sopen_portsS = new_ports_335X;
    Sopen_vm_portsS = new_vm_ports_336X;
    Snumber_of_portsS = new_count_333X;
    arg1K0 = old_count_334X;
    arg1K1 = filename_343X;
    goto L21205;}}
 L21271: {
  i_331X = arg1K0;
  if ((i_331X < new_count_333X)) {
    *(new_vm_ports_336X + i_331X) = 1;
    arg1K0 = (1 + i_331X);
    goto L21271;}
  else {
    arg1K0 = 0;
    goto L21277;}}
 L21260: {
  merged_arg0K0 = 0;
  merged_arg1K1 = filename_343X;
  merged_arg1K2 = (((key_325X)<<2));
  goto raise_exception2;}
 L21249: {
  index_332X = arg1K0;
  if ((index_332X < 0)) {
    new_count_333X = 8 + (Snumber_of_portsS);
    old_count_334X = Snumber_of_portsS;
    new_ports_335X = (FILE **)malloc(sizeof(FILE *) * new_count_333X);
    new_vm_ports_336X = (long*)malloc(sizeof(long) * new_count_333X);
    if ((NULL == new_ports_335X)) {
      goto L21260;}
    else {
      if ((NULL == new_vm_ports_336X)) {
        goto L21260;}
      else {
        arg1K0 = 0;
        goto L21271;}}}
  else {
    arg1K0 = index_332X;
    arg1K1 = filename_343X;
    goto L21205;}}
 L21208: {
  port_337X = arg2K0;
  if ((NULL == port_337X)) {
    RSvalS = 1;
    goto START;}
  else {
    *((long *) (ShpS)) = 4118;
    ShpS = (4 + (ShpS));
    new_338X = 3 + (ShpS);
    ShpS = (16 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_338X)) = (((mode_327X)<<2));
    *((long *) (1 + new_338X)) = (((index_339X)<<2));
    *((long *) (5 + new_338X)) = 1;
    *((long *) (9 + new_338X)) = filename_340X;
    *((Sopen_portsS) + index_339X) = port_337X;
    *((Sopen_vm_portsS) + index_339X) = new_338X;
    RSvalS = new_338X;
    goto START;}}
 L21205: {
  index_339X = arg1K0;
  filename_340X = arg1K1;
  if ((index_339X < 0)) {
    merged_arg1K0 = filename_340X;
    collect_saving_temp_return_tag = 12;
    goto collect_saving_temp;
   collect_saving_temp_return_12:
    filename_343X = collect_saving_temp_return_value;
    arg1K0 = 0;
    goto L21307;}
  else {
    if ((2 == mode_327X)) {
      merged_arg1K0 = filename_340X;
      extract_string_return_tag = 1;
      goto extract_string;
     extract_string_return_1:
      spec_341X = extract_string_return_value;
      arg2K0 = (ps_open(spec_341X, "w"));
      goto L21208;}
    else {
      merged_arg1K0 = filename_340X;
      extract_string_return_tag = 2;
      goto extract_string;
     extract_string_return_2:
      spec_342X = extract_string_return_value;
      arg2K0 = (ps_open(spec_342X, "r"));
      goto L21208;}}}
 L21413: {
  if ((1 == (RSvalS))) {
    *((long *) (-3 + arg2_186X)) = 273;
    goto L21438;}
  else {
    if ((17 == (255 & (*((long *) (-3 + arg2_186X)))))) {
      *((long *) (-3 + arg2_186X)) = 529;
      goto L21438;}
    else {
      goto L21438;}}}
 L21441: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_186X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L21438: {
  RSvalS = 13;
  goto START;}
 L18255: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L18264: {
  v_344X = arg0K0;
  RSvalS = ((long)v_344X);
  goto START;}
 L24504: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg3_189X;
  merged_arg1K2 = arg2_188X;
  merged_arg1K3 = (RSvalS);
  goto raise_exception3;}
 L24497: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg3_189X;
  merged_arg1K2 = (((index_191X)<<2));
  merged_arg1K3 = (9 + (((((long)(Kchar_190X)))<<8)));
  goto raise_exception3;}
 L21618: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_101X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L21613: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_101X;
  merged_arg1K2 = (((index_193X)<<2));
  goto raise_exception2;}
 L21857: {
  len_346X = 1 + len_197X;
  *((long *) (ShpS)) = (62 + (((len_346X)<<8)));
  ShpS = (4 + (ShpS));
  new_345X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_346X)));
  if ((0 < len_346X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_345X;
    goto L21781;}
  else {
    arg1K0 = new_345X;
    goto L21781;}}
 L21806: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_195X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L21763: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (((len_197X)<<2));
  merged_arg1K2 = (9 + (((((long)(init_196X)))<<8)));
  goto raise_exception2;}
 L21781: {
  string_347X = arg1K0;
  arg1K0 = (-1 + len_197X);
  goto L21783;}
 L21783: {
  i_348X = arg1K0;
  if ((i_348X < 0)) {
    RSvalS = string_347X;
    goto START;}
  else {
    *((unsigned char *) ((-3 + string_347X) + i_348X)) = ((unsigned char)((long)(init_196X)));
    arg1K0 = (-1 + i_348X);
    goto L21783;}}
 L24678: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg3_98X;
  merged_arg1K2 = arg2_99X;
  merged_arg1K3 = (RSvalS);
  goto raise_exception3;}
 L24671: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg3_98X;
  merged_arg1K2 = (((index_200X)<<2));
  merged_arg1K3 = (((value_199X)<<2));
  goto raise_exception3;}
 L22033: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_97X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L22028: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_97X;
  merged_arg1K2 = (((index_202X)<<2));
  goto raise_exception2;}
 L22270: {
  *((long *) (ShpS)) = (66 + (((len_94X)<<8)));
  ShpS = (4 + (ShpS));
  new_349X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_94X)));
  if ((0 < len_94X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_349X;
    goto L22196;}
  else {
    arg1K0 = new_349X;
    goto L22196;}}
 L22178: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (((len_94X)<<2));
  merged_arg1K2 = (((init_95X)<<2));
  goto raise_exception2;}
 L22196: {
  code_vector_350X = arg1K0;
  arg1K0 = (-1 + len_94X);
  goto L22198;}
 L22198: {
  i_351X = arg1K0;
  if ((i_351X < 0)) {
    RSvalS = code_vector_350X;
    goto START;}
  else {
    *((unsigned char *) ((-3 + code_vector_350X) + i_351X)) = ((unsigned char)init_95X);
    arg1K0 = (-1 + i_351X);
    goto L22198;}}
 L25476: {
  merged_arg0K0 = 1;
  merged_arg1K1 = arg3_206X;
  merged_arg1K2 = (((((long)b_90X))<<2));
  merged_arg1K3 = (((index_91X)<<2));
  merged_arg1K4 = x_92X;
  goto raise_exception4;}
 L24845: {
  merged_arg0K0 = 1;
  merged_arg1K1 = arg2_207X;
  merged_arg1K2 = (((((long)b_87X))<<2));
  merged_arg1K3 = (((index_88X)<<2));
  goto raise_exception3;}
 L25022: {
  merged_arg0K0 = 1;
  merged_arg1K1 = (((((long)b_83X))<<2));
  merged_arg1K2 = (((len_84X)<<2));
  merged_arg1K3 = x_85X;
  goto raise_exception3;}
 L25038: {
  val_352X = arg1K0;
  arg1K0 = (-1 + len_84X);
  goto L25040;}
 L25040: {
  i_353X = arg1K0;
  if ((i_353X < 0)) {
    RSvalS = val_352X;
    goto START;}
  else {
    *((long *) ((-3 + val_352X) + (((i_353X)<<2)))) = init_355X;
    arg1K0 = (-1 + i_353X);
    goto L25040;}}
 L25027: {
  okayP_354X = arg3K0;
  init_355X = arg1K1;
  if (okayP_354X) {
    len_357X = ((len_84X)<<2);
    *((long *) (ShpS)) = (2 + (((((((len_357X)<<6)) + ((long)b_83X)))<<2)));
    ShpS = (4 + (ShpS));
    new_356X = 3 + (ShpS);
    ShpS = ((ShpS) + (-4 & (3 + len_357X)));
    if ((0 < len_357X)) {
      *((long *) (-4 + (ShpS))) = 0;
      arg1K0 = new_356X;
      goto L25038;}
    else {
      arg1K0 = new_356X;
      goto L25038;}}
  else {
    merged_arg0K0 = 1;
    merged_arg1K1 = (((((long)b_83X))<<2));
    merged_arg1K2 = (((len_84X)<<2));
    merged_arg1K3 = init_355X;
    goto raise_exception3;}}
 L25732: {
  merged_arg0K0 = 2;
  merged_arg1K1 = arg2_80X;
  merged_arg1K2 = (((((long)b_78X))<<2));
  merged_arg1K3 = (((((long)b_77X))<<2));
  merged_arg1K4 = x_79X;
  goto raise_exception4;}
 L25259: {
  merged_arg0K0 = 2;
  merged_arg1K1 = x_209X;
  merged_arg1K2 = (((((long)b_210X))<<2));
  merged_arg1K3 = (((((long)b_211X))<<2));
  goto raise_exception3;}
 L16631: {
  b_361X = *((unsigned char *) (RScode_pointerS));
  RScode_pointerS = (1 + (RScode_pointerS));
  b_360X = *((unsigned char *) (RScode_pointerS));
  RScode_pointerS = (1 + (RScode_pointerS));
  len_359X = ((((long)b_361X))<<2);
  *((long *) (ShpS)) = (2 + (((((((len_359X)<<6)) + ((long)b_360X)))<<2)));
  ShpS = (4 + (ShpS));
  new_358X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_359X)));
  if ((0 < len_359X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_358X;
    goto L16639;}
  else {
    arg1K0 = new_358X;
    goto L16639;}}
 L16639: {
  new_362X = arg1K0;
  if ((((long)b_361X) < 1)) {
    goto L16670;}
  else {
    *((long *) (-7 + (new_362X + (((((long)b_361X))<<2))))) = (RSvalS);
    arg1K0 = (-2 + ((long)b_361X));
    goto L16648;}}
 L16670: {
  RSvalS = new_362X;
  goto START;}
 L16648: {
  i_363X = arg1K0;
  if ((i_363X < 0)) {
    goto L16670;}
  else {
    RSstackS = (4 + (RSstackS));
    *((long *) ((-3 + new_362X) + (((i_363X)<<2)))) = (*((long *) (RSstackS)));
    arg1K0 = (-1 + i_363X);
    goto L16648;}}
 L22430: {
  merged_arg0K0 = 1;
  merged_arg1K1 = x_212X;
  merged_arg1K2 = (((((long)b_213X))<<2));
  goto raise_exception2;}
 L22717: {
  RSvalS = (((result_68X)<<2));
  goto START;}
 L22714: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_220X;
  merged_arg1K2 = x_72X;
  goto raise_exception2;}
 L23274: {
  n_364X = arg1K0;
  RSvalS = (((n_364X)<<2));
  goto START;}
 L23270: {
  b_365X = arg1K0;
  c_366X = a_367X % b_365X;
  if ((a_224X < 0)) {
    arg1K0 = (0 - c_366X);
    goto L23274;}
  else {
    arg1K0 = c_366X;
    goto L23274;}}
 L23268: {
  a_367X = arg1K0;
  if ((b_225X < 0)) {
    arg1K0 = (0 - b_225X);
    goto L23270;}
  else {
    arg1K0 = b_225X;
    goto L23270;}}
 L23407: {
  if ((536870911 < c_369X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_58X;
    merged_arg1K2 = x_226X;
    goto raise_exception2;}
  else {
    RSvalS = (((c_369X)<<2));
    goto START;}}
 L23404: {
  RSvalS = ((((0 - c_369X))<<2));
  goto START;}
 L23401: {
  b_368X = arg1K0;
  c_369X = a_370X / b_368X;
  if ((a_227X < 0)) {
    if ((b_228X < 0)) {
      goto L23407;}
    else {
      goto L23404;}}
  else {
    if ((b_228X < 0)) {
      goto L23404;}
    else {
      goto L23407;}}}
 L23399: {
  a_370X = arg1K0;
  if ((b_228X < 0)) {
    arg1K0 = (0 - b_228X);
    goto L23401;}
  else {
    arg1K0 = b_228X;
    goto L23401;}}
 L23777: {
  if ((536870911 < c_379X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_55X;
    merged_arg1K2 = x_231X;
    goto raise_exception2;}
  else {
    arg1K0 = (((c_379X)<<2));
    goto L23740;}}
 L23753: {
  n_371X = arg1K0;
  if ((0 == (((n_371X)<<2)))) {
    RSvalS = q_375X;
    goto START;}
  else {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_55X;
    merged_arg1K2 = x_231X;
    goto raise_exception2;}}
 L23749: {
  b_372X = arg1K0;
  c_373X = a_374X % b_372X;
  if ((a_376X < 0)) {
    arg1K0 = (0 - c_373X);
    goto L23753;}
  else {
    arg1K0 = c_373X;
    goto L23753;}}
 L23747: {
  a_374X = arg1K0;
  if ((b_377X < 0)) {
    arg1K0 = (0 - b_377X);
    goto L23749;}
  else {
    arg1K0 = b_377X;
    goto L23749;}}
 L23740: {
  q_375X = arg1K0;
  if ((0 == x_231X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_55X;
    merged_arg1K2 = x_231X;
    goto raise_exception2;}
  else {
    a_376X = ((arg2_55X)>>2);
    b_377X = ((x_231X)>>2);
    if ((a_376X < 0)) {
      arg1K0 = (0 - a_376X);
      goto L23747;}
    else {
      arg1K0 = a_376X;
      goto L23747;}}}
 L23736: {
  b_378X = arg1K0;
  c_379X = a_380X / b_378X;
  if ((a_232X < 0)) {
    if ((b_233X < 0)) {
      goto L23777;}
    else {
      arg1K0 = ((((0 - c_379X))<<2));
      goto L23740;}}
  else {
    if ((b_233X < 0)) {
      arg1K0 = ((((0 - c_379X))<<2));
      goto L23740;}
    else {
      goto L23777;}}}
 L23734: {
  a_380X = arg1K0;
  if ((b_233X < 0)) {
    arg1K0 = (0 - b_233X);
    goto L23736;}
  else {
    arg1K0 = b_233X;
    goto L23736;}}
 L23940: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_54X;
  merged_arg1K2 = x_234X;
  goto raise_exception2;}
 L24090: {
  if ((536870911 < c_388X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_53X;
    merged_arg1K2 = x_236X;
    goto raise_exception2;}
  else {
    RSvalS = (((c_388X)<<2));
    goto START;}}
 L24083: {
  if ((536870912 < c_388X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = arg2_53X;
    merged_arg1K2 = x_236X;
    goto raise_exception2;}
  else {
    RSvalS = ((((0 - c_388X))<<2));
    goto START;}}
 L24079: {
  if ((536870911 < lo_c_386X)) {
    goto L24074;}
  else {
    if ((lo_c_386X < 0)) {
      goto L24074;}
    else {
      if ((8192 < mid_c_387X)) {
        goto L24074;}
      else {
        if ((a_237X < 0)) {
          if ((b_238X < 0)) {
            goto L24090;}
          else {
            goto L24083;}}
        else {
          if ((b_238X < 0)) {
            goto L24083;}
          else {
            goto L24090;}}}}}}
 L24074: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_53X;
  merged_arg1K2 = x_236X;
  goto raise_exception2;}
 L24059: {
  b_381X = arg1K0;
  lo_a_382X = 65535 & a_389X;
  lo_b_383X = 65535 & b_381X;
  hi_a_384X = 65535 & (((a_389X)>>16));
  hi_b_385X = 65535 & (((b_381X)>>16));
  lo_c_386X = PS_SMALL_MULTIPLY(lo_a_382X, lo_b_383X);
  mid_c_387X = (PS_SMALL_MULTIPLY(lo_a_382X, hi_b_385X)) + (PS_SMALL_MULTIPLY(lo_b_383X, hi_a_384X));
  c_388X = lo_c_386X + (((mid_c_387X)<<16));
  if ((0 < hi_a_384X)) {
    if ((0 < hi_b_385X)) {
      goto L24074;}
    else {
      goto L24079;}}
  else {
    goto L24079;}}
 L24057: {
  a_389X = arg1K0;
  if ((b_238X < 0)) {
    arg1K0 = (0 - b_238X);
    goto L24059;}
  else {
    arg1K0 = b_238X;
    goto L24059;}}
 L24263: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_239X;
  merged_arg1K2 = x_52X;
  goto raise_exception2;}
 L28572: {
  offset_390X = arg1K0;
  RScode_pointerS = ((RScode_pointerS) + offset_390X);
  goto START;}
 L25344: {
  RSvalS = proc_36X;
  merged_arg0K0 = 0;
  goto perform_application;}
 L15148: {
  RSstackS = (4 + (RSstackS));
  list_391X = *((long *) (RSstackS));
  a_392X = *((long *) (-3 + list_391X));
  *((long *) (ShpS)) = 2050;
  ShpS = (4 + (ShpS));
  new_393X = 3 + (ShpS);
  ShpS = (8 + (ShpS));
  *((long *) (-4 + (ShpS))) = 0;
  *((long *) (-3 + new_393X)) = a_392X;
  *((long *) (1 + new_393X)) = 25;
  arg1K0 = (*((long *) (1 + list_391X)));
  arg1K1 = new_393X;
  goto L15158;}
 L15158: {
  l_394X = arg1K0;
  last_395X = arg1K1;
  if ((25 == l_394X)) {
    *((long *) (RSstackS)) = new_393X;
    RSstackS = (-4 + (RSstackS));
    SnargsS = 64;
    goto L25344;}
  else {
    a_397X = *((long *) (-3 + l_394X));
    *((long *) (ShpS)) = 2050;
    ShpS = (4 + (ShpS));
    new_396X = 3 + (ShpS);
    ShpS = (8 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_396X)) = a_397X;
    *((long *) (1 + new_396X)) = 25;
    *((long *) (1 + last_395X)) = new_396X;
    arg1K0 = (*((long *) (1 + l_394X)));
    arg1K1 = new_396X;
    goto L15158;}}
 L15374: {
  i_398X = arg1K0;
  l_399X = arg1K1;
  if ((0 < i_398X)) {
    *((long *) (RSstackS)) = (*((long *) (-3 + l_399X)));
    RSstackS = (-4 + (RSstackS));
    arg1K0 = (-1 + i_398X);
    arg1K1 = (*((long *) (1 + l_399X)));
    goto L15374;}
  else {
    if ((0 == overflow_401X)) {
      SnargsS = nargs_407X;
      goto L25344;}
    else {
      *((long *) (RSstackS)) = l_399X;
      RSstackS = (-4 + (RSstackS));
      space_400X = 3 * overflow_401X;
      if ((((ShpS) + (((space_400X)<<2))) < (SlimitS))) {
        goto L15148;}
      else {
        merged_arg1K0 = 0;
        collect_saving_temp_return_tag = 13;
        goto collect_saving_temp;
       collect_saving_temp_return_13:
        if ((((ShpS) + (((space_400X)<<2))) < (SlimitS))) {
          goto L15148;}
        else {
          TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
          goto L15148;}}}}}
 L15338: {
  overflow_401X = arg1K0;
  arg1K0 = (len_404X - overflow_401X);
  arg1K1 = args_408X;
  goto L15374;}
 L25378: {
  merged_arg1K0 = 25;
  merged_arg1K1 = ((long)(*((unsigned char *) (RScode_pointerS))));
  pop_args_list_return_tag = 2;
  goto pop_args_list;
 pop_args_list_return_2:
  args_402X = pop_args_list_return_value;
  merged_arg0K0 = 0;
  merged_arg1K1 = proc_36X;
  merged_arg1K2 = args_402X;
  merged_arg1K3 = (RSvalS);
  goto raise_exception3;}
 L25376: {
  fast_403X = arg1K0;
  len_404X = arg1K1;
  slow_405X = arg1K2;
  move_slowP_406X = arg3K3;
  if ((25 == fast_403X)) {
    args_408X = RSvalS;
    nargs_407X = len_404X + ((long)(*((unsigned char *) (RScode_pointerS))));
    if ((63 < nargs_407X)) {
      arg1K0 = (-63 + nargs_407X);
      goto L15338;}
    else {
      arg1K0 = 0;
      goto L15338;}}
  else {
    if ((3 == (3 & fast_403X))) {
      if ((0 == (31 & ((((*((long *) (-7 + fast_403X))))>>2))))) {
        if (move_slowP_406X) {
          if ((fast_403X == slow_405X)) {
            merged_arg1K0 = 25;
            merged_arg1K1 = ((long)(*((unsigned char *) (RScode_pointerS))));
            pop_args_list_return_tag = 3;
            goto pop_args_list;
           pop_args_list_return_3:
            args_409X = pop_args_list_return_value;
            merged_arg0K0 = 0;
            merged_arg1K1 = proc_36X;
            merged_arg1K2 = args_409X;
            merged_arg1K3 = (RSvalS);
            goto raise_exception3;}
          else {
            arg1K0 = (*((long *) (1 + fast_403X)));
            arg1K1 = (1 + len_404X);
            arg1K2 = (*((long *) (1 + slow_405X)));
            arg3K3 = 0;
            goto L25376;}}
        else {
          arg1K0 = (*((long *) (1 + fast_403X)));
          arg1K1 = (1 + len_404X);
          arg1K2 = slow_405X;
          arg3K3 = 1;
          goto L25376;}}
      else {
        goto L25378;}}
    else {
      goto L25378;}}}
 L15912: {
  merged_arg0K0 = 0;
  goto perform_application;}
 L15929: {
  loc_410X = arg1K0;
  arg_411X = arg1K1;
  if (((RSstackS) < arg_411X)) {
    *((long *) loc_410X) = (*((long *) arg_411X));
    arg1K0 = (-4 + loc_410X);
    arg1K1 = (-4 + arg_411X);
    goto L15929;}
  else {
    RSstackS = loc_410X;
    goto L15912;}}
 L28365: {
  v_412X = arg1K0;
  ScontS = v_412X;
  goto START;}
 L28247: {
  key_413X = arg1K0;
  merged_arg1K0 = ((RScode_pointerS) + ((((((long)b_254X))<<8)) + ((long)b_255X)));
  merged_arg1K1 = ((long)b_256X);
  merged_arg1K2 = key_413X;
  push_continuationB_return_tag = 0;
  goto push_continuationB;
 push_continuationB_return_0:
  goto START;}
 L28264: {
  v_414X = arg1K0;
  merged_arg1K0 = v_414X;
  copy_stack_into_heap_return_tag = 0;
  goto copy_stack_into_heap;
 copy_stack_into_heap_return_0:
  arg1K0 = 0;
  goto L28247;}
 L28104: {
  space_415X = arg1K0;
  if ((((ShpS) + (((space_415X)<<2))) < (SlimitS))) {
    arg1K0 = 0;
    goto L28106;}
  else {
    merged_arg1K0 = 0;
    collect_saving_temp_return_tag = 14;
    goto collect_saving_temp;
   collect_saving_temp_return_14:
    if ((((ShpS) + (((space_415X)<<2))) < (SlimitS))) {
      arg1K0 = 0;
      goto L28106;}
    else {
      TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
      arg1K0 = 0;
      goto L28106;}}}
 L28106: {
  key_416X = arg1K0;
  p_417X = RSenvS;
  if ((p_417X < (Sstack_beginS))) {
    arg1K0 = (RSenvS);
    goto L28108;}
  else {
    if (((Sstack_endS) < p_417X)) {
      arg1K0 = (RSenvS);
      goto L28108;}
    else {
      merged_arg1K0 = (RSenvS);
      merged_arg1K1 = (ScontS);
      merged_arg1K2 = key_416X;
      merged_arg0K3 = 0;
      save_env_in_heap_return_tag = 0;
      goto save_env_in_heap;
     save_env_in_heap_return_0:
      v_418X = save_env_in_heap_return_value;
      RSenvS = v_418X;
      arg1K0 = (RSenvS);
      goto L28108;}}}
 L28108: {
  env_419X = arg1K0;
  if (((12 + (ShpS)) < (SlimitS))) {
    goto L28110;}
  else {
    merged_arg1K0 = 0;
    collect_saving_temp_return_tag = 15;
    goto collect_saving_temp;
   collect_saving_temp_return_15:
    if (((12 + (ShpS)) < (SlimitS))) {
      goto L28110;}
    else {
      TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
      goto L28110;}}}
 L28110: {
  b_420X = *((unsigned char *) (RScode_pointerS));
  RScode_pointerS = (1 + (RScode_pointerS));
  a_421X = *((long *) ((-3 + (StemplateS)) + (((((long)b_420X))<<2))));
  *((long *) (ShpS)) = 2062;
  ShpS = (4 + (ShpS));
  new_422X = 3 + (ShpS);
  ShpS = (8 + (ShpS));
  *((long *) (-4 + (ShpS))) = 0;
  *((long *) (-3 + new_422X)) = a_421X;
  *((long *) (1 + new_422X)) = env_419X;
  if ((3 == (3 & new_422X))) {
    if ((0 == (128 & (*((long *) (-7 + new_422X)))))) {
      *((long *) (-7 + new_422X)) = (128 | (*((long *) (-7 + new_422X))));
      arg1K0 = new_422X;
      goto L28114;}
    else {
      arg1K0 = new_422X;
      goto L28114;}}
  else {
    arg1K0 = new_422X;
    goto L28114;}}
 L28006: {
  env_423X = arg1K0;
  i_424X = arg1K1;
  if ((0 == i_424X)) {
    b_425X = *((unsigned char *) (RScode_pointerS));
    RScode_pointerS = (1 + (RScode_pointerS));
    *((long *) ((-3 + env_423X) + (((((long)b_425X))<<2)))) = (RSvalS);
    RSvalS = 13;
    goto START;}
  else {
    arg1K0 = (*((long *) (-3 + env_423X)));
    arg1K1 = (-1 + i_424X);
    goto L28006;}}
 L27698: {
  env_426X = arg1K0;
  i_427X = arg1K1;
  if ((0 == i_427X)) {
    b_428X = *((unsigned char *) (RScode_pointerS));
    RScode_pointerS = (1 + (RScode_pointerS));
    RSvalS = (*((long *) ((-3 + env_426X) + (((((long)b_428X))<<2)))));
    if ((529 == (RSvalS))) {
      merged_arg0K0 = 2;
      goto raise_exception;}
    else {
      goto START;}}
  else {
    arg1K0 = (*((long *) (-3 + env_426X)));
    arg1K1 = (-1 + i_427X);
    goto L27698;}}
 L27934: {
  args_429X = arg1K0;
  RSvalS = args_429X;
  SnargsS = (1 + ((long)b_268X));
  goto START;}
 L27866: {
  b_432X = *((unsigned char *) (RScode_pointerS));
  RScode_pointerS = (1 + (RScode_pointerS));
  len_431X = 4 + (((((long)b_432X))<<2));
  *((long *) (ShpS)) = (10 + (((len_431X)<<8)));
  ShpS = (4 + (ShpS));
  new_430X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_431X)));
  if ((0 < len_431X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_430X;
    goto L9754;}
  else {
    arg1K0 = new_430X;
    goto L9754;}}
 L27800: {
  b_433X = *((unsigned char *) (RScode_pointerS));
  RScode_pointerS = (1 + (RScode_pointerS));
  *((long *) (RSstackS)) = (RSenvS);
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = (1034 + (((((long)b_433X))<<10)));
  RSstackS = (-4 + (RSstackS));
  RSenvS = (11 + (RSstackS));
  goto START;}
 L27833: {
  v_434X = arg1K0;
  merged_arg1K0 = v_434X;
  copy_stack_into_heap_return_tag = 1;
  goto copy_stack_into_heap;
 copy_stack_into_heap_return_1:
  goto L27800;}
 L31145: {
  merged_arg0K0 = 0;
  merged_arg1K1 = proc_151X;
  goto raise_exception1;}
 L31092: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L31073: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L30952: {
  v_435X = arg0K0;
  RSvalS = ((long)v_435X);
  goto START;}
 L30934: {
  v_436X = arg0K0;
  RSvalS = ((long)v_436X);
  goto START;}
 L30912: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L30891: {
  RSvalS = x_185X;
  goto START;}
 L30876: {
  v_437X = arg0K0;
  RSvalS = ((long)v_437X);
  goto START;}
 L30840: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L30809: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (RSvalS);
  goto raise_exception1;}
 L30762: {
  v_438X = arg0K0;
  RSvalS = ((long)v_438X);
  goto START;}
 L30744: {
  v_439X = arg0K0;
  RSvalS = ((long)v_439X);
  goto START;}
 L30722: {
  merged_arg0K0 = 0;
  merged_arg1K1 = (((x_73X)<<2));
  goto raise_exception1;}
 L30691: {
  v_440X = arg0K0;
  RSvalS = ((long)v_440X);
  goto START;}
 L30679: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_215X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L30662: {
  v_441X = arg0K0;
  RSvalS = ((long)v_441X);
  goto START;}
 L30650: {
  merged_arg0K0 = 0;
  merged_arg1K1 = arg2_217X;
  merged_arg1K2 = (RSvalS);
  goto raise_exception2;}
 L30635: {
  v_442X = arg0K0;
  RSvalS = ((long)v_442X);
  goto START;}
 L30507: {
  r_443X = arg1K0;
  if ((536870911 < r_443X)) {
    merged_arg0K0 = 0;
    merged_arg1K1 = x_222X;
    goto raise_exception1;}
  else {
    RSvalS = (((r_443X)<<2));
    goto START;}}
 L30319: {
  v_444X = arg0K0;
  RSvalS = ((long)v_444X);
  goto START;}
 L30295: {
  v_445X = arg0K0;
  RSvalS = ((long)v_445X);
  goto START;}
 L30212: {
  RSvalS = 1;
  goto START;}
 L30185: {
  RSvalS = 1;
  goto START;}
 L30158: {
  RSvalS = 1;
  goto START;}
 L30131: {
  RSvalS = 1;
  goto START;}
 L30113: {
  v_446X = arg0K0;
  RSvalS = ((long)v_446X);
  goto START;}
 L30099: {
  v_447X = arg0K0;
  RSvalS = ((long)v_447X);
  goto START;}
 L29978: {
  v_448X = arg1K0;
  ScontS = v_448X;
  SnargsS = 0;
  merged_arg0K0 = 0;
  goto perform_application;}
 L29948: {
  key_449X = arg1K0;
  merged_arg1K0 = key_449X;
  merged_arg0K1 = 2;
  preserve_continuation_return_tag = 0;
  goto preserve_continuation;
 preserve_continuation_return_0:
  v_450X = preserve_continuation_return_value;
  RSvalS = v_450X;
  goto START;}
 raise_exception: {
  args_676X = merged_arg0K0;{
  push_exception_continuationB_return_tag = 0;
  goto push_exception_continuationB;
 push_exception_continuationB_return_0:
  *((long *) (RSstackS)) = (((((long)(*((unsigned char *) (-1 + ((RScode_pointerS) - ((long)args_676X)))))))<<2));
  RSstackS = (-4 + (RSstackS));
  merged_arg0K0 = 0;
  goto raise;}}

 return_values: {
  nargs_674X = merged_arg1K0;{
  if ((1 == nargs_674X)) {
    RSstackS = (4 + (RSstackS));
    RSvalS = (*((long *) (RSstackS)));
    cont_451X = ScontS;
    tem_452X = *((long *) (5 + cont_451X));
    pc_453X = *((long *) (1 + cont_451X));
    StemplateS = tem_452X;
    RScode_pointerS = ((-3 + (*((long *) (-3 + tem_452X)))) + (((pc_453X)>>2)));
    RSenvS = (*((long *) (9 + cont_451X)));
    ScontS = (*((long *) (-3 + cont_451X)));
    RSstackS = (9 + cont_451X);
    goto START;}
  else {
    if (((ScontS) == (Sbottom_of_stackS))) {
      arg1K0 = (*((long *) (-3 + (Sbottom_of_stackS))));
      goto L27410;}
    else {
      arg1K0 = (ScontS);
      goto L27410;}}}
 L27360: {
  args_465X = arg1K0;
  merged_arg0K0 = 0;
  merged_arg1K1 = args_465X;
  goto raise_exception1;}
 L27307: {
  SnargsS = nargs_674X;
  RSvalS = (*((long *) (13 + cont_457X)));
  merged_arg0K0 = 0;
  goto perform_application;}
 L27410: {
  cont_457X = arg1K0;
  if ((3 == (3 & cont_457X))) {
    if ((8 == (31 & ((((*((long *) (-7 + cont_457X))))>>2))))) {
      next_op_459X = *((unsigned char *) ((-3 + (*((long *) (-3 + (*((long *) (5 + cont_457X))))))) + ((((*((long *) (1 + cont_457X))))>>2))));
      if ((31 == ((long)next_op_459X))) {
        cont_462X = ScontS;
        tem_463X = *((long *) (5 + cont_462X));
        pc_464X = *((long *) (1 + cont_462X));
        StemplateS = tem_463X;
        RScode_pointerS = ((-3 + (*((long *) (-3 + tem_463X)))) + (((pc_464X)>>2)));
        RSenvS = (*((long *) (9 + cont_462X)));
        ScontS = (*((long *) (-3 + cont_462X)));
        RSstackS = (9 + cont_462X);
        goto START;}
      else {
        if ((27 == ((long)next_op_459X))) {
          next_461X = *((long *) (-3 + (ScontS)));
          if (((ScontS) == (Sbottom_of_stackS))) {
            *((long *) (-3 + (ScontS))) = (*((long *) (-3 + next_461X)));
            goto L27307;}
          else {
            ScontS = next_461X;
            goto L27307;}}
        else {
          if ((64 == nargs_674X)) {
            RSstackS = (4 + (RSstackS));
            merged_arg1K0 = (*((long *) (RSstackS)));
            merged_arg1K1 = 63;
            pop_args_list_return_tag = 4;
            goto pop_args_list;
           pop_args_list_return_4:
            v_458X = pop_args_list_return_value;
            arg1K0 = v_458X;
            goto L27360;}
          else {
            merged_arg1K0 = 25;
            merged_arg1K1 = nargs_674X;
            pop_args_list_return_tag = 5;
            goto pop_args_list;
           pop_args_list_return_5:
            v_460X = pop_args_list_return_value;
            arg1K0 = v_460X;
            goto L27360;}}}}
    else {
      goto L27418;}}
  else {
    goto L27418;}}
 L27418: {
  if ((64 == nargs_674X)) {
    RSstackS = (4 + (RSstackS));
    merged_arg1K0 = (*((long *) (RSstackS)));
    merged_arg1K1 = 63;
    pop_args_list_return_tag = 6;
    goto pop_args_list;
   pop_args_list_return_6:
    v_456X = pop_args_list_return_value;
    arg1K0 = v_456X;
    goto L27448;}
  else {
    merged_arg1K0 = 25;
    merged_arg1K1 = nargs_674X;
    pop_args_list_return_tag = 7;
    goto pop_args_list;
   pop_args_list_return_7:
    v_455X = pop_args_list_return_value;
    arg1K0 = v_455X;
    goto L27448;}}
 L27448: {
  args_454X = arg1K0;
  merged_arg0K0 = 0;
  merged_arg1K1 = args_454X;
  goto raise_exception1;}}

 raise_exception1: {
  args_671X = merged_arg0K0;
  a1_672X = merged_arg1K1;{
  push_exception_continuationB_return_tag = 1;
  goto push_exception_continuationB;
 push_exception_continuationB_return_1:
  *((long *) (RSstackS)) = (((((long)(*((unsigned char *) (-1 + ((RScode_pointerS) - ((long)args_671X)))))))<<2));
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a1_672X;
  RSstackS = (-4 + (RSstackS));
  merged_arg0K0 = 1;
  goto raise;}}

 raise_exception2: {
  args_667X = merged_arg0K0;
  a1_668X = merged_arg1K1;
  a2_669X = merged_arg1K2;{
  push_exception_continuationB_return_tag = 2;
  goto push_exception_continuationB;
 push_exception_continuationB_return_2:
  *((long *) (RSstackS)) = (((((long)(*((unsigned char *) (-1 + ((RScode_pointerS) - ((long)args_667X)))))))<<2));
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a1_668X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a2_669X;
  RSstackS = (-4 + (RSstackS));
  merged_arg0K0 = 2;
  goto raise;}}

 raise_exception3: {
  args_662X = merged_arg0K0;
  a1_663X = merged_arg1K1;
  a2_664X = merged_arg1K2;
  a3_665X = merged_arg1K3;{
  push_exception_continuationB_return_tag = 3;
  goto push_exception_continuationB;
 push_exception_continuationB_return_3:
  *((long *) (RSstackS)) = (((((long)(*((unsigned char *) (-1 + ((RScode_pointerS) - ((long)args_662X)))))))<<2));
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a1_663X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a2_664X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a3_665X;
  RSstackS = (-4 + (RSstackS));
  merged_arg0K0 = 3;
  goto raise;}}

 raise_exception4: {
  args_656X = merged_arg0K0;
  a1_657X = merged_arg1K1;
  a2_658X = merged_arg1K2;
  a3_659X = merged_arg1K3;
  a4_660X = merged_arg1K4;{
  push_exception_continuationB_return_tag = 4;
  goto push_exception_continuationB;
 push_exception_continuationB_return_4:
  *((long *) (RSstackS)) = (((((long)(*((unsigned char *) (-1 + ((RScode_pointerS) - ((long)args_656X)))))))<<2));
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a1_657X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a2_658X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a3_659X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a4_660X;
  RSstackS = (-4 + (RSstackS));
  merged_arg0K0 = 4;
  goto raise;}}

 application_exception: {
  byte_args_654X = merged_arg0K0;{
  if ((64 == (SnargsS))) {
    RSstackS = (4 + (RSstackS));
    merged_arg1K0 = (*((long *) (RSstackS)));
    merged_arg1K1 = 63;
    pop_args_list_return_tag = 8;
    goto pop_args_list;
   pop_args_list_return_8:
    v_467X = pop_args_list_return_value;
    arg1K0 = v_467X;
    goto L24425;}
  else {
    merged_arg1K0 = 25;
    merged_arg1K1 = (SnargsS);
    pop_args_list_return_tag = 9;
    goto pop_args_list;
   pop_args_list_return_9:
    v_466X = pop_args_list_return_value;
    arg1K0 = v_466X;
    goto L24425;}}
 L24425: {
  args_468X = arg1K0;
  a1_469X = RSvalS;
  *((long *) (RSstackS)) = (((((long)(*((unsigned char *) (-1 + ((RScode_pointerS) - ((long)byte_args_654X)))))))<<2));
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = a1_469X;
  RSstackS = (-4 + (RSstackS));
  *((long *) (RSstackS)) = args_468X;
  RSstackS = (-4 + (RSstackS));
  merged_arg0K0 = 2;
  goto raise;}}

 raise: {
  nargs_652X = merged_arg0K0;{
  SnargsS = (1 + ((long)nargs_652X));
  RSvalS = (Sexception_handlerS);
  obj_470X = RSvalS;
  if ((3 == (3 & obj_470X))) {
    if ((3 == (31 & ((((*((long *) (-7 + obj_470X))))>>2))))) {
      goto L15972;}
    else {
      goto L16034;}}
  else {
    goto L16034;}}
 L16034: {
  TTerror("exception handler is not a closure", 0, 0, 0, 0);
  goto L15972;}
 L15974: {
  if ((Sexception_space_usedPS)) {
    x_473X = (Sstack_limitS) < (-296 + (RSstackS));
    if (x_473X) {
      goto L15987;}
    else {
      TTerror("no space on stack to reserve exception space", 0, 0, 0, 0);
      goto L15987;}}
  else {
    goto L15976;}}
 L16008: {
  v_472X = arg1K0;
  merged_arg1K0 = v_472X;
  copy_stack_into_heap_return_tag = 2;
  goto copy_stack_into_heap;
 copy_stack_into_heap_return_2:
  goto L15974;}
 L15976: {
  merged_arg0K0 = 0;
  goto perform_application;}
 L15987: {
  Sstack_limitS = (296 + (Sstack_beginS));
  Sexception_space_usedPS = 0;
  goto L15976;}
 L15972: {
  if (((Sstack_limitS) < (-296 + (RSstackS)))) {
    goto L15974;}
  else {
    space_471X = 1 + (((((Sstack_endS) - (RSstackS)))>>2));
    if ((((ShpS) + (((space_471X)<<2))) < (SlimitS))) {
      arg1K0 = 0;
      goto L16008;}
    else {
      merged_arg1K0 = 0;
      collect_saving_temp_return_tag = 16;
      goto collect_saving_temp;
     collect_saving_temp_return_16:
      if ((((ShpS) + (((space_471X)<<2))) < (SlimitS))) {
        arg1K0 = 0;
        goto L16008;}
      else {
        TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
        arg1K0 = 0;
        goto L16008;}}}}}

 perform_application: {
  bytes_consumed_650X = merged_arg0K0;{
  obj_475X = RSvalS;
  if ((3 == (3 & obj_475X))) {
    if ((3 == (31 & ((((*((long *) (-7 + obj_475X))))>>2))))) {
      RSenvS = (*((long *) (1 + (RSvalS))));
      tem_474X = *((long *) (-3 + (RSvalS)));
      StemplateS = tem_474X;
      RScode_pointerS = (-3 + (*((long *) (-3 + tem_474X))));
      if ((0 == ((Spending_interruptsS) & (Senabled_interruptsS)))) {
        goto START;}
      else {
        goto handle_interrupt;}}
    else {
      goto L15787;}}
  else {
    goto L15787;}}
 L15787: {
  merged_arg0K0 = bytes_consumed_650X;
  goto application_exception;}}

 handle_interrupt: {
{ if (((Sstack_limitS) < (-276 + (RSstackS)))) {
    arg1K0 = 0;
    goto L16076;}
  else {
    space_476X = 1 + (((((Sstack_endS) - (RSstackS)))>>2));
    if ((((ShpS) + (((space_476X)<<2))) < (SlimitS))) {
      arg1K0 = 0;
      goto L16316;}
    else {
      merged_arg1K0 = 0;
      collect_saving_temp_return_tag = 17;
      goto collect_saving_temp;
     collect_saving_temp_return_17:
      if ((((ShpS) + (((space_476X)<<2))) < (SlimitS))) {
        arg1K0 = 0;
        goto L16316;}
      else {
        TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
        arg1K0 = 0;
        goto L16316;}}}}
 L16076: {
  key_483X = arg1K0;
  n_484X = (Spending_interruptsS) & (Senabled_interruptsS);
  arg1K0 = 0;
  arg1K1 = 1;
  goto L16304;}
 L16316: {
  v_482X = arg1K0;
  merged_arg1K0 = v_482X;
  copy_stack_into_heap_return_tag = 3;
  goto copy_stack_into_heap;
 copy_stack_into_heap_return_3:
  arg1K0 = 0;
  goto L16076;}
 L16304: {
  i_478X = arg1K0;
  m_479X = arg1K1;
  if ((0 == (n_484X & m_479X))) {
    arg1K0 = (1 + i_478X);
    arg1K1 = (((m_479X)<<1));
    goto L16304;}
  else {
    Spending_interruptsS = (n_484X & (~ m_479X));
    *((long *) (RSstackS)) = (RSvalS);
    RSstackS = (-4 + (RSstackS));
    *((long *) (RSstackS)) = (StemplateS);
    RSstackS = (-4 + (RSstackS));
    *((long *) (RSstackS)) = (RSenvS);
    RSstackS = (-4 + (RSstackS));
    *((long *) (RSstackS)) = ((((SnargsS))<<2));
    RSstackS = (-4 + (RSstackS));
    *((long *) (RSstackS)) = ((((Senabled_interruptsS))<<2));
    RSstackS = (-4 + (RSstackS));
    tem_481X = Sinterrupt_templateS;
    StemplateS = tem_481X;
    RScode_pointerS = (-3 + (*((long *) (-3 + tem_481X))));
    merged_arg1K0 = (RScode_pointerS);
    merged_arg1K1 = (5 + (SnargsS));
    merged_arg1K2 = key_483X;
    push_continuationB_return_tag = 1;
    goto push_continuationB;
   push_continuationB_return_1:
    *((long *) (RSstackS)) = ((((Senabled_interruptsS))<<2));
    RSstackS = (-4 + (RSstackS));
    SnargsS = 1;
    obj_480X = Sinterrupt_handlersS;
    if ((3 == (3 & obj_480X))) {
      if ((2 == (31 & ((((*((long *) (-7 + obj_480X))))>>2))))) {
        goto L16118;}
      else {
        goto L16194;}}
    else {
      goto L16194;}}}
 L16194: {
  TTerror("interrupt handler is not a vector", 0, 0, 0, 0);
  goto L16118;}
 L16146: {
  TTerror("interrupt handler is not a closure", 1, i_478X, 0, 0);
  goto L16136;}
 L16136: {
  merged_arg0K0 = 0;
  goto perform_application;}
 L16118: {
  RSvalS = (*((long *) ((-3 + (Sinterrupt_handlersS)) + (((i_478X)<<2)))));
  Senabled_interruptsS = 0;
  obj_477X = RSvalS;
  if ((3 == (3 & obj_477X))) {
    if ((3 == (31 & ((((*((long *) (-7 + obj_477X))))>>2))))) {
      goto L16136;}
    else {
      goto L16146;}}
  else {
    goto L16146;}}}

 copy_stack_into_heap: {
  key_647X = merged_arg1K0;{
  arg1K0 = (4 + (RSstackS));
  arg1K1 = 0;
  goto L15036;}
 L15036: {
  p_488X = arg1K0;
  i_489X = arg1K1;
  if ((2 == (3 & (*((long *) p_488X))))) {
    len_491X = ((i_489X)<<2);
    *((long *) (ShpS)) = (10 + (((len_491X)<<8)));
    ShpS = (4 + (ShpS));
    new_490X = 3 + (ShpS);
    ShpS = ((ShpS) + (-4 & (3 + len_491X)));
    if ((0 < len_491X)) {
      *((long *) (-4 + (ShpS))) = 0;
      arg1K0 = new_490X;
      goto L14900;}
    else {
      arg1K0 = new_490X;
      goto L14900;}}
  else {
    arg1K0 = (4 + p_488X);
    arg1K1 = (1 + i_489X);
    goto L15036;}}
 L14900: {
  vec_487X = arg1K0;
  arg1K0 = (-1 + i_489X);
  goto L14902;}
 L14926: {
  i_486X = arg1K0;
  if ((i_486X < i_489X)) {
    *((long *) (RSstackS)) = (*((long *) ((-3 + vec_487X) + (((i_486X)<<2)))));
    RSstackS = (-4 + (RSstackS));
    arg1K0 = (1 + i_486X);
    goto L14926;}
  else {
    goto copy_stack_into_heap_return;}}
 L14902: {
  i_485X = arg1K0;
  if ((-1 < i_485X)) {
    RSstackS = (4 + (RSstackS));
    *((long *) ((-3 + vec_487X) + (((i_485X)<<2)))) = (*((long *) (RSstackS)));
    arg1K0 = (-1 + i_485X);
    goto L14902;}
  else {
    merged_arg1K0 = key_647X;
    merged_arg0K1 = 1;
    preserve_continuation_return_tag = 1;
    goto preserve_continuation;
   preserve_continuation_return_1:
    arg1K0 = 0;
    goto L14926;}}
 copy_stack_into_heap_return:
  switch (copy_stack_into_heap_return_tag) {
  case 0: goto copy_stack_into_heap_return_0;
  case 1: goto copy_stack_into_heap_return_1;
  case 2: goto copy_stack_into_heap_return_2;
  case 3: goto copy_stack_into_heap_return_3;
  }}

 preserve_continuation: {
  key_645X = merged_arg1K0;
  reason_646X = merged_arg0K1;{
  p_492X = RSenvS;
  if ((p_492X < (Sstack_beginS))) {
    goto L14645;}
  else {
    if (((Sstack_endS) < p_492X)) {
      goto L14645;}
    else {
      merged_arg1K0 = (RSenvS);
      merged_arg1K1 = (ScontS);
      merged_arg1K2 = key_645X;
      merged_arg0K3 = reason_646X;
      save_env_in_heap_return_tag = 1;
      goto save_env_in_heap;
     save_env_in_heap_return_1:
      v_493X = save_env_in_heap_return_value;
      RSenvS = v_493X;
      goto L14645;}}}
 L14645: {
  end_501X = *((long *) (-3 + (Sbottom_of_stackS)));
  arg1K0 = (ScontS);
  arg1K1 = (Sbottom_of_stackS);
  goto L14650;}
 L14703: {
  v_500X = arg1K0;
  ScontS = v_500X;
  preserve_continuation_return_value = cont_497X;
  goto preserve_continuation_return;}
 L14672: {
  merged_arg1K0 = cont_494X;
  merged_arg1K1 = key_645X;
  copy_stob_return_tag = 0;
  goto copy_stob;
 copy_stob_return_0:
  new_499X = copy_stob_return_value;
  *((long *) (-3 + previous_495X)) = new_499X;
  arg1K0 = (*((long *) (-3 + new_499X)));
  arg1K1 = new_499X;
  goto L14650;}
 L14650: {
  cont_494X = arg1K0;
  previous_495X = arg1K1;
  if ((cont_494X == (Sbottom_of_stackS))) {
    *((long *) (-3 + previous_495X)) = end_501X;
    cont_497X = *((long *) (-3 + (Sbottom_of_stackS)));
    if ((1 == cont_497X)) {
      arg1K0 = (Sbottom_of_stackS);
      goto L14703;}
    else {
      merged_arg1K0 = cont_497X;
      copy_continuation_from_heap_return_tag = 2;
      goto copy_continuation_from_heap;
     copy_continuation_from_heap_return_2:
      v_496X = copy_continuation_from_heap_return_value;
      arg1K0 = v_496X;
      goto L14703;}}
  else {
    p_498X = *((long *) (9 + cont_494X));
    if ((p_498X < (Sstack_beginS))) {
      goto L14672;}
    else {
      if (((Sstack_endS) < p_498X)) {
        goto L14672;}
      else {
        merged_arg1K0 = (*((long *) (9 + cont_494X)));
        merged_arg1K1 = cont_494X;
        merged_arg1K2 = key_645X;
        merged_arg0K3 = reason_646X;
        save_env_in_heap_return_tag = 2;
        goto save_env_in_heap;
       save_env_in_heap_return_2:
        goto L14672;}}}}
 preserve_continuation_return:
  switch (preserve_continuation_return_tag) {
  case 0: goto preserve_continuation_return_0;
  case 1: goto preserve_continuation_return_1;
  }}

 copy_continuation_from_heap: {
  cont_643X = merged_arg1K0;{
  top_502X = (-11 + (Sbottom_of_stackS)) - (-4 & (3 + ((long)(((unsigned long)(*((long *) (-7 + cont_643X))))>>8))));
  new_cont_503X = 7 + top_502X;
  RSstackS = (-4 + top_502X);
  v_504X = (((3 + ((long)(((unsigned long)(*((long *) (-7 + cont_643X))))>>8))))>>2);
  from_505X = -7 + cont_643X;
  arg1K0 = from_505X;
  arg1K1 = top_502X;
  goto L12892;}
 L12892: {
  from_506X = arg1K0;
  to_507X = arg1K1;
  if ((from_506X < (4 + (from_505X + (((v_504X)<<2)))))) {
    *((long *) to_507X) = (*((long *) from_506X));
    arg1K0 = (4 + from_506X);
    arg1K1 = (4 + to_507X);
    goto L12892;}
  else {
    *((long *) (-3 + (Sbottom_of_stackS))) = (*((long *) (-3 + new_cont_503X)));
    *((long *) (-3 + new_cont_503X)) = (Sbottom_of_stackS);
    copy_continuation_from_heap_return_value = new_cont_503X;
    goto copy_continuation_from_heap_return;}}
 copy_continuation_from_heap_return:
  switch (copy_continuation_from_heap_return_tag) {
  case 0: goto copy_continuation_from_heap_return_0;
  case 1: goto copy_continuation_from_heap_return_1;
  case 2: goto copy_continuation_from_heap_return_2;
  }}

 save_env_in_heap: {
  env_639X = merged_arg1K0;
  cont_640X = merged_arg1K1;
  key_641X = merged_arg1K2;{
  merged_arg1K0 = env_639X;
  merged_arg1K1 = key_641X;
  copy_stob_return_tag = 1;
  goto copy_stob;
 copy_stob_return_1:
  new_508X = copy_stob_return_value;
  *((long *) (-7 + env_639X)) = new_508X;
  arg1K0 = new_508X;
  goto L14174;}
 L14198: {
  arg1K0 = cont_640X;
  goto L14200;}
 L14200: {
  cont_513X = arg1K0;
  env_514X = *((long *) (9 + cont_513X));
  if ((3 == (3 & env_514X))) {
    if ((3 == (3 & (*((long *) (-7 + env_514X)))))) {
      *((long *) (9 + cont_513X)) = (*((long *) (-7 + env_514X)));
      arg1K0 = (*((long *) (-3 + cont_513X)));
      goto L14200;}
    else {
      save_env_in_heap_return_value = new_508X;
      goto save_env_in_heap_return;}}
  else {
    save_env_in_heap_return_value = new_508X;
    goto save_env_in_heap_return;}}
 L14174: {
  env_509X = arg1K0;
  p_510X = *((long *) (-3 + env_509X));
  if ((p_510X < (Sstack_beginS))) {
    goto L14198;}
  else {
    if (((Sstack_endS) < p_510X)) {
      goto L14198;}
    else {
      env_511X = *((long *) (-3 + env_509X));
      merged_arg1K0 = env_511X;
      merged_arg1K1 = key_641X;
      copy_stob_return_tag = 2;
      goto copy_stob;
     copy_stob_return_2:
      new_512X = copy_stob_return_value;
      *((long *) (-7 + env_511X)) = new_512X;
      *((long *) (-3 + env_509X)) = new_512X;
      arg1K0 = new_512X;
      goto L14174;}}}
 save_env_in_heap_return:
  switch (save_env_in_heap_return_tag) {
  case 0: goto save_env_in_heap_return_0;
  case 1: goto save_env_in_heap_return_1;
  case 2: goto save_env_in_heap_return_2;
  }}

 copy_stob: {
  old_stob_637X = merged_arg1K0;{
  len_516X = (long)(((unsigned long)(*((long *) (-7 + old_stob_637X))))>>8);
  *((long *) (ShpS)) = (66 + (((len_516X)<<8)));
  ShpS = (4 + (ShpS));
  new_515X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_516X)));
  if ((0 < len_516X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_515X;
    goto L9136;}
  else {
    arg1K0 = new_515X;
    goto L9136;}}
 L9136: {
  new_519X = arg1K0;
  *((long *) (-7 + new_519X)) = (*((long *) (-7 + old_stob_637X)));
  bytes_520X = (long)(((unsigned long)(*((long *) (-7 + old_stob_637X))))>>8);
  from_521X = -3 + old_stob_637X;
  arg1K0 = from_521X;
  arg1K1 = (-3 + new_519X);
  goto L9161;}
 L9161: {
  from_517X = arg1K0;
  to_518X = arg1K1;
  if ((from_517X < (from_521X + (-4 & (3 + bytes_520X))))) {
    *((long *) to_518X) = (*((long *) from_517X));
    arg1K0 = (4 + from_517X);
    arg1K1 = (4 + to_518X);
    goto L9161;}
  else {
    copy_stob_return_value = new_519X;
    goto copy_stob_return;}}
 copy_stob_return:
  switch (copy_stob_return_tag) {
  case 0: goto copy_stob_return_0;
  case 1: goto copy_stob_return_1;
  case 2: goto copy_stob_return_2;
  }}

 push_exception_continuationB: {
{ if (((Sstack_limitS) < (-296 + (RSstackS)))) {
    arg1K0 = 0;
    goto L14138;}
  else {
    Sstack_limitS = (Sstack_beginS);
    Sexception_space_usedPS = 1;
    if (((Sstack_limitS) < (-296 + (RSstackS)))) {
      arg1K0 = 0;
      goto L14138;}
    else {
      TTerror("insufficient space on stack for exception frame", 0, 0, 0, 0);
      arg1K0 = 0;
      goto L14138;}}}
 L14138: {
  key_524X = arg1K0;
  arg1K0 = (4 + (RSstackS));
  arg1K1 = 0;
  goto L14150;}
 L14150: {
  p_522X = arg1K0;
  i_523X = arg1K1;
  if ((2 == (3 & (*((long *) p_522X))))) {
    merged_arg1K0 = (RScode_pointerS);
    merged_arg1K1 = i_523X;
    merged_arg1K2 = key_524X;
    push_continuationB_return_tag = 2;
    goto push_continuationB;
   push_continuationB_return_2:
    goto push_exception_continuationB_return;}
  else {
    arg1K0 = (4 + p_522X);
    arg1K1 = (1 + i_523X);
    goto L14150;}}
 push_exception_continuationB_return:
  switch (push_exception_continuationB_return_tag) {
  case 0: goto push_exception_continuationB_return_0;
  case 1: goto push_exception_continuationB_return_1;
  case 2: goto push_exception_continuationB_return_2;
  case 3: goto push_exception_continuationB_return_3;
  case 4: goto push_exception_continuationB_return_4;
  }}

 push_continuationB: {
  code_pointer_634X = merged_arg1K0;
  size_635X = merged_arg1K1;{
  pc_525X = 12 + ((((code_pointer_634X - (*((long *) (-3 + (StemplateS))))))<<2));
  template_526X = StemplateS;
  RSstackS = (-20 + (RSstackS));
  *((long *) (4 + (RSstackS))) = (128 | (4130 + (((size_635X)<<10))));
  cont_527X = 11 + (RSstackS);
  *((long *) (1 + cont_527X)) = pc_525X;
  *((long *) (5 + cont_527X)) = template_526X;
  *((long *) (9 + cont_527X)) = (RSenvS);
  *((long *) (-3 + cont_527X)) = (ScontS);
  ScontS = cont_527X;
  goto push_continuationB_return;}
 push_continuationB_return:
  switch (push_continuationB_return_tag) {
  case 0: goto push_continuationB_return_0;
  case 1: goto push_continuationB_return_1;
  case 2: goto push_continuationB_return_2;
  }}

 pop_args_list: {
  start_632X = merged_arg1K0;
  count_633X = merged_arg1K1;{
  space_528X = 3 * (SnargsS);
  if ((((ShpS) + (((space_528X)<<2))) < (SlimitS))) {
    goto L15054;}
  else {
    merged_arg1K0 = 0;
    collect_saving_temp_return_tag = 18;
    goto collect_saving_temp;
   collect_saving_temp_return_18:
    if ((((ShpS) + (((space_528X)<<2))) < (SlimitS))) {
      goto L15054;}
    else {
      TTerror("Scheme48 heap overflow", 0, 0, 0, 0);
      goto L15054;}}}
 L15054: {
  arg1K0 = start_632X;
  arg1K1 = count_633X;
  goto L15056;}
 L15056: {
  args_529X = arg1K0;
  count_530X = arg1K1;
  if ((0 < count_530X)) {
    RSstackS = (4 + (RSstackS));
    a_531X = *((long *) (RSstackS));
    *((long *) (ShpS)) = 2050;
    ShpS = (4 + (ShpS));
    new_532X = 3 + (ShpS);
    ShpS = (8 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_532X)) = a_531X;
    *((long *) (1 + new_532X)) = args_529X;
    arg1K0 = new_532X;
    arg1K1 = (-1 + count_530X);
    goto L15056;}
  else {
    pop_args_list_return_value = args_529X;
    goto pop_args_list_return;}}
 pop_args_list_return:
  switch (pop_args_list_return_tag) {
  case 0: goto pop_args_list_return_0;
  case 1: goto pop_args_list_return_1;
  case 2: goto pop_args_list_return_2;
  case 3: goto pop_args_list_return_3;
  case 4: goto pop_args_list_return_4;
  case 5: goto pop_args_list_return_5;
  case 6: goto pop_args_list_return_6;
  case 7: goto pop_args_list_return_7;
  case 8: goto pop_args_list_return_8;
  case 9: goto pop_args_list_return_9;
  }}

 collect_saving_temp: {
  value_630X = merged_arg1K0;{
  b_537X = Snewspace_beginS;
  Snewspace_beginS = (Soldspace_beginS);
  Soldspace_beginS = b_537X;
  e_536X = Snewspace_endS;
  Snewspace_endS = (Soldspace_endS);
  Soldspace_endS = e_536X;
  Ssaved_limitS = (SlimitS);
  Ssaved_hpS = (ShpS);
  SlimitS = (Snewspace_endS);
  ShpS = (Snewspace_beginS);
  Sweak_pointer_hpS = -1;
  pc_535X = 12 + (((((RScode_pointerS) - (*((long *) (-3 + (StemplateS))))))<<2));
  value_534X = StemplateS;
  if ((3 == (3 & value_534X))) {
    a_538X = -3 + value_534X;
    if ((a_538X < (Soldspace_beginS))) {
      arg1K0 = value_534X;
      goto L13915;}
    else {
      if ((a_538X < (Soldspace_endS))) {
        merged_arg1K0 = value_534X;
        copy_object_return_tag = 1;
        goto copy_object;
       copy_object_return_1:
        v_533X = copy_object_return_value;
        arg1K0 = v_533X;
        goto L13915;}
      else {
        arg1K0 = value_534X;
        goto L13915;}}}
  else {
    arg1K0 = value_534X;
    goto L13915;}}
 L13915: {
  tem_585X = arg1K0;
  StemplateS = tem_585X;
  RScode_pointerS = ((-3 + (*((long *) (-3 + tem_585X)))) + (((pc_535X)>>2)));
  value_587X = RSvalS;
  if ((3 == (3 & value_587X))) {
    a_588X = -3 + value_587X;
    if ((a_588X < (Soldspace_beginS))) {
      arg1K0 = value_587X;
      goto L13919;}
    else {
      if ((a_588X < (Soldspace_endS))) {
        merged_arg1K0 = value_587X;
        copy_object_return_tag = 2;
        goto copy_object;
       copy_object_return_2:
        v_586X = copy_object_return_value;
        arg1K0 = v_586X;
        goto L13919;}
      else {
        arg1K0 = value_587X;
        goto L13919;}}}
  else {
    arg1K0 = value_587X;
    goto L13919;}}
 L13919: {
  v_581X = arg1K0;
  RSvalS = v_581X;
  value_583X = Sdynamic_stateS;
  if ((3 == (3 & value_583X))) {
    a_584X = -3 + value_583X;
    if ((a_584X < (Soldspace_beginS))) {
      arg1K0 = value_583X;
      goto L13923;}
    else {
      if ((a_584X < (Soldspace_endS))) {
        merged_arg1K0 = value_583X;
        copy_object_return_tag = 3;
        goto copy_object;
       copy_object_return_3:
        v_582X = copy_object_return_value;
        arg1K0 = v_582X;
        goto L13923;}
      else {
        arg1K0 = value_583X;
        goto L13923;}}}
  else {
    arg1K0 = value_583X;
    goto L13923;}}
 L13923: {
  v_577X = arg1K0;
  Sdynamic_stateS = v_577X;
  value_579X = Sexception_handlerS;
  if ((3 == (3 & value_579X))) {
    a_580X = -3 + value_579X;
    if ((a_580X < (Soldspace_beginS))) {
      arg1K0 = value_579X;
      goto L13927;}
    else {
      if ((a_580X < (Soldspace_endS))) {
        merged_arg1K0 = value_579X;
        copy_object_return_tag = 4;
        goto copy_object;
       copy_object_return_4:
        v_578X = copy_object_return_value;
        arg1K0 = v_578X;
        goto L13927;}
      else {
        arg1K0 = value_579X;
        goto L13927;}}}
  else {
    arg1K0 = value_579X;
    goto L13927;}}
 L13927: {
  v_573X = arg1K0;
  Sexception_handlerS = v_573X;
  value_575X = Sinterrupt_handlersS;
  if ((3 == (3 & value_575X))) {
    a_576X = -3 + value_575X;
    if ((a_576X < (Soldspace_beginS))) {
      arg1K0 = value_575X;
      goto L13931;}
    else {
      if ((a_576X < (Soldspace_endS))) {
        merged_arg1K0 = value_575X;
        copy_object_return_tag = 5;
        goto copy_object;
       copy_object_return_5:
        v_574X = copy_object_return_value;
        arg1K0 = v_574X;
        goto L13931;}
      else {
        arg1K0 = value_575X;
        goto L13931;}}}
  else {
    arg1K0 = value_575X;
    goto L13931;}}
 L13931: {
  v_569X = arg1K0;
  Sinterrupt_handlersS = v_569X;
  value_571X = Sinterrupt_templateS;
  if ((3 == (3 & value_571X))) {
    a_572X = -3 + value_571X;
    if ((a_572X < (Soldspace_beginS))) {
      arg1K0 = value_571X;
      goto L13935;}
    else {
      if ((a_572X < (Soldspace_endS))) {
        merged_arg1K0 = value_571X;
        copy_object_return_tag = 6;
        goto copy_object;
       copy_object_return_6:
        v_570X = copy_object_return_value;
        arg1K0 = v_570X;
        goto L13935;}
      else {
        arg1K0 = value_571X;
        goto L13935;}}}
  else {
    arg1K0 = value_571X;
    goto L13935;}}
 L13935: {
  v_565X = arg1K0;
  Sinterrupt_templateS = v_565X;
  value_567X = RSenvS;
  if ((3 == (3 & value_567X))) {
    a_568X = -3 + value_567X;
    if ((a_568X < (Soldspace_beginS))) {
      arg1K0 = value_567X;
      goto L13941;}
    else {
      if ((a_568X < (Soldspace_endS))) {
        merged_arg1K0 = value_567X;
        copy_object_return_tag = 7;
        goto copy_object;
       copy_object_return_7:
        v_566X = copy_object_return_value;
        arg1K0 = v_566X;
        goto L13941;}
      else {
        arg1K0 = value_567X;
        goto L13941;}}}
  else {
    arg1K0 = value_567X;
    goto L13941;}}
 L13941: {
  env_562X = arg1K0;
  RSenvS = env_562X;
  start_563X = 4 + (RSstackS);
  end_564X = -7 + (ScontS);
  arg1K0 = start_563X;
  goto L14017;}
 L14017: {
  addr_560X = arg1K0;
  if ((addr_560X < end_564X)) {
    merged_arg1K0 = addr_560X;
    copy_next_return_tag = 0;
    goto copy_next;
   copy_next_return_0:
    v_561X = copy_next_return_value;
    arg1K0 = v_561X;
    goto L14017;}
  else {
    arg1K0 = (ScontS);
    arg1K1 = 0;
    goto L13956;}}
 L14003: {
  addr_558X = arg1K0;
  if ((addr_558X < end_550X)) {
    merged_arg1K0 = addr_558X;
    copy_next_return_tag = 1;
    goto copy_next;
   copy_next_return_1:
    v_559X = copy_next_return_value;
    arg1K0 = v_559X;
    goto L14003;}
  else {
    if ((env_549X == last_env_548X)) {
      goto L13961;}
    else {
      arg1K0 = env_549X;
      goto L13971;}}}
 L13989: {
  addr_556X = arg1K0;
  if ((addr_556X < end_555X)) {
    merged_arg1K0 = addr_556X;
    copy_next_return_tag = 2;
    goto copy_next;
   copy_next_return_2:
    v_557X = copy_next_return_value;
    arg1K0 = v_557X;
    goto L13989;}
  else {
    arg1K0 = (*((long *) (-3 + env_554X)));
    goto L13971;}}
 L13971: {
  env_554X = arg1K0;
  if ((env_554X < (Sstack_beginS))) {
    goto L13961;}
  else {
    if (((Sstack_endS) < env_554X)) {
      goto L13961;}
    else {
      end_555X = (-3 + env_554X) + (-4 & (3 + ((long)(((unsigned long)(*((long *) (-7 + env_554X))))>>8))));
      arg1K0 = (-3 + env_554X);
      goto L13989;}}}
 L13961: {
  if ((cont_547X == (Sbottom_of_stackS))) {
    areas_551X = Simpure_areasS;
    sizes_552X = Simpure_sizesS;
    count_553X = Simpure_area_countS;
    arg1K0 = 0;
    goto L14490;}
  else {
    arg1K0 = (*((long *) (-3 + cont_547X)));
    arg1K1 = env_549X;
    goto L13956;}}
 L13956: {
  cont_547X = arg1K0;
  last_env_548X = arg1K1;
  env_549X = *((long *) (9 + cont_547X));
  end_550X = (-3 + cont_547X) + (-4 & (3 + ((long)(((unsigned long)(*((long *) (-7 + cont_547X))))>>8))));
  arg1K0 = (-3 + cont_547X);
  goto L14003;}
 L14500: {
  addr_545X = arg1K0;
  if ((addr_545X < end_544X)) {
    merged_arg1K0 = addr_545X;
    copy_next_return_tag = 3;
    goto copy_next;
   copy_next_return_3:
    v_546X = copy_next_return_value;
    arg1K0 = v_546X;
    goto L14500;}
  else {
    arg1K0 = (1 + i_540X);
    goto L14490;}}
 L14490: {
  i_540X = arg1K0;
  if ((i_540X < ((long)count_553X))) {
    start_543X = *(areas_551X + i_540X);
    end_544X = (*(areas_551X + i_540X)) + (*(sizes_552X + i_540X));
    arg1K0 = start_543X;
    goto L14500;}
  else {
    if ((3 == (3 & value_630X))) {
      a_541X = -3 + value_630X;
      if ((a_541X < (Soldspace_beginS))) {
        arg1K0 = value_630X;
        goto L14416;}
      else {
        if ((a_541X < (Soldspace_endS))) {
          merged_arg1K0 = value_630X;
          copy_object_return_tag = 8;
          goto copy_object;
         copy_object_return_8:
          v_542X = copy_object_return_value;
          arg1K0 = v_542X;
          goto L14416;}
        else {
          arg1K0 = value_630X;
          goto L14416;}}}
    else {
      arg1K0 = value_630X;
      goto L14416;}}}
 L14416: {
  value_539X = arg1K0;
  SvalS = RSvalS;
  SstackS = RSstackS;
  Scode_pointerS = RScode_pointerS;
  SenvS = RSenvS;
  do_gc();
  RSvalS = SvalS;
  RSstackS = SstackS;
  RScode_pointerS = Scode_pointerS;
  RSenvS = SenvS;
  post_gc_fdports(); /* Hack for scsh's i/o system. Olin. */
  Sgc_countS = (1 + (Sgc_countS));
  close_untraced_portsB_return_tag = 1;
  goto close_untraced_portsB;
 close_untraced_portsB_return_1:
  if ((((ShpS) + ((((Sminimum_recovered_spaceS))<<2))) < (SlimitS))) {
    collect_saving_temp_return_value = value_539X;
    goto collect_saving_temp_return;}
  else {
    Spending_interruptsS = (4 | (Spending_interruptsS));
    collect_saving_temp_return_value = value_539X;
    goto collect_saving_temp_return;}}
 collect_saving_temp_return:
  switch (collect_saving_temp_return_tag) {
  case 0: goto collect_saving_temp_return_0;
  case 1: goto collect_saving_temp_return_1;
  case 2: goto collect_saving_temp_return_2;
  case 3: goto collect_saving_temp_return_3;
  case 4: goto collect_saving_temp_return_4;
  case 5: goto collect_saving_temp_return_5;
  case 6: goto collect_saving_temp_return_6;
  case 7: goto collect_saving_temp_return_7;
  case 8: goto collect_saving_temp_return_8;
  case 9: goto collect_saving_temp_return_9;
  case 10: goto collect_saving_temp_return_10;
  case 11: goto collect_saving_temp_return_11;
  case 12: goto collect_saving_temp_return_12;
  case 13: goto collect_saving_temp_return_13;
  case 14: goto collect_saving_temp_return_14;
  case 15: goto collect_saving_temp_return_15;
  case 16: goto collect_saving_temp_return_16;
  case 17: goto collect_saving_temp_return_17;
  case 18: goto collect_saving_temp_return_18;
  }}

 copy_next: {
  addr_628X = merged_arg1K0;{
  next_589X = 4 + addr_628X;
  thing_590X = *((long *) addr_628X);
  if ((2 == (3 & thing_590X))) {
    if (((31 & (((thing_590X)>>2))) < 15)) {
      goto L11536;}
    else {
      copy_next_return_value = (next_589X + (-4 & (3 + ((long)(((unsigned long)thing_590X)>>8)))));
      goto copy_next_return;}}
  else {
    goto L11536;}}
 L11536: {
  if ((3 == (3 & thing_590X))) {
    a_592X = -3 + thing_590X;
    if ((a_592X < (Soldspace_beginS))) {
      copy_next_return_value = next_589X;
      goto copy_next_return;}
    else {
      if ((a_592X < (Soldspace_endS))) {
        merged_arg1K0 = thing_590X;
        copy_object_return_tag = 9;
        goto copy_object;
       copy_object_return_9:
        value_591X = copy_object_return_value;
        *((long *) addr_628X) = value_591X;
        copy_next_return_value = next_589X;
        goto copy_next_return;}
      else {
        copy_next_return_value = next_589X;
        goto copy_next_return;}}}
  else {
    copy_next_return_value = next_589X;
    goto copy_next_return;}}
 copy_next_return:
  switch (copy_next_return_tag) {
  case 0: goto copy_next_return_0;
  case 1: goto copy_next_return_1;
  case 2: goto copy_next_return_2;
  case 3: goto copy_next_return_3;
  }}

 copy_object: {
  thing_626X = merged_arg1K0;{
  h_594X = *((long *) (-7 + thing_626X));
  if ((3 == (3 & h_594X))) {
    copy_object_return_value = h_594X;
    goto copy_object_return;}
  else {
    if ((1070 == h_594X)) {
      descriptor_595X = *((long *) (-3 + thing_626X));
      if ((3 == (3 & descriptor_595X))) {
        a_593X = -3 + descriptor_595X;
        if ((a_593X < (Soldspace_beginS))) {
          goto L9586;}
        else {
          if ((a_593X < (Soldspace_endS))) {
            SvalS = RSvalS;
            SstackS = RSstackS;
            Scode_pointerS = RScode_pointerS;
            SenvS = RSenvS;
            v_596X = copy_weak_pointer(thing_626X);
            RSvalS = SvalS;
            RSstackS = SstackS;
            RScode_pointerS = Scode_pointerS;
            RSenvS = SenvS;
            copy_object_return_value = v_596X;
            goto copy_object_return;}
          else {
            goto L9586;}}}
      else {
        goto L9586;}}
    else {
      goto L9586;}}}
 L9586: {
  *((long *) (ShpS)) = h_594X;
  ShpS = (4 + (ShpS));
  new_598X = 3 + (ShpS);
  *((long *) (-7 + thing_626X)) = new_598X;
  x1_599X = ShpS;
  arg1K0 = (-3 + thing_626X);
  goto L9600;}
 L9600: {
  o_597X = arg1K0;
  if (((ShpS) < (x1_599X + (-4 & (3 + ((long)(((unsigned long)h_594X)>>8))))))) {
    *((long *) (ShpS)) = (*((long *) o_597X));
    ShpS = (4 + (ShpS));
    arg1K0 = (4 + o_597X);
    goto L9600;}
  else {
    copy_object_return_value = new_598X;
    goto copy_object_return;}}
 copy_object_return:
  switch (copy_object_return_tag) {
  case 0: goto copy_object_return_0;
  case 1: goto copy_object_return_1;
  case 2: goto copy_object_return_2;
  case 3: goto copy_object_return_3;
  case 4: goto copy_object_return_4;
  case 5: goto copy_object_return_5;
  case 6: goto copy_object_return_6;
  case 7: goto copy_object_return_7;
  case 8: goto copy_object_return_8;
  case 9: goto copy_object_return_9;
  }}

 close_untraced_portsB: {
{ arg1K0 = 2;
  goto L13688;}
 L13734: {
  merged_arg1K0 = port_601X;
  close_port_return_tag = 1;
  goto close_port;
 close_port_return_1:
  fputs("Port closed: ", (Scurrent_output_portS));
  string_605X = *((long *) (9 + port_601X));
  fwrite((void *)(-3 + string_605X), sizeof(char), (-1 + ((long)(((unsigned long)(*((long *) (-7 + string_605X))))>>8))), (Scurrent_output_portS));
  putc(10, (Scurrent_output_portS));
  arg1K0 = 1;
  goto L13714;}
 L13719: {
  arg1K0 = (1 + i_600X);
  goto L13688;}
 L13714: {
  new_604X = arg1K0;
  *((Sopen_vm_portsS) + i_600X) = new_604X;
  goto L13719;}
 L13688: {
  i_600X = arg1K0;
  if ((i_600X == (Snumber_of_portsS))) {
    close_untraced_portsB_return_value = 0;
    goto close_untraced_portsB_return;}
  else {
    port_601X = *((Sopen_vm_portsS) + i_600X);
    if ((1 == port_601X)) {
      goto L13719;}
    else {
      header_602X = *((long *) (-7 + port_601X));
      if ((3 == (3 & header_602X))) {
        arg1K0 = header_602X;
        goto L13714;}
      else {
        header_603X = *((long *) (-7 + (*((long *) (9 + port_601X)))));
        if ((3 == (3 & header_603X))) {
          goto L13734;}
        else {
          goto L13734;}}}}}
 close_untraced_portsB_return:
  switch (close_untraced_portsB_return_tag) {
  case 0: goto close_untraced_portsB_return_0;
  case 1: goto close_untraced_portsB_return_1;
  }}

 close_port: {
  vm_port_623X = merged_arg1K0;{
  if (((*((long *) (1 + vm_port_623X))) < 0)) {
    goto close_port_return;}
  else {
    index_608X = (((*((long *) (1 + vm_port_623X))))>>2);
    if ((0 == index_608X)) {
      goto close_port_return;}
    else {
      if ((1 == index_608X)) {
        goto close_port_return;}
      else {
        mode_607X = (((*((long *) (-3 + vm_port_623X))))>>2);
        port_606X = *((Sopen_portsS) + ((((*((long *) (1 + vm_port_623X))))>>2)));
        if ((1 == mode_607X)) {
          fclose(port_606X);
          goto L11193;}
        else {
          if ((2 == mode_607X)) {
            fclose(port_606X);
            goto L11193;}
          else {
            TTerror("this shouldn't happen when closing a port", 0, 0, 0, 0);
            goto L11193;}}}}}}
 L11193: {
  *((long *) (-3 + vm_port_623X)) = 0;
  *((long *) (1 + vm_port_623X)) = -4;
  *((Sopen_vm_portsS) + index_608X) = 1;
  goto close_port_return;}
 close_port_return:
  switch (close_port_return_tag) {
  case 0: goto close_port_return_0;
  case 1: goto close_port_return_1;
  }}

 write_number: {
  x_621X = merged_arg1K0;
  port_622X = merged_arg2K1;{
  if ((x_621X < 0)) {
    putc(45, port_622X);
    arg1K0 = (0 - x_621X);
    goto L29338;}
  else {
    arg1K0 = x_621X;
    goto L29338;}}
 L29338: {
  v_609X = arg1K0;
  SvalS = RSvalS;
  SstackS = RSstackS;
  Scode_pointerS = RScode_pointerS;
  SenvS = RSenvS;
  really_write_number(v_609X, port_622X);
  RSvalS = SvalS;
  RSstackS = SstackS;
  RScode_pointerS = Scode_pointerS;
  RSenvS = SenvS;
  putc(10, port_622X);
  goto write_number_return;}
 write_number_return:
  switch (write_number_return_tag) {
  case 0: goto write_number_return_0;
  case 1: goto write_number_return_1;
  case 2: goto write_number_return_2;
  case 3: goto write_number_return_3;
  case 4: goto write_number_return_4;
  }}

 stob_equalP: {
  stob1_619X = merged_arg1K0;
  stob2_620X = merged_arg1K1;{
  z2_611X = *((long *) (-7 + stob2_620X));
  z1_610X = *((long *) (-7 + stob1_619X));
  if (((128 | z1_610X) == (128 | z2_611X))) {
    arg1K0 = 0;
    goto L8355;}
  else {
    stob_equalP_return_value = 0;
    goto stob_equalP_return;}}
 L8355: {
  i_612X = arg1K0;
  if ((i_612X < ((((3 + ((long)(((unsigned long)z1_610X)>>8))))>>2)))) {
    if (((*((long *) ((-3 + stob1_619X) + (((i_612X)<<2))))) == (*((long *) ((-3 + stob2_620X) + (((i_612X)<<2))))))) {
      arg1K0 = (1 + i_612X);
      goto L8355;}
    else {
      stob_equalP_return_value = 0;
      goto stob_equalP_return;}}
  else {
    stob_equalP_return_value = 1;
    goto stob_equalP_return;}}
 stob_equalP_return:
  switch (stob_equalP_return_tag) {
  case 0: goto stob_equalP_return_0;
  case 1: goto stob_equalP_return_1;
  }}

 extract_string: {
  string_617X = merged_arg1K0;{
  z_613X = -1 + ((long)(((unsigned long)(*((long *) (-7 + string_617X))))>>8));
  v_614X = (unsigned char *)calloc( 1, 1 + z_613X);
  arg1K0 = 0;
  goto L10873;}
 L10873: {
  i_615X = arg1K0;
  if ((i_615X < z_613X)) {
    *(v_614X + i_615X) = (((long)(*((unsigned char *) ((-3 + string_617X) + i_615X)))));
    arg1K0 = (1 + i_615X);
    goto L10873;}
  else {
    extract_string_return_value = v_614X;
    goto extract_string_return;}}
 extract_string_return:
  switch (extract_string_return_tag) {
  case 0: goto extract_string_return_0;
  case 1: goto extract_string_return_1;
  case 2: goto extract_string_return_2;
  }}
}

long enter_string(unsigned char *string_677X)
{
  extern long ShpS;
  long arg1K0;
  long new_678X;
  long len_679X;
  long z_680X;
  long s_681X;
  long i_682X;

 {z_680X = strlen(string_677X);
  len_679X = 1 + z_680X;
  *((long *) (ShpS)) = (62 + (((len_679X)<<8)));
  ShpS = (4 + (ShpS));
  new_678X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_679X)));
  if ((0 < len_679X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_678X;
    goto L11945;}
  else {
    arg1K0 = new_678X;
    goto L11945;}}
 L11945: {
  s_681X = arg1K0;
  arg1K0 = 0;
  goto L11947;}
 L11947: {
  i_682X = arg1K0;
  if ((i_682X < z_680X)) {
    *((unsigned char *) ((-3 + s_681X) + i_682X)) = ((unsigned char)((long)((*(string_677X + i_682X)))));
    arg1K0 = (1 + i_682X);
    goto L11947;}
  else {
    return(s_681X);}}}

long copy_weak_pointer(long weak_683X)
{
  extern long ShpS;
  extern long Sweak_pointer_limitS;
  extern long Sweak_pointer_hpS;
  unsigned char tempWW552_684X;
  long old_685X;
  long new_686X;

 {tempWW552_684X = -1 == (Sweak_pointer_hpS);
  if (tempWW552_684X) {
    goto L8005;}
  else {
    if (((Sweak_pointer_hpS) < (Sweak_pointer_limitS))) {
      goto L8010;}
    else {
      goto L8005;}}}
 L8005: {
  old_685X = Sweak_pointer_hpS;
  Sweak_pointer_hpS = (ShpS);
  ShpS = (1024 + (ShpS));
  Sweak_pointer_limitS = (ShpS);
  *((long *) (Sweak_pointer_hpS)) = 261186;
  *((long *) (8 + (Sweak_pointer_hpS))) = old_685X;
  goto L8010;}
 L8010: {
  new_686X = 7 + (Sweak_pointer_hpS);
  *((long *) (4 + (Sweak_pointer_hpS))) = (*((long *) (-3 + weak_683X)));
  Sweak_pointer_hpS = (8 + (Sweak_pointer_hpS));
  *((long *) (-7 + weak_683X)) = new_686X;
  return(new_686X);}}

void really_write_number(long x_687X, FILE * port_688X)
{
  extern void really_write_number(long, FILE *);
  long v_689X;
  long v_690X;

 {if ((x_687X < 10)) {
    goto L29300;}
  else {
    v_689X = x_687X / 10;
    really_write_number(v_689X, port_688X);
    goto L29300;}}
 L29300: {
  v_690X = x_687X % 10;
  putc(((48 + v_690X)), port_688X);
  return;}}

long read_number(FILE * port_691X)
{
  long arg1K0;
  unsigned char arg4K1;
  unsigned char arg4K0;
  unsigned char ch_692X;
  long r_693X;
  unsigned char ch_694X;
  long r_695X;
  unsigned char Kchar_696X;
  unsigned char ch_697X;
  unsigned char Kchar_698X;
  unsigned char ch_699X;

 {goto L4913;}
 L4942: {
  ch_692X = arg4K0;
  arg1K0 = 0;
  arg4K1 = ch_692X;
  goto L4944;}
 L4944: {
  r_693X = arg1K0;
  ch_694X = arg4K1;
  r_695X = (-48 + ((long)(ch_694X))) + (10 * r_693X);
  { int TTchar;
    PS_GETC(port_691X, TTchar);
    if (EOF == TTchar) {
      return(r_695X);}
    else {
      unsigned char Kchar_696X = TTchar;
      ch_697X = Kchar_696X;
      if ((((long)ch_697X) < 48)) {
        return(r_695X);}
      else {
        if ((57 < ((long)ch_697X))) {
          return(r_695X);}
        else {
          arg1K0 = r_695X;
          arg4K1 = Kchar_696X;
          goto L4944;}}}}}
 L4913: {
  { int TTchar;
    PS_GETC(port_691X, TTchar);
    if (EOF == TTchar) {
      arg4K0 = -1;
      goto L4942;}
    else {
      unsigned char Kchar_698X = TTchar;
      ch_699X = Kchar_698X;
      if ((((long)ch_699X) < 48)) {
        goto L4913;}
      else {
        if ((57 < ((long)ch_699X))) {
          goto L4913;}
        else {
          arg4K0 = Kchar_698X;
          goto L4942;}}}}}}

long call_startup_procedure(long startup_proc_700X, unsigned char **startup_vector_701X, long startup_vector_length_702X)
{
  extern long Sbottom_of_stackS;
  extern long SenvS;
  extern long Sinterrupt_templateS;
  extern long StemplateS;
  extern long Sdynamic_stateS;
  extern long Sexception_handlerS;
  extern long Sinterrupt_handlersS;
  extern long Senabled_interruptsS;
  extern long Spending_interruptsS;
  extern long *Sopen_vm_portsS;
  extern long Scode_pointerS;
  extern long Tinterpret();
  extern long SnargsS;
  extern long SvalS;
  extern long SstackS;
  extern long Sstack_beginS;
  extern long Sstack_limitS;
  extern unsigned char Sexception_space_usedPS;
  extern long enter_string(unsigned char*);
  extern long ShpS;
  long arg1K0;
  long new_703X;
  long len_704X;
  long tem_705X;
  long new_706X;
  long v_707X;
  unsigned char option_708X;
  long vector_709X;
  long i_710X;
  unsigned char x_711X;
  long val_712X;

 {len_704X = ((startup_vector_length_702X)<<2);
  *((long *) (ShpS)) = (10 + (((len_704X)<<8)));
  ShpS = (4 + (ShpS));
  new_703X = 3 + (ShpS);
  ShpS = ((ShpS) + (-4 & (3 + len_704X)));
  if ((0 < len_704X)) {
    *((long *) (-4 + (ShpS))) = 0;
    arg1K0 = new_703X;
    goto L15473;}
  else {
    arg1K0 = new_703X;
    goto L15473;}}
 L12652: {
  SenvS = 13;
  tem_705X = Sinterrupt_templateS;
  StemplateS = tem_705X;
  Scode_pointerS = (-3 + (*((long *) (-3 + tem_705X))));
  SnargsS = 0;
  SvalS = 13;
  Sdynamic_stateS = 25;
  Sexception_handlerS = 25;
  Sinterrupt_handlersS = 25;
  Senabled_interruptsS = 0;
  Spending_interruptsS = 0;
  *((long *) (SstackS)) = vector_709X;
  SstackS = (-4 + (SstackS));
  *((long *) (SstackS)) = (*((Sopen_vm_portsS) + 0));
  SstackS = (-4 + (SstackS));
  *((long *) (SstackS)) = (*((Sopen_vm_portsS) + 1));
  SstackS = (-4 + (SstackS));
  *((long *) (ShpS)) = 578;
  ShpS = (4 + (ShpS));
  new_706X = 3 + (ShpS);
  ShpS = (4 + (ShpS));
  *((long *) (-4 + (ShpS))) = 0;
  *((unsigned char *) (-3 + new_706X)) = 23;
  *((unsigned char *) (-2 + new_706X)) = 3;
  Scode_pointerS = (-3 + new_706X);
  SvalS = startup_proc_700X;
  goto L15407;}
 L12697: {
  Sstack_limitS = (296 + (Sstack_beginS));
  Sexception_space_usedPS = 0;
  goto L12652;}
 L15407: {
  option_708X = TTrun_machine((long)Tinterpret);
  if ((0 == ((long)option_708X))) {
    return((SvalS));}
  else {
    if ((1 == ((long)option_708X))) {
      v_707X = ((long(*)())(*((long *) (-3 + (*((long *) (1 + (SvalS))))))))((SnargsS), (4 + (SstackS)));
      SvalS = v_707X;
      SstackS = ((SstackS) - ((((-1 - (SnargsS)))<<2)));
      goto L15407;}
    else {
      TTerror("unkown VM return option", 1, ((long)option_708X), 0, 0);
      return(-1);}}}
 L15473: {
  vector_709X = arg1K0;
  arg1K0 = 0;
  goto L15475;}
 L15475: {
  i_710X = arg1K0;
  if ((i_710X < startup_vector_length_702X)) {
    val_712X = enter_string((*(startup_vector_701X + i_710X)));
    *((long *) ((-3 + vector_709X) + (((i_710X)<<2)))) = val_712X;
    arg1K0 = (1 + i_710X);
    goto L15475;}
  else {
    SstackS = (-11 + (Sbottom_of_stackS));
    *((long *) (-3 + (Sbottom_of_stackS))) = 1;
    if ((Sexception_space_usedPS)) {
      x_711X = (Sstack_limitS) < (-296 + (SstackS));
      if (x_711X) {
        goto L12697;}
      else {
        TTerror("no space on stack to reserve exception space", 0, 0, 0, 0);
        goto L12697;}}
    else {
      goto L12652;}}}}

void initialize_vm(long memory_begin_713X, long memory_size_714X, long stack_begin_715X, long stack_size_716X)
{
  extern long Soldspace_beginS;
  extern long Soldspace_endS;
  extern long Snewspace_beginS;
  extern long Snewspace_endS;
  extern long SlimitS;
  extern long Snumber_of_portsS;
  extern FILE * Scurrent_input_portS;
  extern FILE * Scurrent_output_portS;
  extern FILE * *Sopen_portsS;
  extern long enter_string(unsigned char*);
  extern long ShpS;
  extern long Sstack_beginS;
  extern long Sstack_limitS;
  extern long Sstack_endS;
  extern long SstackS;
  extern long SenvS;
  extern long ScontS;
  extern long Sbottom_of_stackS;
  extern long Sinterrupt_templateS;
  extern long *Sopen_vm_portsS;
  long arg1K0;
  unsigned char merged_arg0K1;
  unsigned char merged_arg0K0;

  int make_template_containing_ops_return_tag;
  long make_template_containing_ops_return_value;
  long semisize_717X;
  unsigned char tempWW560_718X;
  long i_719X;
  long v_720X;
  long cont_721X;
  long template_722X;
  long new_723X;
  long d_724X;
  long new_725X;
  long d_726X;
  long *v_727X;
  long length_728X;
  long new_729X;
  long new_730X;
  long c_731X;
  unsigned char op1_732X;
  unsigned char op2_733X;
 {semisize_717X = (((-2 & memory_size_714X))<<1);
  Snewspace_beginS = memory_begin_713X;
  Snewspace_endS = ((Snewspace_beginS) + semisize_717X);
  Soldspace_beginS = (Snewspace_endS);
  Soldspace_endS = ((Soldspace_beginS) + semisize_717X);
  ShpS = (Snewspace_beginS);
  SlimitS = (Snewspace_endS);
  Sopen_portsS = ((FILE **)malloc(sizeof(FILE *) * (Snumber_of_portsS)));
  Sopen_vm_portsS = ((long*)malloc(sizeof(long) * (Snumber_of_portsS)));
  tempWW560_718X = NULL == (Sopen_portsS);
  if (tempWW560_718X) {
    goto L12952;}
  else {
    if ((NULL == (Sopen_vm_portsS))) {
      goto L12952;}
    else {
      goto L12957;}}}
 L12952: {
  TTerror("out of memory, unable to continue", 0, 0, 0, 0);
  goto L12957;}
 L13064: {
  i_719X = arg1K0;
  if ((i_719X < length_728X)) {
    *(v_727X + i_719X) = 1;
    arg1K0 = (1 + i_719X);
    goto L13064;}
  else {
    *((Sopen_portsS) + 0) = (Scurrent_input_portS);
    *((Sopen_portsS) + 1) = (Scurrent_output_portS);
    d_726X = enter_string("so");
    *((long *) (ShpS)) = 4118;
    ShpS = (4 + (ShpS));
    new_725X = 3 + (ShpS);
    ShpS = (16 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_725X)) = 8;
    *((long *) (1 + new_725X)) = 4;
    *((long *) (5 + new_725X)) = 1;
    *((long *) (9 + new_725X)) = d_726X;
    d_724X = enter_string("si");
    *((long *) (ShpS)) = 4118;
    ShpS = (4 + (ShpS));
    new_723X = 3 + (ShpS);
    ShpS = (16 + (ShpS));
    *((long *) (-4 + (ShpS))) = 0;
    *((long *) (-3 + new_723X)) = 4;
    *((long *) (1 + new_723X)) = 0;
    *((long *) (5 + new_723X)) = 1;
    *((long *) (9 + new_723X)) = d_724X;
    *((Sopen_vm_portsS) + 0) = new_723X;
    *((Sopen_vm_portsS) + 1) = new_725X;
    Sstack_beginS = stack_begin_715X;
    Sstack_endS = (stack_begin_715X + (((stack_size_716X)<<2)));
    Sstack_limitS = (Sstack_beginS);
    SstackS = (-4 + (Sstack_endS));
    ScontS = 1;
    SenvS = 17;
    merged_arg0K0 = 22;
    merged_arg0K1 = 28;
    make_template_containing_ops_return_tag = 0;
    goto make_template_containing_ops;
   make_template_containing_ops_return_0:
    template_722X = make_template_containing_ops_return_value;
    SstackS = (-20 + (SstackS));
    *((long *) (4 + (SstackS))) = 4258;
    cont_721X = 11 + (SstackS);
    *((long *) (1 + cont_721X)) = 0;
    *((long *) (5 + cont_721X)) = template_722X;
    *((long *) (9 + cont_721X)) = (SenvS);
    *((long *) (-3 + cont_721X)) = (ScontS);
    ScontS = cont_721X;
    Sbottom_of_stackS = (ScontS);
    merged_arg0K0 = 31;
    merged_arg0K1 = 127;
    make_template_containing_ops_return_tag = 1;
    goto make_template_containing_ops;
   make_template_containing_ops_return_1:
    v_720X = make_template_containing_ops_return_value;
    Sinterrupt_templateS = v_720X;
    return;}}
 L12957: {
  v_727X = Sopen_vm_portsS;
  length_728X = Snumber_of_portsS;
  arg1K0 = 0;
  goto L13064;}
 make_template_containing_ops: {
  op1_732X = merged_arg0K0;
  op2_733X = merged_arg0K1;{
  *((long *) (ShpS)) = 578;
  ShpS = (4 + (ShpS));
  new_729X = 3 + (ShpS);
  ShpS = (4 + (ShpS));
  *((long *) (-4 + (ShpS))) = 0;
  *((long *) (ShpS)) = 2090;
  ShpS = (4 + (ShpS));
  new_730X = 3 + (ShpS);
  ShpS = (8 + (ShpS));
  *((long *) (-4 + (ShpS))) = 0;
  *((long *) (-3 + new_730X)) = new_729X;
  *((unsigned char *) (-3 + new_729X)) = ((unsigned char)((long)op1_732X));
  *((unsigned char *) (-2 + new_729X)) = ((unsigned char)((long)op2_733X));
  make_template_containing_ops_return_value = new_730X;
  goto make_template_containing_ops_return;}
 make_template_containing_ops_return:
  switch (make_template_containing_ops_return_tag) {
  case 0: goto make_template_containing_ops_return_0;
  case 1: goto make_template_containing_ops_return_1;
  }}
}

long required_init_space(unsigned char **startup_vector_734X, long startup_vector_length_735X)
{
  long arg1K1;
  long arg1K0;
  long i_736X;
  long s_737X;

 {arg1K0 = 0;
  arg1K1 = 0;
  goto L5373;}
 L5373: {
  i_736X = arg1K0;
  s_737X = arg1K1;
  if ((i_736X < startup_vector_length_735X)) {
    arg1K0 = (1 + i_736X);
    arg1K1 = (1 + (s_737X + ((((4 + (strlen((*(startup_vector_734X + i_736X))))))>>2))));
    goto L5373;}
  else {
    return((22 + s_737X));}}}

void note_interruptB(unsigned char interrupt_738X)
{
  extern long Spending_interruptsS;
  long x_739X;

 {PS_SHIFT_LEFT(1, ((long)interrupt_738X), x_739X)
  Spending_interruptsS = ((Spending_interruptsS) | x_739X);
  return;}}

void do_gc()
{
  extern long Sweak_pointer_hpS;
  extern long Sweak_pointer_limitS;
  extern long SlimitS;
  extern long ShpS;
  extern long Soldspace_beginS;
  extern long Soldspace_endS;
  extern long copy_weak_pointer(long);
  extern long Snewspace_beginS;
  long arg1K1;
  long arg1K0;
  long RShpS = ShpS;
  long value_740X;
  long scan_741X;
  long value_742X;
  long a_743X;
  long h_744X;
  long start_745X;
  long end_746X;
  long next_747X;
  long value_748X;
  long o_749X;
  long new_750X;
  long x1_751X;
  long v_752X;
  long descriptor_753X;
  long a_754X;
  long h_755X;
  long a_756X;
  long end_757X;
  long x1_758X;
  long addr_759X;
  long next_760X;
  long thing_761X;
  long start_762X;
  long end_763X;

 {arg1K0 = (Snewspace_beginS);
  goto L13830;}
 L7761: {
  arg1K0 = (8 + scan_741X);
  goto L7716;}
 L7756: {
  value_740X = arg1K0;
  *((long *) (4 + scan_741X)) = value_740X;
  goto L7761;}
 L7716: {
  scan_741X = arg1K0;
  if ((scan_741X < end_746X)) {
    *((long *) scan_741X) = 1070;
    value_742X = *((long *) (4 + scan_741X));
    if ((3 == (3 & value_742X))) {
      a_743X = -3 + value_742X;
      if ((a_743X < (Soldspace_beginS))) {
        goto L7761;}
      else {
        if ((a_743X < (Soldspace_endS))) {
          if ((3 == (3 & value_742X))) {
            h_744X = *((long *) (-7 + value_742X));
            if ((3 == (3 & h_744X))) {
              arg1K0 = h_744X;
              goto L7756;}
            else {
              arg1K0 = 1;
              goto L7756;}}
          else {
            goto L7761;}}
        else {
          goto L7761;}}}
    else {
      goto L7761;}}
  else {
    if ((-1 == next_747X)) {
      if ((end_757X < (Sweak_pointer_limitS))) {
        *((long *) end_757X) = (66 + ((((-4 & (-4 + ((Sweak_pointer_limitS) - end_757X))))<<8)));
        ShpS = RShpS;
        return;}
      else {
        ShpS = RShpS;
        return;}}
    else {
      arg1K0 = (-1024 + next_747X);
      arg1K1 = next_747X;
      goto L11112;}}}
 L11112: {
  start_745X = arg1K0;
  end_746X = arg1K1;
  next_747X = *((long *) (8 + start_745X));
  arg1K0 = start_745X;
  goto L7716;}
 L31642: {
  value_748X = arg1K0;
  *((long *) addr_759X) = value_748X;
  arg1K0 = next_760X;
  goto L13896;}
 L31695: {
  o_749X = arg1K0;
  if (((RShpS) < (x1_751X + (-4 & (3 + ((long)(((unsigned long)h_755X)>>8))))))) {
    *((long *) (RShpS)) = (*((long *) o_749X));
    RShpS = (4 + (RShpS));
    arg1K0 = (4 + o_749X);
    goto L31695;}
  else {
    arg1K0 = new_750X;
    goto L31642;}}
 L31679: {
  *((long *) (RShpS)) = h_755X;
  RShpS = (4 + (RShpS));
  new_750X = 3 + (RShpS);
  *((long *) (-7 + thing_761X)) = new_750X;
  x1_751X = RShpS;
  arg1K0 = (-3 + thing_761X);
  goto L31695;}
 L31634: {
  if ((3 == (3 & thing_761X))) {
    a_754X = -3 + thing_761X;
    if ((a_754X < (Soldspace_beginS))) {
      arg1K0 = next_760X;
      goto L13896;}
    else {
      if ((a_754X < (Soldspace_endS))) {
        h_755X = *((long *) (-7 + thing_761X));
        if ((3 == (3 & h_755X))) {
          arg1K0 = h_755X;
          goto L31642;}
        else {
          if ((1070 == h_755X)) {
            descriptor_753X = *((long *) (-3 + thing_761X));
            if ((3 == (3 & descriptor_753X))) {
              a_756X = -3 + descriptor_753X;
              if ((a_756X < (Soldspace_beginS))) {
                goto L31679;}
              else {
                if ((a_756X < (Soldspace_endS))) {
                  ShpS = RShpS;
                  v_752X = copy_weak_pointer(thing_761X);
                  RShpS = ShpS;
                  arg1K0 = v_752X;
                  goto L31642;}
                else {
                  goto L31679;}}}
            else {
              goto L31679;}}
          else {
            goto L31679;}}}
      else {
        arg1K0 = next_760X;
        goto L13896;}}}
  else {
    arg1K0 = next_760X;
    goto L13896;}}
 L13856: {
  if ((-1 == (Sweak_pointer_hpS))) {
    ShpS = RShpS;
    return;}
  else {
    x1_758X = Sweak_pointer_limitS;
    end_757X = Sweak_pointer_hpS;
    arg1K0 = (-1024 + x1_758X);
    arg1K1 = end_757X;
    goto L11112;}}
 L13896: {
  addr_759X = arg1K0;
  if ((addr_759X < end_763X)) {
    next_760X = 4 + addr_759X;
    thing_761X = *((long *) addr_759X);
    if ((2 == (3 & thing_761X))) {
      if (((31 & (((thing_761X)>>2))) < 15)) {
        goto L31634;}
      else {
        arg1K0 = (next_760X + (-4 & (3 + ((long)(((unsigned long)thing_761X)>>8)))));
        goto L13896;}}
    else {
      goto L31634;}}
  else {
    if (((RShpS) < (SlimitS))) {
      if ((end_763X < (RShpS))) {
        arg1K0 = end_763X;
        goto L13830;}
      else {
        goto L13856;}}
    else {
      TTerror("GC error: ran out of space in new heap", 0, 0, 0, 0);
      goto L13856;}}}
 L13830: {
  start_762X = arg1K0;
  end_763X = RShpS;
  arg1K0 = start_762X;
  goto L13896;}}

long read_image(unsigned char *filename_764X, long startup_space_765X)
{
  extern long read_number(FILE *);
  extern long Snewspace_endS;
  extern FILE * Scurrent_output_portS;
  extern long ShpS;
  long arg1K0;
  unsigned char arg3K0;
  FILE * port_766X;
  unsigned char reverseP_767X;
  long v_768X;
  long ptr_769X;
  long value_770X;
  unsigned char x_771X;
  unsigned char x_772X;
  long d_773X;
  long v_774X;
  long ptr_775X;
  long descriptor_776X;
  long result_777X;
  long old_level_778X;
  long old_bytes_per_cell_779X;
  long cells_780X;
  long old_begin_781X;
  long cells_782X;
  long old_hp_783X;
  long startup_proc_784X;
  unsigned char Kchar_785X;
  unsigned char Kchar_786X;
  long addr_787X;
  unsigned char x_788X;
  unsigned char x_789X;
  long start_790X;
  long new_limit_791X;
  long new_hp_792X;
  long delta_793X;

 {port_766X = ps_open(filename_764X, "r");
  if ((NULL == port_766X)) {
    TTerror("Can't open heap image file", 0, 0, 0, 0);
    goto L10206;}
  else {
    goto L10206;}}
 L10266: {
  reverseP_767X = arg3K0;
  fread((void *)(ShpS), sizeof(char), (old_hp_783X - old_begin_781X), port_766X);
  if (reverseP_767X) {
    fputs("Correcting byte order of resumed image.", (Scurrent_output_portS));
    putc(10, (Scurrent_output_portS));
    arg1K0 = start_790X;
    goto L8611;}
  else {
    goto L10276;}}
 L8637: {
  v_768X = arg1K0;
  arg1K0 = v_768X;
  goto L8611;}
 L8611: {
  ptr_769X = arg1K0;
  x_772X = *((unsigned char *) ptr_769X);
  *((unsigned char *) ptr_769X) = ((unsigned char)((long)(*((unsigned char *) (3 + ptr_769X)))));
  *((unsigned char *) (3 + ptr_769X)) = ((unsigned char)((long)x_772X));
  x_771X = *((unsigned char *) (1 + ptr_769X));
  *((unsigned char *) (1 + ptr_769X)) = ((unsigned char)((long)(*((unsigned char *) (2 + ptr_769X)))));
  *((unsigned char *) (2 + ptr_769X)) = ((unsigned char)((long)x_771X));
  value_770X = *((long *) ptr_769X);
  if ((ptr_769X < new_hp_792X)) {
    if ((2 == (3 & value_770X))) {
      if (((31 & (((value_770X)>>2))) < 15)) {
        arg1K0 = (4 + ptr_769X);
        goto L8637;}
      else {
        arg1K0 = ((4 + ptr_769X) + (-4 & (3 + ((long)(((unsigned long)value_770X)>>8)))));
        goto L8637;}}
    else {
      arg1K0 = (4 + ptr_769X);
      goto L8637;}}
  else {
    goto L10276;}}
 L8736: {
  d_773X = arg1K0;
  *((long *) ptr_775X) = d_773X;
  if ((2 == (3 & d_773X))) {
    if (((31 & (((d_773X)>>2))) < 15)) {
      arg1K0 = (4 + ptr_775X);
      goto L8754;}
    else {
      arg1K0 = ((4 + ptr_775X) + (-4 & (3 + ((long)(((unsigned long)d_773X)>>8)))));
      goto L8754;}}
  else {
    arg1K0 = (4 + ptr_775X);
    goto L8754;}}
 L8754: {
  v_774X = arg1K0;
  arg1K0 = v_774X;
  goto L8726;}
 L8726: {
  ptr_775X = arg1K0;
  if ((ptr_775X < new_hp_792X)) {
    descriptor_776X = *((long *) ptr_775X);
    if ((3 == (3 & descriptor_776X))) {
      arg1K0 = (3 + ((-3 + descriptor_776X) + delta_793X));
      goto L8736;}
    else {
      arg1K0 = descriptor_776X;
      goto L8736;}}
  else {
    goto L10286;}}
 L10456: {
  result_777X = arg1K0;
  fclose(port_766X);
  return(result_777X);}
 L10208: {
  old_level_778X = read_number(port_766X);
  old_bytes_per_cell_779X = read_number(port_766X);
  cells_780X = read_number(port_766X);
  old_begin_781X = ((cells_780X)<<2);
  cells_782X = read_number(port_766X);
  old_hp_783X = ((cells_782X)<<2);
  startup_proc_784X = read_number(port_766X);
  goto L10407;}
 L10432: {
  { int TTchar;
    PS_GETC(port_766X, TTchar);
    if (EOF == TTchar) {
      TTerror("end of file while looking for page break", 0, 0, 0, 0);
      goto L10208;}
    else {
      unsigned char Kchar_785X = TTchar;
      if ((12 == ((long)Kchar_785X))) {
        goto L10208;}
      else {
        goto L10432;}}}}
 L10229: {
  if ((15 == old_level_778X)) {
    goto L10239;}
  else {
    TTerror("format of image is incompatible with this version of system", 2, old_level_778X, 15, 0);
    goto L10239;}}
 L10407: {
  { int TTchar;
    PS_GETC(port_766X, TTchar);
    if (EOF == TTchar) {
      TTerror("end of file while looking for page break", 0, 0, 0, 0);
      goto L10229;}
    else {
      unsigned char Kchar_786X = TTchar;
      if ((12 == ((long)Kchar_786X))) {
        goto L10229;}
      else {
        goto L10407;}}}}
 L10286: {
  ShpS = new_hp_792X;
  if ((3 == (3 & startup_proc_784X))) {
    arg1K0 = (3 + ((-3 + startup_proc_784X) + delta_793X));
    goto L10456;}
  else {
    arg1K0 = startup_proc_784X;
    goto L10456;}}
 L10276: {
  if ((0 == delta_793X)) {
    goto L10286;}
  else {
    arg1K0 = start_790X;
    goto L8726;}}
 L10263: {
  fread((void *)(ShpS), sizeof(char), 4, port_766X);
  if ((1 == (*((long *) (ShpS))))) {
    arg3K0 = 0;
    goto L10266;}
  else {
    addr_787X = ShpS;
    x_788X = *((unsigned char *) addr_787X);
    *((unsigned char *) addr_787X) = ((unsigned char)((long)(*((unsigned char *) (3 + addr_787X)))));
    *((unsigned char *) (3 + addr_787X)) = ((unsigned char)((long)x_788X));
    x_789X = *((unsigned char *) (1 + addr_787X));
    *((unsigned char *) (1 + addr_787X)) = ((unsigned char)((long)(*((unsigned char *) (2 + addr_787X)))));
    *((unsigned char *) (2 + addr_787X)) = ((unsigned char)((long)x_789X));
    if ((1 == (*((long *) (ShpS))))) {
      arg3K0 = 1;
      goto L10266;}
    else {
      TTerror("unable to correct byte order", 1, (*((long *) (ShpS))), 0, 0);
      arg3K0 = 0;
      goto L10266;}}}
 L10249: {
  delta_793X = (ShpS) - old_begin_781X;
  new_hp_792X = old_hp_783X + delta_793X;
  new_limit_791X = Snewspace_endS;
  start_790X = ShpS;
  if (((startup_space_765X + new_hp_792X) < new_limit_791X)) {
    goto L10263;}
  else {
    TTerror("heap not big enough to restore this image", 2, new_hp_792X, new_limit_791X, 0);
    goto L10263;}}
 L10239: {
  if ((4 == old_bytes_per_cell_779X)) {
    goto L10249;}
  else {
    TTerror("incompatible bytes-per-cell", 2, old_bytes_per_cell_779X, 4, 0);
    goto L10249;}}
 L10206: {
  goto L10432;}}

long check_image_header(unsigned char *filename_794X)
{
  extern long read_number(FILE *);
  extern FILE * Scurrent_output_portS;
  long arg1K0;
  FILE * port_795X;
  FILE * out_796X;
  long result_797X;
  FILE * out_798X;
  long old_level_799X;
  long old_bytes_per_cell_800X;
  long cells_801X;
  long cells_802X;
  FILE * out_803X;
  unsigned char Kchar_804X;

 {port_795X = ps_open(filename_794X, "r");
  if ((NULL == port_795X)) {
    out_796X = Scurrent_output_portS;
    fputs("Can't open heap image file", out_796X);
    putc(10, out_796X);
    arg1K0 = -1;
    goto L6547;}
  else {
    goto L6503;}}
 L6547: {
  result_797X = arg1K0;
  fclose(port_795X);
  return(result_797X);}
 L6409: {
  old_level_799X = read_number(port_795X);
  old_bytes_per_cell_800X = read_number(port_795X);
  cells_801X = read_number(port_795X);
  cells_802X = read_number(port_795X);
  if ((15 == old_level_799X)) {
    if ((4 == old_bytes_per_cell_800X)) {
      arg1K0 = ((((cells_802X)<<2)) - (((cells_801X)<<2)));
      goto L6547;}
    else {
      out_798X = Scurrent_output_portS;
      fputs("incompatible bytes-per-cell in image", out_798X);
      putc(10, out_798X);
      arg1K0 = -1;
      goto L6547;}}
  else {
    out_803X = Scurrent_output_portS;
    fputs("format of image is incompatible with this version of system", out_803X);
    putc(10, out_803X);
    arg1K0 = -1;
    goto L6547;}}
 L6503: {
  { int TTchar;
    PS_GETC(port_795X, TTchar);
    if (EOF == TTchar) {
      TTerror("end of file while looking for page break", 0, 0, 0, 0);
      goto L6409;}
    else {
      unsigned char Kchar_804X = TTchar;
      if ((12 == ((long)Kchar_804X))) {
        goto L6409;}
      else {
        goto L6503;}}}}}

void register_static_areas(unsigned char pure_count_805X, long *pure_areas_806X, long *pure_sizes_807X, unsigned char impure_count_808X, long *impure_areas_809X, long *impure_sizes_810X)
{
  extern unsigned char Spure_area_countS;
  extern long *Spure_areasS;
  extern long *Spure_sizesS;
  extern unsigned char Simpure_area_countS;
  extern long *Simpure_areasS;
  extern long *Simpure_sizesS;

 {Spure_area_countS = pure_count_805X;
  Spure_areasS = pure_areas_806X;
  Spure_sizesS = pure_sizes_807X;
  Simpure_area_countS = impure_count_808X;
  Simpure_areasS = impure_areas_809X;
  Simpure_sizesS = impure_sizes_810X;
  return;}}
scheme48_init()
{
Sminimum_recovered_spaceS = 0;
Sexception_space_usedPS = 1;
Snumber_of_portsS = 100;
Sweak_pointer_limitS = 0;
Sweak_pointer_hpS = -1;
Ssaved_limitS = 0;
Ssaved_hpS = 0;
Sgc_countS = 0;
Simpure_area_countS = 0;
Spure_area_countS = 0;
SlimitS = 0;
ShpS = 0;
Scurrent_output_portS = stdout;
Scurrent_input_portS = stdin;
}