c_src: update
[nit.git] / c_src / syntax___flow._sep.c
similarity index 51%
rename from c_src/flow._sep.c
rename to c_src/syntax___flow._sep.c
index 123c5cf..fd2e601 100644 (file)
@@ -1,6 +1,6 @@
-/* This C file is generated by NIT to compile module flow. */
-#include "flow._sep.h"
-void flow___FlowContext___check_is_set(val_t p0, val_t p1, val_t p2){
+/* This C file is generated by NIT to compile module syntax___flow. */
+#include "syntax___flow._sep.h"
+void syntax___flow___FlowContext___check_is_set(val_t p0, val_t p1, val_t p2){
   struct {struct stack_frame_t me; val_t MORE_REG[4];} fra;
   val_t REGB0;
   val_t REGB1;
@@ -8,9 +8,9 @@ void flow___FlowContext___check_is_set(val_t p0, val_t p1, val_t p2){
     static val_t once_value_1; /* Once value */
     static val_t once_value_2; /* Once value */
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 34;
-  fra.me.meth = LOCATE_flow___FlowContext___check_is_set;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___check_is_set;
   fra.me.has_broke = 0;
   fra.me.REG_size = 5;
   fra.me.REG[0] = NIT_NULL;
@@ -22,9 +22,9 @@ void flow___FlowContext___check_is_set(val_t p0, val_t p1, val_t p2){
   fra.me.REG[1] = p1;
   fra.me.REG[2] = p2;
   /* ./syntax//flow.nit:37 */
-  REGB0 = CALL_flow___Variable___must_be_set(fra.me.REG[2])(fra.me.REG[2]);
+  REGB0 = CALL_syntax___flow___Variable___must_be_set(fra.me.REG[2])(fra.me.REG[2]);
   if (UNTAG_Bool(REGB0)) {
-    REGB0 = CALL_flow___FlowContext___is_set(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]);
+    REGB0 = CALL_syntax___flow___FlowContext___is_set(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[2]);
     REGB0 = TAG_Bool(!UNTAG_Bool(REGB0));
   } else {
     REGB1 = TAG_Bool(false);
@@ -32,47 +32,47 @@ void flow___FlowContext___check_is_set(val_t p0, val_t p1, val_t p2){
   }
   if (UNTAG_Bool(REGB0)) {
     /* ./syntax//flow.nit:38 */
-    REGB0 = TAG_Bool(ATTR_flow___FlowContext____visitor(fra.me.REG[0])!=NIT_NULL);
+    REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB0)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_flow, 38);
+      nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_syntax___flow, 38);
     }
-    fra.me.REG[0] = ATTR_flow___FlowContext____visitor(fra.me.REG[0]);
+    fra.me.REG[0] = ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[0]);
     REGB0 = TAG_Int(3);
-    fra.me.REG[3] = NEW_Array_array___Array___with_capacity(REGB0);
+    fra.me.REG[3] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0);
     if (!once_value_1) {
       fra.me.REG[4] = BOX_NativeString("Error: variable '");
       REGB0 = TAG_Int(17);
-      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_1 = fra.me.REG[4];
       register_static_object(&once_value_1);
     } else fra.me.REG[4] = once_value_1;
     fra.me.REG[4] = fra.me.REG[4];
-    CALL_abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]);
-    fra.me.REG[2] = CALL_string___Object___to_s(fra.me.REG[2])(fra.me.REG[2]);
-    CALL_abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2]);
+    CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[4]);
+    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[3])(fra.me.REG[3], fra.me.REG[2]);
     if (!once_value_2) {
       fra.me.REG[2] = BOX_NativeString("' is possibly unset.");
       REGB0 = TAG_Int(20);
-      fra.me.REG[2] = NEW_String_string___String___with_native(fra.me.REG[2], REGB0);
+      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[2] = once_value_2;
     fra.me.REG[2] = fra.me.REG[2];
-    CALL_abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2]);
-    fra.me.REG[3] = CALL_string___Object___to_s(fra.me.REG[3])(fra.me.REG[3]);
-    CALL_syntax_base___AbsSyntaxVisitor___error(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[3]);
+    CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[2]);
+    fra.me.REG[3] = CALL_standard___string___Object___to_s(fra.me.REG[3])(fra.me.REG[3]);
+    CALL_syntax___syntax_base___AbsSyntaxVisitor___error(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[3]);
   }
   stack_frame_head = fra.me.prev;
   return;
 }
-val_t flow___FlowContext___stype(val_t p0, val_t p1){
+val_t syntax___flow___FlowContext___stype(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 42;
-  fra.me.meth = LOCATE_flow___FlowContext___stype;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___stype;
   fra.me.has_broke = 0;
   fra.me.REG_size = 2;
   fra.me.REG[0] = NIT_NULL;
@@ -80,20 +80,20 @@ val_t flow___FlowContext___stype(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:46 */
-  fra.me.REG[1] = CALL_syntax_base___Variable___stype(fra.me.REG[1])(fra.me.REG[1]);
+  fra.me.REG[1] = CALL_syntax___syntax_base___Variable___stype(fra.me.REG[1])(fra.me.REG[1]);
   goto label1;
   label1: while(0);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[1];
 }
-val_t flow___FlowContext___sub_setvariable(val_t p0, val_t p1){
+val_t syntax___flow___FlowContext___sub_setvariable(val_t p0, val_t p1){
   struct {struct stack_frame_t me; val_t MORE_REG[2];} fra;
   val_t REGB0;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 49;
-  fra.me.meth = LOCATE_flow___FlowContext___sub_setvariable;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___sub_setvariable;
   fra.me.has_broke = 0;
   fra.me.REG_size = 3;
   fra.me.REG[0] = NIT_NULL;
@@ -102,30 +102,30 @@ val_t flow___FlowContext___sub_setvariable(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:52 */
-  fra.me.REG[2] = CALL_flow___FlowContext___node(fra.me.REG[0])(fra.me.REG[0]);
-  fra.me.REG[2] = NEW_SubFlowContext_flow___SubFlowContext___with_prev(fra.me.REG[0], fra.me.REG[2]);
+  fra.me.REG[2] = CALL_syntax___flow___FlowContext___node(fra.me.REG[0])(fra.me.REG[0]);
+  fra.me.REG[2] = NEW_SubFlowContext_syntax___flow___SubFlowContext___with_prev(fra.me.REG[0], fra.me.REG[2]);
   /* ./syntax//flow.nit:53 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____set_variables(fra.me.REG[2])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[2])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_flow, 53);
+    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_syntax___flow, 53);
   }
-  fra.me.REG[0] = ATTR_flow___FlowContext____set_variables(fra.me.REG[2]);
-  CALL_abstract_collection___SimpleCollection___add(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+  fra.me.REG[0] = ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[2]);
+  CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
   /* ./syntax//flow.nit:54 */
   goto label1;
   label1: while(0);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[2];
 }
-val_t flow___FlowContext___sub_unreash(val_t p0, val_t p1){
+val_t syntax___flow___FlowContext___sub_unreash(val_t p0, val_t p1){
   struct {struct stack_frame_t me; val_t MORE_REG[1];} fra;
   val_t REGB0;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 57;
-  fra.me.meth = LOCATE_flow___FlowContext___sub_unreash;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___sub_unreash;
   fra.me.has_broke = 0;
   fra.me.REG_size = 2;
   fra.me.REG[0] = NIT_NULL;
@@ -133,23 +133,23 @@ val_t flow___FlowContext___sub_unreash(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:60 */
-  fra.me.REG[1] = NEW_SubFlowContext_flow___SubFlowContext___with_prev(fra.me.REG[0], fra.me.REG[1]);
+  fra.me.REG[1] = NEW_SubFlowContext_syntax___flow___SubFlowContext___with_prev(fra.me.REG[0], fra.me.REG[1]);
   /* ./syntax//flow.nit:61 */
   REGB0 = TAG_Bool(true);
-  ATTR_flow___FlowContext____unreash(fra.me.REG[1]) = REGB0;
+  ATTR_syntax___flow___FlowContext____unreash(fra.me.REG[1]) = REGB0;
   /* ./syntax//flow.nit:62 */
   goto label1;
   label1: while(0);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[1];
 }
-val_t flow___FlowContext___sub_with(val_t p0, val_t p1, val_t p2, val_t p3){
+val_t syntax___flow___FlowContext___sub_with(val_t p0, val_t p1, val_t p2, val_t p3){
   struct {struct stack_frame_t me; val_t MORE_REG[3];} fra;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 65;
-  fra.me.meth = LOCATE_flow___FlowContext___sub_with;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___sub_with;
   fra.me.has_broke = 0;
   fra.me.REG_size = 4;
   fra.me.REG[0] = NIT_NULL;
@@ -161,22 +161,22 @@ val_t flow___FlowContext___sub_with(val_t p0, val_t p1, val_t p2, val_t p3){
   fra.me.REG[2] = p2;
   fra.me.REG[3] = p3;
   /* ./syntax//flow.nit:68 */
-  fra.me.REG[3] = NEW_CastFlowContext_flow___CastFlowContext___init(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2], fra.me.REG[3]);
+  fra.me.REG[3] = NEW_CastFlowContext_syntax___flow___CastFlowContext___init(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2], fra.me.REG[3]);
   goto label1;
   label1: while(0);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[3];
 }
-val_t flow___FlowContext___merge(val_t p0, val_t p1, val_t p2){
+val_t syntax___flow___FlowContext___merge(val_t p0, val_t p1, val_t p2){
   struct {struct stack_frame_t me; val_t MORE_REG[5];} fra;
   val_t REGB0;
   val_t REGB1;
   val_t REGB2;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 71;
-  fra.me.meth = LOCATE_flow___FlowContext___merge;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___merge;
   fra.me.has_broke = 0;
   fra.me.REG_size = 6;
   fra.me.REG[0] = NIT_NULL;
@@ -188,97 +188,102 @@ val_t flow___FlowContext___merge(val_t p0, val_t p1, val_t p2){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   fra.me.REG[2] = p2;
-  /* ./../lib/standard//collection//array.nit:231 */
+  /* ./../lib/standard//collection//array.nit:229 */
   fra.me.REG[3] = fra.me.REG[2];
-  /* ./../lib/standard//collection//array.nit:234 */
+  /* ./../lib/standard//collection//array.nit:232 */
   REGB0 = TAG_Int(0);
-  /* ./../lib/standard//collection//array.nit:235 */
-  REGB1 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
+  /* ./../lib/standard//collection//array.nit:233 */
+  REGB1 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
   if (UNTAG_Bool(REGB1)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 235);
+    nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 233);
   }
-  REGB1 = ATTR_array___AbstractArrayRead____length(fra.me.REG[3]);
-  /* ./../lib/standard//collection//array.nit:236 */
-  fra.me.REG[4] = ATTR_array___Array____items(fra.me.REG[3]);
-  /* ./../lib/standard//collection//array.nit:237 */
+  REGB1 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3]);
+  /* ./../lib/standard//collection//array.nit:234 */
+  fra.me.REG[4] = ATTR_standard___collection___array___Array____items(fra.me.REG[3]);
+  /* ./../lib/standard//collection//array.nit:235 */
   while(1) {
     /* ./../lib/standard//collection//array.nit:23 */
-    REGB1 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
+    REGB1 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
     if (UNTAG_Bool(REGB1)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 23);
+      nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 23);
+    }
+    REGB1 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3]);
+    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);
     }
