c_src: update
[nit.git] / c_src / program._sep.c
index 0ac1e78..a80b373 100644 (file)
 /* This C file is generated by NIT to compile module program. */
 #include "program._sep.h"
-val_t program___Program___module(val_t p0){
+val_t program___ToolContext___global(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_program;
-  fra.me.line = 25;
-  fra.me.meth = LOCATE_program___Program___module;
+  fra.me.line = 26;
+  fra.me.meth = LOCATE_program___ToolContext___global;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
-  REGB0 = TAG_Bool(ATTR_program___Program____module(fra.me.REG[0])!=NIT_NULL);
-  /* ./program.nit:25 */
+  /* ./program.nit:26 */
+  REGB0 = TAG_Bool(ATTR_program___ToolContext____global(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    fprintf(stderr, "Uninitialized attribute %s", "_module");
-    fprintf(stderr, " (%s:%d)\n", LOCATE_program, 25);
-    nit_exit(1);
+    nit_abort("Uninitialized attribute %s", "_global", LOCATE_program, 26);
   }
-  fra.me.REG[0] = ATTR_program___Program____module(fra.me.REG[0]);
+  REGB0 = ATTR_program___ToolContext____global(fra.me.REG[0]);
+  stack_frame_head = fra.me.prev;
+  return REGB0;
+}
+void program___ToolContext___global__eq(val_t p0, val_t p1){
+  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_program;
+  fra.me.line = 26;
+  fra.me.meth = LOCATE_program___ToolContext___global__eq;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  REGB0 = p1;
+  /* ./program.nit:26 */
+  ATTR_program___ToolContext____global(fra.me.REG[0]) = REGB0;
+  stack_frame_head = fra.me.prev;
+  return;
+}
+void program___ToolContext___use_SFT_optimization__eq(val_t p0, val_t p1){
+  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_program;
+  fra.me.line = 27;
+  fra.me.meth = LOCATE_program___ToolContext___use_SFT_optimization__eq;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  REGB0 = p1;
+  /* ./program.nit:27 */
+  ATTR_program___ToolContext____use_SFT_optimization(fra.me.REG[0]) = REGB0;
+  stack_frame_head = fra.me.prev;
+  return;
+}
+val_t program___ToolContext___use_SFT_optimization(val_t p0){
+  struct {struct stack_frame_t me;} fra;
+  val_t REGB0;
+  val_t REGB1;
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 29;
+  fra.me.meth = LOCATE_program___ToolContext___use_SFT_optimization;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:31 */
+  REGB0 = CALL_program___ToolContext___global(fra.me.REG[0])(fra.me.REG[0]);
+  if (UNTAG_Bool(REGB0)) {
+    REGB0 = TAG_Bool(ATTR_program___ToolContext____use_SFT_optimization(fra.me.REG[0])!=NIT_NULL);
+    if (UNTAG_Bool(REGB0)) {
+    } else {
+      nit_abort("Uninitialized attribute %s", "_use_SFT_optimization", LOCATE_program, 31);
+    }
+    REGB0 = ATTR_program___ToolContext____use_SFT_optimization(fra.me.REG[0]);
+  } else {
+    REGB1 = TAG_Bool(false);
+    REGB0 = REGB1;
+  }
+  goto label1;
+  label1: while(0);
+  stack_frame_head = fra.me.prev;
+  return REGB0;
+}
+val_t program___Program___tc(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_program;
+  fra.me.line = 37;
+  fra.me.meth = LOCATE_program___Program___tc;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:37 */
+  REGB0 = TAG_Bool(ATTR_program___Program____tc(fra.me.REG[0])!=NIT_NULL);
+  if (UNTAG_Bool(REGB0)) {
+  } else {
+    nit_abort("Uninitialized attribute %s", "_tc", LOCATE_program, 37);
+  }
+  fra.me.REG[0] = ATTR_program___Program____tc(fra.me.REG[0]);
+  stack_frame_head = fra.me.prev;
+  return fra.me.REG[0];
+}
+val_t program___Program___main_module(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_program;
+  fra.me.line = 41;
+  fra.me.meth = LOCATE_program___Program___main_module;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:41 */
+  REGB0 = TAG_Bool(ATTR_program___Program____main_module(fra.me.REG[0])!=NIT_NULL);
+  if (UNTAG_Bool(REGB0)) {
+  } else {
+    nit_abort("Uninitialized attribute %s", "_main_module", LOCATE_program, 41);
+  }
+  fra.me.REG[0] = ATTR_program___Program____main_module(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[0];
 }
@@ -29,14 +138,14 @@ val_t program___Program___main_method(val_t p0){
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
   fra.me.file = LOCATE_program;
-  fra.me.line = 28;
+  fra.me.line = 44;
   fra.me.meth = LOCATE_program___Program___main_method;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
+  /* ./program.nit:44 */
   fra.me.REG[0] = ATTR_program___Program____main_method(fra.me.REG[0]);
-  /* ./program.nit:28 */
   stack_frame_head = fra.me.prev;
   return fra.me.REG[0];
 }
@@ -45,17 +154,108 @@ val_t program___Program___main_class(val_t p0){
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
   fra.me.file = LOCATE_program;
-  fra.me.line = 32;
+  fra.me.line = 48;
   fra.me.meth = LOCATE_program___Program___main_class;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
+  /* ./program.nit:48 */
   fra.me.REG[0] = ATTR_program___Program____main_class(fra.me.REG[0]);
-  /* ./program.nit:32 */
   stack_frame_head = fra.me.prev;
   return fra.me.REG[0];
 }
+void program___Program___finish_processing_classes(val_t p0){
+  struct {struct stack_frame_t me; val_t MORE_REG[2];} fra;
+  val_t REGB0;
+  val_t REGB1;
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 52;
+  fra.me.meth = LOCATE_program___Program___finish_processing_classes;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 3;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[1] = NIT_NULL;
+  fra.me.REG[2] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:55 */
+  fra.me.REG[1] = NEW_Array_array___Array___init();
+  /* ./program.nit:56 */
+  fra.me.REG[0] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]);
+  fra.me.REG[0] = CALL_abstractmetamodel___MMModule___local_classes(fra.me.REG[0])(fra.me.REG[0]);
+  CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], (&(fra.me)), ((fun_t)OC_program___Program___finish_processing_classes_1));
+  /* ./../lib/standard//collection//array.nit:234 */
+  REGB0 = TAG_Int(0);
+  /* ./../lib/standard//collection//array.nit:235 */
+  REGB1 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[1])!=NIT_NULL);
+  if (UNTAG_Bool(REGB1)) {
+  } else {
+    nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 235);
+  }
+  REGB1 = ATTR_array___AbstractArrayRead____length(fra.me.REG[1]);
+  /* ./../lib/standard//collection//array.nit:236 */
+  fra.me.REG[0] = ATTR_array___Array____items(fra.me.REG[1]);
+  /* ./../lib/standard//collection//array.nit:237 */
+  while(1) {
+    /* ./../lib/standard//collection//array.nit:23 */
+    REGB1 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[1])!=NIT_NULL);
+    if (UNTAG_Bool(REGB1)) {
+    } else {
+      nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 23);
+    }
+    REGB1 = ATTR_array___AbstractArrayRead____length(fra.me.REG[1]);
+    /* ./../lib/standard//kernel.nit:212 */
+    REGB1 = TAG_Bool(UNTAG_Int(REGB0)<UNTAG_Int(REGB1));
+    /* ./../lib/standard//collection//array.nit:237 */
+    if (UNTAG_Bool(REGB1)) {
+      /* ./../lib/standard//collection//array.nit:238 */
+      REGB1 = TAG_Bool(fra.me.REG[0]==NIT_NULL);
+      if (UNTAG_Bool(REGB1)) {
+        nit_abort("Reciever is null", NULL, LOCATE_array, 238);
+      }
+      /* ./../lib/standard//collection//array.nit:654 */
+      fra.me.REG[2] = ((Nit_NativeArray)fra.me.REG[0])->val[UNTAG_Int(REGB0)];
+      /* ./program.nit:62 */
+      CALL_inheritance___MMLocalClass___compute_ancestors(fra.me.REG[2])(fra.me.REG[2]);
+      /* ./../lib/standard//collection//array.nit:239 */
+      REGB1 = TAG_Int(1);
+      /* ./../lib/standard//kernel.nit:215 */
+      REGB1 = TAG_Int(UNTAG_Int(REGB0)+UNTAG_Int(REGB1));
+      /* ./../lib/standard//collection//array.nit:239 */
+      REGB0 = REGB1;
+    } else {
+      /* ./../lib/standard//collection//array.nit:237 */
+      goto label2;
+    }
+  }
+  label2: while(0);
+  stack_frame_head = fra.me.prev;
+  return;
+}
+  void OC_program___Program___finish_processing_classes_1(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_program;
+    fra.me.line = 0;
+    fra.me.meth = LOCATE_program___Program___finish_processing_classes;
+    fra.me.has_broke = 0;
+    fra.me.REG_size = 1;
+    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;
+    /* ./program.nit:57 */
+    CALL_inheritance___MMLocalClass___compute_super_classes(fra.me.REG[0])(fra.me.REG[0]);
+    /* ./program.nit:58 */
+    CALL_abstract_collection___SimpleCollection___add(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]);
+    stack_frame_head = fra.me.prev;
+    return;
+  }
 void program___Program___compute_main_method(val_t p0){
   struct {struct stack_frame_t me; val_t MORE_REG[2];} fra;
   val_t REGB0;
@@ -66,7 +266,7 @@ void program___Program___compute_main_method(val_t p0){
     static val_t once_value_5; /* Once value */
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
   fra.me.file = LOCATE_program;
-  fra.me.line = 36;
+  fra.me.line = 66;
   fra.me.meth = LOCATE_program___Program___compute_main_method;
   fra.me.has_broke = 0;
   fra.me.REG_size = 3;
@@ -74,7 +274,7 @@ void program___Program___compute_main_method(val_t p0){
   fra.me.REG[1] = NIT_NULL;
   fra.me.REG[2] = NIT_NULL;
   fra.me.REG[0] = p0;
-  /* ./program.nit:38 */
+  /* ./program.nit:68 */
   if (!once_value_1) {
     if (!once_value_2) {
       fra.me.REG[1] = BOX_NativeString("Sys");
@@ -83,20 +283,23 @@ void program___Program___compute_main_method(val_t p0){
       once_value_2 = fra.me.REG[1];
       register_static_object(&once_value_2);
     } else fra.me.REG[1] = once_value_2;
+    fra.me.REG[1] = fra.me.REG[1];
     fra.me.REG[1] = CALL_symbol___String___to_symbol(fra.me.REG[1])(fra.me.REG[1]);
     once_value_1 = fra.me.REG[1];
     register_static_object(&once_value_1);
   } else fra.me.REG[1] = once_value_1;
-  fra.me.REG[2] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]);
+  fra.me.REG[1] = fra.me.REG[1];
+  /* ./program.nit:69 */
+  fra.me.REG[2] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]);
   REGB0 = CALL_abstractmetamodel___MMModule___has_global_class_named(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
   REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
-  /* ./program.nit:39 */
   if (UNTAG_Bool(REGB0)) {
     goto label3;
   }
-  fra.me.REG[2] = CALL_program___Program___module(fra.me.REG[0])(fra.me.REG[0]);
+  /* ./program.nit:70 */
+  fra.me.REG[2] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]);
   fra.me.REG[1] = CALL_abstractmetamodel___MMModule___class_by_name(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
-  /* ./program.nit:43 */
+  /* ./program.nit:73 */
   if (!once_value_4) {
     if (!once_value_5) {
       fra.me.REG[2] = BOX_NativeString("main");
@@ -105,43 +308,942 @@ void program___Program___compute_main_method(val_t p0){
       once_value_5 = fra.me.REG[2];
       register_static_object(&once_value_5);
     } else fra.me.REG[2] = once_value_5;
+    fra.me.REG[2] = fra.me.REG[2];
     fra.me.REG[2] = CALL_symbol___String___to_symbol(fra.me.REG[2])(fra.me.REG[2]);
     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];
+  /* ./program.nit:74 */
   REGB0 = CALL_abstractmetamodel___MMLocalClass___has_global_property_by_name(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]);
   REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
-  /* ./program.nit:44 */
   if (UNTAG_Bool(REGB0)) {
     goto label3;
   }
+  /* ./program.nit:76 */
   fra.me.REG[2] = CALL_abstractmetamodel___MMLocalClass___select_method(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]);
