X-Git-Url: http://nitlanguage.org diff --git a/c_src/compiling._sep.c b/c_src/compiling._sep.c index a2988ac..aab5b33 100644 --- a/c_src/compiling._sep.c +++ b/c_src/compiling._sep.c @@ -1,746 +1,275 @@ /* This C file is generated by NIT to compile module compiling. */ #include "compiling._sep.h" -void compiling___Program___generate_classes_init_to_icode(val_t p0){ +val_t compiling___Program___output_format(val_t p0){ + struct {struct stack_frame_t me;} fra; + val_t REGB0; + val_t tmp; + fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; + fra.me.file = LOCATE_compiling; + fra.me.line = 28; + fra.me.meth = LOCATE_compiling___Program___output_format; + fra.me.has_broke = 0; + fra.me.REG_size = 1; + fra.me.nitni_local_ref_head = NULL; + fra.me.REG[0] = NIT_NULL; + fra.me.REG[0] = p0; + /* compiling/compiling.nit:28 */ + REGB0 = TAG_Bool(ATTR_compiling___Program____output_format(fra.me.REG[0])!=NIT_NULL); + if (UNTAG_Bool(REGB0)) { + } else { + nit_abort("Uninitialized attribute %s", "_output_format", LOCATE_compiling, 28); + } + fra.me.REG[0] = ATTR_compiling___Program____output_format(fra.me.REG[0]); + stack_frame_head = fra.me.prev; + return fra.me.REG[0]; +} +void compiling___Program___output_format__eq(val_t p0, val_t p1){ + struct {struct stack_frame_t me; val_t MORE_REG[1];} fra; + val_t tmp; + fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; + fra.me.file = LOCATE_compiling; + fra.me.line = 28; + fra.me.meth = LOCATE_compiling___Program___output_format__eq; + fra.me.has_broke = 0; + fra.me.REG_size = 2; + fra.me.nitni_local_ref_head = NULL; + fra.me.REG[0] = NIT_NULL; + fra.me.REG[1] = NIT_NULL; + fra.me.REG[0] = p0; + fra.me.REG[1] = p1; + /* compiling/compiling.nit:28 */ + ATTR_compiling___Program____output_format(fra.me.REG[0]) = fra.me.REG[1]; + stack_frame_head = fra.me.prev; + return; +} +void compiling___Program___compile_prog(val_t p0){ struct {struct stack_frame_t me; val_t MORE_REG[2];} fra; val_t REGB0; + val_t REGB1; val_t tmp; + static val_t once_value_1; /* Once value */ + static val_t once_value_3; /* Once value */ + static val_t once_value_4; /* Once value */ fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; fra.me.file = LOCATE_compiling; - fra.me.line = 26; - fra.me.meth = LOCATE_compiling___Program___generate_classes_init_to_icode; + fra.me.line = 31; + fra.me.meth = LOCATE_compiling___Program___compile_prog; fra.me.has_broke = 0; fra.me.REG_size = 3; + fra.me.nitni_local_ref_head = NULL; fra.me.REG[0] = NIT_NULL; fra.me.REG[1] = NIT_NULL; fra.me.REG[2] = NIT_NULL; fra.me.REG[0] = p0; - fra.me.REG[1] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[1] = CALL_abstractmetamodel___MMModule___local_classes(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[1] = CALL_abstract_collection___Collection___iterator(fra.me.REG[1])(fra.me.REG[1]); - /* ./compiling//compiling.nit:29 */ - while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[1])(fra.me.REG[1]); + /* compiling/compiling.nit:34 */ + fra.me.REG[1] = CALL_compiling___Program___output_format(fra.me.REG[0])(fra.me.REG[0]); + if (!once_value_1) { + fra.me.REG[2] = BOX_NativeString("none"); + REGB0 = TAG_Int(4); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_1 = fra.me.REG[2]; + register_static_object(&once_value_1); + } else fra.me.REG[2] = once_value_1; + fra.me.REG[2] = fra.me.REG[2]; + REGB0 = TAG_Bool(IS_EQUAL_OO(fra.me.REG[1],fra.me.REG[2])); + if (UNTAG_Bool(REGB0)) { + } else { + REGB1 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]); + REGB0 = REGB1; + } + if (UNTAG_Bool(REGB0)) { + } else { + CALL_program___Program___with_each_iroutines(fra.me.REG[0])(fra.me.REG[0], (&(fra.me)), ((fun_t)OC_compiling___Program___compile_prog_2)); + /* compiling/compiling.nit:40 */ + fra.me.REG[2] = CALL_compiling___Program___output_format(fra.me.REG[0])(fra.me.REG[0]); + if (!once_value_3) { + fra.me.REG[1] = BOX_NativeString("C"); + REGB0 = TAG_Int(1); + fra.me.REG[1] = NEW_String_standard___string___String___with_native(fra.me.REG[1], REGB0); + once_value_3 = fra.me.REG[1]; + register_static_object(&once_value_3); + } else fra.me.REG[1] = once_value_3; + fra.me.REG[1] = fra.me.REG[1]; + REGB0 = TAG_Bool(IS_EQUAL_OO(fra.me.REG[2],fra.me.REG[1])); if (UNTAG_Bool(REGB0)) { - fra.me.REG[2] = CALL_abstract_collection___Iterator___item(fra.me.REG[1])(fra.me.REG[1]); - /* ./compiling//compiling.nit:30 */ - CALL_compiling_global___MMLocalClass___generate_allocation_iroutines(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[0]); } else { - /* ./compiling//compiling.nit:29 */ - goto label1; + REGB1 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]); + REGB0 = REGB1; + } + if (UNTAG_Bool(REGB0)) { + /* compiling/compiling.nit:41 */ + CALL_compiling___Program___compile_prog_to_c(fra.me.REG[0])(fra.me.REG[0]); + } else { + /* compiling/compiling.nit:42 */ + fra.me.REG[1] = CALL_compiling___Program___output_format(fra.me.REG[0])(fra.me.REG[0]); + if (!once_value_4) { + fra.me.REG[2] = BOX_NativeString("icode"); + REGB0 = TAG_Int(5); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_4 = fra.me.REG[2]; + register_static_object(&once_value_4); + } else fra.me.REG[2] = once_value_4; + fra.me.REG[2] = fra.me.REG[2]; + REGB0 = TAG_Bool(IS_EQUAL_OO(fra.me.REG[1],fra.me.REG[2])); + if (UNTAG_Bool(REGB0)) { + } else { + REGB1 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]); + REGB0 = REGB1; + } + if (UNTAG_Bool(REGB0)) { + /* compiling/compiling.nit:43 */ + CALL_compiling___icode_generator___Program___generate_icode_files(fra.me.REG[0])(fra.me.REG[0]); + } } - CALL_abstract_collection___Iterator___next(fra.me.REG[1])(fra.me.REG[1]); } - label1: while(0); stack_frame_head = fra.me.prev; return; } -void compiling___Program___compile_prog_to_c(val_t p0, val_t p1){ - struct {struct stack_frame_t me; val_t MORE_REG[8];} fra; + void OC_compiling___Program___compile_prog_2(struct stack_frame_t *closctx, val_t p0, val_t p1){ + struct {struct stack_frame_t me; val_t MORE_REG[1];} fra; + val_t tmp; + /* compiling/compiling.nit:38 */ + fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; + fra.me.file = LOCATE_compiling; + fra.me.line = 38; + fra.me.meth = LOCATE_compiling___Program___compile_prog; + fra.me.has_broke = 0; + fra.me.REG_size = 2; + fra.me.nitni_local_ref_head = NULL; + fra.me.REG[0] = NIT_NULL; + fra.me.REG[1] = NIT_NULL; + fra.me.REG[0] = p0; + fra.me.REG[1] = p1; + CALL_analysis___IRoutine___optimize(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]); + stack_frame_head = fra.me.prev; + return; + } +void compiling___Program___compile_prog_to_c(val_t p0){ + struct {struct stack_frame_t me; val_t MORE_REG[3];} fra; val_t REGB0; - val_t REGB1; val_t tmp; static val_t once_value_1; /* Once value */ static val_t once_value_2; /* Once value */ static val_t once_value_3; /* Once value */ static val_t once_value_4; /* Once value */ - static val_t once_value_5; /* Once value */ - static val_t once_value_6; /* Once value */ - static val_t once_value_7; /* Once value */ - static val_t once_value_8; /* Once value */ - static val_t once_value_9; /* Once value */ - static val_t once_value_10; /* Once value */ - static val_t once_value_11; /* Once value */ - static val_t once_value_12; /* Once value */ - static val_t once_value_13; /* Once value */ - static val_t once_value_14; /* Once value */ - static val_t once_value_16; /* Once value */ - static val_t once_value_17; /* Once value */ - static val_t once_value_18; /* Once value */ - static val_t once_value_19; /* Once value */ - static val_t once_value_20; /* Once value */ - static val_t once_value_21; /* Once value */ - static val_t once_value_22; /* Once value */ - static val_t once_value_23; /* Once value */ - static val_t once_value_24; /* Once value */ - static val_t once_value_25; /* Once value */ - static val_t once_value_27; /* Once value */ - static val_t once_value_28; /* Once value */ - static val_t once_value_29; /* Once value */ - static val_t once_value_30; /* Once value */ - static val_t once_value_31; /* Once value */ - static val_t once_value_32; /* Once value */ - static val_t once_value_33; /* Once value */ - static val_t once_value_34; /* Once value */ - static val_t once_value_35; /* Once value */ - static val_t once_value_36; /* Once value */ - static val_t once_value_37; /* Once value */ - static val_t once_value_38; /* Once value */ - static val_t once_value_39; /* Once value */ - static val_t once_value_40; /* Once value */ - static val_t once_value_41; /* Once value */ - static val_t once_value_42; /* Once value */ - static val_t once_value_43; /* Once value */ - static val_t once_value_44; /* Once value */ - static val_t once_value_45; /* Once value */ - static val_t once_value_46; /* Once value */ - static val_t once_value_47; /* Once value */ - static val_t once_value_48; /* Once value */ - static val_t once_value_49; /* Once value */ - static val_t once_value_50; /* Once value */ - static val_t once_value_51; /* Once value */ + static val_t once_value_6; /* Once value */ fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; fra.me.file = LOCATE_compiling; - fra.me.line = 34; + fra.me.line = 48; fra.me.meth = LOCATE_compiling___Program___compile_prog_to_c; fra.me.has_broke = 0; - fra.me.REG_size = 9; + fra.me.REG_size = 4; + fra.me.nitni_local_ref_head = NULL; fra.me.REG[0] = NIT_NULL; fra.me.REG[1] = NIT_NULL; fra.me.REG[2] = NIT_NULL; fra.me.REG[3] = NIT_NULL; - fra.me.REG[4] = NIT_NULL; - fra.me.REG[5] = NIT_NULL; - fra.me.REG[6] = NIT_NULL; - fra.me.REG[7] = NIT_NULL; - fra.me.REG[8] = NIT_NULL; fra.me.REG[0] = p0; - fra.me.REG[1] = p1; - fra.me.REG[2] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - REGB0 = TAG_Bool(fra.me.REG[2]==NIT_NULL); - /* ./compiling//compiling.nit:39 */ - if (UNTAG_Bool(REGB0)) { - fprintf(stderr, "Reciever is null"); - fprintf(stderr, " (%s:%d)\n", LOCATE_compiling, 39); - nit_exit(1); - } - CALL_file___String___mkdir(fra.me.REG[2])(fra.me.REG[2]); - fra.me.REG[2] = NEW_Array_array___Array___init(); - fra.me.REG[3] = NEW_ArraySet_array___ArraySet___init(); - /* ./compiling//compiling.nit:43 */ + /* compiling/compiling.nit:53 */ + fra.me.REG[1] = NEW_CProgram_compiling___compiling_base___CProgram___init(fra.me.REG[0]); + /* compiling/compiling.nit:55 */ + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___compdir(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___file___String___mkdir(fra.me.REG[2])(fra.me.REG[2]); + /* compiling/compiling.nit:57 */ + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); if (!once_value_1) { - fra.me.REG[4] = BOX_NativeString("$CLIBDIR/nit_main.c"); + fra.me.REG[3] = BOX_NativeString("$CLIBDIR/nit_main.c"); REGB0 = TAG_Int(19); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_1 = fra.me.REG[4]; + fra.me.REG[3] = NEW_String_standard___string___String___with_native(fra.me.REG[3], REGB0); + once_value_1 = fra.me.REG[3]; register_static_object(&once_value_1); - } else fra.me.REG[4] = once_value_1; - array___Array___add(fra.me.REG[2], fra.me.REG[4]); - /* ./compiling//compiling.nit:44 */ + } else fra.me.REG[3] = once_value_1; + fra.me.REG[3] = fra.me.REG[3]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); + /* compiling/compiling.nit:58 */ + fra.me.REG[3] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); if (!once_value_2) { - fra.me.REG[4] = BOX_NativeString("$CLIBDIR/gc.c"); + fra.me.REG[2] = BOX_NativeString("$CLIBDIR/gc.c"); REGB0 = TAG_Int(13); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_2 = fra.me.REG[4]; + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_2 = fra.me.REG[2]; register_static_object(&once_value_2); - } else fra.me.REG[4] = once_value_2; - array___Array___add(fra.me.REG[2], fra.me.REG[4]); - /* ./compiling//compiling.nit:45 */ + } else fra.me.REG[2] = once_value_2; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2]); + /* compiling/compiling.nit:59 */ + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); if (!once_value_3) { - fra.me.REG[4] = BOX_NativeString("$CLIBDIR/gc_static_objects_list.c"); + fra.me.REG[3] = BOX_NativeString("$CLIBDIR/gc_static_objects_list.c"); REGB0 = TAG_Int(33); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_3 = fra.me.REG[4]; + fra.me.REG[3] = NEW_String_standard___string___String___with_native(fra.me.REG[3], REGB0); + once_value_3 = fra.me.REG[3]; register_static_object(&once_value_3); - } else fra.me.REG[4] = once_value_3; - array___Array___add(fra.me.REG[2], fra.me.REG[4]); - /* ./compiling//compiling.nit:46 */ + } else fra.me.REG[3] = once_value_3; + fra.me.REG[3] = fra.me.REG[3]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); + /* compiling/compiling.nit:61 */ + fra.me.REG[3] = CALL_program___Program___tc(fra.me.REG[0])(fra.me.REG[0]); if (!once_value_4) { - fra.me.REG[4] = BOX_NativeString("Generating C code"); + fra.me.REG[2] = BOX_NativeString("Generating C code"); REGB0 = TAG_Int(17); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_4 = fra.me.REG[4]; + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_4 = fra.me.REG[2]; register_static_object(&once_value_4); - } else fra.me.REG[4] = once_value_4; + } else fra.me.REG[2] = once_value_4; + fra.me.REG[2] = fra.me.REG[2]; REGB0 = TAG_Int(1); - CALL_mmloader___ToolContext___info(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[4], REGB0); - fra.me.REG[4] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[4] = CALL_abstractmetamodel___MMModule___mhe(fra.me.REG[4])(fra.me.REG[4]); - REGB0 = TAG_Bool(fra.me.REG[4]==NIT_NULL); - /* ./compiling//compiling.nit:47 */ + CALL_toolcontext___ToolContext___info(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2], REGB0); + /* compiling/compiling.nit:62 */ + fra.me.REG[2] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[2] = CALL_metamodel___abstractmetamodel___MMModule___mhe(fra.me.REG[2])(fra.me.REG[2]); + REGB0 = TAG_Bool(fra.me.REG[2]==NIT_NULL); if (UNTAG_Bool(REGB0)) { - fprintf(stderr, "Reciever is null"); - fprintf(stderr, " (%s:%d)\n", LOCATE_compiling, 47); - nit_exit(1); - } - fra.me.REG[4] = CALL_partial_order___PartialOrderElement___greaters_and_self(fra.me.REG[4])(fra.me.REG[4]); - fra.me.REG[4] = CALL_abstract_collection___Collection___iterator(fra.me.REG[4])(fra.me.REG[4]); - while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[4])(fra.me.REG[4]); - if (UNTAG_Bool(REGB0)) { - fra.me.REG[5] = CALL_abstract_collection___Iterator___item(fra.me.REG[4])(fra.me.REG[4]); - REGB0 = TAG_Int(5); - fra.me.REG[6] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:48 */ - if (!once_value_5) { - fra.me.REG[7] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_5 = fra.me.REG[7]; - register_static_object(&once_value_5); - } else fra.me.REG[7] = once_value_5; - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - fra.me.REG[7] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - if (!once_value_6) { - fra.me.REG[7] = BOX_NativeString("/"); - REGB0 = TAG_Int(1); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_6 = fra.me.REG[7]; - register_static_object(&once_value_6); - } else fra.me.REG[7] = once_value_6; - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - fra.me.REG[7] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - if (!once_value_7) { - fra.me.REG[7] = BOX_NativeString("._sep.c"); - REGB0 = TAG_Int(7); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_7 = fra.me.REG[7]; - register_static_object(&once_value_7); - } else fra.me.REG[7] = once_value_7; - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[2], fra.me.REG[6]); - REGB0 = TAG_Int(3); - fra.me.REG[6] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:49 */ - if (!once_value_8) { - fra.me.REG[7] = BOX_NativeString("Generating C code for module: "); - REGB0 = TAG_Int(30); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_8 = fra.me.REG[7]; - register_static_object(&once_value_8); - } else fra.me.REG[7] = once_value_8; - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - fra.me.REG[7] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - if (!once_value_9) { - fra.me.REG[7] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_9 = fra.me.REG[7]; - register_static_object(&once_value_9); - } else fra.me.REG[7] = once_value_9; - array___Array___add(fra.me.REG[6], fra.me.REG[7]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - REGB0 = TAG_Int(2); - CALL_mmloader___ToolContext___info(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[6], REGB0); - /* ./compiling//compiling.nit:50 */ - CALL_compiling___MMModule___compile_separate_module(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[1], fra.me.REG[0]); - fra.me.REG[5] = CALL_abstractmetamodel___MMModule___location(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[5] = CALL_location___Location___file(fra.me.REG[5])(fra.me.REG[5]); - /* ./compiling//compiling.nit:51 */ - if (!once_value_10) { - fra.me.REG[6] = BOX_NativeString(".nit"); - REGB0 = TAG_Int(4); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_10 = fra.me.REG[6]; - register_static_object(&once_value_10); - } else fra.me.REG[6] = once_value_10; - fra.me.REG[6] = CALL_file___String___strip_extension(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[6]); - /* ./compiling//compiling.nit:52 */ - if (!once_value_11) { - fra.me.REG[5] = BOX_NativeString("_nit.h"); - REGB0 = TAG_Int(6); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_11 = fra.me.REG[5]; - register_static_object(&once_value_11); - } else fra.me.REG[5] = once_value_11; - fra.me.REG[5] = CALL_string___String_____plus(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[5]); - REGB0 = CALL_file___String___file_exists(fra.me.REG[5])(fra.me.REG[5]); - if (UNTAG_Bool(REGB0)) { - REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:53 */ - if (!once_value_12) { - fra.me.REG[7] = BOX_NativeString("-I "); - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_12 = fra.me.REG[7]; - register_static_object(&once_value_12); - } else fra.me.REG[7] = once_value_12; - array___Array___add(fra.me.REG[5], fra.me.REG[7]); - fra.me.REG[7] = CALL_file___String___dirname(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[5], fra.me.REG[7]); - if (!once_value_13) { - fra.me.REG[7] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_13 = fra.me.REG[7]; - register_static_object(&once_value_13); - } else fra.me.REG[7] = once_value_13; - array___Array___add(fra.me.REG[5], fra.me.REG[7]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - CALL_abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - } - /* ./compiling//compiling.nit:55 */ - if (!once_value_14) { - fra.me.REG[5] = BOX_NativeString("_nit.c"); - REGB0 = TAG_Int(6); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_14 = fra.me.REG[5]; - register_static_object(&once_value_14); - } else fra.me.REG[5] = once_value_14; - fra.me.REG[5] = CALL_string___String_____plus(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[5]); - fra.me.REG[6] = fra.me.REG[5]; - REGB0 = CALL_file___String___file_exists(fra.me.REG[6])(fra.me.REG[6]); - /* ./compiling//compiling.nit:56 */ - if (UNTAG_Bool(REGB0)) { - array___Array___add(fra.me.REG[2], fra.me.REG[6]); - } - } else { - /* ./compiling//compiling.nit:47 */ - goto label15; - } - CALL_abstract_collection___Iterator___next(fra.me.REG[4])(fra.me.REG[4]); + nit_abort("Reciever is null", NULL, LOCATE_compiling, 62); } - label15: while(0); - /* ./compiling//compiling.nit:59 */ - if (!once_value_16) { - fra.me.REG[4] = BOX_NativeString("Generating main, tables and makefile ..."); + fra.me.REG[2] = CALL_metamodel___partial_order___PartialOrderElement___greaters_and_self(fra.me.REG[2])(fra.me.REG[2]); + CALL_standard___collection___abstract_collection___Collection___iterate(fra.me.REG[2])(fra.me.REG[2], (&(fra.me)), ((fun_t)OC_compiling___Program___compile_prog_to_c_5)); + /* compiling/compiling.nit:64 */ + fra.me.REG[2] = CALL_program___Program___tc(fra.me.REG[0])(fra.me.REG[0]); + if (!once_value_6) { + fra.me.REG[3] = BOX_NativeString("Generating main, tables and makefile ..."); REGB0 = TAG_Int(40); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_16 = fra.me.REG[4]; - register_static_object(&once_value_16); - } else fra.me.REG[4] = once_value_16; + fra.me.REG[3] = NEW_String_standard___string___String___with_native(fra.me.REG[3], REGB0); + once_value_6 = fra.me.REG[3]; + register_static_object(&once_value_6); + } else fra.me.REG[3] = once_value_6; + fra.me.REG[3] = fra.me.REG[3]; REGB0 = TAG_Int(1); - CALL_mmloader___ToolContext___info(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[4], REGB0); - REGB0 = TAG_Int(5); - fra.me.REG[4] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:60 */ - if (!once_value_17) { - fra.me.REG[6] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_17 = fra.me.REG[6]; - register_static_object(&once_value_17); - } else fra.me.REG[6] = once_value_17; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[6] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - if (!once_value_18) { - fra.me.REG[6] = BOX_NativeString("/"); - REGB0 = TAG_Int(1); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_18 = fra.me.REG[6]; - register_static_object(&once_value_18); - } else fra.me.REG[6] = once_value_18; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[6] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[6] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[6])(fra.me.REG[6]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - if (!once_value_19) { - fra.me.REG[6] = BOX_NativeString("._tables.c"); - REGB0 = TAG_Int(10); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_19 = fra.me.REG[6]; - register_static_object(&once_value_19); - } else fra.me.REG[6] = once_value_19; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[4] = CALL_string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); - array___Array___add(fra.me.REG[2], fra.me.REG[4]); - /* ./compiling//compiling.nit:61 */ + CALL_toolcontext___ToolContext___info(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3], REGB0); + /* compiling/compiling.nit:65 */ CALL_compiling___Program___compile_main(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]); - REGB0 = TAG_Int(5); - fra.me.REG[4] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:63 */ - if (!once_value_20) { - fra.me.REG[6] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_20 = fra.me.REG[6]; - register_static_object(&once_value_20); - } else fra.me.REG[6] = once_value_20; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[6] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - if (!once_value_21) { - fra.me.REG[6] = BOX_NativeString("/"); - REGB0 = TAG_Int(1); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_21 = fra.me.REG[6]; - register_static_object(&once_value_21); - } else fra.me.REG[6] = once_value_21; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[6] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[6] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[6])(fra.me.REG[6]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - if (!once_value_22) { - fra.me.REG[6] = BOX_NativeString("._build.sh"); - REGB0 = TAG_Int(10); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_22 = fra.me.REG[6]; - register_static_object(&once_value_22); - } else fra.me.REG[6] = once_value_22; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[4] = CALL_string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); - fra.me.REG[6] = NEW_OFStream_file___OFStream___open(fra.me.REG[4]); - /* ./compiling//compiling.nit:65 */ - if (!once_value_23) { - fra.me.REG[5] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_23 = fra.me.REG[5]; - register_static_object(&once_value_23); - } else fra.me.REG[5] = once_value_23; - REGB0 = CALL_mmloader___ToolContext___verbose_level(fra.me.REG[1])(fra.me.REG[1]); - REGB1 = TAG_Int(0); - REGB1 = TAG_Bool(UNTAG_Int(REGB0)>UNTAG_Int(REGB1)); - /* ./compiling//compiling.nit:67 */ - if (UNTAG_Bool(REGB1)) { - /* ./compiling//compiling.nit:68 */ - if (!once_value_24) { - fra.me.REG[7] = BOX_NativeString("-"); - REGB1 = TAG_Int(1); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB1); - once_value_24 = fra.me.REG[7]; - register_static_object(&once_value_24); - } else fra.me.REG[7] = once_value_24; - fra.me.REG[5] = fra.me.REG[7]; - REGB1 = TAG_Int(1); - REGB0 = CALL_mmloader___ToolContext___verbose_level(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[7] = NEW_Range_range___Range___init(REGB1, REGB0); - fra.me.REG[7] = CALL_abstract_collection___Collection___iterator(fra.me.REG[7])(fra.me.REG[7]); - /* ./compiling//compiling.nit:69 */ - while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[7])(fra.me.REG[7]); - if (UNTAG_Bool(REGB0)) { - REGB0 = CALL_abstract_collection___Iterator___item(fra.me.REG[7])(fra.me.REG[7]); - if (!once_value_25) { - fra.me.REG[8] = BOX_NativeString("v"); - REGB0 = TAG_Int(1); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_25 = fra.me.REG[8]; - register_static_object(&once_value_25); - } else fra.me.REG[8] = once_value_25; - fra.me.REG[8] = CALL_string___String_____plus(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[8]); - fra.me.REG[5] = fra.me.REG[8]; - } else { - goto label26; - } - CALL_abstract_collection___Iterator___next(fra.me.REG[7])(fra.me.REG[7]); - } - label26: while(0); - } - /* ./compiling//compiling.nit:72 */ - if (!once_value_27) { - fra.me.REG[7] = BOX_NativeString("#!/bin/sh\n"); - REGB0 = TAG_Int(10); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_27 = fra.me.REG[7]; - register_static_object(&once_value_27); - } else fra.me.REG[7] = once_value_27; - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:73 */ - if (!once_value_28) { - fra.me.REG[8] = BOX_NativeString("# This shell script is generated by NIT to compile the program "); - REGB0 = TAG_Int(63); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_28 = fra.me.REG[8]; - register_static_object(&once_value_28); - } else fra.me.REG[8] = once_value_28; - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - fra.me.REG[8] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[8] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[8])(fra.me.REG[8]); - fra.me.REG[8] = CALL_string___Object___to_s(fra.me.REG[8])(fra.me.REG[8]); - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - if (!once_value_29) { - fra.me.REG[8] = BOX_NativeString(".\n"); - REGB0 = TAG_Int(2); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_29 = fra.me.REG[8]; - register_static_object(&once_value_29); - } else fra.me.REG[8] = once_value_29; - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:74 */ - if (!once_value_30) { - fra.me.REG[8] = BOX_NativeString("CLIBDIR=\""); - REGB0 = TAG_Int(9); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_30 = fra.me.REG[8]; - register_static_object(&once_value_30); - } else fra.me.REG[8] = once_value_30; - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - fra.me.REG[8] = CALL_compiling_base___ToolContext___clibdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[8] = CALL_string___Object___to_s(fra.me.REG[8])(fra.me.REG[8]); - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - if (!once_value_31) { - fra.me.REG[8] = BOX_NativeString("\"\n"); - REGB0 = TAG_Int(2); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_31 = fra.me.REG[8]; - register_static_object(&once_value_31); - } else fra.me.REG[8] = once_value_31; - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - REGB0 = TAG_Int(9); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:75 */ - if (!once_value_32) { - fra.me.REG[8] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_32 = fra.me.REG[8]; - register_static_object(&once_value_32); - } else fra.me.REG[8] = once_value_32; - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - fra.me.REG[8] = CALL_compiling_base___ToolContext___bindir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[8] = CALL_string___Object___to_s(fra.me.REG[8])(fra.me.REG[8]); - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - if (!once_value_33) { - fra.me.REG[8] = BOX_NativeString("/gccx "); - REGB0 = TAG_Int(6); - fra.me.REG[8] = NEW_String_string___String___with_native(fra.me.REG[8], REGB0); - once_value_33 = fra.me.REG[8]; - register_static_object(&once_value_33); - } else fra.me.REG[8] = once_value_33; - array___Array___add(fra.me.REG[7], fra.me.REG[8]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_34) { - fra.me.REG[5] = BOX_NativeString(" -d "); - REGB0 = TAG_Int(4); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_34 = fra.me.REG[5]; - register_static_object(&once_value_34); - } else fra.me.REG[5] = once_value_34; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[5] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_35) { - fra.me.REG[5] = BOX_NativeString(" -I $CLIBDIR "); - REGB0 = TAG_Int(13); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_35 = fra.me.REG[5]; - register_static_object(&once_value_35); - } else fra.me.REG[5] = once_value_35; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_36) { - fra.me.REG[5] = BOX_NativeString(" "); - REGB0 = TAG_Int(1); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_36 = fra.me.REG[5]; - register_static_object(&once_value_36); - } else fra.me.REG[5] = once_value_36; - fra.me.REG[5] = CALL_string___Collection___join(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_37) { - fra.me.REG[5] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_37 = fra.me.REG[5]; - register_static_object(&once_value_37); - } else fra.me.REG[5] = once_value_37; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - fra.me.REG[7] = CALL_compiling_base___ToolContext___output_file(fra.me.REG[1])(fra.me.REG[1]); - REGB0 = TAG_Bool(fra.me.REG[7]==NIT_NULL); - /* ./compiling//compiling.nit:76 */ - if (UNTAG_Bool(REGB0)) { - } else { - REGB1 = TAG_Bool(fra.me.REG[7]==NIT_NULL); - if (UNTAG_Bool(REGB1)) { - REGB1 = TAG_Bool(false); - REGB0 = REGB1; - } else { - REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[7])(fra.me.REG[7], NIT_NULL); - REGB0 = REGB1; - } - } + /* compiling/compiling.nit:67 */ + CALL_compiling___compiling_base___CProgram___generate_build_file(fra.me.REG[1])(fra.me.REG[1]); + /* compiling/compiling.nit:69 */ + fra.me.REG[0] = CALL_program___Program___tc(fra.me.REG[0])(fra.me.REG[0]); + REGB0 = CALL_compiling___compiling_base___ToolContext___no_cc(fra.me.REG[0])(fra.me.REG[0]); REGB0 = TAG_Bool(!UNTAG_Bool(REGB0)); if (UNTAG_Bool(REGB0)) { - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:77 */ - if (!once_value_38) { - fra.me.REG[5] = BOX_NativeString(" -o "); - REGB0 = TAG_Int(4); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_38 = fra.me.REG[5]; - register_static_object(&once_value_38); - } else fra.me.REG[5] = once_value_38; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[5] = CALL_compiling_base___ToolContext___output_file(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_39) { - fra.me.REG[5] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_39 = fra.me.REG[5]; - register_static_object(&once_value_39); - } else fra.me.REG[5] = once_value_39; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - } else { - fra.me.REG[7] = CALL_compiling_base___ToolContext___ext_prefix(fra.me.REG[1])(fra.me.REG[1]); - REGB0 = CALL_abstract_collection___Collection___is_empty(fra.me.REG[7])(fra.me.REG[7]); - /* ./compiling//compiling.nit:78 */ - if (UNTAG_Bool(REGB0)) { - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:79 */ - if (!once_value_40) { - fra.me.REG[5] = BOX_NativeString(" -o "); - REGB0 = TAG_Int(4); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_40 = fra.me.REG[5]; - register_static_object(&once_value_40); - } else fra.me.REG[5] = once_value_40; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[5] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[5] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_41) { - fra.me.REG[5] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_41 = fra.me.REG[5]; - register_static_object(&once_value_41); - } else fra.me.REG[5] = once_value_41; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - } else { - REGB0 = TAG_Int(5); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:81 */ - if (!once_value_42) { - fra.me.REG[5] = BOX_NativeString(" -o "); - REGB0 = TAG_Int(4); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_42 = fra.me.REG[5]; - register_static_object(&once_value_42); - } else fra.me.REG[5] = once_value_42; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[5] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[5] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_43) { - fra.me.REG[5] = BOX_NativeString("_"); - REGB0 = TAG_Int(1); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_43 = fra.me.REG[5]; - register_static_object(&once_value_43); - } else fra.me.REG[5] = once_value_43; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[5] = CALL_compiling_base___ToolContext___ext_prefix(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_44) { - fra.me.REG[5] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_44 = fra.me.REG[5]; - register_static_object(&once_value_44); - } else fra.me.REG[5] = once_value_44; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - } - } - REGB0 = CALL_compiling_base___ToolContext___boost(fra.me.REG[1])(fra.me.REG[1]); - /* ./compiling//compiling.nit:83 */ - if (UNTAG_Bool(REGB0)) { - if (!once_value_45) { - fra.me.REG[7] = BOX_NativeString(" -O"); - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_45 = fra.me.REG[7]; - register_static_object(&once_value_45); - } else fra.me.REG[7] = once_value_45; - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - } - REGB0 = TAG_Int(3); - fra.me.REG[7] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:84 */ - if (!once_value_46) { - fra.me.REG[5] = BOX_NativeString(" \"$@\" \\\n "); - REGB0 = TAG_Int(10); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_46 = fra.me.REG[5]; - register_static_object(&once_value_46); - } else fra.me.REG[5] = once_value_46; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_47) { - fra.me.REG[5] = BOX_NativeString("\\\n "); - REGB0 = TAG_Int(4); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_47 = fra.me.REG[5]; - register_static_object(&once_value_47); - } else fra.me.REG[5] = once_value_47; - fra.me.REG[5] = CALL_string___Collection___join(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[5]); - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - if (!once_value_48) { - fra.me.REG[5] = BOX_NativeString("\n"); - REGB0 = TAG_Int(1); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_48 = fra.me.REG[5]; - register_static_object(&once_value_48); - } else fra.me.REG[5] = once_value_48; - array___Array___add(fra.me.REG[7], fra.me.REG[5]); - fra.me.REG[7] = CALL_string___Object___to_s(fra.me.REG[7])(fra.me.REG[7]); - CALL_stream___OStream___write(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[7]); - /* ./compiling//compiling.nit:85 */ - CALL_stream___IOS___close(fra.me.REG[6])(fra.me.REG[6]); - REGB0 = CALL_compiling_base___ToolContext___no_cc(fra.me.REG[1])(fra.me.REG[1]); - REGB0 = TAG_Bool(!UNTAG_Bool(REGB0)); - /* ./compiling//compiling.nit:87 */ - if (UNTAG_Bool(REGB0)) { - /* ./compiling//compiling.nit:88 */ - if (!once_value_49) { - fra.me.REG[6] = BOX_NativeString("Building"); - REGB0 = TAG_Int(8); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_49 = fra.me.REG[6]; - register_static_object(&once_value_49); - } else fra.me.REG[6] = once_value_49; - REGB0 = TAG_Int(1); - CALL_mmloader___ToolContext___info(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[6], REGB0); - fra.me.REG[0] = CALL_kernel___Object___sys(fra.me.REG[0])(fra.me.REG[0]); - REGB0 = TAG_Int(3); - fra.me.REG[6] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:89 */ - if (!once_value_50) { - fra.me.REG[1] = BOX_NativeString("sh "); - REGB0 = TAG_Int(3); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_50 = fra.me.REG[1]; - register_static_object(&once_value_50); - } else fra.me.REG[1] = once_value_50; - array___Array___add(fra.me.REG[6], fra.me.REG[1]); - array___Array___add(fra.me.REG[6], fra.me.REG[4]); - if (!once_value_51) { - fra.me.REG[4] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_51 = fra.me.REG[4]; - register_static_object(&once_value_51); - } else fra.me.REG[4] = once_value_51; - array___Array___add(fra.me.REG[6], fra.me.REG[4]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - CALL_exec___Sys___system(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[6]); + CALL_compiling___compiling_base___CProgram___run_c_compiler(fra.me.REG[1])(fra.me.REG[1]); } stack_frame_head = fra.me.prev; return; } + void OC_compiling___Program___compile_prog_to_c_5(struct stack_frame_t *closctx, val_t p0, struct stack_frame_t *closctx_param, fun_t clos_fun0){ + struct {struct stack_frame_t me;} fra; + fun_t CREG[1]; + val_t tmp; + fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; + fra.me.file = LOCATE_compiling; + fra.me.line = 0; + fra.me.meth = LOCATE_compiling___Program___compile_prog_to_c; + fra.me.has_broke = 0; + fra.me.REG_size = 1; + fra.me.nitni_local_ref_head = NULL; + fra.me.REG[0] = NIT_NULL; + fra.me.closure_ctx = closctx_param; + fra.me.closure_funs = CREG; + fra.me.REG[0] = p0; + CREG[0] = clos_fun0; + CALL_compiling___MMModule___compile_separate_module(fra.me.REG[0])(fra.me.REG[0], closctx->REG[1]); + stack_frame_head = fra.me.prev; + return; + } void compiling___Program___compile_main(val_t p0, val_t p1){ struct {struct stack_frame_t me; val_t MORE_REG[5];} fra; val_t REGB0; @@ -751,14 +280,13 @@ void compiling___Program___compile_main(val_t p0, val_t p1){ static val_t once_value_4; /* Once value */ static val_t once_value_5; /* Once value */ static val_t once_value_6; /* Once value */ - static val_t once_value_7; /* Once value */ - static val_t once_value_8; /* Once value */ fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; fra.me.file = LOCATE_compiling; - fra.me.line = 93; + fra.me.line = 72; fra.me.meth = LOCATE_compiling___Program___compile_main; fra.me.has_broke = 0; fra.me.REG_size = 6; + fra.me.nitni_local_ref_head = NULL; fra.me.REG[0] = NIT_NULL; fra.me.REG[1] = NIT_NULL; fra.me.REG[2] = NIT_NULL; @@ -767,142 +295,164 @@ void compiling___Program___compile_main(val_t p0, val_t p1){ fra.me.REG[5] = NIT_NULL; fra.me.REG[0] = p0; fra.me.REG[1] = p1; - fra.me.REG[2] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[2] = NEW_GlobalCompilerVisitor_compiling_global___GlobalCompilerVisitor___init(fra.me.REG[2], fra.me.REG[1], fra.me.REG[0]); - REGB0 = TAG_Int(0); - fra.me.REG[3] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:97 */ + /* compiling/compiling.nit:75 */ + fra.me.REG[2] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[2] = NEW_CompilerVisitor_compiling___compiling_base___CompilerVisitor___init(fra.me.REG[2], fra.me.REG[1]); + /* compiling/compiling.nit:76 */ if (!once_value_1) { - fra.me.REG[4] = BOX_NativeString("#include "); + fra.me.REG[3] = BOX_NativeString("#include "); REGB0 = TAG_Int(23); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_1 = fra.me.REG[4]; + fra.me.REG[3] = NEW_String_standard___string___String___with_native(fra.me.REG[3], REGB0); + once_value_1 = fra.me.REG[3]; register_static_object(&once_value_1); - } else fra.me.REG[4] = once_value_1; - array___Array___add(fra.me.REG[3], fra.me.REG[4]); - CALL_compiling_base___CompilerVisitor___add_decl(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); - /* ./compiling//compiling.nit:98 */ - CALL_compiling_global___Program___compile_tables_to_c(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]); - /* ./compiling//compiling.nit:99 */ - CALL_compiling_global___Program___compile_main_part(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]); + } else fra.me.REG[3] = once_value_1; + fra.me.REG[3] = fra.me.REG[3]; + CALL_compiling___compiling_base___CompilerVisitor___add_decl(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); + /* compiling/compiling.nit:77 */ + CALL_compiling___compiling_global___Program___compile_tables_to_c(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]); + /* compiling/compiling.nit:78 */ + CALL_compiling___compiling_global___Program___compile_main_part(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]); + /* compiling/compiling.nit:79 */ REGB0 = TAG_Int(5); - fra.me.REG[3] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:100 */ + fra.me.REG[3] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); if (!once_value_2) { fra.me.REG[4] = BOX_NativeString(""); REGB0 = TAG_Int(0); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); once_value_2 = fra.me.REG[4]; register_static_object(&once_value_2); } else fra.me.REG[4] = once_value_2; - array___Array___add(fra.me.REG[3], fra.me.REG[4]); - fra.me.REG[1] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[3], fra.me.REG[1]); + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + fra.me.REG[4] = CALL_compiling___compiling_base___CProgram___compdir(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); if (!once_value_3) { - fra.me.REG[1] = BOX_NativeString("/"); + fra.me.REG[4] = BOX_NativeString("/"); REGB0 = TAG_Int(1); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_3 = fra.me.REG[1]; + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); + once_value_3 = fra.me.REG[4]; register_static_object(&once_value_3); - } else fra.me.REG[1] = once_value_3; - array___Array___add(fra.me.REG[3], fra.me.REG[1]); - fra.me.REG[1] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[1] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[3], fra.me.REG[1]); + } else fra.me.REG[4] = once_value_3; + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + fra.me.REG[4] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[4] = CALL_compiling___compiling_base___MMModule___cname(fra.me.REG[4])(fra.me.REG[4]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); if (!once_value_4) { - fra.me.REG[1] = BOX_NativeString("._tables.c"); + fra.me.REG[4] = BOX_NativeString("._tables.c"); REGB0 = TAG_Int(10); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_4 = fra.me.REG[1]; + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); + once_value_4 = fra.me.REG[4]; register_static_object(&once_value_4); - } else fra.me.REG[1] = once_value_4; - array___Array___add(fra.me.REG[3], fra.me.REG[1]); - fra.me.REG[3] = CALL_string___Object___to_s(fra.me.REG[3])(fra.me.REG[3]); - fra.me.REG[3] = NEW_OFStream_file___OFStream___open(fra.me.REG[3]); + } else fra.me.REG[4] = once_value_4; + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + fra.me.REG[3] = CALL_standard___string___Object___to_s(fra.me.REG[3])(fra.me.REG[3]); + /* compiling/compiling.nit:80 */ + fra.me.REG[4] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[3]); + /* compiling/compiling.nit:81 */ + fra.me.REG[3] = NEW_OFStream_standard___file___OFStream___open(fra.me.REG[3]); + /* compiling/compiling.nit:82 */ REGB0 = TAG_Int(3); - fra.me.REG[1] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:101 */ + fra.me.REG[4] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); if (!once_value_5) { - fra.me.REG[4] = BOX_NativeString("/* This C file is generated by NIT to compile program "); + fra.me.REG[5] = BOX_NativeString("/* This C file is generated by NIT to compile program "); REGB0 = TAG_Int(54); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_5 = fra.me.REG[4]; + fra.me.REG[5] = NEW_String_standard___string___String___with_native(fra.me.REG[5], REGB0); + once_value_5 = fra.me.REG[5]; register_static_object(&once_value_5); - } else fra.me.REG[4] = once_value_5; - array___Array___add(fra.me.REG[1], fra.me.REG[4]); - fra.me.REG[4] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[4] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[4])(fra.me.REG[4]); - fra.me.REG[4] = CALL_string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); - array___Array___add(fra.me.REG[1], fra.me.REG[4]); + } else fra.me.REG[5] = once_value_5; + fra.me.REG[5] = fra.me.REG[5]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); + fra.me.REG[5] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[5] = CALL_compiling___compiling_base___MMModule___cname(fra.me.REG[5])(fra.me.REG[5]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); if (!once_value_6) { - fra.me.REG[4] = BOX_NativeString(". */\n"); + fra.me.REG[5] = BOX_NativeString(". */\n"); REGB0 = TAG_Int(5); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_6 = fra.me.REG[4]; + fra.me.REG[5] = NEW_String_standard___string___String___with_native(fra.me.REG[5], REGB0); + once_value_6 = fra.me.REG[5]; register_static_object(&once_value_6); - } else fra.me.REG[4] = once_value_6; - array___Array___add(fra.me.REG[1], fra.me.REG[4]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[1]); - fra.me.REG[0] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[0] = CALL_abstractmetamodel___MMModule___mhe(fra.me.REG[0])(fra.me.REG[0]); + } else fra.me.REG[5] = once_value_6; + fra.me.REG[5] = fra.me.REG[5]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); + fra.me.REG[4] = CALL_standard___string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); + CALL_standard___stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + /* compiling/compiling.nit:83 */ + fra.me.REG[0] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[0] = CALL_metamodel___abstractmetamodel___MMModule___mhe(fra.me.REG[0])(fra.me.REG[0]); REGB0 = TAG_Bool(fra.me.REG[0]==NIT_NULL); - /* ./compiling//compiling.nit:102 */ if (UNTAG_Bool(REGB0)) { - fprintf(stderr, "Reciever is null"); - fprintf(stderr, " (%s:%d)\n", LOCATE_compiling, 102); - nit_exit(1); - } - fra.me.REG[0] = CALL_partial_order___PartialOrderElement___greaters_and_self(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[0] = CALL_abstract_collection___Collection___iterator(fra.me.REG[0])(fra.me.REG[0]); - while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[0])(fra.me.REG[0]); - if (UNTAG_Bool(REGB0)) { - fra.me.REG[1] = CALL_abstract_collection___Iterator___item(fra.me.REG[0])(fra.me.REG[0]); - REGB0 = TAG_Int(3); - fra.me.REG[4] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:103 */ - if (!once_value_7) { - fra.me.REG[5] = BOX_NativeString("#include \""); - REGB0 = TAG_Int(10); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_7 = fra.me.REG[5]; - register_static_object(&once_value_7); - } else fra.me.REG[5] = once_value_7; - array___Array___add(fra.me.REG[4], fra.me.REG[5]); - fra.me.REG[1] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[4], fra.me.REG[1]); - if (!once_value_8) { - fra.me.REG[1] = BOX_NativeString("._sep.h\"\n"); - REGB0 = TAG_Int(9); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_8 = fra.me.REG[1]; - register_static_object(&once_value_8); - } else fra.me.REG[1] = once_value_8; - array___Array___add(fra.me.REG[4], fra.me.REG[1]); - fra.me.REG[4] = CALL_string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); - } else { - /* ./compiling//compiling.nit:102 */ - goto label9; - } - CALL_abstract_collection___Iterator___next(fra.me.REG[0])(fra.me.REG[0]); + nit_abort("Reciever is null", NULL, LOCATE_compiling, 83); } - label9: while(0); - fra.me.REG[2] = CALL_string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]); - /* ./compiling//compiling.nit:105 */ - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2]); - /* ./compiling//compiling.nit:106 */ - CALL_stream___IOS___close(fra.me.REG[3])(fra.me.REG[3]); + fra.me.REG[0] = CALL_metamodel___partial_order___PartialOrderElement___greaters_and_self(fra.me.REG[0])(fra.me.REG[0]); + CALL_standard___collection___abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], (&(fra.me)), ((fun_t)OC_compiling___Program___compile_main_7)); + /* compiling/compiling.nit:86 */ + fra.me.REG[1] = CALL_compiling___compiling_base___CompilerVisitor___header_writer(fra.me.REG[2])(fra.me.REG[2]); + CALL_compiling___compiling_writer___Writer___write_to_stream(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[3]); + /* compiling/compiling.nit:87 */ + fra.me.REG[2] = CALL_compiling___compiling_base___CompilerVisitor___writer(fra.me.REG[2])(fra.me.REG[2]); + CALL_compiling___compiling_writer___Writer___write_to_stream(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); + /* compiling/compiling.nit:88 */ + CALL_standard___stream___IOS___close(fra.me.REG[3])(fra.me.REG[3]); stack_frame_head = fra.me.prev; return; } -void compiling___MMModule___compile_separate_module(val_t p0, val_t p1, val_t p2){ - struct {struct stack_frame_t me; val_t MORE_REG[7];} fra; + void OC_compiling___Program___compile_main_7(struct stack_frame_t *closctx, val_t p0, struct stack_frame_t *closctx_param, fun_t clos_fun0){ + struct {struct stack_frame_t me; val_t MORE_REG[2];} fra; + val_t REGB0; + fun_t CREG[1]; + val_t tmp; + static val_t once_value_8; /* Once value */ + static val_t once_value_9; /* Once value */ + fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; + fra.me.file = LOCATE_compiling; + fra.me.line = 0; + fra.me.meth = LOCATE_compiling___Program___compile_main; + fra.me.has_broke = 0; + fra.me.REG_size = 3; + fra.me.nitni_local_ref_head = NULL; + fra.me.REG[0] = NIT_NULL; + fra.me.REG[1] = NIT_NULL; + fra.me.REG[2] = NIT_NULL; + fra.me.closure_ctx = closctx_param; + fra.me.closure_funs = CREG; + fra.me.REG[0] = p0; + CREG[0] = clos_fun0; + /* compiling/compiling.nit:84 */ + REGB0 = TAG_Int(3); + fra.me.REG[1] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_8) { + fra.me.REG[2] = BOX_NativeString("#include \""); + REGB0 = TAG_Int(10); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_8 = fra.me.REG[2]; + register_static_object(&once_value_8); + } else fra.me.REG[2] = once_value_8; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]); + fra.me.REG[0] = CALL_compiling___compiling_base___CProgram___module_header_name(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]); + if (!once_value_9) { + fra.me.REG[0] = BOX_NativeString("\"\n"); + REGB0 = TAG_Int(2); + fra.me.REG[0] = NEW_String_standard___string___String___with_native(fra.me.REG[0], REGB0); + once_value_9 = fra.me.REG[0]; + register_static_object(&once_value_9); + } else fra.me.REG[0] = once_value_9; + fra.me.REG[0] = fra.me.REG[0]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]); + fra.me.REG[1] = CALL_standard___string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___stream___OStream___write(closctx->REG[3])(closctx->REG[3], fra.me.REG[1]); + stack_frame_head = fra.me.prev; + return; + } +void compiling___MMModule___compile_separate_module(val_t p0, val_t p1){ + struct {struct stack_frame_t me; val_t MORE_REG[9];} fra; val_t REGB0; + val_t REGB1; + val_t REGB2; val_t tmp; static val_t once_value_1; /* Once value */ static val_t once_value_2; /* Once value */ @@ -910,17 +460,19 @@ void compiling___MMModule___compile_separate_module(val_t p0, val_t p1, val_t p2 static val_t once_value_4; /* Once value */ static val_t once_value_5; /* Once value */ static val_t once_value_6; /* Once value */ - static val_t once_value_7; /* Once value */ - static val_t once_value_8; /* Once value */ - static val_t once_value_9; /* Once value */ - static val_t once_value_10; /* Once value */ - static val_t once_value_11; /* Once value */ - static val_t once_value_12; /* Once value */ - static val_t once_value_13; /* Once value */ - static val_t once_value_14; /* Once value */ - static val_t once_value_15; /* Once value */ - static val_t once_value_16; /* Once value */ - static val_t once_value_17; /* Once value */ + static val_t once_value_7; /* Once value */ + static val_t once_value_8; /* Once value */ + static val_t once_value_9; /* Once value */ + static val_t once_value_10; /* Once value */ + static val_t once_value_11; /* Once value */ + static val_t once_value_12; /* Once value */ + static val_t once_value_13; /* Once value */ + static val_t once_value_14; /* Once value */ + static val_t once_value_15; /* Once value */ + static val_t once_value_16; /* Once value */ + static val_t once_value_17; /* Once value */ + static val_t once_value_18; /* Once value */ + static val_t once_value_19; /* Once value */ static val_t once_value_20; /* Once value */ static val_t once_value_21; /* Once value */ static val_t once_value_22; /* Once value */ @@ -928,13 +480,26 @@ void compiling___MMModule___compile_separate_module(val_t p0, val_t p1, val_t p2 static val_t once_value_24; /* Once value */ static val_t once_value_25; /* Once value */ static val_t once_value_26; /* Once value */ - static val_t once_value_27; /* Once value */ + static val_t once_value_27; /* Once value */ + static val_t once_value_28; /* Once value */ + static val_t once_value_30; /* Once value */ + static val_t once_value_31; /* Once value */ + static val_t once_value_32; /* Once value */ + static val_t once_value_33; /* Once value */ + static val_t once_value_34; /* Once value */ + static val_t once_value_35; /* Once value */ + static val_t once_value_36; /* Once value */ + static val_t once_value_37; /* Once value */ + static val_t once_value_38; /* Once value */ + static val_t once_value_39; /* Once value */ + static val_t once_value_40; /* Once value */ fra.me.prev = stack_frame_head; stack_frame_head = &fra.me; fra.me.file = LOCATE_compiling; - fra.me.line = 111; + fra.me.line = 93; fra.me.meth = LOCATE_compiling___MMModule___compile_separate_module; fra.me.has_broke = 0; - fra.me.REG_size = 8; + fra.me.REG_size = 10; + fra.me.nitni_local_ref_head = NULL; fra.me.REG[0] = NIT_NULL; fra.me.REG[1] = NIT_NULL; fra.me.REG[2] = NIT_NULL; @@ -943,364 +508,580 @@ void compiling___MMModule___compile_separate_module(val_t p0, val_t p1, val_t p2 fra.me.REG[5] = NIT_NULL; fra.me.REG[6] = NIT_NULL; fra.me.REG[7] = NIT_NULL; + fra.me.REG[8] = NIT_NULL; + fra.me.REG[9] = NIT_NULL; fra.me.REG[0] = p0; fra.me.REG[1] = p1; - fra.me.REG[2] = p2; - fra.me.REG[2] = NEW_GlobalCompilerVisitor_compiling_global___GlobalCompilerVisitor___init(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2]); - REGB0 = TAG_Int(0); - fra.me.REG[3] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:115 */ + /* compiling/compiling.nit:96 */ + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___program(fra.me.REG[1])(fra.me.REG[1]); + fra.me.REG[2] = CALL_program___Program___tc(fra.me.REG[2])(fra.me.REG[2]); + /* compiling/compiling.nit:97 */ + REGB0 = TAG_Int(3); + fra.me.REG[3] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); if (!once_value_1) { - fra.me.REG[4] = BOX_NativeString("#include "); - REGB0 = TAG_Int(23); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); + fra.me.REG[4] = BOX_NativeString("Generating C code for module: "); + REGB0 = TAG_Int(30); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); once_value_1 = fra.me.REG[4]; register_static_object(&once_value_1); } else fra.me.REG[4] = once_value_1; - array___Array___add(fra.me.REG[3], fra.me.REG[4]); - CALL_compiling_base___CompilerVisitor___add_decl(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); - fra.me.REG[3] = CALL_abstractmetamodel___MMModule___location(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[3] = CALL_location___Location___file(fra.me.REG[3])(fra.me.REG[3]); - /* ./compiling//compiling.nit:116 */ + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + fra.me.REG[4] = CALL_metamodel___abstractmetamodel___MMModule___full_name(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[4] = CALL_standard___string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); if (!once_value_2) { - fra.me.REG[4] = BOX_NativeString(".nit"); - REGB0 = TAG_Int(4); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); + fra.me.REG[4] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); once_value_2 = fra.me.REG[4]; register_static_object(&once_value_2); } else fra.me.REG[4] = once_value_2; - fra.me.REG[4] = CALL_file___String___strip_extension(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); - /* ./compiling//compiling.nit:117 */ + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + fra.me.REG[3] = CALL_standard___string___Object___to_s(fra.me.REG[3])(fra.me.REG[3]); + REGB0 = TAG_Int(2); + CALL_toolcontext___ToolContext___info(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3], REGB0); + /* compiling/compiling.nit:98 */ + fra.me.REG[3] = NEW_CompilerVisitor_compiling___compiling_base___CompilerVisitor___init(fra.me.REG[0], fra.me.REG[1]); + /* compiling/compiling.nit:99 */ if (!once_value_3) { - fra.me.REG[3] = BOX_NativeString("_nit.h"); - REGB0 = TAG_Int(6); - fra.me.REG[3] = NEW_String_string___String___with_native(fra.me.REG[3], REGB0); - once_value_3 = fra.me.REG[3]; + fra.me.REG[2] = BOX_NativeString("#include "); + REGB0 = TAG_Int(23); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_3 = fra.me.REG[2]; register_static_object(&once_value_3); - } else fra.me.REG[3] = once_value_3; - fra.me.REG[3] = CALL_string___String_____plus(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[3]); - fra.me.REG[4] = fra.me.REG[3]; - REGB0 = CALL_file___String___file_exists(fra.me.REG[4])(fra.me.REG[4]); - /* ./compiling//compiling.nit:118 */ + } else fra.me.REG[2] = once_value_3; + fra.me.REG[2] = fra.me.REG[2]; + CALL_compiling___compiling_base___CompilerVisitor___add_decl(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2]); + /* compiling/compiling.nit:101 */ + REGB0 = CALL_metamodel___abstractmetamodel___MMModule___is_extern_hybrid(fra.me.REG[0])(fra.me.REG[0]); if (UNTAG_Bool(REGB0)) { - REGB0 = TAG_Int(0); - fra.me.REG[3] = NEW_Array_array___Array___with_capacity(REGB0); + /* compiling/compiling.nit:104 */ REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); + fra.me.REG[2] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); if (!once_value_4) { - fra.me.REG[6] = BOX_NativeString("#include <"); - REGB0 = TAG_Int(10); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_4 = fra.me.REG[6]; + fra.me.REG[4] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); + once_value_4 = fra.me.REG[4]; register_static_object(&once_value_4); - } else fra.me.REG[6] = once_value_4; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); + } else fra.me.REG[4] = once_value_4; + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[4]); + fra.me.REG[4] = CALL_metamodel___abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[4] = CALL_standard___string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[4]); if (!once_value_5) { - fra.me.REG[6] = BOX_NativeString(""); - REGB0 = TAG_Int(0); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_5 = fra.me.REG[6]; + fra.me.REG[4] = BOX_NativeString("._nitni.h"); + REGB0 = TAG_Int(9); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); + once_value_5 = fra.me.REG[4]; register_static_object(&once_value_5); - } else fra.me.REG[6] = once_value_5; - fra.me.REG[6] = CALL_file___String___basename(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[6]); - array___Array___add(fra.me.REG[5], fra.me.REG[6]); + } else fra.me.REG[4] = once_value_5; + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[4]); + fra.me.REG[2] = CALL_standard___string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]); + /* compiling/compiling.nit:105 */ + REGB0 = TAG_Int(3); + fra.me.REG[4] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); if (!once_value_6) { - fra.me.REG[6] = BOX_NativeString(">"); - REGB0 = TAG_Int(1); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_6 = fra.me.REG[6]; + fra.me.REG[5] = BOX_NativeString("#include \""); + REGB0 = TAG_Int(10); + fra.me.REG[5] = NEW_String_standard___string___String___with_native(fra.me.REG[5], REGB0); + once_value_6 = fra.me.REG[5]; register_static_object(&once_value_6); - } else fra.me.REG[6] = once_value_6; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[3], fra.me.REG[5]); - CALL_compiling_base___CompilerVisitor___add_decl(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]); + } else fra.me.REG[5] = once_value_6; + fra.me.REG[5] = fra.me.REG[5]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + if (!once_value_7) { + fra.me.REG[2] = BOX_NativeString("\""); + REGB0 = TAG_Int(1); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_7 = fra.me.REG[2]; + register_static_object(&once_value_7); + } else fra.me.REG[2] = once_value_7; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + fra.me.REG[4] = CALL_standard___string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); + CALL_compiling___compiling_base___CompilerVisitor___add_decl(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + /* compiling/compiling.nit:106 */ + REGB0 = TAG_Int(3); + fra.me.REG[4] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_8) { + fra.me.REG[2] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_8 = fra.me.REG[2]; + register_static_object(&once_value_8); + } else fra.me.REG[2] = once_value_8; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + fra.me.REG[2] = CALL_metamodel___abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[2] = CALL_standard___string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + if (!once_value_9) { + fra.me.REG[2] = BOX_NativeString("._nitni.c"); + REGB0 = TAG_Int(9); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_9 = fra.me.REG[2]; + register_static_object(&once_value_9); + } else fra.me.REG[2] = once_value_9; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + fra.me.REG[4] = CALL_standard___string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); + /* compiling/compiling.nit:107 */ + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); + REGB0 = TAG_Int(5); + fra.me.REG[5] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_10) { + fra.me.REG[6] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_10 = fra.me.REG[6]; + register_static_object(&once_value_10); + } else fra.me.REG[6] = once_value_10; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[6]); + fra.me.REG[6] = CALL_compiling___compiling_base___CProgram___compdir(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[6]); + if (!once_value_11) { + fra.me.REG[6] = BOX_NativeString("/"); + REGB0 = TAG_Int(1); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_11 = fra.me.REG[6]; + register_static_object(&once_value_11); + } else fra.me.REG[6] = once_value_11; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[6]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[4]); + if (!once_value_12) { + fra.me.REG[4] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); + once_value_12 = fra.me.REG[4]; + register_static_object(&once_value_12); + } else fra.me.REG[4] = once_value_12; + fra.me.REG[4] = fra.me.REG[4]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[4]); + fra.me.REG[5] = CALL_standard___string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[5]); + /* compiling/compiling.nit:110 */ + fra.me.REG[5] = CALL_metamodel___abstractmetamodel___MMModule___location(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[5] = CALL_location___Location___file(fra.me.REG[5])(fra.me.REG[5]); + REGB0 = TAG_Bool(fra.me.REG[5]==NIT_NULL); + if (UNTAG_Bool(REGB0)) { + nit_abort("Reciever is null", NULL, LOCATE_compiling, 110); + } + fra.me.REG[5] = CALL_location___SourceFile___filename(fra.me.REG[5])(fra.me.REG[5]); + if (!once_value_13) { + fra.me.REG[2] = BOX_NativeString(".nit"); + REGB0 = TAG_Int(4); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_13 = fra.me.REG[2]; + register_static_object(&once_value_13); + } else fra.me.REG[2] = once_value_13; + fra.me.REG[2] = fra.me.REG[2]; + fra.me.REG[2] = CALL_standard___file___String___strip_extension(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[2]); + /* compiling/compiling.nit:111 */ + if (!once_value_14) { + fra.me.REG[5] = BOX_NativeString(".nit.c"); + REGB0 = TAG_Int(6); + fra.me.REG[5] = NEW_String_standard___string___String___with_native(fra.me.REG[5], REGB0); + once_value_14 = fra.me.REG[5]; + register_static_object(&once_value_14); + } else fra.me.REG[5] = once_value_14; + fra.me.REG[5] = fra.me.REG[5]; + fra.me.REG[5] = CALL_standard___string___String_____plus(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[5]); + /* compiling/compiling.nit:112 */ + REGB0 = CALL_standard___file___String___file_exists(fra.me.REG[5])(fra.me.REG[5]); + if (UNTAG_Bool(REGB0)) { + /* compiling/compiling.nit:113 */ + fra.me.REG[4] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); + } else { + /* compiling/compiling.nit:115 */ + if (!once_value_15) { + fra.me.REG[4] = BOX_NativeString("_nit.c"); + REGB0 = TAG_Int(6); + fra.me.REG[4] = NEW_String_standard___string___String___with_native(fra.me.REG[4], REGB0); + once_value_15 = fra.me.REG[4]; + register_static_object(&once_value_15); + } else fra.me.REG[4] = once_value_15; + fra.me.REG[4] = fra.me.REG[4]; + fra.me.REG[4] = CALL_standard___string___String_____plus(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[4]); + fra.me.REG[5] = fra.me.REG[4]; + /* compiling/compiling.nit:116 */ + REGB0 = CALL_standard___file___String___file_exists(fra.me.REG[5])(fra.me.REG[5]); + if (UNTAG_Bool(REGB0)) { + fra.me.REG[4] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); + } + } } - /* ./compiling//compiling.nit:119 */ - CALL_compiling_global___MMModule___declare_class_tables_to_c(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]); - /* ./compiling//compiling.nit:120 */ - CALL_compiling_global___MMModule___compile_mod_to_c(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]); + /* compiling/compiling.nit:120 */ + CALL_compiling___compiling_global___MMModule___declare_class_tables_to_c(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[3]); + /* compiling/compiling.nit:121 */ + CALL_compiling___compiling_global___MMModule___compile_mod_to_c(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[3]); + /* compiling/compiling.nit:123 */ + fra.me.REG[5] = CALL_compiling___compiling_base___CProgram___module_header_name(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]); + /* compiling/compiling.nit:124 */ REGB0 = TAG_Int(5); - fra.me.REG[3] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:121 */ - if (!once_value_7) { - fra.me.REG[5] = BOX_NativeString(""); + fra.me.REG[4] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_16) { + fra.me.REG[2] = BOX_NativeString(""); REGB0 = TAG_Int(0); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_7 = fra.me.REG[5]; - register_static_object(&once_value_7); - } else fra.me.REG[5] = once_value_7; - array___Array___add(fra.me.REG[3], fra.me.REG[5]); - fra.me.REG[5] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[3], fra.me.REG[5]); - if (!once_value_8) { - fra.me.REG[5] = BOX_NativeString("/"); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_16 = fra.me.REG[2]; + register_static_object(&once_value_16); + } else fra.me.REG[2] = once_value_16; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___compdir(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + if (!once_value_17) { + fra.me.REG[2] = BOX_NativeString("/"); REGB0 = TAG_Int(1); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_8 = fra.me.REG[5]; - register_static_object(&once_value_8); - } else fra.me.REG[5] = once_value_8; - array___Array___add(fra.me.REG[3], fra.me.REG[5]); - fra.me.REG[5] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - array___Array___add(fra.me.REG[3], fra.me.REG[5]); - if (!once_value_9) { - fra.me.REG[5] = BOX_NativeString("._sep.h"); - REGB0 = TAG_Int(7); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_9 = fra.me.REG[5]; - register_static_object(&once_value_9); - } else fra.me.REG[5] = once_value_9; - array___Array___add(fra.me.REG[3], fra.me.REG[5]); - fra.me.REG[3] = CALL_string___Object___to_s(fra.me.REG[3])(fra.me.REG[3]); - fra.me.REG[3] = NEW_OFStream_file___OFStream___open(fra.me.REG[3]); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_17 = fra.me.REG[2]; + register_static_object(&once_value_17); + } else fra.me.REG[2] = once_value_17; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]); + if (!once_value_18) { + fra.me.REG[2] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_18 = fra.me.REG[2]; + register_static_object(&once_value_18); + } else fra.me.REG[2] = once_value_18; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + fra.me.REG[4] = CALL_standard___string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); + fra.me.REG[4] = NEW_OFStream_standard___file___OFStream___open(fra.me.REG[4]); + /* compiling/compiling.nit:125 */ REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:122 */ - if (!once_value_10) { + fra.me.REG[2] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_19) { fra.me.REG[6] = BOX_NativeString("/* This C header file is generated by NIT to compile modules and programs that requires "); REGB0 = TAG_Int(88); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_10 = fra.me.REG[6]; - register_static_object(&once_value_10); - } else fra.me.REG[6] = once_value_10; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[6] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - if (!once_value_11) { + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_19 = fra.me.REG[6]; + register_static_object(&once_value_19); + } else fra.me.REG[6] = once_value_19; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[6] = CALL_metamodel___abstractmetamodel___MMModule___full_name(fra.me.REG[0])(fra.me.REG[0]); + fra.me.REG[6] = CALL_standard___string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + if (!once_value_20) { fra.me.REG[6] = BOX_NativeString(". */\n"); REGB0 = TAG_Int(5); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_11 = fra.me.REG[6]; - register_static_object(&once_value_11); - } else fra.me.REG[6] = once_value_11; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:123 */ - if (!once_value_12) { + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_20 = fra.me.REG[6]; + register_static_object(&once_value_20); + } else fra.me.REG[6] = once_value_20; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[2] = CALL_standard___string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]); + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + /* compiling/compiling.nit:126 */ + REGB0 = TAG_Int(5); + fra.me.REG[2] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_21) { fra.me.REG[6] = BOX_NativeString("#ifndef "); REGB0 = TAG_Int(8); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_12 = fra.me.REG[6]; - register_static_object(&once_value_12); - } else fra.me.REG[6] = once_value_12; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[6] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - if (!once_value_13) { - fra.me.REG[6] = BOX_NativeString("_sep\n"); - REGB0 = TAG_Int(5); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_13 = fra.me.REG[6]; - register_static_object(&once_value_13); - } else fra.me.REG[6] = once_value_13; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:124 */ - if (!once_value_14) { + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_21 = fra.me.REG[6]; + register_static_object(&once_value_21); + } else fra.me.REG[6] = once_value_21; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[6] = CALL_compiling___compiling_base___MMModule___cname(fra.me.REG[0])(fra.me.REG[0]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + if (!once_value_22) { + fra.me.REG[6] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_22 = fra.me.REG[6]; + register_static_object(&once_value_22); + } else fra.me.REG[6] = once_value_22; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[6] = CALL_compiling___compiling_base___CProgram___get_file_ending(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + if (!once_value_23) { + fra.me.REG[6] = BOX_NativeString("\n"); + REGB0 = TAG_Int(1); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_23 = fra.me.REG[6]; + register_static_object(&once_value_23); + } else fra.me.REG[6] = once_value_23; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[2] = CALL_standard___string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]); + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + /* compiling/compiling.nit:127 */ + REGB0 = TAG_Int(5); + fra.me.REG[2] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_24) { fra.me.REG[6] = BOX_NativeString("#define "); REGB0 = TAG_Int(8); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_14 = fra.me.REG[6]; - register_static_object(&once_value_14); - } else fra.me.REG[6] = once_value_14; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[6] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - if (!once_value_15) { - fra.me.REG[6] = BOX_NativeString("_sep\n"); - REGB0 = TAG_Int(5); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_15 = fra.me.REG[6]; - register_static_object(&once_value_15); - } else fra.me.REG[6] = once_value_15; - array___Array___add(fra.me.REG[5], fra.me.REG[6]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - fra.me.REG[5] = CALL_abstractmetamodel___MMModule___mhe(fra.me.REG[0])(fra.me.REG[0]); - REGB0 = TAG_Bool(fra.me.REG[5]==NIT_NULL); - /* ./compiling//compiling.nit:125 */ + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_24 = fra.me.REG[6]; + register_static_object(&once_value_24); + } else fra.me.REG[6] = once_value_24; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[6] = CALL_compiling___compiling_base___MMModule___cname(fra.me.REG[0])(fra.me.REG[0]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + if (!once_value_25) { + fra.me.REG[6] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_25 = fra.me.REG[6]; + register_static_object(&once_value_25); + } else fra.me.REG[6] = once_value_25; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[6] = CALL_compiling___compiling_base___CProgram___get_file_ending(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + if (!once_value_26) { + fra.me.REG[6] = BOX_NativeString("\n"); + REGB0 = TAG_Int(1); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_26 = fra.me.REG[6]; + register_static_object(&once_value_26); + } else fra.me.REG[6] = once_value_26; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]); + fra.me.REG[2] = CALL_standard___string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]); + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]); + /* compiling/compiling.nit:128 */ + fra.me.REG[2] = CALL_metamodel___abstractmetamodel___MMModule___mhe(fra.me.REG[0])(fra.me.REG[0]); + REGB0 = TAG_Bool(fra.me.REG[2]==NIT_NULL); if (UNTAG_Bool(REGB0)) { - fprintf(stderr, "Reciever is null"); - fprintf(stderr, " (%s:%d)\n", LOCATE_compiling, 125); - nit_exit(1); + nit_abort("Reciever is null", NULL, LOCATE_compiling, 128); + } + fra.me.REG[2] = CALL_metamodel___partial_order___PartialOrderElement___direct_greaters(fra.me.REG[2])(fra.me.REG[2]); + /* ../lib/standard/collection/array.nit:269 */ + REGB0 = TAG_Int(0); + /* ../lib/standard/collection/array.nit:270 */ + REGB1 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL); + if (UNTAG_Bool(REGB1)) { + } else { + nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 270); } - fra.me.REG[5] = CALL_partial_order___PartialOrderElement___direct_greaters(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[5] = CALL_abstract_collection___Collection___iterator(fra.me.REG[5])(fra.me.REG[5]); + REGB1 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2]); + /* ../lib/standard/collection/array.nit:271 */ + fra.me.REG[6] = ATTR_standard___collection___array___Array____items(fra.me.REG[2]); + /* ../lib/standard/collection/array.nit:272 */ while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[5])(fra.me.REG[5]); - if (UNTAG_Bool(REGB0)) { - fra.me.REG[6] = CALL_abstract_collection___Iterator___item(fra.me.REG[5])(fra.me.REG[5]); - REGB0 = TAG_Int(3); - fra.me.REG[4] = NEW_Array_array___Array___with_capacity(REGB0); - if (!once_value_16) { - fra.me.REG[7] = BOX_NativeString("#include \""); - REGB0 = TAG_Int(10); - fra.me.REG[7] = NEW_String_string___String___with_native(fra.me.REG[7], REGB0); - once_value_16 = fra.me.REG[7]; - register_static_object(&once_value_16); - } else fra.me.REG[7] = once_value_16; - array___Array___add(fra.me.REG[4], fra.me.REG[7]); - fra.me.REG[6] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[6])(fra.me.REG[6]); - fra.me.REG[6] = CALL_string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - if (!once_value_17) { - fra.me.REG[6] = BOX_NativeString("._sep.h\"\n"); - REGB0 = TAG_Int(9); - fra.me.REG[6] = NEW_String_string___String___with_native(fra.me.REG[6], REGB0); - once_value_17 = fra.me.REG[6]; - register_static_object(&once_value_17); - } else fra.me.REG[6] = once_value_17; - array___Array___add(fra.me.REG[4], fra.me.REG[6]); - fra.me.REG[4] = CALL_string___Object___to_s(fra.me.REG[4])(fra.me.REG[4]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + /* ../lib/standard/collection/array.nit:24 */ + REGB1 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL); + if (UNTAG_Bool(REGB1)) { } else { - goto label18; + nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 24); } - CALL_abstract_collection___Iterator___next(fra.me.REG[5])(fra.me.REG[5]); - } - label18: while(0); - fra.me.REG[5] = CALL_compiling_base___CompilerVisitor___ctx(fra.me.REG[2])(fra.me.REG[2]); - fra.me.REG[5] = CALL_compiling_base___CContext___decls(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[5] = CALL_abstract_collection___Collection___iterator(fra.me.REG[5])(fra.me.REG[5]); - /* ./compiling//compiling.nit:126 */ - while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[5])(fra.me.REG[5]); - if (UNTAG_Bool(REGB0)) { - fra.me.REG[4] = CALL_abstract_collection___Iterator___item(fra.me.REG[5])(fra.me.REG[5]); - /* ./compiling//compiling.nit:127 */ - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + REGB1 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2]); + REGB2 = TAG_Bool(VAL_ISA(REGB1, VTCOLOR_standard___kernel___Comparable___OTHER(REGB0), VTID_standard___kernel___Comparable___OTHER(REGB0))) /*cast OTHER*/; + if (UNTAG_Bool(REGB2)) { + } else { + nit_abort("Cast failed", NULL, LOCATE_standard___kernel, 0); + } + /* ../lib/standard/kernel.nit:232 */ + REGB1 = TAG_Bool(UNTAG_Int(REGB0)val[UNTAG_Int(REGB0)]; + /* compiling/compiling.nit:128 */ + REGB1 = TAG_Int(3); + fra.me.REG[8] = NEW_Array_standard___collection___array___Array___with_capacity(REGB1); + if (!once_value_27) { + fra.me.REG[9] = BOX_NativeString("#include \""); + REGB1 = TAG_Int(10); + fra.me.REG[9] = NEW_String_standard___string___String___with_native(fra.me.REG[9], REGB1); + once_value_27 = fra.me.REG[9]; + register_static_object(&once_value_27); + } else fra.me.REG[9] = once_value_27; + fra.me.REG[9] = fra.me.REG[9]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[8])(fra.me.REG[8], fra.me.REG[9]); + fra.me.REG[7] = CALL_compiling___compiling_base___CProgram___module_header_name(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[7]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[8])(fra.me.REG[8], fra.me.REG[7]); + if (!once_value_28) { + fra.me.REG[7] = BOX_NativeString("\"\n"); + REGB1 = TAG_Int(2); + fra.me.REG[7] = NEW_String_standard___string___String___with_native(fra.me.REG[7], REGB1); + once_value_28 = fra.me.REG[7]; + register_static_object(&once_value_28); + } else fra.me.REG[7] = once_value_28; + fra.me.REG[7] = fra.me.REG[7]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[8])(fra.me.REG[8], fra.me.REG[7]); + fra.me.REG[8] = CALL_standard___string___Object___to_s(fra.me.REG[8])(fra.me.REG[8]); + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[8]); + /* ../lib/standard/collection/array.nit:274 */ + REGB1 = TAG_Int(1); + /* ../lib/standard/kernel.nit:235 */ + REGB1 = TAG_Int(UNTAG_Int(REGB0)+UNTAG_Int(REGB1)); + /* ../lib/standard/collection/array.nit:274 */ + REGB0 = REGB1; } else { - /* ./compiling//compiling.nit:126 */ - goto label19; + /* ../lib/standard/collection/array.nit:272 */ + goto label29; } - CALL_abstract_collection___Iterator___next(fra.me.REG[5])(fra.me.REG[5]); } - label19: while(0); - /* ./compiling//compiling.nit:129 */ - if (!once_value_20) { - fra.me.REG[5] = BOX_NativeString("#endif\n"); + label29: while(0); + /* compiling/compiling.nit:129 */ + fra.me.REG[6] = CALL_compiling___compiling_base___CompilerVisitor___header_writer(fra.me.REG[3])(fra.me.REG[3]); + CALL_compiling___compiling_writer___Writer___write_to_stream(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[4]); + /* compiling/compiling.nit:130 */ + if (!once_value_30) { + fra.me.REG[6] = BOX_NativeString("#endif\n"); REGB0 = TAG_Int(7); - fra.me.REG[5] = NEW_String_string___String___with_native(fra.me.REG[5], REGB0); - once_value_20 = fra.me.REG[5]; - register_static_object(&once_value_20); - } else fra.me.REG[5] = once_value_20; - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - /* ./compiling//compiling.nit:130 */ - CALL_stream___IOS___close(fra.me.REG[3])(fra.me.REG[3]); - REGB0 = TAG_Int(5); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:132 */ - if (!once_value_21) { - fra.me.REG[4] = BOX_NativeString(""); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_30 = fra.me.REG[6]; + register_static_object(&once_value_30); + } else fra.me.REG[6] = once_value_30; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[6]); + /* compiling/compiling.nit:131 */ + CALL_standard___stream___IOS___close(fra.me.REG[4])(fra.me.REG[4]); + /* compiling/compiling.nit:133 */ + REGB0 = TAG_Int(7); + fra.me.REG[6] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_31) { + fra.me.REG[2] = BOX_NativeString(""); REGB0 = TAG_Int(0); - fra.me.REG[4] = NEW_String_string___String___with_native(fra.me.REG[4], REGB0); - once_value_21 = fra.me.REG[4]; - register_static_object(&once_value_21); - } else fra.me.REG[4] = once_value_21; - array___Array___add(fra.me.REG[5], fra.me.REG[4]); - fra.me.REG[1] = CALL_compiling_base___ToolContext___compdir(fra.me.REG[1])(fra.me.REG[1]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - if (!once_value_22) { - fra.me.REG[1] = BOX_NativeString("/"); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_31 = fra.me.REG[2]; + register_static_object(&once_value_31); + } else fra.me.REG[2] = once_value_31; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___compdir(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + if (!once_value_32) { + fra.me.REG[2] = BOX_NativeString("/"); REGB0 = TAG_Int(1); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_22 = fra.me.REG[1]; - register_static_object(&once_value_22); - } else fra.me.REG[1] = once_value_22; - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - fra.me.REG[1] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - if (!once_value_23) { - fra.me.REG[1] = BOX_NativeString("._sep.c"); - REGB0 = TAG_Int(7); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_23 = fra.me.REG[1]; - register_static_object(&once_value_23); - } else fra.me.REG[1] = once_value_23; - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - fra.me.REG[5] = NEW_OFStream_file___OFStream___open(fra.me.REG[5]); - fra.me.REG[3] = fra.me.REG[5]; + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_32 = fra.me.REG[2]; + register_static_object(&once_value_32); + } else fra.me.REG[2] = once_value_32; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + fra.me.REG[2] = CALL_compiling___compiling_base___MMModule___cname(fra.me.REG[0])(fra.me.REG[0]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + if (!once_value_33) { + fra.me.REG[2] = BOX_NativeString("."); + REGB0 = TAG_Int(1); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_33 = fra.me.REG[2]; + register_static_object(&once_value_33); + } else fra.me.REG[2] = once_value_33; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + fra.me.REG[2] = CALL_compiling___compiling_base___CProgram___get_file_ending(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + if (!once_value_34) { + fra.me.REG[2] = BOX_NativeString(".c"); + REGB0 = TAG_Int(2); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_34 = fra.me.REG[2]; + register_static_object(&once_value_34); + } else fra.me.REG[2] = once_value_34; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[2]); + fra.me.REG[6] = CALL_standard___string___Object___to_s(fra.me.REG[6])(fra.me.REG[6]); + /* compiling/compiling.nit:134 */ + fra.me.REG[1] = CALL_compiling___compiling_base___CProgram___files(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[6]); + /* compiling/compiling.nit:135 */ REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:133 */ - if (!once_value_24) { - fra.me.REG[1] = BOX_NativeString("/* This C file is generated by NIT to compile module "); + fra.me.REG[1] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_35) { + fra.me.REG[2] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[2] = NEW_String_standard___string___String___with_native(fra.me.REG[2], REGB0); + once_value_35 = fra.me.REG[2]; + register_static_object(&once_value_35); + } else fra.me.REG[2] = once_value_35; + fra.me.REG[2] = fra.me.REG[2]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[6]); + if (!once_value_36) { + fra.me.REG[6] = BOX_NativeString(""); + REGB0 = TAG_Int(0); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_36 = fra.me.REG[6]; + register_static_object(&once_value_36); + } else fra.me.REG[6] = once_value_36; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[6]); + fra.me.REG[1] = CALL_standard___string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); + fra.me.REG[1] = NEW_OFStream_standard___file___OFStream___open(fra.me.REG[1]); + fra.me.REG[4] = fra.me.REG[1]; + /* compiling/compiling.nit:136 */ + REGB0 = TAG_Int(3); + fra.me.REG[1] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_37) { + fra.me.REG[6] = BOX_NativeString("/* This C file is generated by NIT to compile module "); REGB0 = TAG_Int(53); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_24 = fra.me.REG[1]; - register_static_object(&once_value_24); - } else fra.me.REG[1] = once_value_24; - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - fra.me.REG[1] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[1] = CALL_string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - if (!once_value_25) { - fra.me.REG[1] = BOX_NativeString(". */\n"); + fra.me.REG[6] = NEW_String_standard___string___String___with_native(fra.me.REG[6], REGB0); + once_value_37 = fra.me.REG[6]; + register_static_object(&once_value_37); + } else fra.me.REG[6] = once_value_37; + fra.me.REG[6] = fra.me.REG[6]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[6]); + fra.me.REG[0] = CALL_compiling___compiling_base___MMModule___cname(fra.me.REG[0])(fra.me.REG[0]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]); + if (!once_value_38) { + fra.me.REG[0] = BOX_NativeString(". */\n"); REGB0 = TAG_Int(5); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_25 = fra.me.REG[1]; - register_static_object(&once_value_25); - } else fra.me.REG[1] = once_value_25; - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); + fra.me.REG[0] = NEW_String_standard___string___String___with_native(fra.me.REG[0], REGB0); + once_value_38 = fra.me.REG[0]; + register_static_object(&once_value_38); + } else fra.me.REG[0] = once_value_38; + fra.me.REG[0] = fra.me.REG[0]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]); + fra.me.REG[1] = CALL_standard___string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]); + /* compiling/compiling.nit:137 */ REGB0 = TAG_Int(3); - fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0); - /* ./compiling//compiling.nit:134 */ - if (!once_value_26) { - fra.me.REG[1] = BOX_NativeString("#include \""); + fra.me.REG[1] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0); + if (!once_value_39) { + fra.me.REG[0] = BOX_NativeString("#include \""); REGB0 = TAG_Int(10); - fra.me.REG[1] = NEW_String_string___String___with_native(fra.me.REG[1], REGB0); - once_value_26 = fra.me.REG[1]; - register_static_object(&once_value_26); - } else fra.me.REG[1] = once_value_26; - array___Array___add(fra.me.REG[5], fra.me.REG[1]); - fra.me.REG[0] = CALL_abstractmetamodel___MMModule___name(fra.me.REG[0])(fra.me.REG[0]); - fra.me.REG[0] = CALL_string___Object___to_s(fra.me.REG[0])(fra.me.REG[0]); - array___Array___add(fra.me.REG[5], fra.me.REG[0]); - if (!once_value_27) { - fra.me.REG[0] = BOX_NativeString("._sep.h\"\n"); - REGB0 = TAG_Int(9); - fra.me.REG[0] = NEW_String_string___String___with_native(fra.me.REG[0], REGB0); - once_value_27 = fra.me.REG[0]; - register_static_object(&once_value_27); - } else fra.me.REG[0] = once_value_27; - array___Array___add(fra.me.REG[5], fra.me.REG[0]); - fra.me.REG[5] = CALL_string___Object___to_s(fra.me.REG[5])(fra.me.REG[5]); - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - fra.me.REG[2] = CALL_compiling_base___CompilerVisitor___ctx(fra.me.REG[2])(fra.me.REG[2]); - fra.me.REG[2] = CALL_compiling_base___CContext___instrs(fra.me.REG[2])(fra.me.REG[2]); - fra.me.REG[2] = CALL_abstract_collection___Collection___iterator(fra.me.REG[2])(fra.me.REG[2]); - /* ./compiling//compiling.nit:135 */ - while(1) { - REGB0 = CALL_abstract_collection___Iterator___is_ok(fra.me.REG[2])(fra.me.REG[2]); - if (UNTAG_Bool(REGB0)) { - fra.me.REG[5] = CALL_abstract_collection___Iterator___item(fra.me.REG[2])(fra.me.REG[2]); - /* ./compiling//compiling.nit:136 */ - CALL_stream___OStream___write(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[5]); - } else { - /* ./compiling//compiling.nit:135 */ - goto label28; - } - CALL_abstract_collection___Iterator___next(fra.me.REG[2])(fra.me.REG[2]); - } - label28: while(0); - /* ./compiling//compiling.nit:138 */ - CALL_stream___IOS___close(fra.me.REG[3])(fra.me.REG[3]); + fra.me.REG[0] = NEW_String_standard___string___String___with_native(fra.me.REG[0], REGB0); + once_value_39 = fra.me.REG[0]; + register_static_object(&once_value_39); + } else fra.me.REG[0] = once_value_39; + fra.me.REG[0] = fra.me.REG[0]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0]); + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[5]); + if (!once_value_40) { + fra.me.REG[5] = BOX_NativeString("\"\n"); + REGB0 = TAG_Int(2); + fra.me.REG[5] = NEW_String_standard___string___String___with_native(fra.me.REG[5], REGB0); + once_value_40 = fra.me.REG[5]; + register_static_object(&once_value_40); + } else fra.me.REG[5] = once_value_40; + fra.me.REG[5] = fra.me.REG[5]; + CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[5]); + fra.me.REG[1] = CALL_standard___string___Object___to_s(fra.me.REG[1])(fra.me.REG[1]); + CALL_standard___stream___OStream___write(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]); + /* compiling/compiling.nit:138 */ + fra.me.REG[3] = CALL_compiling___compiling_base___CompilerVisitor___top_writer(fra.me.REG[3])(fra.me.REG[3]); + CALL_compiling___compiling_writer___Writer___write_to_stream(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]); + /* compiling/compiling.nit:139 */ + CALL_standard___stream___IOS___close(fra.me.REG[4])(fra.me.REG[4]); stack_frame_head = fra.me.prev; return; }