-    REGB1 = ATTR_array___AbstractArrayRead____length(fra.me.REG[3]);
-    /* ./../lib/standard//kernel.nit:212 */
+    /* ./../lib/standard//kernel.nit:215 */
     REGB1 = TAG_Bool(UNTAG_Int(REGB0)<UNTAG_Int(REGB1));
-    /* ./../lib/standard//collection//array.nit:237 */
+    /* ./../lib/standard//collection//array.nit:235 */
     if (UNTAG_Bool(REGB1)) {
-      /* ./../lib/standard//collection//array.nit:238 */
+      /* ./../lib/standard//collection//array.nit:236 */
       REGB1 = TAG_Bool(fra.me.REG[4]==NIT_NULL);
       if (UNTAG_Bool(REGB1)) {
-        nit_abort("Reciever is null", NULL, LOCATE_array, 238);
+        nit_abort("Reciever is null", NULL, LOCATE_standard___collection___array, 236);
       }
-      /* ./../lib/standard//collection//array.nit:654 */
+      /* ./../lib/standard//collection//array.nit:652 */
       fra.me.REG[5] = ((Nit_NativeArray)fra.me.REG[4])->val[UNTAG_Int(REGB0)];
       /* ./syntax//flow.nit:76 */
-      REGB1 = CALL_flow___FlowContext___unreash(fra.me.REG[5])(fra.me.REG[5]);
+      REGB1 = CALL_syntax___flow___FlowContext___unreash(fra.me.REG[5])(fra.me.REG[5]);
       REGB1 = TAG_Bool(!UNTAG_Bool(REGB1));
       if (UNTAG_Bool(REGB1)) {
       } else {
-        nit_abort("Assert failed", NULL, LOCATE_flow, 76);
+        nit_abort("Assert failed", NULL, LOCATE_syntax___flow, 76);
       }
-      /* ./../lib/standard//collection//array.nit:239 */
+      /* ./../lib/standard//collection//array.nit:237 */
       REGB1 = TAG_Int(1);
-      /* ./../lib/standard//kernel.nit:215 */
+      /* ./../lib/standard//kernel.nit:218 */
       REGB1 = TAG_Int(UNTAG_Int(REGB0)+UNTAG_Int(REGB1));
-      /* ./../lib/standard//collection//array.nit:239 */
+      /* ./../lib/standard//collection//array.nit:237 */
       REGB0 = REGB1;
     } else {
-      /* ./../lib/standard//collection//array.nit:237 */
+      /* ./../lib/standard//collection//array.nit:235 */
       goto label1;
     }
   }
   label1: while(0);
   /* ./../lib/standard//collection//array.nit:23 */
-  REGB0 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 23);
+    nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 23);
   }
-  REGB0 = ATTR_array___AbstractArrayRead____length(fra.me.REG[2]);
+  REGB0 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2]);
   /* ./syntax//flow.nit:77 */
   REGB1 = TAG_Int(1);
   REGB2 = TAG_Bool(IS_EQUAL_OO(REGB0,REGB1));
   if (UNTAG_Bool(REGB2)) {
   } else {
-    /* ./../lib/standard//kernel.nit:207 */
+    /* ./../lib/standard//kernel.nit:210 */
     REGB1 = TAG_Bool((REGB0)==(REGB1));
     /* ./syntax//flow.nit:77 */
     REGB2 = REGB1;
   }
   if (UNTAG_Bool(REGB2)) {
-    fra.me.REG[4] = CALL_abstract_collection___Collection___first(fra.me.REG[2])(fra.me.REG[2]);
+    fra.me.REG[4] = CALL_standard___collection___abstract_collection___Collection___first(fra.me.REG[2])(fra.me.REG[2]);
     goto label2;
   }
   /* ./syntax//flow.nit:78 */
-  fra.me.REG[2] = NEW_MergeFlowContext_flow___MergeFlowContext___init(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2]);
+  fra.me.REG[2] = NEW_MergeFlowContext_syntax___flow___MergeFlowContext___init(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2]);
   fra.me.REG[4] = fra.me.REG[2];
   goto label2;
   label2: while(0);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[4];
 }
-val_t flow___FlowContext___merge_reash(val_t p0, val_t p1, val_t p2, val_t p3){
+val_t syntax___flow___FlowContext___merge_reash(val_t p0, val_t p1, val_t p2, val_t p3){
   struct {struct stack_frame_t me; val_t MORE_REG[5];} fra;
   val_t REGB0;
   val_t REGB1;
   val_t REGB2;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 81;
-  fra.me.meth = LOCATE_flow___FlowContext___merge_reash;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___merge_reash;
   fra.me.has_broke = 0;
   fra.me.REG_size = 6;
   fra.me.REG[0] = NIT_NULL;
@@ -292,13 +297,13 @@ val_t flow___FlowContext___merge_reash(val_t p0, val_t p1, val_t p2, val_t p3){
   fra.me.REG[2] = p2;
   fra.me.REG[3] = p3;
   /* ./syntax//flow.nit:86 */
-  REGB0 = CALL_flow___FlowContext___unreash(fra.me.REG[2])(fra.me.REG[2]);
+  REGB0 = CALL_syntax___flow___FlowContext___unreash(fra.me.REG[2])(fra.me.REG[2]);
   if (UNTAG_Bool(REGB0)) {
     /* ./syntax//flow.nit:87 */
-    REGB0 = CALL_flow___FlowContext___unreash(fra.me.REG[3])(fra.me.REG[3]);
+    REGB0 = CALL_syntax___flow___FlowContext___unreash(fra.me.REG[3])(fra.me.REG[3]);
     if (UNTAG_Bool(REGB0)) {
       /* ./syntax//flow.nit:88 */
-      fra.me.REG[4] = CALL_flow___FlowContext___sub_unreash(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+      fra.me.REG[4] = CALL_syntax___flow___FlowContext___sub_unreash(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
       goto label1;
     } else {
       /* ./syntax//flow.nit:90 */
@@ -310,14 +315,14 @@ val_t flow___FlowContext___merge_reash(val_t p0, val_t p1, val_t p2, val_t p3){
     }
   }
   /* ./syntax//flow.nit:96 */
-  REGB0 = CALL_flow___FlowContext___unreash(fra.me.REG[3])(fra.me.REG[3]);
+  REGB0 = CALL_syntax___flow___FlowContext___unreash(fra.me.REG[3])(fra.me.REG[3]);
   if (UNTAG_Bool(REGB0)) {
     REGB0 = TAG_Bool(true);
   } else {
     REGB1 = TAG_Bool(IS_EQUAL_OO(fra.me.REG[2],fra.me.REG[3]));
     if (UNTAG_Bool(REGB1)) {
     } else {
-      REGB2 = CALL_kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]);
+      REGB2 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[3]);
       REGB1 = REGB2;
     }
     REGB0 = REGB1;
@@ -329,10 +334,10 @@ val_t flow___FlowContext___merge_reash(val_t p0, val_t p1, val_t p2, val_t p3){
   } else {
     /* ./syntax//flow.nit:104 */
     REGB0 = TAG_Int(2);
-    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[2]);
-    CALL_abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[3]);
-    fra.me.REG[5] = CALL_flow___FlowContext___merge(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[5]);
+    fra.me.REG[5] = NEW_Array_standard___collection___array___Array___with_capacity(REGB0);
+    CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[2]);
+    CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[5])(fra.me.REG[5], fra.me.REG[3]);
+    fra.me.REG[5] = CALL_syntax___flow___FlowContext___merge(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[5]);
     fra.me.REG[4] = fra.me.REG[5];
     goto label1;
   }