-  /* ./program.nit:46 */
   ATTR_program___Program____main_method(fra.me.REG[0]) = fra.me.REG[2];
-  /* ./program.nit:47 */
+  /* ./program.nit:77 */
   ATTR_program___Program____main_class(fra.me.REG[0]) = fra.me.REG[1];
   label3: while(0);
   stack_frame_head = fra.me.prev;
   return;
 }
-void program___Program___init(val_t p0, val_t p1, int* init_table){
-  int itpos0 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_Program].i;
+void program___Program___generate_allocation_iroutines(val_t p0){
+  struct {struct stack_frame_t me; val_t MORE_REG[4];} fra;
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 80;
+  fra.me.meth = LOCATE_program___Program___generate_allocation_iroutines;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 5;
+  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[0] = p0;
+  /* ./program.nit:83 */
+  fra.me.REG[1] = CALL_program___Program___main_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]);
+  CALL_abstract_collection___Collection___iterate(fra.me.REG[1])(fra.me.REG[1], (&(fra.me)), ((fun_t)OC_program___Program___generate_allocation_iroutines_1));
+  stack_frame_head = fra.me.prev;
+  return;
+}
+  void OC_program___Program___generate_allocation_iroutines_1(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[1];} fra;
+    val_t REGB0;
+    val_t REGB1;
+    fun_t CREG[1];
+    val_t tmp;
+    fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+    fra.me.file = LOCATE_program;
+    fra.me.line = 0;
+    fra.me.meth = LOCATE_program___Program___generate_allocation_iroutines;
+    fra.me.has_broke = 0;
+    fra.me.REG_size = 2;
+    fra.me.REG[0] = NIT_NULL;
+    fra.me.REG[1] = NIT_NULL;
+    fra.me.closure_ctx = closctx_param;
+    fra.me.closure_funs = CREG;
+    fra.me.REG[0] = p0;
+    CREG[0] = clos_fun0;
+    closctx->REG[1] = fra.me.REG[0];
+    /* ./program.nit:84 */
+    fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass___global(closctx->REG[1])(closctx->REG[1]);
+    REGB0 = CALL_abstractmetamodel___MMGlobalClass___is_abstract(fra.me.REG[0])(fra.me.REG[0]);
+    if (UNTAG_Bool(REGB0)) {
+      REGB0 = TAG_Bool(true);
+    } else {
+      fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass___global(closctx->REG[1])(closctx->REG[1]);
+      REGB1 = CALL_abstractmetamodel___MMGlobalClass___is_interface(fra.me.REG[0])(fra.me.REG[0]);
+      REGB0 = REGB1;
+    }
+    if (UNTAG_Bool(REGB0)) {
+      goto label2;
+    }
+    /* ./program.nit:85 */
+    fra.me.REG[0] = CALL_primitive_info___MMLocalClass___primitive_info(closctx->REG[1])(closctx->REG[1]);
+    /* ./program.nit:86 */
+    REGB0 = TAG_Bool(fra.me.REG[0]==NIT_NULL);
+    if (UNTAG_Bool(REGB0)) {
+    } else {
+      REGB1 = TAG_Bool(fra.me.REG[0]==NIT_NULL);
+      if (UNTAG_Bool(REGB1)) {
+        REGB1 = TAG_Bool(false);
+        REGB0 = REGB1;
+      } else {
+        REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[0])(fra.me.REG[0], NIT_NULL);
+        REGB0 = REGB1;
+      }
+    }
+    if (UNTAG_Bool(REGB0)) {
+      /* ./program.nit:89 */
+      fra.me.REG[0] = CALL_static_type___MMLocalClass___get_type(closctx->REG[1])(closctx->REG[1]);
+      fra.me.REG[0] = NEW_IRegister_icode_base___IRegister___init(fra.me.REG[0]);
+      closctx->REG[2] = fra.me.REG[0];
+      /* ./program.nit:90 */
+      REGB0 = TAG_Int(1);
+      fra.me.REG[0] = NEW_Array_array___Array___with_capacity(REGB0);
+      CALL_abstract_collection___SimpleCollection___add(fra.me.REG[0])(fra.me.REG[0], closctx->REG[2]);
+      closctx->REG[3] = fra.me.REG[0];
+      /* ./program.nit:91 */
+      fra.me.REG[0] = NEW_IRoutine_icode_base___IRoutine___init(closctx->REG[3], NIT_NULL);
+      /* ./program.nit:92 */
+      fra.me.REG[1] = CALL_program___Program___main_module(closctx->REG[0])(closctx->REG[0]);
+      fra.me.REG[1] = NEW_ICodeBuilder_icode_builder___ICodeBuilder___init(fra.me.REG[1], fra.me.REG[0]);
+      closctx->REG[4] = fra.me.REG[1];
+      /* ./program.nit:94 */
+      fra.me.REG[1] = CALL_abstractmetamodel___MMLocalClass___global_properties(closctx->REG[1])(closctx->REG[1]);
+      CALL_abstract_collection___Collection___iterate(fra.me.REG[1])(fra.me.REG[1], closctx, ((fun_t)OC_program___Program___generate_allocation_iroutines_3));
+      /* ./program.nit:107 */
+      CALL_program___MMLocalClass___init_var_iroutine__eq(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]);
+      /* ./program.nit:111 */
+      fra.me.REG[0] = CALL_static_type___MMLocalClass___get_type(closctx->REG[1])(closctx->REG[1]);
+      fra.me.REG[0] = NEW_IRegister_icode_base___IRegister___init(fra.me.REG[0]);
+      closctx->REG[4] = fra.me.REG[0];
+      /* ./program.nit:112 */
+      REGB0 = TAG_Int(1);
+      fra.me.REG[0] = NEW_Array_array___Array___with_capacity(REGB0);
+      CALL_abstract_collection___SimpleCollection___add(fra.me.REG[0])(fra.me.REG[0], closctx->REG[4]);
+      /* ./program.nit:113 */
+      fra.me.REG[0] = NEW_IRoutine_icode_base___IRoutine___init(fra.me.REG[0], NIT_NULL);
+      /* ./program.nit:114 */
+      fra.me.REG[1] = CALL_program___Program___main_module(closctx->REG[0])(closctx->REG[0]);
+      fra.me.REG[1] = NEW_ICodeBuilder_icode_builder___ICodeBuilder___init(fra.me.REG[1], fra.me.REG[0]);
+      closctx->REG[2] = fra.me.REG[1];
+      /* ./program.nit:115 */
+      fra.me.REG[1] = CALL_abstractmetamodel___MMLocalClass___global_properties(closctx->REG[1])(closctx->REG[1]);
+      CALL_abstract_collection___Collection___iterate(fra.me.REG[1])(fra.me.REG[1], closctx, ((fun_t)OC_program___Program___generate_allocation_iroutines_5));
+      /* ./program.nit:124 */
+      CALL_program___MMLocalClass___checknew_iroutine__eq(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]);
+      /* ./program.nit:127 */
+      fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass___global_properties(closctx->REG[1])(closctx->REG[1]);
+      CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], closctx, ((fun_t)OC_program___Program___generate_allocation_iroutines_7));
+    }
+    label2: while(0);
+    stack_frame_head = fra.me.prev;
+    return;
+  }
+      void OC_program___Program___generate_allocation_iroutines_3(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[1];} fra;
+        val_t REGB0;
+        val_t REGB1;
+        fun_t CREG[1];
+        val_t tmp;
+        fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+        fra.me.file = LOCATE_program;
+        fra.me.line = 0;
+        fra.me.meth = LOCATE_program___Program___generate_allocation_iroutines;
+        fra.me.has_broke = 0;
+        fra.me.REG_size = 2;
+        fra.me.REG[0] = NIT_NULL;
+        fra.me.REG[1] = NIT_NULL;
+        fra.me.closure_ctx = closctx_param;
+        fra.me.closure_funs = CREG;
+        fra.me.REG[0] = p0;
+        CREG[0] = clos_fun0;
+        /* ./program.nit:95 */
+        fra.me.REG[1] = CALL_abstractmetamodel___MMGlobalProperty___intro(fra.me.REG[0])(fra.me.REG[0]);
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[1], COLOR_MMAttribute, ID_MMAttribute)) /*cast MMAttribute*/;
+        REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+        if (UNTAG_Bool(REGB0)) {
+          goto label4;
+        }
+        /* ./program.nit:96 */
+        fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass_____bra(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]);
+        /* ./program.nit:97 */
+        fra.me.REG[1] = CALL_static_type___MMLocalProperty___signature(fra.me.REG[0])(fra.me.REG[0]);
+        REGB0 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+        if (UNTAG_Bool(REGB0)) {
+          nit_abort("Reciever is null", NULL, LOCATE_program, 97);
+        }
+        fra.me.REG[1] = CALL_static_type___MMSignature___return_type(fra.me.REG[1])(fra.me.REG[1]);
+        /* ./program.nit:98 */
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[0], COLOR_MMAttribute, ID_MMAttribute)) /*cast MMAttribute*/;
+        if (UNTAG_Bool(REGB0)) {
+          REGB0 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+          if (UNTAG_Bool(REGB0)) {
+          } else {
+            REGB1 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+            if (UNTAG_Bool(REGB1)) {
+              REGB1 = TAG_Bool(false);
+              REGB0 = REGB1;
+            } else {
+              REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], NIT_NULL);
+              REGB0 = REGB1;
+            }
+          }
+          REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+        } else {
+          REGB1 = TAG_Bool(false);
+          REGB0 = REGB1;
+        }
+        if (UNTAG_Bool(REGB0)) {
+          /* ./program.nit:99 */
+          fra.me.REG[1] = CALL_icode_base___MMAttribute___iroutine(fra.me.REG[0])(fra.me.REG[0]);
+          /* ./program.nit:100 */
+          REGB0 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+          if (UNTAG_Bool(REGB0)) {
+          } else {
+            REGB1 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+            if (UNTAG_Bool(REGB1)) {
+              REGB1 = TAG_Bool(false);
+              REGB0 = REGB1;
+            } else {
+              REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], NIT_NULL);
+              REGB0 = REGB1;
+            }
+          }
+          if (UNTAG_Bool(REGB0)) {
+            goto label4;
+          }
+          /* ./program.nit:102 */
+          fra.me.REG[1] = CALL_icode_tools___ICodeBuilder___inline_routine(closctx->REG[4])(closctx->REG[4], fra.me.REG[1], closctx->REG[3], NIT_NULL);
+          REGB0 = TAG_Bool((fra.me.REG[1]!=NIT_NULL) && VAL_ISA(fra.me.REG[1], COLOR_IRegister, ID_IRegister)) /*cast IRegister*/;
+          if (UNTAG_Bool(REGB0)) {
+          } else {
+            nit_abort("Cast failed", NULL, LOCATE_program, 102);
+          }
+          /* ./program.nit:103 */
+          fra.me.REG[1] = NEW_IAttrWrite_icode_base___IAttrWrite___init(fra.me.REG[0], closctx->REG[2], fra.me.REG[1]);
+          CALL_icode_builder___ICodeBuilder___stmt(closctx->REG[4])(closctx->REG[4], fra.me.REG[1]);
+        }
+        label4: while(0);
+        stack_frame_head = fra.me.prev;
+        return;
+      }
+      void OC_program___Program___generate_allocation_iroutines_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; val_t MORE_REG[1];} fra;
+        val_t REGB0;
+        val_t REGB1;
+        fun_t CREG[1];
+        val_t tmp;
+        fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+        fra.me.file = LOCATE_program;
+        fra.me.line = 0;
+        fra.me.meth = LOCATE_program___Program___generate_allocation_iroutines;
+        fra.me.has_broke = 0;
+        fra.me.REG_size = 2;
+        fra.me.REG[0] = NIT_NULL;
+        fra.me.REG[1] = NIT_NULL;
+        fra.me.closure_ctx = closctx_param;
+        fra.me.closure_funs = CREG;
+        fra.me.REG[0] = p0;
+        CREG[0] = clos_fun0;
+        /* ./program.nit:116 */
+        fra.me.REG[1] = CALL_abstractmetamodel___MMGlobalProperty___intro(fra.me.REG[0])(fra.me.REG[0]);
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[1], COLOR_MMAttribute, ID_MMAttribute)) /*cast MMAttribute*/;
+        REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+        if (UNTAG_Bool(REGB0)) {
+          goto label6;
+        }
+        /* ./program.nit:117 */
+        fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass_____bra(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]);
+        /* ./program.nit:118 */
+        fra.me.REG[1] = CALL_static_type___MMLocalProperty___signature(fra.me.REG[0])(fra.me.REG[0]);
+        REGB0 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+        if (UNTAG_Bool(REGB0)) {
+          nit_abort("Reciever is null", NULL, LOCATE_program, 118);
+        }
+        fra.me.REG[1] = CALL_static_type___MMSignature___return_type(fra.me.REG[1])(fra.me.REG[1]);
+        /* ./program.nit:119 */
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[0], COLOR_MMAttribute, ID_MMAttribute)) /*cast MMAttribute*/;
+        if (UNTAG_Bool(REGB0)) {
+          REGB0 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+          if (UNTAG_Bool(REGB0)) {
+          } else {
+            REGB1 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+            if (UNTAG_Bool(REGB1)) {
+              REGB1 = TAG_Bool(false);
+              REGB0 = REGB1;
+            } else {
+              REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], NIT_NULL);
+              REGB0 = REGB1;
+            }
+          }
+          REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+        } else {
+          REGB1 = TAG_Bool(false);
+          REGB0 = REGB1;
+        }
+        if (UNTAG_Bool(REGB0)) {
+          REGB0 = TAG_Bool(fra.me.REG[1]==NIT_NULL);
+          if (UNTAG_Bool(REGB0)) {
+            nit_abort("Reciever is null", NULL, LOCATE_program, 119);
+          }
+          REGB0 = CALL_static_type___MMType___is_nullable(fra.me.REG[1])(fra.me.REG[1]);
+          REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+        } else {
+          REGB1 = TAG_Bool(false);
+          REGB0 = REGB1;
+        }
+        if (UNTAG_Bool(REGB0)) {
+          /* ./program.nit:120 */
+          CALL_icode_builder___ICodeBuilder___add_attr_check(closctx->REG[2])(closctx->REG[2], fra.me.REG[0], closctx->REG[4]);
+        }
+        label6: while(0);
+        stack_frame_head = fra.me.prev;
+        return;
+      }
+      void OC_program___Program___generate_allocation_iroutines_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[5];} fra;
+        val_t REGB0;
+        val_t REGB1;
+        val_t REGB2;
+        val_t REGB3;
+        fun_t CREG[1];
+        val_t tmp;
+        fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+        fra.me.file = LOCATE_program;
+        fra.me.line = 0;
+        fra.me.meth = LOCATE_program___Program___generate_allocation_iroutines;
+        fra.me.has_broke = 0;
+        fra.me.REG_size = 6;
+        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.closure_ctx = closctx_param;
+        fra.me.closure_funs = CREG;
+        fra.me.REG[0] = p0;
+        CREG[0] = clos_fun0;
+        /* ./program.nit:129 */
+        REGB0 = CALL_abstractmetamodel___MMGlobalProperty___is_init_for(fra.me.REG[0])(fra.me.REG[0], closctx->REG[1]);
+        REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+        if (UNTAG_Bool(REGB0)) {
+          goto label8;
+        }
+        /* ./program.nit:130 */
+        fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass_____bra(closctx->REG[1])(closctx->REG[1], fra.me.REG[0]);
+        /* ./program.nit:131 */
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[0], COLOR_MMMethod, ID_MMMethod)) /*cast MMMethod*/;
+        if (UNTAG_Bool(REGB0)) {
+        } else {
+          nit_abort("Assert failed", NULL, LOCATE_program, 131);
+        }
+        /* ./program.nit:133 */
+        fra.me.REG[1] = CALL_static_type___MMLocalClass___get_type(closctx->REG[1])(closctx->REG[1]);
+        fra.me.REG[1] = NEW_IRegister_icode_base___IRegister___init(fra.me.REG[1]);
+        /* ./program.nit:134 */
+        fra.me.REG[2] = NEW_Array_array___Array___init();
+        /* ./program.nit:135 */
+        REGB0 = TAG_Int(0);
+        fra.me.REG[3] = CALL_static_type___MMLocalProperty___signature(fra.me.REG[0])(fra.me.REG[0]);
+        REGB1 = TAG_Bool(fra.me.REG[3]==NIT_NULL);
+        if (UNTAG_Bool(REGB1)) {
+          nit_abort("Reciever is null", NULL, LOCATE_program, 135);
+        }
+        REGB1 = CALL_static_type___MMSignature___arity(fra.me.REG[3])(fra.me.REG[3]);
+        /* ./../lib/standard//kernel.nit:332 */
+        while(1) {
+          /* ./../lib/standard//kernel.nit:212 */
+          REGB2 = TAG_Bool(UNTAG_Int(REGB0)<UNTAG_Int(REGB1));
+          /* ./../lib/standard//kernel.nit:332 */
+          if (UNTAG_Bool(REGB2)) {
+            /* ./program.nit:135 */
+            REGB2 = REGB0;
+            fra.me.REG[3] = CALL_static_type___MMLocalProperty___signature(fra.me.REG[0])(fra.me.REG[0]);
+            REGB3 = TAG_Bool(fra.me.REG[3]==NIT_NULL);
+            if (UNTAG_Bool(REGB3)) {
+              nit_abort("Reciever is null", NULL, LOCATE_program, 135);
+            }
+            fra.me.REG[3] = CALL_static_type___MMSignature_____bra(fra.me.REG[3])(fra.me.REG[3], REGB2);
+            fra.me.REG[3] = NEW_IRegister_icode_base___IRegister___init(fra.me.REG[3]);
+            CALL_abstract_collection___SimpleCollection___add(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]);
+            /* ./../lib/standard//kernel.nit:334 */
+            REGB2 = TAG_Int(1);
+            /* ./../lib/standard//kernel.nit:215 */
+            REGB2 = TAG_Int(UNTAG_Int(REGB0)+UNTAG_Int(REGB2));
+            /* ./../lib/standard//kernel.nit:334 */
+            REGB0 = REGB2;
+          } else {
+            /* ./../lib/standard//kernel.nit:332 */
+            goto label9;
+          }
+        }
+        label9: while(0);
+        /* ./program.nit:136 */
+        fra.me.REG[3] = NEW_IRoutine_icode_base___IRoutine___init(fra.me.REG[2], fra.me.REG[1]);
+        /* ./program.nit:137 */
+        fra.me.REG[4] = CALL_icode_base___MMMethod___iroutine(fra.me.REG[0])(fra.me.REG[0]);
+        REGB0 = TAG_Bool(fra.me.REG[4]==NIT_NULL);
+        if (UNTAG_Bool(REGB0)) {
+          nit_abort("Reciever is null", NULL, LOCATE_program, 137);
+        }
+        fra.me.REG[4] = CALL_icode_base___IRoutine___location(fra.me.REG[4])(fra.me.REG[4]);
+        CALL_icode_base___IRoutine___location__eq(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]);
+        /* ./program.nit:138 */
+        fra.me.REG[4] = CALL_program___Program___main_module(closctx->REG[0])(closctx->REG[0]);
+        fra.me.REG[4] = NEW_ICodeBuilder_icode_builder___ICodeBuilder___init(fra.me.REG[4], fra.me.REG[3]);
+        /* ./program.nit:140 */
+        fra.me.REG[5] = CALL_static_type___MMLocalClass___get_type(closctx->REG[1])(closctx->REG[1]);
+        fra.me.REG[5] = NEW_IAllocateInstance_icode_base___IAllocateInstance___init(fra.me.REG[5]);
+        /* ./program.nit:141 */
+        CALL_icode_base___ICode___result__eq(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[1]);
+        /* ./program.nit:142 */
+        CALL_icode_builder___ICodeBuilder___stmt(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]);
+        /* ./program.nit:143 */
+        REGB0 = TAG_Int(1);
+        fra.me.REG[5] = NEW_Array_array___Array___with_capacity(REGB0);
+        CALL_abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[1]);
+        /* ./program.nit:144 */
+        CALL_abstract_collection___SimpleCollection___add_all(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[2]);
+        /* ./program.nit:146 */
+        fra.me.REG[2] = CALL_static_type___MMLocalClass___get_type(closctx->REG[1])(closctx->REG[1]);
+        fra.me.REG[2] = NEW_IInitAttributes_icode_base___IInitAttributes___init(fra.me.REG[2], fra.me.REG[1]);
+        CALL_icode_builder___ICodeBuilder___stmt(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]);
+        /* ./program.nit:147 */
+        fra.me.REG[5] = NEW_IStaticCall_icode_base___IStaticCall___init(fra.me.REG[0], fra.me.REG[5]);
+        CALL_icode_builder___ICodeBuilder___stmt(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[5]);
+        /* ./program.nit:148 */
+        fra.me.REG[5] = CALL_static_type___MMLocalClass___get_type(closctx->REG[1])(closctx->REG[1]);
+        fra.me.REG[1] = NEW_ICheckInstance_icode_base___ICheckInstance___init(fra.me.REG[5], fra.me.REG[1]);
+        CALL_icode_builder___ICodeBuilder___stmt(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
+        /* ./program.nit:150 */
+        fra.me.REG[1] = CALL_program___MMLocalClass___new_instance_iroutine(closctx->REG[1])(closctx->REG[1]);
+        CALL_abstract_collection___Map_____braeq(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[0], fra.me.REG[3]);
+        label8: while(0);
+        stack_frame_head = fra.me.prev;
+        return;
+      }
+void program___Program___with_each_iroutines(val_t p0, struct stack_frame_t *closctx_param, fun_t clos_fun0){
   struct {struct stack_frame_t me; val_t MORE_REG[1];} fra;
+  val_t REGB0;
+  fun_t CREG[1];
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 156;
+  fra.me.meth = LOCATE_program___Program___with_each_iroutines;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 2;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[1] = NIT_NULL;
+  fra.me.closure_ctx = closctx_param;
+  fra.me.closure_funs = CREG;
+  fra.me.REG[0] = p0;
+  CREG[0] = clos_fun0;
+  /* ./program.nit:161 */
+  fra.me.REG[0] = CALL_program___Program___main_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]);
+  REGB0 = TAG_Bool(fra.me.REG[0]==NIT_NULL);
+  if (UNTAG_Bool(REGB0)) {
+    nit_abort("Reciever is null", NULL, LOCATE_program, 161);
+  }
+  fra.me.REG[0] = CALL_partial_order___PartialOrderElement___greaters_and_self(fra.me.REG[0])(fra.me.REG[0]);
+  CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], (&(fra.me)), ((fun_t)OC_program___Program___with_each_iroutines_1));
+  switch ((&(fra.me))->has_broke) {
+    case 0: break;
+    case 1: (&(fra.me))->has_broke = 0; goto label9;
+  }
+  label9: while(0);
+  stack_frame_head = fra.me.prev;
+  return;
+}
+  void OC_program___Program___with_each_iroutines_1(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_program;
+    fra.me.line = 0;
+    fra.me.meth = LOCATE_program___Program___with_each_iroutines;
+    fra.me.has_broke = 0;
+    fra.me.REG_size = 1;
+    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;
+    closctx->REG[0] = fra.me.REG[0];
+    /* ./program.nit:162 */
+    fra.me.REG[0] = CALL_abstractmetamodel___MMModule___local_classes(closctx->REG[0])(closctx->REG[0]);
+    CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], closctx, ((fun_t)OC_program___Program___with_each_iroutines_2));
+    switch (closctx->has_broke) {
+      case 0: break;
+      default: goto label8;
+    }
+    label8: while(0);
+    stack_frame_head = fra.me.prev;
+    return;
+  }
+    void OC_program___Program___with_each_iroutines_2(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[1];} fra;
+      val_t REGB0;
+      val_t REGB1;
+      fun_t CREG[1];
+      val_t tmp;
+      fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+      fra.me.file = LOCATE_program;
+      fra.me.line = 0;
+      fra.me.meth = LOCATE_program___Program___with_each_iroutines;
+      fra.me.has_broke = 0;
+      fra.me.REG_size = 2;
+      fra.me.REG[0] = NIT_NULL;
+      fra.me.REG[1] = NIT_NULL;
+      fra.me.closure_ctx = closctx_param;
+      fra.me.closure_funs = CREG;
+      fra.me.REG[0] = p0;
+      CREG[0] = clos_fun0;
+      /* ./program.nit:163 */
+      closctx->REG[1] = NIT_NULL;
+      /* ./program.nit:166 */
+      fra.me.REG[1] = CALL_abstractmetamodel___MMLocalClass___local_local_properties(fra.me.REG[0])(fra.me.REG[0]);
+      CALL_abstract_collection___Collection___iterate(fra.me.REG[1])(fra.me.REG[1], closctx, ((fun_t)OC_program___Program___with_each_iroutines_3));
+      switch (closctx->has_broke) {
+        case 0: break;
+        default: goto label5;
+      }
+      /* ./program.nit:177 */
+      fra.me.REG[1] = CALL_program___MMLocalClass___init_var_iroutine(fra.me.REG[0])(fra.me.REG[0]);
+      closctx->REG[1] = fra.me.REG[1];
+      /* ./program.nit:178 */
+      REGB0 = TAG_Bool(closctx->REG[1]==NIT_NULL);
+      if (UNTAG_Bool(REGB0)) {
+      } else {
+        REGB1 = TAG_Bool(closctx->REG[1]==NIT_NULL);
+        if (UNTAG_Bool(REGB1)) {
+          REGB1 = TAG_Bool(false);
+          REGB0 = REGB1;
+        } else {
+          REGB1 = CALL_kernel___Object_____eqeq(closctx->REG[1])(closctx->REG[1], NIT_NULL);
+          REGB0 = REGB1;
+        }
+      }
+      REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+      if (UNTAG_Bool(REGB0)) {
+        /* ./program.nit:179 */
+        ((void (*)(struct stack_frame_t *, val_t, val_t))(closctx->closure_funs[0]))(closctx->closure_ctx, closctx->REG[1], closctx->REG[0]);
+        if (closctx->closure_ctx->has_broke) {
+          closctx->has_broke = 1;
+          goto label5;
+        }
+      }
+      /* ./program.nit:181 */
+      fra.me.REG[1] = CALL_program___MMLocalClass___checknew_iroutine(fra.me.REG[0])(fra.me.REG[0]);
+      closctx->REG[1] = fra.me.REG[1];
+      /* ./program.nit:182 */
+      REGB0 = TAG_Bool(closctx->REG[1]==NIT_NULL);
+      if (UNTAG_Bool(REGB0)) {
+      } else {
+        REGB1 = TAG_Bool(closctx->REG[1]==NIT_NULL);
+        if (UNTAG_Bool(REGB1)) {
+          REGB1 = TAG_Bool(false);
+          REGB0 = REGB1;
+        } else {
+          REGB1 = CALL_kernel___Object_____eqeq(closctx->REG[1])(closctx->REG[1], NIT_NULL);
+          REGB0 = REGB1;
+        }
+      }
+      REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
+      if (UNTAG_Bool(REGB0)) {
+        /* ./program.nit:183 */
+        ((void (*)(struct stack_frame_t *, val_t, val_t))(closctx->closure_funs[0]))(closctx->closure_ctx, closctx->REG[1], closctx->REG[0]);
+        if (closctx->closure_ctx->has_broke) {
+          closctx->has_broke = 1;
+          goto label5;
+        }
+      }
+      /* ./program.nit:185 */
+      fra.me.REG[0] = CALL_program___MMLocalClass___new_instance_iroutine(fra.me.REG[0])(fra.me.REG[0]);
+      CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], closctx, ((fun_t)OC_program___Program___with_each_iroutines_6));
+      switch (closctx->has_broke) {
+        case 0: break;
+        default: goto label5;
+      }
+      label5: while(0);
+      stack_frame_head = fra.me.prev;
+      return;
+    }
+      void OC_program___Program___with_each_iroutines_3(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[1];} fra;
+        val_t REGB0;
+        val_t REGB1;
+        fun_t CREG[1];
+        val_t tmp;
+        fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+        fra.me.file = LOCATE_program;
+        fra.me.line = 0;
+        fra.me.meth = LOCATE_program___Program___with_each_iroutines;
+        fra.me.has_broke = 0;
+        fra.me.REG_size = 2;
+        fra.me.REG[0] = NIT_NULL;
+        fra.me.REG[1] = NIT_NULL;
+        fra.me.closure_ctx = closctx_param;
+        fra.me.closure_funs = CREG;
+        fra.me.REG[0] = p0;
+        CREG[0] = clos_fun0;
+        /* ./program.nit:167 */
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[0], COLOR_MMAttribute, ID_MMAttribute)) /*cast MMAttribute*/;
+        if (UNTAG_Bool(REGB0)) {
+          /* ./program.nit:168 */
+          fra.me.REG[1] = CALL_icode_base___MMAttribute___iroutine(fra.me.REG[0])(fra.me.REG[0]);
+          closctx->REG[1] = fra.me.REG[1];
+        } else {
+          /* ./program.nit:169 */
+          REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[0], COLOR_MMMethod, ID_MMMethod)) /*cast MMMethod*/;
+          if (UNTAG_Bool(REGB0)) {
+            /* ./program.nit:170 */
+            fra.me.REG[0] = CALL_icode_base___MMMethod___iroutine(fra.me.REG[0])(fra.me.REG[0]);
+            closctx->REG[1] = fra.me.REG[0];
+          }
+        }
+        /* ./program.nit:172 */
+        REGB0 = TAG_Bool(closctx->REG[1]==NIT_NULL);
+        if (UNTAG_Bool(REGB0)) {
+        } else {
+          REGB1 = TAG_Bool(closctx->REG[1]==NIT_NULL);
+          if (UNTAG_Bool(REGB1)) {
+            REGB1 = TAG_Bool(false);
+            REGB0 = REGB1;
+          } else {
+            REGB1 = CALL_kernel___Object_____eqeq(closctx->REG[1])(closctx->REG[1], NIT_NULL);
+            REGB0 = REGB1;
+          }
+        }
+        if (UNTAG_Bool(REGB0)) {
+          goto label4;
+        }
+        /* ./program.nit:173 */
+        ((void (*)(struct stack_frame_t *, val_t, val_t))(closctx->closure_funs[0]))(closctx->closure_ctx, closctx->REG[1], closctx->REG[0]);
+        if (closctx->closure_ctx->has_broke) {
+          closctx->has_broke = 1;
+          goto label4;
+        }
+        label4: while(0);
+        stack_frame_head = fra.me.prev;
+        return;
+      }
+      void OC_program___Program___with_each_iroutines_6(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_program;
+        fra.me.line = 0;
+        fra.me.meth = LOCATE_program___Program___with_each_iroutines;
+        fra.me.has_broke = 0;
+        fra.me.REG_size = 1;
+        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;
+        /* ./program.nit:186 */
+        ((void (*)(struct stack_frame_t *, val_t, val_t))(closctx->closure_funs[0]))(closctx->closure_ctx, fra.me.REG[0], closctx->REG[0]);
+        if (closctx->closure_ctx->has_broke) {
+          closctx->has_broke = 1;
+          goto label7;
+        }
+        label7: while(0);
+        stack_frame_head = fra.me.prev;
+        return;
+      }
+void program___Program___with_each_methods(val_t p0, struct stack_frame_t *closctx_param, fun_t clos_fun0){
+  struct {struct stack_frame_t me;} fra;
+  val_t REGB0;
+  fun_t CREG[1];
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 192;
+  fra.me.meth = LOCATE_program___Program___with_each_methods;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  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;
+  /* ./program.nit:197 */
+  fra.me.REG[0] = CALL_program___Program___main_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]);
+  REGB0 = TAG_Bool(fra.me.REG[0]==NIT_NULL);
+  if (UNTAG_Bool(REGB0)) {
+    nit_abort("Reciever is null", NULL, LOCATE_program, 197);
+  }
+  fra.me.REG[0] = CALL_partial_order___PartialOrderElement___greaters_and_self(fra.me.REG[0])(fra.me.REG[0]);
+  CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], (&(fra.me)), ((fun_t)OC_program___Program___with_each_methods_1));
+  switch ((&(fra.me))->has_broke) {
+    case 0: break;
+    case 1: (&(fra.me))->has_broke = 0; goto label7;
+  }
+  label7: while(0);
+  stack_frame_head = fra.me.prev;
+  return;
+}
+  void OC_program___Program___with_each_methods_1(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_program;
+    fra.me.line = 0;
+    fra.me.meth = LOCATE_program___Program___with_each_methods;
+    fra.me.has_broke = 0;
+    fra.me.REG_size = 1;
+    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;
+    /* ./program.nit:198 */
+    fra.me.REG[0] = CALL_abstractmetamodel___MMModule___local_classes(fra.me.REG[0])(fra.me.REG[0]);
+    CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], closctx, ((fun_t)OC_program___Program___with_each_methods_2));
+    switch (closctx->has_broke) {
+      case 0: break;
+      default: goto label6;
+    }
+    label6: while(0);
+    stack_frame_head = fra.me.prev;
+    return;
+  }
+    void OC_program___Program___with_each_methods_2(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_program;
+      fra.me.line = 0;
+      fra.me.meth = LOCATE_program___Program___with_each_methods;
+      fra.me.has_broke = 0;
+      fra.me.REG_size = 1;
+      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;
+      /* ./program.nit:200 */
+      fra.me.REG[0] = CALL_abstractmetamodel___MMLocalClass___local_local_properties(fra.me.REG[0])(fra.me.REG[0]);
+      CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], closctx, ((fun_t)OC_program___Program___with_each_methods_3));
+      switch (closctx->has_broke) {
+        case 0: break;
+        default: goto label5;
+      }
+      label5: while(0);
+      stack_frame_head = fra.me.prev;
+      return;
+    }
+      void OC_program___Program___with_each_methods_3(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;
+        val_t REGB0;
+        fun_t CREG[1];
+        val_t tmp;
+        fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+        fra.me.file = LOCATE_program;
+        fra.me.line = 0;
+        fra.me.meth = LOCATE_program___Program___with_each_methods;
+        fra.me.has_broke = 0;
+        fra.me.REG_size = 1;
+        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;
+        /* ./program.nit:201 */
+        REGB0 = TAG_Bool(VAL_ISA(fra.me.REG[0], COLOR_MMMethod, ID_MMMethod)) /*cast MMMethod*/;
+        if (UNTAG_Bool(REGB0)) {
+          /* ./program.nit:202 */
+          ((void (*)(struct stack_frame_t *, val_t))(closctx->closure_funs[0]))(closctx->closure_ctx, fra.me.REG[0]);
+          if (closctx->closure_ctx->has_broke) {
+            closctx->has_broke = 1;
+            goto label4;
+          }
+        }
+        label4: while(0);
+        stack_frame_head = fra.me.prev;
+        return;
+      }
+void program___Program___with_each_live_local_classes(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_program;
+  fra.me.line = 209;
+  fra.me.meth = LOCATE_program___Program___with_each_live_local_classes;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  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;
+  /* ./program.nit:214 */
+  fra.me.REG[0] = CALL_program___Program___main_module(fra.me.REG[0])(fra.me.REG[0]);
+  fra.me.REG[0] = CALL_abstractmetamodel___MMModule___local_classes(fra.me.REG[0])(fra.me.REG[0]);
+  CALL_abstract_collection___Collection___iterate(fra.me.REG[0])(fra.me.REG[0], (&(fra.me)), ((fun_t)OC_program___Program___with_each_live_local_classes_1));
+  switch ((&(fra.me))->has_broke) {
+    case 0: break;
+    case 1: (&(fra.me))->has_broke = 0; goto label3;
+  }
+  label3: while(0);
+  stack_frame_head = fra.me.prev;
+  return;
+}
+  void OC_program___Program___with_each_live_local_classes_1(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_program;
+    fra.me.line = 0;
+    fra.me.meth = LOCATE_program___Program___with_each_live_local_classes;
+    fra.me.has_broke = 0;
+    fra.me.REG_size = 1;
+    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;
+    /* ./program.nit:215 */
+    ((void (*)(struct stack_frame_t *, val_t))(closctx->closure_funs[0]))(closctx->closure_ctx, fra.me.REG[0]);
+    if (closctx->closure_ctx->has_broke) {
+      closctx->has_broke = 1;
+      goto label2;
+    }
+    label2: while(0);
+    stack_frame_head = fra.me.prev;
+    return;
+  }
+void program___Program___init(val_t p0, val_t p1, val_t p2, int* init_table){
+  int itpos0 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_Program].i;
+  struct {struct stack_frame_t me; val_t MORE_REG[2];} fra;
   val_t tmp;
   if (init_table[itpos0]) return;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
   fra.me.file = LOCATE_program;