@@ -340,37 +345,37 @@ val_t flow___FlowContext___merge_reash(val_t p0, val_t p1, val_t p2, val_t p3){
   stack_frame_head = fra.me.prev;
   return fra.me.REG[4];
 }
-val_t flow___FlowContext___node(val_t p0){
+val_t syntax___flow___FlowContext___node(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 111;
-  fra.me.meth = LOCATE_flow___FlowContext___node;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___node;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
   /* ./syntax//flow.nit:111 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____node(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____node(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_node", LOCATE_flow, 111);
+    nit_abort("Uninitialized attribute %s", "_node", LOCATE_syntax___flow, 111);
   }
-  fra.me.REG[0] = ATTR_flow___FlowContext____node(fra.me.REG[0]);
+  fra.me.REG[0] = ATTR_syntax___flow___FlowContext____node(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[0];
 }
-void flow___FlowContext___init(val_t p0, val_t p1, val_t p2, int* init_table){
-  int itpos0 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_FlowContext].i;
+void syntax___flow___FlowContext___init(val_t p0, val_t p1, val_t p2, int* init_table){
+  int itpos0 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_syntax___flow___FlowContext].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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 114;
-  fra.me.meth = LOCATE_flow___FlowContext___init;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___init;
   fra.me.has_broke = 0;
   fra.me.REG_size = 3;
   fra.me.REG[0] = NIT_NULL;
@@ -380,105 +385,105 @@ void flow___FlowContext___init(val_t p0, val_t p1, val_t p2, int* init_table){
   fra.me.REG[1] = p1;
   fra.me.REG[2] = p2;
   /* ./syntax//flow.nit:116 */
-  ATTR_flow___FlowContext____visitor(fra.me.REG[0]) = fra.me.REG[1];
+  ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[0]) = fra.me.REG[1];
   /* ./syntax//flow.nit:117 */
-  ATTR_flow___FlowContext____node(fra.me.REG[0]) = fra.me.REG[2];
+  ATTR_syntax___flow___FlowContext____node(fra.me.REG[0]) = fra.me.REG[2];
   stack_frame_head = fra.me.prev;
   init_table[itpos0] = 1;
   return;
 }
-val_t flow___FlowContext___unreash(val_t p0){
+val_t syntax___flow___FlowContext___unreash(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 120;
-  fra.me.meth = LOCATE_flow___FlowContext___unreash;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___unreash;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
   /* ./syntax//flow.nit:120 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____unreash(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____unreash(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_unreash", LOCATE_flow, 120);
+    nit_abort("Uninitialized attribute %s", "_unreash", LOCATE_syntax___flow, 120);
   }
-  REGB0 = ATTR_flow___FlowContext____unreash(fra.me.REG[0]);
+  REGB0 = ATTR_syntax___flow___FlowContext____unreash(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   return REGB0;
 }
-val_t flow___FlowContext___already_unreash(val_t p0){
+val_t syntax___flow___FlowContext___already_unreash(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 123;
-  fra.me.meth = LOCATE_flow___FlowContext___already_unreash;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___already_unreash;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
   /* ./syntax//flow.nit:123 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____already_unreash(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____already_unreash(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_already_unreash", LOCATE_flow, 123);
+    nit_abort("Uninitialized attribute %s", "_already_unreash", LOCATE_syntax___flow, 123);
   }
-  REGB0 = ATTR_flow___FlowContext____already_unreash(fra.me.REG[0]);
+  REGB0 = ATTR_syntax___flow___FlowContext____already_unreash(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   return REGB0;
 }
-void flow___FlowContext___already_unreash__eq(val_t p0, val_t p1){
+void syntax___flow___FlowContext___already_unreash__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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 123;
-  fra.me.meth = LOCATE_flow___FlowContext___already_unreash__eq;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___already_unreash__eq;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
   REGB0 = p1;
   /* ./syntax//flow.nit:123 */
-  ATTR_flow___FlowContext____already_unreash(fra.me.REG[0]) = REGB0;
+  ATTR_syntax___flow___FlowContext____already_unreash(fra.me.REG[0]) = REGB0;
   stack_frame_head = fra.me.prev;
   return;
 }
-val_t flow___FlowContext___set_variables(val_t p0){
+val_t syntax___flow___FlowContext___set_variables(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 127;
-  fra.me.meth = LOCATE_flow___FlowContext___set_variables;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___set_variables;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
   /* ./syntax//flow.nit:127 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_flow, 127);
+    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_syntax___flow, 127);
   }
-  fra.me.REG[0] = ATTR_flow___FlowContext____set_variables(fra.me.REG[0]);
+  fra.me.REG[0] = ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[0];
 }
-val_t flow___FlowContext___is_set(val_t p0, val_t p1){
+val_t syntax___flow___FlowContext___is_set(val_t p0, val_t p1){
   struct {struct stack_frame_t me; val_t MORE_REG[1];} fra;
   val_t REGB0;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 130;
-  fra.me.meth = LOCATE_flow___FlowContext___is_set;
+  fra.me.meth = LOCATE_syntax___flow___FlowContext___is_set;
   fra.me.has_broke = 0;
   fra.me.REG_size = 2;
   fra.me.REG[0] = NIT_NULL;
@@ -486,27 +491,27 @@ val_t flow___FlowContext___is_set(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:133 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_flow, 133);
+    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_syntax___flow, 133);
   }
-  fra.me.REG[0] = ATTR_flow___FlowContext____set_variables(fra.me.REG[0]);
-  REGB0 = CALL_abstract_collection___Collection___has(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+  fra.me.REG[0] = ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0]);
+  REGB0 = CALL_standard___collection___abstract_collection___Collection___has(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
   goto label1;
   label1: while(0);
   stack_frame_head = fra.me.prev;
   return REGB0;
 }
-void flow___RootFlowContext___init(val_t p0, val_t p1, val_t p2, int* init_table){
-  int itpos1 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_RootFlowContext].i;
+void syntax___flow___RootFlowContext___init(val_t p0, val_t p1, val_t p2, int* init_table){
+  int itpos1 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_syntax___flow___RootFlowContext].i;
   struct {struct stack_frame_t me; val_t MORE_REG[2];} fra;
   val_t tmp;
   if (init_table[itpos1]) return;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 140;
-  fra.me.meth = LOCATE_flow___RootFlowContext___init;
+  fra.me.meth = LOCATE_syntax___flow___RootFlowContext___init;
   fra.me.has_broke = 0;
   fra.me.REG_size = 3;
   fra.me.REG[0] = NIT_NULL;
@@ -516,42 +521,42 @@ void flow___RootFlowContext___init(val_t p0, val_t p1, val_t p2, int* init_table
   fra.me.REG[1] = p1;
   fra.me.REG[2] = p2;
   /* ./syntax//flow.nit:142 */
-  CALL_flow___FlowContext___init(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2], init_table);
+  CALL_syntax___flow___FlowContext___init(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2], init_table);
   stack_frame_head = fra.me.prev;
   init_table[itpos1] = 1;
   return;
 }
-val_t flow___SubFlowContext___prev(val_t p0){
+val_t syntax___flow___SubFlowContext___prev(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 149;
-  fra.me.meth = LOCATE_flow___SubFlowContext___prev;
+  fra.me.meth = LOCATE_syntax___flow___SubFlowContext___prev;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
   fra.me.REG[0] = p0;
   /* ./syntax//flow.nit:149 */
-  REGB0 = TAG_Bool(ATTR_flow___SubFlowContext____prev(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___SubFlowContext____prev(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_prev", LOCATE_flow, 149);
+    nit_abort("Uninitialized attribute %s", "_prev", LOCATE_syntax___flow, 149);
   }
-  fra.me.REG[0] = ATTR_flow___SubFlowContext____prev(fra.me.REG[0]);
+  fra.me.REG[0] = ATTR_syntax___flow___SubFlowContext____prev(fra.me.REG[0]);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[0];
 }
-val_t flow___SubFlowContext___is_set(val_t p0, val_t p1){
+val_t syntax___flow___SubFlowContext___is_set(val_t p0, val_t p1){
   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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 151;
-  fra.me.meth = LOCATE_flow___SubFlowContext___is_set;
+  fra.me.meth = LOCATE_syntax___flow___SubFlowContext___is_set;
   fra.me.has_broke = 0;
   fra.me.REG_size = 3;
   fra.me.REG[0] = NIT_NULL;
@@ -560,23 +565,23 @@ val_t flow___SubFlowContext___is_set(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:153 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_flow, 153);
+    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_syntax___flow, 153);
   }
-  fra.me.REG[2] = ATTR_flow___FlowContext____set_variables(fra.me.REG[0]);
-  REGB0 = CALL_abstract_collection___Collection___has(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
+  fra.me.REG[2] = ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0]);
+  REGB0 = CALL_standard___collection___abstract_collection___Collection___has(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
   if (UNTAG_Bool(REGB0)) {
     REGB0 = TAG_Bool(true);
   } else {
-    REGB1 = TAG_Bool(ATTR_flow___SubFlowContext____prev(fra.me.REG[0])!=NIT_NULL);
+    REGB1 = TAG_Bool(ATTR_syntax___flow___SubFlowContext____prev(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB1)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_prev", LOCATE_flow, 153);
+      nit_abort("Uninitialized attribute %s", "_prev", LOCATE_syntax___flow, 153);
     }
-    fra.me.REG[0] = ATTR_flow___SubFlowContext____prev(fra.me.REG[0]);
-    REGB1 = CALL_flow___FlowContext___is_set(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+    fra.me.REG[0] = ATTR_syntax___flow___SubFlowContext____prev(fra.me.REG[0]);
+    REGB1 = CALL_syntax___flow___FlowContext___is_set(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
     REGB0 = REGB1;
   }
   goto label1;
@@ -584,13 +589,13 @@ val_t flow___SubFlowContext___is_set(val_t p0, val_t p1){
   stack_frame_head = fra.me.prev;
   return REGB0;
 }
-val_t flow___SubFlowContext___stype(val_t p0, val_t p1){
+val_t syntax___flow___SubFlowContext___stype(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 156;
-  fra.me.meth = LOCATE_flow___SubFlowContext___stype;
+  fra.me.meth = LOCATE_syntax___flow___SubFlowContext___stype;
   fra.me.has_broke = 0;
   fra.me.REG_size = 2;
   fra.me.REG[0] = NIT_NULL;
@@ -598,23 +603,23 @@ val_t flow___SubFlowContext___stype(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:158 */
-  fra.me.REG[0] = CALL_flow___SubFlowContext___prev(fra.me.REG[0])(fra.me.REG[0]);
-  fra.me.REG[1] = CALL_flow___FlowContext___stype(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+  fra.me.REG[0] = CALL_syntax___flow___SubFlowContext___prev(fra.me.REG[0])(fra.me.REG[0]);
+  fra.me.REG[1] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
   goto label1;
   label1: while(0);
   stack_frame_head = fra.me.prev;
   return fra.me.REG[1];
 }
-void flow___SubFlowContext___with_prev(val_t p0, val_t p1, val_t p2, int* init_table){
-  int itpos2 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_SubFlowContext].i;
+void syntax___flow___SubFlowContext___with_prev(val_t p0, val_t p1, val_t p2, int* init_table){
+  int itpos2 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_syntax___flow___SubFlowContext].i;
   struct {struct stack_frame_t me; val_t MORE_REG[3];} fra;
   val_t REGB0;
   val_t tmp;
   if (init_table[itpos2]) return;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 161;
-  fra.me.meth = LOCATE_flow___SubFlowContext___with_prev;
+  fra.me.meth = LOCATE_syntax___flow___SubFlowContext___with_prev;
   fra.me.has_broke = 0;
   fra.me.REG_size = 4;
   fra.me.REG[0] = NIT_NULL;
@@ -625,28 +630,28 @@ void flow___SubFlowContext___with_prev(val_t p0, val_t p1, val_t p2, int* init_t
   fra.me.REG[1] = p1;
   fra.me.REG[2] = p2;
   /* ./syntax//flow.nit:163 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____visitor(fra.me.REG[1])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[1])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_flow, 163);
+    nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_syntax___flow, 163);
   }
-  fra.me.REG[3] = ATTR_flow___FlowContext____visitor(fra.me.REG[1]);
-  CALL_flow___FlowContext___init(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[3], fra.me.REG[2], init_table);
+  fra.me.REG[3] = ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[1]);
+  CALL_syntax___flow___FlowContext___init(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[3], fra.me.REG[2], init_table);
   /* ./syntax//flow.nit:164 */
-  ATTR_flow___SubFlowContext____prev(fra.me.REG[0]) = fra.me.REG[1];
+  ATTR_syntax___flow___SubFlowContext____prev(fra.me.REG[0]) = fra.me.REG[1];
   stack_frame_head = fra.me.prev;
   init_table[itpos2] = 1;
   return;
 }
-val_t flow___CastFlowContext___stype(val_t p0, val_t p1){
+val_t syntax___flow___CastFlowContext___stype(val_t p0, val_t p1){
   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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 177;
-  fra.me.meth = LOCATE_flow___CastFlowContext___stype;
+  fra.me.meth = LOCATE_syntax___flow___CastFlowContext___stype;
   fra.me.has_broke = 0;
   fra.me.REG_size = 3;
   fra.me.REG[0] = NIT_NULL;
@@ -655,26 +660,26 @@ val_t flow___CastFlowContext___stype(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:179 */
-  REGB0 = TAG_Bool(ATTR_flow___CastFlowContext____variable(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___CastFlowContext____variable(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_variable", LOCATE_flow, 179);
+    nit_abort("Uninitialized attribute %s", "_variable", LOCATE_syntax___flow, 179);
   }
-  fra.me.REG[2] = ATTR_flow___CastFlowContext____variable(fra.me.REG[0]);
+  fra.me.REG[2] = ATTR_syntax___flow___CastFlowContext____variable(fra.me.REG[0]);
   REGB0 = TAG_Bool(IS_EQUAL_OO(fra.me.REG[1],fra.me.REG[2]));
   if (UNTAG_Bool(REGB0)) {
   } else {
-    REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]);
+    REGB1 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[1])(fra.me.REG[1], fra.me.REG[2]);
     REGB0 = REGB1;
   }
   if (UNTAG_Bool(REGB0)) {
     /* ./syntax//flow.nit:180 */
-    fra.me.REG[2] = ATTR_flow___CastFlowContext____stype(fra.me.REG[0]);
+    fra.me.REG[2] = ATTR_syntax___flow___CastFlowContext____stype(fra.me.REG[0]);
     goto label1;
   } else {
     /* ./syntax//flow.nit:182 */
-    fra.me.REG[0] = CALL_flow___SubFlowContext___prev(fra.me.REG[0])(fra.me.REG[0]);
-    fra.me.REG[1] = CALL_flow___FlowContext___stype(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+    fra.me.REG[0] = CALL_syntax___flow___SubFlowContext___prev(fra.me.REG[0])(fra.me.REG[0]);
+    fra.me.REG[1] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
     fra.me.REG[2] = fra.me.REG[1];
     goto label1;
   }
@@ -682,15 +687,15 @@ val_t flow___CastFlowContext___stype(val_t p0, val_t p1){
   stack_frame_head = fra.me.prev;
   return fra.me.REG[2];
 }
-void flow___CastFlowContext___init(val_t p0, val_t p1, val_t p2, val_t p3, val_t p4, int* init_table){
-  int itpos3 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_CastFlowContext].i;
+void syntax___flow___CastFlowContext___init(val_t p0, val_t p1, val_t p2, val_t p3, val_t p4, int* init_table){
+  int itpos3 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_syntax___flow___CastFlowContext].i;
   struct {struct stack_frame_t me; val_t MORE_REG[4];} fra;
   val_t tmp;
   if (init_table[itpos3]) return;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 186;
-  fra.me.meth = LOCATE_flow___CastFlowContext___init;
+  fra.me.meth = LOCATE_syntax___flow___CastFlowContext___init;
   fra.me.has_broke = 0;
   fra.me.REG_size = 5;
   fra.me.REG[0] = NIT_NULL;
@@ -704,25 +709,25 @@ void flow___CastFlowContext___init(val_t p0, val_t p1, val_t p2, val_t p3, val_t
   fra.me.REG[3] = p3;
   fra.me.REG[4] = p4;
   /* ./syntax//flow.nit:188 */
-  CALL_flow___SubFlowContext___with_prev(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2], init_table);
+  CALL_syntax___flow___SubFlowContext___with_prev(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[2], init_table);
   /* ./syntax//flow.nit:189 */
-  ATTR_flow___CastFlowContext____variable(fra.me.REG[0]) = fra.me.REG[3];
+  ATTR_syntax___flow___CastFlowContext____variable(fra.me.REG[0]) = fra.me.REG[3];
   /* ./syntax//flow.nit:190 */
-  ATTR_flow___CastFlowContext____stype(fra.me.REG[0]) = fra.me.REG[4];
+  ATTR_syntax___flow___CastFlowContext____stype(fra.me.REG[0]) = fra.me.REG[4];
   stack_frame_head = fra.me.prev;
   init_table[itpos3] = 1;
   return;
 }
-void flow___MergeFlowContext___init(val_t p0, val_t p1, val_t p2, val_t p3, int* init_table){
-  int itpos4 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_MergeFlowContext].i;
+void syntax___flow___MergeFlowContext___init(val_t p0, val_t p1, val_t p2, val_t p3, int* init_table){
+  int itpos4 = VAL2OBJ(p0)->vft[INIT_TABLE_POS_syntax___flow___MergeFlowContext].i;
   struct {struct stack_frame_t me; val_t MORE_REG[5];} fra;
   val_t REGB0;
   val_t tmp;
   if (init_table[itpos4]) return;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 204;
-  fra.me.meth = LOCATE_flow___MergeFlowContext___init;
+  fra.me.meth = LOCATE_syntax___flow___MergeFlowContext___init;
   fra.me.has_broke = 0;
   fra.me.REG_size = 6;
   fra.me.REG[0] = NIT_NULL;
@@ -738,29 +743,29 @@ void flow___MergeFlowContext___init(val_t p0, val_t p1, val_t p2, val_t p3, int*
   /* ./syntax//flow.nit:204 */
   fra.me.REG[4] = fra.me.REG[0];
   /* ./syntax//flow.nit:206 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____visitor(fra.me.REG[1])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[1])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_flow, 206);
+    nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_syntax___flow, 206);
   }
-  fra.me.REG[5] = ATTR_flow___FlowContext____visitor(fra.me.REG[1]);
-  CALL_flow___FlowContext___init(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[5], fra.me.REG[2], init_table);
+  fra.me.REG[5] = ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[1]);
+  CALL_syntax___flow___FlowContext___init(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[5], fra.me.REG[2], init_table);
   /* ./syntax//flow.nit:207 */
-  ATTR_flow___MergeFlowContext____alts(fra.me.REG[4]) = fra.me.REG[3];
+  ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[4]) = fra.me.REG[3];
   /* ./syntax//flow.nit:208 */
-  ATTR_flow___MergeFlowContext____base(fra.me.REG[4]) = fra.me.REG[1];
+  ATTR_syntax___flow___MergeFlowContext____base(fra.me.REG[4]) = fra.me.REG[1];
   stack_frame_head = fra.me.prev;
   init_table[itpos4] = 1;
   return;
 }
-val_t flow___MergeFlowContext___stype(val_t p0, val_t p1){
+val_t syntax___flow___MergeFlowContext___stype(val_t p0, val_t p1){
   struct {struct stack_frame_t me; val_t MORE_REG[3];} fra;
   val_t REGB0;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 211;
-  fra.me.meth = LOCATE_flow___MergeFlowContext___stype;
+  fra.me.meth = LOCATE_syntax___flow___MergeFlowContext___stype;
   fra.me.has_broke = 0;
   fra.me.REG_size = 4;
   fra.me.REG[0] = NIT_NULL;
@@ -770,34 +775,34 @@ val_t flow___MergeFlowContext___stype(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:213 */
-  REGB0 = TAG_Bool(ATTR_flow___MergeFlowContext____stypes(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____stypes(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_stypes", LOCATE_flow, 213);
+    nit_abort("Uninitialized attribute %s", "_stypes", LOCATE_syntax___flow, 213);
   }
-  fra.me.REG[2] = ATTR_flow___MergeFlowContext____stypes(fra.me.REG[0]);
-  REGB0 = CALL_abstract_collection___MapRead___has_key(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
+  fra.me.REG[2] = ATTR_syntax___flow___MergeFlowContext____stypes(fra.me.REG[0]);
+  REGB0 = CALL_standard___collection___abstract_collection___MapRead___has_key(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
   if (UNTAG_Bool(REGB0)) {
     /* ./syntax//flow.nit:214 */
-    REGB0 = TAG_Bool(ATTR_flow___MergeFlowContext____stypes(fra.me.REG[0])!=NIT_NULL);
+    REGB0 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____stypes(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB0)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_stypes", LOCATE_flow, 214);
+      nit_abort("Uninitialized attribute %s", "_stypes", LOCATE_syntax___flow, 214);
     }
-    fra.me.REG[2] = ATTR_flow___MergeFlowContext____stypes(fra.me.REG[0]);
-    fra.me.REG[2] = CALL_abstract_collection___MapRead_____bra(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
+    fra.me.REG[2] = ATTR_syntax___flow___MergeFlowContext____stypes(fra.me.REG[0]);
+    fra.me.REG[2] = CALL_standard___collection___abstract_collection___MapRead_____bra(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
     goto label1;
   } else {
     /* ./syntax//flow.nit:216 */
-    fra.me.REG[3] = CALL_flow___MergeFlowContext___merge_stype(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+    fra.me.REG[3] = CALL_syntax___flow___MergeFlowContext___merge_stype(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
     /* ./syntax//flow.nit:217 */
-    REGB0 = TAG_Bool(ATTR_flow___MergeFlowContext____stypes(fra.me.REG[0])!=NIT_NULL);
+    REGB0 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____stypes(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB0)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_stypes", LOCATE_flow, 217);
+      nit_abort("Uninitialized attribute %s", "_stypes", LOCATE_syntax___flow, 217);
     }
-    fra.me.REG[0] = ATTR_flow___MergeFlowContext____stypes(fra.me.REG[0]);
-    CALL_abstract_collection___Map_____braeq(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[3]);
+    fra.me.REG[0] = ATTR_syntax___flow___MergeFlowContext____stypes(fra.me.REG[0]);
+    CALL_standard___collection___abstract_collection___Map_____braeq(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1], fra.me.REG[3]);
     /* ./syntax//flow.nit:218 */
     fra.me.REG[2] = fra.me.REG[3];
     goto label1;
@@ -806,7 +811,7 @@ val_t flow___MergeFlowContext___stype(val_t p0, val_t p1){
   stack_frame_head = fra.me.prev;
   return fra.me.REG[2];
 }
-val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
+val_t syntax___flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
   struct {struct stack_frame_t me; val_t MORE_REG[8];} fra;
   val_t REGB0;
   val_t REGB1;
@@ -814,9 +819,9 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
   val_t REGB3;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 222;
-  fra.me.meth = LOCATE_flow___MergeFlowContext___merge_stype;
+  fra.me.meth = LOCATE_syntax___flow___MergeFlowContext___merge_stype;
   fra.me.has_broke = 0;
   fra.me.REG_size = 9;
   fra.me.REG[0] = NIT_NULL;
@@ -835,58 +840,63 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
   /* ./syntax//flow.nit:225 */
   REGB0 = TAG_Bool(false);
   /* ./syntax//flow.nit:226 */
-  REGB1 = TAG_Bool(ATTR_flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
+  REGB1 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB1)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_alts", LOCATE_flow, 226);
+    nit_abort("Uninitialized attribute %s", "_alts", LOCATE_syntax___flow, 226);
   }
-  fra.me.REG[3] = ATTR_flow___MergeFlowContext____alts(fra.me.REG[0]);
-  fra.me.REG[3] = CALL_abstract_collection___Collection___first(fra.me.REG[3])(fra.me.REG[3]);
+  fra.me.REG[3] = ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0]);
+  fra.me.REG[3] = CALL_standard___collection___abstract_collection___Collection___first(fra.me.REG[3])(fra.me.REG[3]);
   REGB1 = TAG_Bool(fra.me.REG[3]==NIT_NULL);
   if (UNTAG_Bool(REGB1)) {
-    nit_abort("Reciever is null", NULL, LOCATE_flow, 226);
+    nit_abort("Reciever is null", NULL, LOCATE_syntax___flow, 226);
   }
-  fra.me.REG[3] = CALL_flow___FlowContext___stype(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[1]);
+  fra.me.REG[3] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[1]);
   /* ./syntax//flow.nit:227 */
-  REGB1 = TAG_Bool(ATTR_flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
+  REGB1 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB1)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_alts", LOCATE_flow, 227);
+    nit_abort("Uninitialized attribute %s", "_alts", LOCATE_syntax___flow, 227);
   }
-  fra.me.REG[4] = ATTR_flow___MergeFlowContext____alts(fra.me.REG[0]);
-  /* ./../lib/standard//collection//array.nit:234 */
+  fra.me.REG[4] = ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0]);
+  /* ./../lib/standard//collection//array.nit:232 */
   REGB1 = TAG_Int(0);
-  /* ./../lib/standard//collection//array.nit:235 */
-  REGB2 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[4])!=NIT_NULL);
+  /* ./../lib/standard//collection//array.nit:233 */
+  REGB2 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[4])!=NIT_NULL);
   if (UNTAG_Bool(REGB2)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 235);
+    nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 233);
   }
-  REGB2 = ATTR_array___AbstractArrayRead____length(fra.me.REG[4]);
-  /* ./../lib/standard//collection//array.nit:236 */
-  fra.me.REG[5] = ATTR_array___Array____items(fra.me.REG[4]);
-  /* ./../lib/standard//collection//array.nit:237 */
+  REGB2 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[4]);
+  /* ./../lib/standard//collection//array.nit:234 */
+  fra.me.REG[5] = ATTR_standard___collection___array___Array____items(fra.me.REG[4]);
+  /* ./../lib/standard//collection//array.nit:235 */
   while(1) {
     /* ./../lib/standard//collection//array.nit:23 */
-    REGB2 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[4])!=NIT_NULL);
+    REGB2 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[4])!=NIT_NULL);
     if (UNTAG_Bool(REGB2)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 23);
+      nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 23);
+    }
+    REGB2 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[4]);
+    REGB3 = TAG_Bool(VAL_ISA(REGB2, VTCOLOR_standard___kernel___Comparable___OTHER(REGB1), VTID_standard___kernel___Comparable___OTHER(REGB1))) /*cast OTHER*/;
+    if (UNTAG_Bool(REGB3)) {
+    } else {
+      nit_abort("Cast failed", NULL, LOCATE_standard___kernel, 0);
     }