-  fra.me.line = 50;
+  fra.me.line = 219;
   fra.me.meth = LOCATE_program___Program___init;
   fra.me.has_broke = 0;
-  fra.me.REG_size = 2;
+  fra.me.REG_size = 3;
   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] = p1;
-  /* ./program.nit:51 */
-  ATTR_program___Program____module(fra.me.REG[0]) = fra.me.REG[1];
+  fra.me.REG[2] = p2;
+  /* ./program.nit:220 */
+  ATTR_program___Program____main_module(fra.me.REG[0]) = fra.me.REG[1];
+  /* ./program.nit:221 */
+  ATTR_program___Program____tc(fra.me.REG[0]) = fra.me.REG[2];
+  /* ./program.nit:222 */
+  CALL_program___Program___finish_processing_classes(fra.me.REG[0])(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   init_table[itpos0] = 1;
   return;
 }
+val_t program___MMLocalClass___init_var_iroutine(val_t p0){
+  struct {struct stack_frame_t me;} fra;
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 227;
+  fra.me.meth = LOCATE_program___MMLocalClass___init_var_iroutine;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:227 */
+  fra.me.REG[0] = ATTR_program___MMLocalClass____init_var_iroutine(fra.me.REG[0]);
+  stack_frame_head = fra.me.prev;
+  return fra.me.REG[0];
+}
+void program___MMLocalClass___init_var_iroutine__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_program;
+  fra.me.line = 227;
+  fra.me.meth = LOCATE_program___MMLocalClass___init_var_iroutine__eq;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 2;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[1] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  fra.me.REG[1] = p1;
+  /* ./program.nit:227 */
+  ATTR_program___MMLocalClass____init_var_iroutine(fra.me.REG[0]) = fra.me.REG[1];
+  stack_frame_head = fra.me.prev;
+  return;
+}
+val_t program___MMLocalClass___checknew_iroutine(val_t p0){
+  struct {struct stack_frame_t me;} fra;
+  val_t tmp;
+  fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
+  fra.me.file = LOCATE_program;
+  fra.me.line = 229;
+  fra.me.meth = LOCATE_program___MMLocalClass___checknew_iroutine;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:229 */
+  fra.me.REG[0] = ATTR_program___MMLocalClass____checknew_iroutine(fra.me.REG[0]);
+  stack_frame_head = fra.me.prev;
+  return fra.me.REG[0];
+}
+void program___MMLocalClass___checknew_iroutine__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_program;
+  fra.me.line = 229;
+  fra.me.meth = LOCATE_program___MMLocalClass___checknew_iroutine__eq;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 2;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[1] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  fra.me.REG[1] = p1;
+  /* ./program.nit:229 */
+  ATTR_program___MMLocalClass____checknew_iroutine(fra.me.REG[0]) = fra.me.REG[1];
+  stack_frame_head = fra.me.prev;
+  return;
+}
+val_t program___MMLocalClass___new_instance_iroutine(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_program;
+  fra.me.line = 231;
+  fra.me.meth = LOCATE_program___MMLocalClass___new_instance_iroutine;
+  fra.me.has_broke = 0;
+  fra.me.REG_size = 1;
+  fra.me.REG[0] = NIT_NULL;
+  fra.me.REG[0] = p0;
+  /* ./program.nit:231 */
+  REGB0 = TAG_Bool(ATTR_program___MMLocalClass____new_instance_iroutine(fra.me.REG[0])!=NIT_NULL);
+  if (UNTAG_Bool(REGB0)) {
+  } else {
+    nit_abort("Uninitialized attribute %s", "_new_instance_iroutine", LOCATE_program, 231);
+  }
+  fra.me.REG[0] = ATTR_program___MMLocalClass____new_instance_iroutine(fra.me.REG[0]);
+  stack_frame_head = fra.me.prev;
+  return fra.me.REG[0];
+}