-    REGB2 = ATTR_array___AbstractArrayRead____length(fra.me.REG[4]);
-    /* ./../lib/standard//kernel.nit:212 */
+    /* ./../lib/standard//kernel.nit:215 */
     REGB2 = TAG_Bool(UNTAG_Int(REGB1)<UNTAG_Int(REGB2));
-    /* ./../lib/standard//collection//array.nit:237 */
+    /* ./../lib/standard//collection//array.nit:235 */
     if (UNTAG_Bool(REGB2)) {
-      /* ./../lib/standard//collection//array.nit:238 */
+      /* ./../lib/standard//collection//array.nit:236 */
       REGB2 = TAG_Bool(fra.me.REG[5]==NIT_NULL);
       if (UNTAG_Bool(REGB2)) {
-        nit_abort("Reciever is null", NULL, LOCATE_array, 238);
+        nit_abort("Reciever is null", NULL, LOCATE_standard___collection___array, 236);
       }
-      /* ./../lib/standard//collection//array.nit:654 */
+      /* ./../lib/standard//collection//array.nit:652 */
       fra.me.REG[6] = ((Nit_NativeArray)fra.me.REG[5])->val[UNTAG_Int(REGB1)];
       /* ./syntax//flow.nit:228 */
-      fra.me.REG[6] = CALL_flow___FlowContext___stype(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[1]);
+      fra.me.REG[6] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[1]);
       /* ./syntax//flow.nit:229 */
       REGB2 = TAG_Bool(fra.me.REG[6]==NIT_NULL);
       if (UNTAG_Bool(REGB2)) {
@@ -896,7 +906,7 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
           REGB3 = TAG_Bool(false);
           REGB2 = REGB3;
         } else {
-          REGB3 = CALL_kernel___Object_____eqeq(fra.me.REG[6])(fra.me.REG[6], NIT_NULL);
+          REGB3 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[6])(fra.me.REG[6], NIT_NULL);
           REGB2 = REGB3;
         }
       }
@@ -914,7 +924,7 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
           REGB3 = TAG_Bool(false);
           REGB2 = REGB3;
         } else {
-          REGB3 = CALL_kernel___Object_____eqeq(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[3]);
+          REGB3 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[6])(fra.me.REG[6], fra.me.REG[3]);
           REGB2 = REGB3;
         }
       }
@@ -924,7 +934,7 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
         fra.me.REG[3] = NIT_NULL;
       }
       /* ./syntax//flow.nit:235 */
-      REGB2 = TAG_Bool((fra.me.REG[6]!=NIT_NULL) && VAL_ISA(fra.me.REG[6], COLOR_MMTypeNone, ID_MMTypeNone)) /*cast MMTypeNone*/;
+      REGB2 = TAG_Bool((fra.me.REG[6]!=NIT_NULL) && VAL_ISA(fra.me.REG[6], COLOR_metamodel___static_type___MMTypeNone, ID_metamodel___static_type___MMTypeNone)) /*cast MMTypeNone*/;
       if (UNTAG_Bool(REGB2)) {
         /* ./syntax//flow.nit:236 */
         REGB2 = TAG_Bool(true);
@@ -933,7 +943,7 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
         goto label2;
       }
       /* ./syntax//flow.nit:239 */
-      REGB2 = TAG_Bool((fra.me.REG[6]!=NIT_NULL) && VAL_ISA(fra.me.REG[6], COLOR_MMNullableType, ID_MMNullableType)) /*cast MMNullableType*/;
+      REGB2 = TAG_Bool((fra.me.REG[6]!=NIT_NULL) && VAL_ISA(fra.me.REG[6], COLOR_metamodel___static_type___MMNullableType, ID_metamodel___static_type___MMNullableType)) /*cast MMNullableType*/;
       if (UNTAG_Bool(REGB2)) {
         /* ./syntax//flow.nit:240 */
         REGB2 = TAG_Bool(true);
@@ -941,9 +951,9 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
         /* ./syntax//flow.nit:241 */
         REGB2 = TAG_Bool(fra.me.REG[6]==NIT_NULL);
         if (UNTAG_Bool(REGB2)) {
-          nit_abort("Reciever is null", NULL, LOCATE_flow, 241);
+          nit_abort("Reciever is null", NULL, LOCATE_syntax___flow, 241);
         }
-        fra.me.REG[8] = CALL_static_type___MMType___as_notnull(fra.me.REG[6])(fra.me.REG[6]);
+        fra.me.REG[8] = CALL_metamodel___static_type___MMType___as_notnull(fra.me.REG[6])(fra.me.REG[6]);
         fra.me.REG[6] = fra.me.REG[8];
       }
       /* ./syntax//flow.nit:243 */
@@ -955,7 +965,7 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
           REGB3 = TAG_Bool(false);
           REGB2 = REGB3;
         } else {
-          REGB3 = CALL_kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], NIT_NULL);
+          REGB3 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], NIT_NULL);
           REGB2 = REGB3;
         }
       }
@@ -964,9 +974,9 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
       } else {
         REGB3 = TAG_Bool(fra.me.REG[2]==NIT_NULL);
         if (UNTAG_Bool(REGB3)) {
-          nit_abort("Reciever is null", NULL, LOCATE_flow, 243);
+          nit_abort("Reciever is null", NULL, LOCATE_syntax___flow, 243);
         }
-        REGB3 = CALL_static_type___MMType_____l(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]);
+        REGB3 = CALL_metamodel___static_type___MMType_____l(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[6]);
         REGB2 = REGB3;
       }
       if (UNTAG_Bool(REGB2)) {
@@ -974,14 +984,14 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
         fra.me.REG[2] = fra.me.REG[6];
       }
       label2: while(0);
-      /* ./../lib/standard//collection//array.nit:239 */
+      /* ./../lib/standard//collection//array.nit:237 */
       REGB2 = TAG_Int(1);
-      /* ./../lib/standard//kernel.nit:215 */
+      /* ./../lib/standard//kernel.nit:218 */
       REGB2 = TAG_Int(UNTAG_Int(REGB1)+UNTAG_Int(REGB2));
-      /* ./../lib/standard//collection//array.nit:239 */
+      /* ./../lib/standard//collection//array.nit:237 */
       REGB1 = REGB2;
     } else {
-      /* ./../lib/standard//collection//array.nit:237 */
+      /* ./../lib/standard//collection//array.nit:235 */
       goto label3;
     }
   }
@@ -995,7 +1005,7 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
       REGB2 = TAG_Bool(false);
       REGB1 = REGB2;
     } else {
-      REGB2 = CALL_kernel___Object_____eqeq(fra.me.REG[3])(fra.me.REG[3], NIT_NULL);
+      REGB2 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[3])(fra.me.REG[3], NIT_NULL);
       REGB1 = REGB2;
     }
   }
@@ -1016,28 +1026,28 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
         REGB1 = TAG_Bool(false);
         REGB0 = REGB1;
       } else {
-        REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], NIT_NULL);
+        REGB1 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], NIT_NULL);
         REGB0 = REGB1;
       }
     }
     if (UNTAG_Bool(REGB0)) {
       /* ./syntax//flow.nit:252 */
-      REGB0 = TAG_Bool(ATTR_flow___FlowContext____visitor(fra.me.REG[0])!=NIT_NULL);
+      REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[0])!=NIT_NULL);
       if (UNTAG_Bool(REGB0)) {
       } else {
-        nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_flow, 252);
+        nit_abort("Uninitialized attribute %s", "_visitor", LOCATE_syntax___flow, 252);
       }
-      fra.me.REG[3] = ATTR_flow___FlowContext____visitor(fra.me.REG[0]);
-      fra.me.REG[3] = CALL_syntax_base___AbsSyntaxVisitor___type_none(fra.me.REG[3])(fra.me.REG[3]);
+      fra.me.REG[3] = ATTR_syntax___flow___FlowContext____visitor(fra.me.REG[0]);
+      fra.me.REG[3] = CALL_syntax___syntax_base___AbsSyntaxVisitor___type_none(fra.me.REG[3])(fra.me.REG[3]);
       fra.me.REG[7] = fra.me.REG[3];
       goto label1;
     } else {
       /* ./syntax//flow.nit:254 */
       REGB0 = TAG_Bool(fra.me.REG[2]==NIT_NULL);
       if (UNTAG_Bool(REGB0)) {
-        nit_abort("Reciever is null", NULL, LOCATE_flow, 254);
+        nit_abort("Reciever is null", NULL, LOCATE_syntax___flow, 254);
       }
-      fra.me.REG[3] = CALL_static_type___MMType___as_nullable(fra.me.REG[2])(fra.me.REG[2]);
+      fra.me.REG[3] = CALL_metamodel___static_type___MMType___as_nullable(fra.me.REG[2])(fra.me.REG[2]);
       fra.me.REG[2] = fra.me.REG[3];
     }
   }
@@ -1050,89 +1060,94 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
       REGB1 = TAG_Bool(false);
       REGB0 = REGB1;
     } else {
-      REGB1 = CALL_kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], NIT_NULL);
+      REGB1 = CALL_standard___kernel___Object_____eqeq(fra.me.REG[2])(fra.me.REG[2], NIT_NULL);
       REGB0 = REGB1;
     }
   }
   if (UNTAG_Bool(REGB0)) {
     /* ./syntax//flow.nit:258 */
-    REGB0 = TAG_Bool(ATTR_flow___MergeFlowContext____base(fra.me.REG[0])!=NIT_NULL);
+    REGB0 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____base(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB0)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_base", LOCATE_flow, 258);
+      nit_abort("Uninitialized attribute %s", "_base", LOCATE_syntax___flow, 258);
     }
-    fra.me.REG[3] = ATTR_flow___MergeFlowContext____base(fra.me.REG[0]);
-    fra.me.REG[3] = CALL_flow___FlowContext___stype(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[1]);
+    fra.me.REG[3] = ATTR_syntax___flow___MergeFlowContext____base(fra.me.REG[0]);
+    fra.me.REG[3] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[3])(fra.me.REG[3], fra.me.REG[1]);
     fra.me.REG[7] = fra.me.REG[3];
     goto label1;
   } else {
     /* ./syntax//flow.nit:260 */
-    REGB0 = TAG_Bool(ATTR_flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
+    REGB0 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB0)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_alts", LOCATE_flow, 260);
+      nit_abort("Uninitialized attribute %s", "_alts", LOCATE_syntax___flow, 260);
     }
-    fra.me.REG[3] = ATTR_flow___MergeFlowContext____alts(fra.me.REG[0]);
-    /* ./../lib/standard//collection//array.nit:234 */
+    fra.me.REG[3] = ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0]);
+    /* ./../lib/standard//collection//array.nit:232 */
     REGB0 = TAG_Int(0);
-    /* ./../lib/standard//collection//array.nit:235 */
-    REGB1 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
+    /* ./../lib/standard//collection//array.nit:233 */
+    REGB1 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
     if (UNTAG_Bool(REGB1)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 235);
+      nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 233);
     }
-    REGB1 = ATTR_array___AbstractArrayRead____length(fra.me.REG[3]);
-    /* ./../lib/standard//collection//array.nit:236 */
-    fra.me.REG[5] = ATTR_array___Array____items(fra.me.REG[3]);
-    /* ./../lib/standard//collection//array.nit:237 */
+    REGB1 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3]);
+    /* ./../lib/standard//collection//array.nit:234 */
+    fra.me.REG[5] = ATTR_standard___collection___array___Array____items(fra.me.REG[3]);
+    /* ./../lib/standard//collection//array.nit:235 */
     while(1) {
       /* ./../lib/standard//collection//array.nit:23 */
-      REGB1 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
+      REGB1 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3])!=NIT_NULL);
       if (UNTAG_Bool(REGB1)) {
       } else {
-        nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 23);
+        nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 23);
+      }
+      REGB1 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[3]);
+      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);
       }
-      REGB1 = ATTR_array___AbstractArrayRead____length(fra.me.REG[3]);
-      /* ./../lib/standard//kernel.nit:212 */
+      /* ./../lib/standard//kernel.nit:215 */
       REGB1 = TAG_Bool(UNTAG_Int(REGB0)<UNTAG_Int(REGB1));
-      /* ./../lib/standard//collection//array.nit:237 */
+      /* ./../lib/standard//collection//array.nit:235 */
       if (UNTAG_Bool(REGB1)) {
-        /* ./../lib/standard//collection//array.nit:238 */
+        /* ./../lib/standard//collection//array.nit:236 */
         REGB1 = TAG_Bool(fra.me.REG[5]==NIT_NULL);
         if (UNTAG_Bool(REGB1)) {
-          nit_abort("Reciever is null", NULL, LOCATE_array, 238);
+          nit_abort("Reciever is null", NULL, LOCATE_standard___collection___array, 236);
         }
-        /* ./../lib/standard//collection//array.nit:654 */
+        /* ./../lib/standard//collection//array.nit:652 */
         fra.me.REG[4] = ((Nit_NativeArray)fra.me.REG[5])->val[UNTAG_Int(REGB0)];
         /* ./syntax//flow.nit:261 */
-        fra.me.REG[4] = CALL_flow___FlowContext___stype(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
+        fra.me.REG[4] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
         /* ./syntax//flow.nit:262 */
         REGB1 = TAG_Bool(fra.me.REG[4]==NIT_NULL);
         if (UNTAG_Bool(REGB1)) {
-          nit_abort("Reciever is null", NULL, LOCATE_flow, 262);
+          nit_abort("Reciever is null", NULL, LOCATE_syntax___flow, 262);
         }
-        REGB1 = CALL_static_type___MMType_____l(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]);
+        REGB1 = CALL_metamodel___static_type___MMType_____l(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[2]);
         REGB1 = TAG_Bool(!UNTAG_Bool(REGB1));
         if (UNTAG_Bool(REGB1)) {
           /* ./syntax//flow.nit:263 */
-          REGB1 = TAG_Bool(ATTR_flow___MergeFlowContext____base(fra.me.REG[0])!=NIT_NULL);
+          REGB1 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____base(fra.me.REG[0])!=NIT_NULL);
           if (UNTAG_Bool(REGB1)) {
           } else {
-            nit_abort("Uninitialized attribute %s", "_base", LOCATE_flow, 263);
+            nit_abort("Uninitialized attribute %s", "_base", LOCATE_syntax___flow, 263);
           }
-          fra.me.REG[4] = ATTR_flow___MergeFlowContext____base(fra.me.REG[0]);
-          fra.me.REG[4] = CALL_flow___FlowContext___stype(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
+          fra.me.REG[4] = ATTR_syntax___flow___MergeFlowContext____base(fra.me.REG[0]);
+          fra.me.REG[4] = CALL_syntax___flow___FlowContext___stype(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
           fra.me.REG[7] = fra.me.REG[4];
           goto label1;
         }
-        /* ./../lib/standard//collection//array.nit:239 */
+        /* ./../lib/standard//collection//array.nit:237 */
         REGB1 = TAG_Int(1);
-        /* ./../lib/standard//kernel.nit:215 */
+        /* ./../lib/standard//kernel.nit:218 */
         REGB1 = TAG_Int(UNTAG_Int(REGB0)+UNTAG_Int(REGB1));
-        /* ./../lib/standard//collection//array.nit:239 */
+        /* ./../lib/standard//collection//array.nit:237 */
         REGB0 = REGB1;
       } else {
-        /* ./../lib/standard//collection//array.nit:237 */
+        /* ./../lib/standard//collection//array.nit:235 */
         goto label4;
       }
     }
@@ -1145,16 +1160,17 @@ val_t flow___MergeFlowContext___merge_stype(val_t p0, val_t p1){
   stack_frame_head = fra.me.prev;
   return fra.me.REG[7];
 }
-val_t flow___MergeFlowContext___is_set(val_t p0, val_t p1){
+val_t syntax___flow___MergeFlowContext___is_set(val_t p0, val_t p1){
   struct {struct stack_frame_t me; val_t MORE_REG[4];} fra;
   val_t REGB0;
   val_t REGB1;
   val_t REGB2;
+  val_t REGB3;
   val_t tmp;
   fra.me.prev = stack_frame_head; stack_frame_head = &fra.me;
-  fra.me.file = LOCATE_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 270;
-  fra.me.meth = LOCATE_flow___MergeFlowContext___is_set;
+  fra.me.meth = LOCATE_syntax___flow___MergeFlowContext___is_set;
   fra.me.has_broke = 0;
   fra.me.REG_size = 5;
   fra.me.REG[0] = NIT_NULL;
@@ -1165,58 +1181,63 @@ val_t flow___MergeFlowContext___is_set(val_t p0, val_t p1){
   fra.me.REG[0] = p0;
   fra.me.REG[1] = p1;
   /* ./syntax//flow.nit:272 */
-  REGB0 = TAG_Bool(ATTR_flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
+  REGB0 = TAG_Bool(ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
   if (UNTAG_Bool(REGB0)) {
   } else {
-    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_flow, 272);
+    nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_syntax___flow, 272);
   }
-  fra.me.REG[2] = ATTR_flow___FlowContext____set_variables(fra.me.REG[0]);
-  REGB0 = CALL_abstract_collection___Collection___has(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
+  fra.me.REG[2] = ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0]);
+  REGB0 = CALL_standard___collection___abstract_collection___Collection___has(fra.me.REG[2])(fra.me.REG[2], fra.me.REG[1]);
   if (UNTAG_Bool(REGB0)) {
     /* ./syntax//flow.nit:273 */
     REGB0 = TAG_Bool(true);
     goto label1;
   } else {
     /* ./syntax//flow.nit:275 */
-    REGB1 = TAG_Bool(ATTR_flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
+    REGB1 = TAG_Bool(ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB1)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_alts", LOCATE_flow, 275);
+      nit_abort("Uninitialized attribute %s", "_alts", LOCATE_syntax___flow, 275);
     }
-    fra.me.REG[2] = ATTR_flow___MergeFlowContext____alts(fra.me.REG[0]);
-    /* ./../lib/standard//collection//array.nit:234 */
+    fra.me.REG[2] = ATTR_syntax___flow___MergeFlowContext____alts(fra.me.REG[0]);
+    /* ./../lib/standard//collection//array.nit:232 */
     REGB1 = TAG_Int(0);
-    /* ./../lib/standard//collection//array.nit:235 */
-    REGB2 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL);
+    /* ./../lib/standard//collection//array.nit:233 */
+    REGB2 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL);
     if (UNTAG_Bool(REGB2)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 235);
+      nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 233);
     }
-    REGB2 = ATTR_array___AbstractArrayRead____length(fra.me.REG[2]);
-    /* ./../lib/standard//collection//array.nit:236 */
-    fra.me.REG[3] = ATTR_array___Array____items(fra.me.REG[2]);
-    /* ./../lib/standard//collection//array.nit:237 */
+    REGB2 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2]);
+    /* ./../lib/standard//collection//array.nit:234 */
+    fra.me.REG[3] = ATTR_standard___collection___array___Array____items(fra.me.REG[2]);
+    /* ./../lib/standard//collection//array.nit:235 */
     while(1) {
       /* ./../lib/standard//collection//array.nit:23 */
-      REGB2 = TAG_Bool(ATTR_array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL);
+      REGB2 = TAG_Bool(ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2])!=NIT_NULL);
       if (UNTAG_Bool(REGB2)) {
       } else {
-        nit_abort("Uninitialized attribute %s", "_length", LOCATE_array, 23);
+        nit_abort("Uninitialized attribute %s", "_length", LOCATE_standard___collection___array, 23);
+      }
+      REGB2 = ATTR_standard___collection___array___AbstractArrayRead____length(fra.me.REG[2]);
+      REGB3 = TAG_Bool(VAL_ISA(REGB2, VTCOLOR_standard___kernel___Comparable___OTHER(REGB1), VTID_standard___kernel___Comparable___OTHER(REGB1))) /*cast OTHER*/;
+      if (UNTAG_Bool(REGB3)) {
+      } else {
+        nit_abort("Cast failed", NULL, LOCATE_standard___kernel, 0);
       }
-      REGB2 = ATTR_array___AbstractArrayRead____length(fra.me.REG[2]);
-      /* ./../lib/standard//kernel.nit:212 */
+      /* ./../lib/standard//kernel.nit:215 */
       REGB2 = TAG_Bool(UNTAG_Int(REGB1)<UNTAG_Int(REGB2));
-      /* ./../lib/standard//collection//array.nit:237 */
+      /* ./../lib/standard//collection//array.nit:235 */
       if (UNTAG_Bool(REGB2)) {
-        /* ./../lib/standard//collection//array.nit:238 */
+        /* ./../lib/standard//collection//array.nit:236 */
         REGB2 = TAG_Bool(fra.me.REG[3]==NIT_NULL);
         if (UNTAG_Bool(REGB2)) {
-          nit_abort("Reciever is null", NULL, LOCATE_array, 238);
+          nit_abort("Reciever is null", NULL, LOCATE_standard___collection___array, 236);
         }
-        /* ./../lib/standard//collection//array.nit:654 */
+        /* ./../lib/standard//collection//array.nit:652 */
         fra.me.REG[4] = ((Nit_NativeArray)fra.me.REG[3])->val[UNTAG_Int(REGB1)];
         /* ./syntax//flow.nit:276 */
-        REGB2 = CALL_flow___FlowContext___is_set(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
+        REGB2 = CALL_syntax___flow___FlowContext___is_set(fra.me.REG[4])(fra.me.REG[4], fra.me.REG[1]);
         REGB2 = TAG_Bool(!UNTAG_Bool(REGB2));
         if (UNTAG_Bool(REGB2)) {
           /* ./syntax//flow.nit:277 */
@@ -1224,26 +1245,26 @@ val_t flow___MergeFlowContext___is_set(val_t p0, val_t p1){
           REGB0 = REGB2;
           goto label1;
         }
-        /* ./../lib/standard//collection//array.nit:239 */
+        /* ./../lib/standard//collection//array.nit:237 */
         REGB2 = TAG_Int(1);
-        /* ./../lib/standard//kernel.nit:215 */
+        /* ./../lib/standard//kernel.nit:218 */
         REGB2 = TAG_Int(UNTAG_Int(REGB1)+UNTAG_Int(REGB2));
-        /* ./../lib/standard//collection//array.nit:239 */
+        /* ./../lib/standard//collection//array.nit:237 */
         REGB1 = REGB2;
       } else {
-        /* ./../lib/standard//collection//array.nit:237 */
+        /* ./../lib/standard//collection//array.nit:235 */
         goto label2;
       }
     }
     label2: while(0);
     /* ./syntax//flow.nit:280 */
-    REGB1 = TAG_Bool(ATTR_flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
+    REGB1 = TAG_Bool(ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0])!=NIT_NULL);
     if (UNTAG_Bool(REGB1)) {
     } else {
-      nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_flow, 280);
+      nit_abort("Uninitialized attribute %s", "_set_variables", LOCATE_syntax___flow, 280);
     }
-    fra.me.REG[0] = ATTR_flow___FlowContext____set_variables(fra.me.REG[0]);
-    CALL_abstract_collection___SimpleCollection___add(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
+    fra.me.REG[0] = ATTR_syntax___flow___FlowContext____set_variables(fra.me.REG[0]);
+    CALL_standard___collection___abstract_collection___SimpleCollection___add(fra.me.REG[0])(fra.me.REG[0], fra.me.REG[1]);
     /* ./syntax//flow.nit:281 */
     REGB1 = TAG_Bool(true);
     REGB0 = REGB1;
@@ -1253,14 +1274,14 @@ val_t flow___MergeFlowContext___is_set(val_t p0, val_t p1){
   stack_frame_head = fra.me.prev;
   return REGB0;
 }
-val_t flow___Variable___must_be_set(val_t p0){
+val_t syntax___flow___Variable___must_be_set(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 288;
-  fra.me.meth = LOCATE_flow___Variable___must_be_set;
+  fra.me.meth = LOCATE_syntax___flow___Variable___must_be_set;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;
@@ -1272,14 +1293,14 @@ val_t flow___Variable___must_be_set(val_t p0){
   stack_frame_head = fra.me.prev;
   return REGB0;
 }
-val_t flow___VarVariable___must_be_set(val_t p0){
+val_t syntax___flow___VarVariable___must_be_set(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_flow;
+  fra.me.file = LOCATE_syntax___flow;
   fra.me.line = 293;
-  fra.me.meth = LOCATE_flow___VarVariable___must_be_set;
+  fra.me.meth = LOCATE_syntax___flow___VarVariable___must_be_set;
   fra.me.has_broke = 0;
   fra.me.REG_size = 1;
   fra.me.REG[0] = NIT_NULL;