short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
long var6 /* : Int */;
long var8 /* : Int */;
short int var12 /* : Bool */;
int cltype13;
int idtype14;
-short int var15 /* : Bool */;
-long var16 /* : Int */;
+const char* var_class_name15;
+short int var16 /* : Bool */;
long var17 /* : Int */;
-short int var18 /* : Bool */;
-short int var20 /* : Bool */;
-int cltype21;
-int idtype22;
-short int var23 /* : Bool */;
-long var24 /* : Int */;
+long var18 /* : Int */;
+short int var19 /* : Bool */;
+short int var21 /* : Bool */;
+int cltype22;
+int idtype23;
+const char* var_class_name24;
short int var25 /* : Bool */;
+long var26 /* : Int */;
short int var27 /* : Bool */;
-int cltype28;
-int idtype29;
-short int var30 /* : Bool */;
-val* var31 /* : Buffer */;
-long var32 /* : Int */;
-long var34 /* : Int */;
+short int var29 /* : Bool */;
+int cltype30;
+int idtype31;
+const char* var_class_name32;
+short int var33 /* : Bool */;
+val* var34 /* : Buffer */;
+long var35 /* : Int */;
+long var37 /* : Int */;
val* var_r /* var r: Buffer */;
-short int var35 /* : Bool */;
-short int var37 /* : Bool */;
-int cltype38;
-int idtype39;
+short int var38 /* : Bool */;
short int var40 /* : Bool */;
-char* var41 /* : NativeString */;
-char var42 /* : Char */;
-char var44 /* : Char */;
-val* var45 /* : nullable Object */;
-long var46 /* : Int */;
-long var47 /* : Int */;
-long var49 /* : Int */;
-val* var50 /* : String */;
-static val* varonce;
-val* var51 /* : String */;
-char* var52 /* : NativeString */;
+int cltype41;
+int idtype42;
+const char* var_class_name43;
+short int var44 /* : Bool */;
+char* var45 /* : NativeString */;
+char var46 /* : Char */;
+char var48 /* : Char */;
+val* var49 /* : nullable Object */;
+long var50 /* : Int */;
+long var51 /* : Int */;
long var53 /* : Int */;
val* var54 /* : String */;
+static val* varonce;
+val* var55 /* : String */;
+char* var56 /* : NativeString */;
+long var57 /* : Int */;
+val* var58 /* : String */;
var_from = p0;
var_count = p1;
var1 = 0;
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var5 = var_count >= var1;
RET_LABEL3:(void)0;
}
if (!var2) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 50);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 50);
exit(1);
}
{ /* Inline kernel#Int#+ (var_count,var_from) */
/* <var9:Int> isa OTHER */
var12 = 1; /* easy <var9:Int> isa OTHER*/
if (!var12) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name15 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name15);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var15 = var_from < var9;
-var10 = var15;
+var16 = var_from < var9;
+var10 = var16;
goto RET_LABEL11;
RET_LABEL11:(void)0;
}
if (var10){
-var16 = 0;
-var_from = var16;
+var17 = 0;
+var_from = var17;
} else {
}
-var17 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:AbstractString>*/;
-{ /* Inline kernel#Int#> (var_count,var17) */
-/* Covariant cast for argument 0 (i) <var17:Int> isa OTHER */
-/* <var17:Int> isa OTHER */
-var20 = 1; /* easy <var17:Int> isa OTHER*/
-if (!var20) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var18 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:AbstractString>*/;
+{ /* Inline kernel#Int#> (var_count,var18) */
+/* Covariant cast for argument 0 (i) <var18:Int> isa OTHER */
+/* <var18:Int> isa OTHER */
+var21 = 1; /* easy <var18:Int> isa OTHER*/
+if (!var21) {
+var_class_name24 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name24);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
-var23 = var_count > var17;
-var18 = var23;
-goto RET_LABEL19;
-RET_LABEL19:(void)0;
+var25 = var_count > var18;
+var19 = var25;
+goto RET_LABEL20;
+RET_LABEL20:(void)0;
}
-if (var18){
-var24 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:AbstractString>*/;
-var_count = var24;
+if (var19){
+var26 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:AbstractString>*/;
+var_count = var26;
} else {
}
{ /* Inline kernel#Int#< (var_from,var_count) */
/* Covariant cast for argument 0 (i) <var_count:Int> isa OTHER */
/* <var_count:Int> isa OTHER */
-var27 = 1; /* easy <var_count:Int> isa OTHER*/
-if (!var27) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var29 = 1; /* easy <var_count:Int> isa OTHER*/
+if (!var29) {
+var_class_name32 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name32);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var30 = var_from < var_count;
-var25 = var30;
-goto RET_LABEL26;
-RET_LABEL26:(void)0;
+var33 = var_from < var_count;
+var27 = var33;
+goto RET_LABEL28;
+RET_LABEL28:(void)0;
}
-if (var25){
-var31 = NEW_string__Buffer(&type_string__Buffer);
+if (var27){
+var34 = NEW_string__Buffer(&type_string__Buffer);
{ /* Inline kernel#Int#- (var_count,var_from) */
-var34 = var_count - var_from;
-var32 = var34;
-goto RET_LABEL33;
-RET_LABEL33:(void)0;
+var37 = var_count - var_from;
+var35 = var37;
+goto RET_LABEL36;
+RET_LABEL36:(void)0;
}
-((void (*)(val*, long))(var31->class->vft[COLOR_string__Buffer__with_capacity]))(var31, var32) /* with_capacity on <var31:Buffer>*/;
-CHECK_NEW_string__Buffer(var31);
-var_r = var31;
+((void (*)(val*, long))(var34->class->vft[COLOR_string__Buffer__with_capacity]))(var34, var35) /* with_capacity on <var34:Buffer>*/;
+CHECK_NEW_string__Buffer(var34);
+var_r = var34;
for(;;) {
{ /* Inline kernel#Int#< (var_from,var_count) */
/* Covariant cast for argument 0 (i) <var_count:Int> isa OTHER */
/* <var_count:Int> isa OTHER */
-var37 = 1; /* easy <var_count:Int> isa OTHER*/
-if (!var37) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var40 = 1; /* easy <var_count:Int> isa OTHER*/
+if (!var40) {
+var_class_name43 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name43);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var40 = var_from < var_count;
-var35 = var40;
-goto RET_LABEL36;
-RET_LABEL36:(void)0;
+var44 = var_from < var_count;
+var38 = var44;
+goto RET_LABEL39;
+RET_LABEL39:(void)0;
}
-if (!var35) break;
-var41 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:AbstractString> */
-{ /* Inline string#NativeString#[] (var41,var_from) */
-var44 = var41[var_from];
-var42 = var44;
-goto RET_LABEL43;
-RET_LABEL43:(void)0;
+if (!var38) break;
+var45 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:AbstractString> */
+{ /* Inline string#NativeString#[] (var45,var_from) */
+var48 = var45[var_from];
+var46 = var48;
+goto RET_LABEL47;
+RET_LABEL47:(void)0;
}
-var45 = BOX_kernel__Char(var42); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_r->class->vft[COLOR_abstract_collection__Sequence__push]))(var_r, var45) /* push on <var_r:Buffer>*/;
-var46 = 1;
-{ /* Inline kernel#Int#+ (var_from,var46) */
-var49 = var_from + var46;
-var47 = var49;
-goto RET_LABEL48;
-RET_LABEL48:(void)0;
+var49 = BOX_kernel__Char(var46); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_r->class->vft[COLOR_abstract_collection__Sequence__push]))(var_r, var49) /* push on <var_r:Buffer>*/;
+var50 = 1;
+{ /* Inline kernel#Int#+ (var_from,var50) */
+var53 = var_from + var50;
+var51 = var53;
+goto RET_LABEL52;
+RET_LABEL52:(void)0;
}
-var_from = var47;
+var_from = var51;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
-var50 = ((val* (*)(val*))(var_r->class->vft[COLOR_string__Object__to_s]))(var_r) /* to_s on <var_r:Buffer>*/;
-var = var50;
+var54 = ((val* (*)(val*))(var_r->class->vft[COLOR_string__Object__to_s]))(var_r) /* to_s on <var_r:Buffer>*/;
+var = var54;
goto RET_LABEL;
} else {
if (varonce) {
-var51 = varonce;
+var55 = varonce;
} else {
-var52 = "";
-var53 = 0;
-var54 = string__NativeString__to_s_with_length(var52, var53);
-var51 = var54;
-varonce = var51;
+var56 = "";
+var57 = 0;
+var58 = string__NativeString__to_s_with_length(var56, var57);
+var55 = var58;
+varonce = var55;
}
-var = var51;
+var = var55;
goto RET_LABEL;
}
RET_LABEL:;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
long var6 /* : Int */;
long var7 /* : Int */;
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
var5 = var_from < var1;
RET_LABEL3:(void)0;
}
if (!var2) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 75);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 75);
exit(1);
}
var6 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:AbstractString>*/;
short int var15 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var16 /* : Bool */;
short int var_ /* var : Bool */;
short int var17 /* : Bool */;
short int var19 /* : Bool */;
int cltype20;
int idtype21;
-short int var22 /* : Bool */;
+const char* var_class_name22;
short int var23 /* : Bool */;
-long var24 /* : Int */;
-long var_its_index_from /* var its_index_from: Int */;
+short int var24 /* : Bool */;
long var25 /* : Int */;
-long var27 /* : Int */;
-short int var28 /* : Bool */;
-short int var30 /* : Bool */;
-int cltype31;
-int idtype32;
-short int var33 /* : Bool */;
-char var34 /* : Char */;
+long var_its_index_from /* var its_index_from: Int */;
+long var26 /* : Int */;
+long var28 /* : Int */;
+short int var29 /* : Bool */;
+short int var31 /* : Bool */;
+int cltype32;
+int idtype33;
+const char* var_class_name34;
+short int var35 /* : Bool */;
char var36 /* : Char */;
-char var37 /* : Char */;
+char var38 /* : Char */;
char var39 /* : Char */;
-short int var40 /* : Bool */;
+char var41 /* : Char */;
short int var42 /* : Bool */;
-short int var43 /* : Bool */;
short int var44 /* : Bool */;
-long var45 /* : Int */;
-long var46 /* : Int */;
+short int var45 /* : Bool */;
+short int var46 /* : Bool */;
+long var47 /* : Int */;
long var48 /* : Int */;
-long var49 /* : Int */;
long var50 /* : Int */;
+long var51 /* : Int */;
long var52 /* : Int */;
-short int var53 /* : Bool */;
+long var54 /* : Int */;
+short int var55 /* : Bool */;
var_str = p0;
var_pos = p1;
var1 = ((long (*)(val*))(var_str->class->vft[COLOR_abstract_collection__Collection__length]))(var_str) /* length on <var_str:String>*/;
/* <var12:Int> isa OTHER */
var15 = 1; /* easy <var12:Int> isa OTHER*/
if (!var15) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
var16 = var_myindex > var12;
/* <var_myindex:Int> isa OTHER */
var19 = 1; /* easy <var_myindex:Int> isa OTHER*/
if (!var19) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name22 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name22);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
-var22 = var_itsindex > var_myindex;
-var17 = var22;
+var23 = var_itsindex > var_myindex;
+var17 = var23;
goto RET_LABEL18;
RET_LABEL18:(void)0;
}
var11 = var17;
}
if (var11){
-var23 = 0;
-var = var23;
+var24 = 0;
+var = var24;
goto RET_LABEL;
} else {
}
-var24 = var_str->attrs[COLOR_string__String___index_from].l; /* _index_from on <var_str:String> */
-var_its_index_from = var24;
+var25 = var_str->attrs[COLOR_string__String___index_from].l; /* _index_from on <var_str:String> */
+var_its_index_from = var25;
{ /* Inline kernel#Int#+ (var_itsindex,var_its_index_from) */
-var27 = var_itsindex + var_its_index_from;
-var25 = var27;
-goto RET_LABEL26;
-RET_LABEL26:(void)0;
+var28 = var_itsindex + var_its_index_from;
+var26 = var28;
+goto RET_LABEL27;
+RET_LABEL27:(void)0;
}
-var_itsindex = var25;
+var_itsindex = var26;
for(;;) {
{ /* Inline kernel#Int#>= (var_itsindex,var_its_index_from) */
/* Covariant cast for argument 0 (i) <var_its_index_from:Int> isa OTHER */
/* <var_its_index_from:Int> isa OTHER */
-var30 = 1; /* easy <var_its_index_from:Int> isa OTHER*/
-if (!var30) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var31 = 1; /* easy <var_its_index_from:Int> isa OTHER*/
+if (!var31) {
+var_class_name34 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name34);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
-var33 = var_itsindex >= var_its_index_from;
-var28 = var33;
-goto RET_LABEL29;
-RET_LABEL29:(void)0;
+var35 = var_itsindex >= var_its_index_from;
+var29 = var35;
+goto RET_LABEL30;
+RET_LABEL30:(void)0;
}
-if (!var28) break;
+if (!var29) break;
{ /* Inline string#NativeString#[] (var_myitems,var_myindex) */
-var36 = var_myitems[var_myindex];
-var34 = var36;
-goto RET_LABEL35;
-RET_LABEL35:(void)0;
+var38 = var_myitems[var_myindex];
+var36 = var38;
+goto RET_LABEL37;
+RET_LABEL37:(void)0;
}
{ /* Inline string#NativeString#[] (var_itsitems,var_itsindex) */
-var39 = var_itsitems[var_itsindex];
-var37 = var39;
-goto RET_LABEL38;
-RET_LABEL38:(void)0;
+var41 = var_itsitems[var_itsindex];
+var39 = var41;
+goto RET_LABEL40;
+RET_LABEL40:(void)0;
}
-{ /* Inline kernel#Char#!= (var34,var37) */
-var42 = var34 == var37;
-var43 = !var42;
-var40 = var43;
-goto RET_LABEL41;
-RET_LABEL41:(void)0;
+{ /* Inline kernel#Char#!= (var36,var39) */
+var44 = var36 == var39;
+var45 = !var44;
+var42 = var45;
+goto RET_LABEL43;
+RET_LABEL43:(void)0;
}
-if (var40){
-var44 = 0;
-var = var44;
+if (var42){
+var46 = 0;
+var = var46;
goto RET_LABEL;
} else {
}
-var45 = 1;
-{ /* Inline kernel#Int#- (var_myindex,var45) */
-var48 = var_myindex - var45;
-var46 = var48;
-goto RET_LABEL47;
-RET_LABEL47:(void)0;
+var47 = 1;
+{ /* Inline kernel#Int#- (var_myindex,var47) */
+var50 = var_myindex - var47;
+var48 = var50;
+goto RET_LABEL49;
+RET_LABEL49:(void)0;
}
-var_myindex = var46;
-var49 = 1;
-{ /* Inline kernel#Int#- (var_itsindex,var49) */
-var52 = var_itsindex - var49;
-var50 = var52;
-goto RET_LABEL51;
-RET_LABEL51:(void)0;
+var_myindex = var48;
+var51 = 1;
+{ /* Inline kernel#Int#- (var_itsindex,var51) */
+var54 = var_itsindex - var51;
+var52 = var54;
+goto RET_LABEL53;
+RET_LABEL53:(void)0;
}
-var_itsindex = var50;
+var_itsindex = var52;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
-var53 = 1;
-var = var53;
+var55 = 1;
+var = var55;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var10 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var11 /* : Bool */;
long var12 /* : Int */;
long var14 /* : Int */;
short int var18 /* : Bool */;
int cltype19;
int idtype20;
-short int var21 /* : Bool */;
+const char* var_class_name21;
short int var22 /* : Bool */;
-long var23 /* : Int */;
-long var25 /* : Int */;
+short int var23 /* : Bool */;
+long var24 /* : Int */;
long var26 /* : Int */;
-long var28 /* : Int */;
+long var27 /* : Int */;
long var29 /* : Int */;
-long var31 /* : Int */;
+long var30 /* : Int */;
+long var32 /* : Int */;
var_base = p0;
var1 = 0;
var_i = var1;
/* <var_base:Int> isa OTHER */
var10 = 1; /* easy <var_base:Int> isa OTHER*/
if (!var10) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
var11 = var_v > var_base;
/* <var15:Int> isa OTHER */
var18 = 1; /* easy <var15:Int> isa OTHER*/
if (!var18) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name21 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name21);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var21 = var_v < var15;
-var16 = var21;
+var22 = var_v < var15;
+var16 = var22;
goto RET_LABEL17;
RET_LABEL17:(void)0;
}
if (var16){
-var22 = 1;
-var_neg = var22;
+var23 = 1;
+var_neg = var23;
} else {
{ /* Inline kernel#Int#* (var_i,var_base) */
-var25 = var_i * var_base;
-var23 = var25;
-goto RET_LABEL24;
-RET_LABEL24:(void)0;
+var26 = var_i * var_base;
+var24 = var26;
+goto RET_LABEL25;
+RET_LABEL25:(void)0;
}
-{ /* Inline kernel#Int#+ (var23,var_v) */
-var28 = var23 + var_v;
-var26 = var28;
-goto RET_LABEL27;
-RET_LABEL27:(void)0;
+{ /* Inline kernel#Int#+ (var24,var_v) */
+var29 = var24 + var_v;
+var27 = var29;
+goto RET_LABEL28;
+RET_LABEL28:(void)0;
}
-var_i = var26;
+var_i = var27;
}
}
CONTINUE_label: (void)0;
BREAK_label: (void)0;
if (var_neg){
{ /* Inline kernel#Int#unary - (var_i) */
-var31 = -var_i;
-var29 = var31;
-goto RET_LABEL30;
-RET_LABEL30:(void)0;
+var32 = -var_i;
+var30 = var32;
+goto RET_LABEL31;
+RET_LABEL31:(void)0;
}
-var = var29;
+var = var30;
goto RET_LABEL;
} else {
var = var_i;
short int var16 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var17 /* : Bool */;
long var18 /* : Int */;
long var19 /* : Int */;
short int var43 /* : Bool */;
int cltype44;
int idtype45;
-short int var46 /* : Bool */;
-long var47 /* : Int */;
+const char* var_class_name46;
+short int var47 /* : Bool */;
long var48 /* : Int */;
-long var50 /* : Int */;
-short int var51 /* : Bool */;
-short int var53 /* : Bool */;
-val* var54 /* : nullable Object */;
-val* var55 /* : String */;
-char var56 /* : Char */;
-long var58 /* : Int */;
-long var60 /* : Int */;
+long var49 /* : Int */;
+long var51 /* : Int */;
+short int var52 /* : Bool */;
+short int var54 /* : Bool */;
+val* var55 /* : nullable Object */;
+val* var56 /* : String */;
+char var57 /* : Char */;
+long var59 /* : Int */;
long var61 /* : Int */;
long var62 /* : Int */;
-long var64 /* : Int */;
-val* var65 /* : String */;
+long var63 /* : Int */;
+long var65 /* : Int */;
+val* var66 /* : String */;
var1 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:AbstractString> */
var2 = 0;
{ /* Inline kernel#Int#== (var1,var2) */
/* <var13:Int> isa OTHER */
var16 = 1; /* easy <var13:Int> isa OTHER*/
if (!var16) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
var17 = var9 <= var13;
/* <var40:Int> isa OTHER */
var43 = 1; /* easy <var40:Int> isa OTHER*/
if (!var43) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name46 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name46);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
-var46 = var36 <= var40;
-var41 = var46;
+var47 = var36 <= var40;
+var41 = var47;
goto RET_LABEL42;
RET_LABEL42:(void)0;
}
if (!var41) break;
-var47 = 1;
-{ /* Inline kernel#Int#- (var_end_pos,var47) */
-var50 = var_end_pos - var47;
-var48 = var50;
-goto RET_LABEL49;
-RET_LABEL49:(void)0;
+var48 = 1;
+{ /* Inline kernel#Int#- (var_end_pos,var48) */
+var51 = var_end_pos - var48;
+var49 = var51;
+goto RET_LABEL50;
+RET_LABEL50:(void)0;
}
-var_end_pos = var48;
+var_end_pos = var49;
{ /* Inline kernel#Int#== (var_end_pos,var_start_pos) */
-var53 = var_end_pos == var_start_pos;
-var51 = var53;
-goto RET_LABEL52;
-RET_LABEL52:(void)0;
-}
-if (var51){
-var54 = ((val* (*)(val*, long))(self->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(self, var_start_pos) /* [] on <self:AbstractString>*/;
-var56 = ((struct instance_kernel__Char*)var54)->value; /* autounbox from nullable Object to Char */;
-var55 = string__Char__to_s(var56);
-var = var55;
+var54 = var_end_pos == var_start_pos;
+var52 = var54;
+goto RET_LABEL53;
+RET_LABEL53:(void)0;
+}
+if (var52){
+var55 = ((val* (*)(val*, long))(self->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(self, var_start_pos) /* [] on <self:AbstractString>*/;
+var57 = ((struct instance_kernel__Char*)var55)->value; /* autounbox from nullable Object to Char */;
+var56 = string__Char__to_s(var57);
+var = var56;
goto RET_LABEL;
} else {
}
-CONTINUE_label57: (void)0;
+CONTINUE_label58: (void)0;
}
-BREAK_label57: (void)0;
+BREAK_label58: (void)0;
{ /* Inline kernel#Int#- (var_end_pos,var_start_pos) */
-var60 = var_end_pos - var_start_pos;
-var58 = var60;
-goto RET_LABEL59;
-RET_LABEL59:(void)0;
+var61 = var_end_pos - var_start_pos;
+var59 = var61;
+goto RET_LABEL60;
+RET_LABEL60:(void)0;
+}
+var62 = 1;
+{ /* Inline kernel#Int#+ (var59,var62) */
+var65 = var59 + var62;
+var63 = var65;
+goto RET_LABEL64;
+RET_LABEL64:(void)0;
}
-var61 = 1;
-{ /* Inline kernel#Int#+ (var58,var61) */
-var64 = var58 + var61;
-var62 = var64;
-goto RET_LABEL63;
-RET_LABEL63:(void)0;
-}
-var65 = ((val* (*)(val*, long, long))(self->class->vft[COLOR_string__AbstractString__substring]))(self, var_start_pos, var62) /* substring on <self:AbstractString>*/;
-var = var65;
+var66 = ((val* (*)(val*, long, long))(self->class->vft[COLOR_string__AbstractString__substring]))(self, var_start_pos, var63) /* substring on <self:AbstractString>*/;
+var = var66;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
char* var6 /* : NativeString */;
char var7 /* : Char */;
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
var5 = var_i < var1;
short int var12 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var13 /* : Bool */;
short int var_ /* var : Bool */;
char var14 /* : Char */;
short int var17 /* : Bool */;
int cltype18;
int idtype19;
-short int var20 /* : Bool */;
-short int var_21 /* var : Bool */;
-short int var22 /* : Bool */;
-char var23 /* : Char */;
-short int var24 /* : Bool */;
-short int var26 /* : Bool */;
-int cltype27;
-int idtype28;
-short int var29 /* : Bool */;
-short int var_30 /* var : Bool */;
-char var31 /* : Char */;
-short int var32 /* : Bool */;
-short int var34 /* : Bool */;
-int cltype35;
-int idtype36;
-short int var37 /* : Bool */;
-val* var38 /* : nullable Object */;
-short int var39 /* : Bool */;
-char var40 /* : Char */;
-long var41 /* : Int */;
-long var43 /* : Int */;
-val* var44 /* : String */;
-char var45 /* : Char */;
-val* var46 /* : nullable Object */;
-short int var47 /* : Bool */;
+const char* var_class_name20;
+short int var21 /* : Bool */;
+short int var_22 /* var : Bool */;
+short int var23 /* : Bool */;
+char var24 /* : Char */;
+short int var25 /* : Bool */;
+short int var27 /* : Bool */;
+int cltype28;
+int idtype29;
+const char* var_class_name30;
+short int var31 /* : Bool */;
+short int var_32 /* var : Bool */;
+char var33 /* : Char */;
+short int var34 /* : Bool */;
+short int var36 /* : Bool */;
+int cltype37;
+int idtype38;
+const char* var_class_name39;
+short int var40 /* : Bool */;
+val* var41 /* : nullable Object */;
+short int var42 /* : Bool */;
+char var43 /* : Char */;
+long var44 /* : Int */;
+long var46 /* : Int */;
+val* var47 /* : String */;
char var48 /* : Char */;
-short int var49 /* : Bool */;
-short int var51 /* : Bool */;
-int cltype52;
-int idtype53;
+val* var49 /* : nullable Object */;
+short int var50 /* : Bool */;
+char var51 /* : Char */;
+short int var52 /* : Bool */;
short int var54 /* : Bool */;
-short int var_55 /* var : Bool */;
-char var56 /* : Char */;
-short int var57 /* : Bool */;
-short int var59 /* : Bool */;
-int cltype60;
-int idtype61;
-short int var62 /* : Bool */;
-val* var63 /* : nullable Object */;
-short int var64 /* : Bool */;
-char var65 /* : Char */;
-short int var66 /* : Bool */;
-short int var68 /* : Bool */;
-val* var69 /* : nullable Object */;
-short int var70 /* : Bool */;
-char var71 /* : Char */;
-val* var72 /* : nullable Object */;
-long var73 /* : Int */;
-long var75 /* : Int */;
-val* var76 /* : String */;
-char var77 /* : Char */;
-val* var78 /* : nullable Object */;
-short int var79 /* : Bool */;
-val* var80 /* : String */;
+int cltype55;
+int idtype56;
+const char* var_class_name57;
+short int var58 /* : Bool */;
+short int var_59 /* var : Bool */;
+char var60 /* : Char */;
+short int var61 /* : Bool */;
+short int var63 /* : Bool */;
+int cltype64;
+int idtype65;
+const char* var_class_name66;
+short int var67 /* : Bool */;
+val* var68 /* : nullable Object */;
+short int var69 /* : Bool */;
+char var70 /* : Char */;
+short int var71 /* : Bool */;
+short int var73 /* : Bool */;
+val* var74 /* : nullable Object */;
+short int var75 /* : Bool */;
+char var76 /* : Char */;
+val* var77 /* : nullable Object */;
+long var78 /* : Int */;
+long var80 /* : Int */;
+val* var81 /* : String */;
+char var82 /* : Char */;
+val* var83 /* : nullable Object */;
+short int var84 /* : Bool */;
+val* var85 /* : String */;
var1 = NEW_string__Buffer(&type_string__Buffer);
((void (*)(val*))(var1->class->vft[COLOR_string__Buffer__init]))(var1) /* init on <var1:Buffer>*/;
CHECK_NEW_string__Buffer(var1);
/* <var9:Char> isa OTHER */
var12 = 1; /* easy <var9:Char> isa OTHER*/
if (!var12) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 456);
+var_class_name = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 438);
exit(1);
}
var13 = var_c >= var9;
/* <var14:Char> isa OTHER */
var17 = 1; /* easy <var14:Char> isa OTHER*/
if (!var17) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 454);
+var_class_name20 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name20);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 436);
exit(1);
}
-var20 = var_c <= var14;
-var15 = var20;
+var21 = var_c <= var14;
+var15 = var21;
goto RET_LABEL16;
RET_LABEL16:(void)0;
}
} else {
var8 = var_;
}
-var_21 = var8;
+var_22 = var8;
if (var8){
-var7 = var_21;
+var7 = var_22;
} else {
-var23 = 'A';
-{ /* Inline kernel#Char#>= (var_c,var23) */
-/* Covariant cast for argument 0 (i) <var23:Char> isa OTHER */
-/* <var23:Char> isa OTHER */
-var26 = 1; /* easy <var23:Char> isa OTHER*/
-if (!var26) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 456);
+var24 = 'A';
+{ /* Inline kernel#Char#>= (var_c,var24) */
+/* Covariant cast for argument 0 (i) <var24:Char> isa OTHER */
+/* <var24:Char> isa OTHER */
+var27 = 1; /* easy <var24:Char> isa OTHER*/
+if (!var27) {
+var_class_name30 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name30);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 438);
exit(1);
}
-var29 = var_c >= var23;
-var24 = var29;
-goto RET_LABEL25;
-RET_LABEL25:(void)0;
+var31 = var_c >= var24;
+var25 = var31;
+goto RET_LABEL26;
+RET_LABEL26:(void)0;
}
-var_30 = var24;
-if (var24){
-var31 = 'Z';
-{ /* Inline kernel#Char#<= (var_c,var31) */
-/* Covariant cast for argument 0 (i) <var31:Char> isa OTHER */
-/* <var31:Char> isa OTHER */
-var34 = 1; /* easy <var31:Char> isa OTHER*/
-if (!var34) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 454);
+var_32 = var25;
+if (var25){
+var33 = 'Z';
+{ /* Inline kernel#Char#<= (var_c,var33) */
+/* Covariant cast for argument 0 (i) <var33:Char> isa OTHER */
+/* <var33:Char> isa OTHER */
+var36 = 1; /* easy <var33:Char> isa OTHER*/
+if (!var36) {
+var_class_name39 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name39);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 436);
exit(1);
}
-var37 = var_c <= var31;
-var32 = var37;
-goto RET_LABEL33;
-RET_LABEL33:(void)0;
+var40 = var_c <= var33;
+var34 = var40;
+goto RET_LABEL35;
+RET_LABEL35:(void)0;
}
-var22 = var32;
+var23 = var34;
} else {
-var22 = var_30;
+var23 = var_32;
}
-var7 = var22;
+var7 = var23;
}
if (var7){
-var38 = BOX_kernel__Char(var_c); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var38) /* add on <var_res:Buffer>*/;
-var39 = 0;
-var_underscore = var39;
+var41 = BOX_kernel__Char(var_c); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var41) /* add on <var_res:Buffer>*/;
+var42 = 0;
+var_underscore = var42;
goto CONTINUE_label;
} else {
}
if (var_underscore){
-var40 = '_';
-{ /* Inline kernel#Char#ascii (var40) */
-var43 = (unsigned char)var40;
-var41 = var43;
-goto RET_LABEL42;
-RET_LABEL42:(void)0;
-}
-var44 = string__Int__to_s(var41);
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__Sequence__append]))(var_res, var44) /* append on <var_res:Buffer>*/;
-var45 = 'd';
-var46 = BOX_kernel__Char(var45); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var46) /* add on <var_res:Buffer>*/;
-} else {
+var43 = '_';
+{ /* Inline kernel#Char#ascii (var43) */
+var46 = (unsigned char)var43;
+var44 = var46;
+goto RET_LABEL45;
+RET_LABEL45:(void)0;
}
-var48 = '0';
-{ /* Inline kernel#Char#>= (var_c,var48) */
-/* Covariant cast for argument 0 (i) <var48:Char> isa OTHER */
-/* <var48:Char> isa OTHER */
-var51 = 1; /* easy <var48:Char> isa OTHER*/
-if (!var51) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 456);
+var47 = string__Int__to_s(var44);
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__Sequence__append]))(var_res, var47) /* append on <var_res:Buffer>*/;
+var48 = 'd';
+var49 = BOX_kernel__Char(var48); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var49) /* add on <var_res:Buffer>*/;
+} else {
+}
+var51 = '0';
+{ /* Inline kernel#Char#>= (var_c,var51) */
+/* Covariant cast for argument 0 (i) <var51:Char> isa OTHER */
+/* <var51:Char> isa OTHER */
+var54 = 1; /* easy <var51:Char> isa OTHER*/
+if (!var54) {
+var_class_name57 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name57);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 438);
exit(1);
}
-var54 = var_c >= var48;
-var49 = var54;
-goto RET_LABEL50;
-RET_LABEL50:(void)0;
-}
-var_55 = var49;
-if (var49){
-var56 = '9';
-{ /* Inline kernel#Char#<= (var_c,var56) */
-/* Covariant cast for argument 0 (i) <var56:Char> isa OTHER */
-/* <var56:Char> isa OTHER */
-var59 = 1; /* easy <var56:Char> isa OTHER*/
-if (!var59) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 454);
+var58 = var_c >= var51;
+var52 = var58;
+goto RET_LABEL53;
+RET_LABEL53:(void)0;
+}
+var_59 = var52;
+if (var52){
+var60 = '9';
+{ /* Inline kernel#Char#<= (var_c,var60) */
+/* Covariant cast for argument 0 (i) <var60:Char> isa OTHER */
+/* <var60:Char> isa OTHER */
+var63 = 1; /* easy <var60:Char> isa OTHER*/
+if (!var63) {
+var_class_name66 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name66);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 436);
exit(1);
}
-var62 = var_c <= var56;
-var57 = var62;
-goto RET_LABEL58;
-RET_LABEL58:(void)0;
+var67 = var_c <= var60;
+var61 = var67;
+goto RET_LABEL62;
+RET_LABEL62:(void)0;
}
-var47 = var57;
+var50 = var61;
} else {
-var47 = var_55;
+var50 = var_59;
}
-if (var47){
-var63 = BOX_kernel__Char(var_c); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var63) /* add on <var_res:Buffer>*/;
-var64 = 0;
-var_underscore = var64;
-} else {
-var65 = '_';
-{ /* Inline kernel#Char#== (var_c,var65) */
-var68 = var_c == var65;
-var66 = var68;
-goto RET_LABEL67;
-RET_LABEL67:(void)0;
-}
-if (var66){
-var69 = BOX_kernel__Char(var_c); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var69) /* add on <var_res:Buffer>*/;
-var70 = 1;
-var_underscore = var70;
-} else {
-var71 = '_';
-var72 = BOX_kernel__Char(var71); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var72) /* add on <var_res:Buffer>*/;
+if (var50){
+var68 = BOX_kernel__Char(var_c); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var68) /* add on <var_res:Buffer>*/;
+var69 = 0;
+var_underscore = var69;
+} else {
+var70 = '_';
+{ /* Inline kernel#Char#== (var_c,var70) */
+var73 = var_c == var70;
+var71 = var73;
+goto RET_LABEL72;
+RET_LABEL72:(void)0;
+}
+if (var71){
+var74 = BOX_kernel__Char(var_c); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var74) /* add on <var_res:Buffer>*/;
+var75 = 1;
+var_underscore = var75;
+} else {
+var76 = '_';
+var77 = BOX_kernel__Char(var76); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var77) /* add on <var_res:Buffer>*/;
{ /* Inline kernel#Char#ascii (var_c) */
-var75 = (unsigned char)var_c;
-var73 = var75;
-goto RET_LABEL74;
-RET_LABEL74:(void)0;
+var80 = (unsigned char)var_c;
+var78 = var80;
+goto RET_LABEL79;
+RET_LABEL79:(void)0;
}
-var76 = string__Int__to_s(var73);
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__Sequence__append]))(var_res, var76) /* append on <var_res:Buffer>*/;
-var77 = 'd';
-var78 = BOX_kernel__Char(var77); /* autobox from Char to nullable Object */
-((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var78) /* add on <var_res:Buffer>*/;
-var79 = 0;
-var_underscore = var79;
+var81 = string__Int__to_s(var78);
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__Sequence__append]))(var_res, var81) /* append on <var_res:Buffer>*/;
+var82 = 'd';
+var83 = BOX_kernel__Char(var82); /* autobox from Char to nullable Object */
+((void (*)(val*, val*))(var_res->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_res, var83) /* add on <var_res:Buffer>*/;
+var84 = 0;
+var_underscore = var84;
}
}
CONTINUE_label: (void)0;
((void (*)(val*))(var3->class->vft[COLOR_abstract_collection__Iterator__next]))(var3) /* next on <var3:Iterator[nullable Object]>*/;
}
BREAK_label: (void)0;
-var80 = ((val* (*)(val*))(var_res->class->vft[COLOR_string__Object__to_s]))(var_res) /* to_s on <var_res:Buffer>*/;
-var = var80;
+var85 = ((val* (*)(val*))(var_res->class->vft[COLOR_string__Object__to_s]))(var_res) /* to_s on <var_res:Buffer>*/;
+var = var85;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var56 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var57 /* : Bool */;
static val* varonce58;
val* var59 /* : String */;
/* <var53:Int> isa OTHER */
var56 = 1; /* easy <var53:Int> isa OTHER*/
if (!var56) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
var57 = var50 < var53;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
long var6 /* : Int */;
long var7 /* : Int */;
short int var13 /* : Bool */;
int cltype14;
int idtype15;
-short int var16 /* : Bool */;
-char* var17 /* : NativeString */;
-long var18 /* : Int */;
+const char* var_class_name16;
+short int var17 /* : Bool */;
+char* var18 /* : NativeString */;
long var19 /* : Int */;
-long var21 /* : Int */;
-char var22 /* : Char */;
-char var24 /* : Char */;
+long var20 /* : Int */;
+long var22 /* : Int */;
+char var23 /* : Char */;
+char var25 /* : Char */;
var_index = p0;
var1 = 0;
{ /* Inline kernel#Int#>= (var_index,var1) */
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var5 = var_index >= var1;
RET_LABEL3:(void)0;
}
if (!var2) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 379);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 379);
exit(1);
}
var6 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
/* <var10:Int> isa OTHER */
var13 = 1; /* easy <var10:Int> isa OTHER*/
if (!var13) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name16 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name16);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
-var16 = var7 <= var10;
-var11 = var16;
+var17 = var7 <= var10;
+var11 = var17;
goto RET_LABEL12;
RET_LABEL12:(void)0;
}
if (!var11) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 382);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 382);
exit(1);
}
-var17 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
-var18 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
-{ /* Inline kernel#Int#+ (var_index,var18) */
-var21 = var_index + var18;
-var19 = var21;
-goto RET_LABEL20;
-RET_LABEL20:(void)0;
+var18 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
+var19 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
+{ /* Inline kernel#Int#+ (var_index,var19) */
+var22 = var_index + var19;
+var20 = var22;
+goto RET_LABEL21;
+RET_LABEL21:(void)0;
}
-{ /* Inline string#NativeString#[] (var17,var19) */
-var24 = var17[var19];
-var22 = var24;
-goto RET_LABEL23;
-RET_LABEL23:(void)0;
+{ /* Inline string#NativeString#[] (var18,var20) */
+var25 = var18[var20];
+var23 = var25;
+goto RET_LABEL24;
+RET_LABEL24:(void)0;
}
-var = var22;
+var = var23;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
long var6 /* : Int */;
short int var7 /* : Bool */;
short int var9 /* : Bool */;
int cltype10;
int idtype11;
-short int var12 /* : Bool */;
-long var13 /* : Int */;
-long var15 /* : Int */;
+const char* var_class_name12;
+short int var13 /* : Bool */;
+long var14 /* : Int */;
long var16 /* : Int */;
-short int var17 /* : Bool */;
-short int var19 /* : Bool */;
-int cltype20;
-int idtype21;
-short int var22 /* : Bool */;
-long var23 /* : Int */;
-long var24 /* : Int */;
+long var17 /* : Int */;
+short int var18 /* : Bool */;
+short int var20 /* : Bool */;
+int cltype21;
+int idtype22;
+const char* var_class_name23;
+short int var24 /* : Bool */;
long var25 /* : Int */;
long var26 /* : Int */;
+long var27 /* : Int */;
long var28 /* : Int */;
+long var30 /* : Int */;
long var_realFrom /* var realFrom: Int */;
-long var29 /* : Int */;
long var31 /* : Int */;
-long var32 /* : Int */;
-short int var33 /* : Bool */;
+long var33 /* : Int */;
+long var34 /* : Int */;
short int var35 /* : Bool */;
-int cltype36;
-int idtype37;
-short int var38 /* : Bool */;
-val* var39 /* : String */;
-long var40 /* : Int */;
-char* var41 /* : NativeString */;
-long var42 /* : Int */;
-short int var43 /* : Bool */;
-short int var45 /* : Bool */;
+short int var37 /* : Bool */;
+int cltype38;
+int idtype39;
+const char* var_class_name40;
+short int var41 /* : Bool */;
+val* var42 /* : String */;
+long var43 /* : Int */;
+char* var44 /* : NativeString */;
+long var45 /* : Int */;
+short int var46 /* : Bool */;
+short int var48 /* : Bool */;
static val* varonce;
-val* var46 /* : String */;
-char* var47 /* : NativeString */;
-long var48 /* : Int */;
val* var49 /* : String */;
-val* var50 /* : String */;
+char* var50 /* : NativeString */;
long var51 /* : Int */;
-long var53 /* : Int */;
+val* var52 /* : String */;
+val* var53 /* : String */;
long var54 /* : Int */;
-long var55 /* : Int */;
+long var56 /* : Int */;
long var57 /* : Int */;
-char* var58 /* : NativeString */;
+long var58 /* : Int */;
+long var60 /* : Int */;
+char* var61 /* : NativeString */;
var_from = p0;
var_count = p1;
var1 = 0;
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var5 = var_count >= var1;
RET_LABEL3:(void)0;
}
if (!var2) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 388);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 388);
exit(1);
}
var6 = 0;
/* <var6:Int> isa OTHER */
var9 = 1; /* easy <var6:Int> isa OTHER*/
if (!var9) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name12 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name12);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var12 = var_from < var6;
-var7 = var12;
+var13 = var_from < var6;
+var7 = var13;
goto RET_LABEL8;
RET_LABEL8:(void)0;
}
if (var7){
{ /* Inline kernel#Int#+ (var_count,var_from) */
-var15 = var_count + var_from;
-var13 = var15;
-goto RET_LABEL14;
-RET_LABEL14:(void)0;
+var16 = var_count + var_from;
+var14 = var16;
+goto RET_LABEL15;
+RET_LABEL15:(void)0;
}
-var_count = var13;
-var16 = 0;
-{ /* Inline kernel#Int#< (var_count,var16) */
-/* Covariant cast for argument 0 (i) <var16:Int> isa OTHER */
-/* <var16:Int> isa OTHER */
-var19 = 1; /* easy <var16:Int> isa OTHER*/
-if (!var19) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_count = var14;
+var17 = 0;
+{ /* Inline kernel#Int#< (var_count,var17) */
+/* Covariant cast for argument 0 (i) <var17:Int> isa OTHER */
+/* <var17:Int> isa OTHER */
+var20 = 1; /* easy <var17:Int> isa OTHER*/
+if (!var20) {
+var_class_name23 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name23);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var22 = var_count < var16;
-var17 = var22;
-goto RET_LABEL18;
-RET_LABEL18:(void)0;
+var24 = var_count < var17;
+var18 = var24;
+goto RET_LABEL19;
+RET_LABEL19:(void)0;
}
-if (var17){
-var23 = 0;
-var_count = var23;
+if (var18){
+var25 = 0;
+var_count = var25;
} else {
}
-var24 = 0;
-var_from = var24;
+var26 = 0;
+var_from = var26;
} else {
}
-var25 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
-{ /* Inline kernel#Int#+ (var25,var_from) */
-var28 = var25 + var_from;
-var26 = var28;
-goto RET_LABEL27;
-RET_LABEL27:(void)0;
+var27 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
+{ /* Inline kernel#Int#+ (var27,var_from) */
+var30 = var27 + var_from;
+var28 = var30;
+goto RET_LABEL29;
+RET_LABEL29:(void)0;
}
-var_realFrom = var26;
+var_realFrom = var28;
{ /* Inline kernel#Int#+ (var_realFrom,var_count) */
-var31 = var_realFrom + var_count;
-var29 = var31;
-goto RET_LABEL30;
-RET_LABEL30:(void)0;
+var33 = var_realFrom + var_count;
+var31 = var33;
+goto RET_LABEL32;
+RET_LABEL32:(void)0;
}
-var32 = self->attrs[COLOR_string__String___index_to].l; /* _index_to on <self:String> */
-{ /* Inline kernel#Int#> (var29,var32) */
-/* Covariant cast for argument 0 (i) <var32:Int> isa OTHER */
-/* <var32:Int> isa OTHER */
-var35 = 1; /* easy <var32:Int> isa OTHER*/
-if (!var35) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var34 = self->attrs[COLOR_string__String___index_to].l; /* _index_to on <self:String> */
+{ /* Inline kernel#Int#> (var31,var34) */
+/* Covariant cast for argument 0 (i) <var34:Int> isa OTHER */
+/* <var34:Int> isa OTHER */
+var37 = 1; /* easy <var34:Int> isa OTHER*/
+if (!var37) {
+var_class_name40 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name40);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
-var38 = var29 > var32;
-var33 = var38;
-goto RET_LABEL34;
-RET_LABEL34:(void)0;
+var41 = var31 > var34;
+var35 = var41;
+goto RET_LABEL36;
+RET_LABEL36:(void)0;
}
-if (var33){
-var39 = NEW_string__String(&type_string__String);
-var40 = self->attrs[COLOR_string__String___index_to].l; /* _index_to on <self:String> */
-var41 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
-((void (*)(val*, long, long, char*))(var39->class->vft[COLOR_string__String__from_substring]))(var39, var_realFrom, var40, var41) /* from_substring on <var39:String>*/;
-CHECK_NEW_string__String(var39);
-var = var39;
+if (var35){
+var42 = NEW_string__String(&type_string__String);
+var43 = self->attrs[COLOR_string__String___index_to].l; /* _index_to on <self:String> */
+var44 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
+((void (*)(val*, long, long, char*))(var42->class->vft[COLOR_string__String__from_substring]))(var42, var_realFrom, var43, var44) /* from_substring on <var42:String>*/;
+CHECK_NEW_string__String(var42);
+var = var42;
goto RET_LABEL;
} else {
}
-var42 = 0;
-{ /* Inline kernel#Int#== (var_count,var42) */
-var45 = var_count == var42;
-var43 = var45;
-goto RET_LABEL44;
-RET_LABEL44:(void)0;
+var45 = 0;
+{ /* Inline kernel#Int#== (var_count,var45) */
+var48 = var_count == var45;
+var46 = var48;
+goto RET_LABEL47;
+RET_LABEL47:(void)0;
}
-if (var43){
+if (var46){
if (varonce) {
-var46 = varonce;
+var49 = varonce;
} else {
-var47 = "";
-var48 = 0;
-var49 = string__NativeString__to_s_with_length(var47, var48);
-var46 = var49;
-varonce = var46;
+var50 = "";
+var51 = 0;
+var52 = string__NativeString__to_s_with_length(var50, var51);
+var49 = var52;
+varonce = var49;
}
-var = var46;
+var = var49;
goto RET_LABEL;
} else {
}
-var50 = NEW_string__String(&type_string__String);
+var53 = NEW_string__String(&type_string__String);
{ /* Inline kernel#Int#+ (var_realFrom,var_count) */
-var53 = var_realFrom + var_count;
-var51 = var53;
-goto RET_LABEL52;
-RET_LABEL52:(void)0;
+var56 = var_realFrom + var_count;
+var54 = var56;
+goto RET_LABEL55;
+RET_LABEL55:(void)0;
}
-var54 = 1;
-{ /* Inline kernel#Int#- (var51,var54) */
-var57 = var51 - var54;
-var55 = var57;
-goto RET_LABEL56;
-RET_LABEL56:(void)0;
+var57 = 1;
+{ /* Inline kernel#Int#- (var54,var57) */
+var60 = var54 - var57;
+var58 = var60;
+goto RET_LABEL59;
+RET_LABEL59:(void)0;
}
-var58 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
-((void (*)(val*, long, long, char*))(var50->class->vft[COLOR_string__String__from_substring]))(var50, var_realFrom, var55, var58) /* from_substring on <var50:String>*/;
-CHECK_NEW_string__String(var50);
-var = var50;
+var61 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
+((void (*)(val*, long, long, char*))(var53->class->vft[COLOR_string__String__from_substring]))(var53, var_realFrom, var58, var61) /* from_substring on <var53:String>*/;
+CHECK_NEW_string__String(var53);
+var = var53;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
static val* varonce;
val* var6 /* : String */;
short int var13 /* : Bool */;
int cltype14;
int idtype15;
-short int var16 /* : Bool */;
-long var17 /* : Int */;
+const char* var_class_name16;
+short int var17 /* : Bool */;
long var18 /* : Int */;
-val* var19 /* : String */;
+long var19 /* : Int */;
+val* var20 /* : String */;
var_from = p0;
var1 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
{ /* Inline kernel#Int#> (var_from,var1) */
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
var5 = var_from > var1;
/* <var10:Int> isa OTHER */
var13 = 1; /* easy <var10:Int> isa OTHER*/
if (!var13) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name16 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name16);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var16 = var_from < var10;
-var11 = var16;
+var17 = var_from < var10;
+var11 = var17;
goto RET_LABEL12;
RET_LABEL12:(void)0;
}
if (var11){
-var17 = 0;
-var_from = var17;
+var18 = 0;
+var_from = var18;
} else {
}
-var18 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
-var19 = ((val* (*)(val*, long, long))(self->class->vft[COLOR_string__AbstractString__substring]))(self, var_from, var18) /* substring on <self:String>*/;
-var = var19;
+var19 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
+var20 = ((val* (*)(val*, long, long))(self->class->vft[COLOR_string__AbstractString__substring]))(self, var_from, var19) /* substring on <self:String>*/;
+var = var20;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var15 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var16 /* : Bool */;
short int var_ /* var : Bool */;
short int var17 /* : Bool */;
short int var19 /* : Bool */;
int cltype20;
int idtype21;
-short int var22 /* : Bool */;
+const char* var_class_name22;
short int var23 /* : Bool */;
-long var24 /* : Int */;
-long var_itsindexfrom /* var itsindexfrom: Int */;
+short int var24 /* : Bool */;
long var25 /* : Int */;
-long var27 /* : Int */;
+long var_itsindexfrom /* var itsindexfrom: Int */;
+long var26 /* : Int */;
long var28 /* : Int */;
long var29 /* : Int */;
-long var31 /* : Int */;
-short int var32 /* : Bool */;
-short int var34 /* : Bool */;
-int cltype35;
-int idtype36;
-short int var37 /* : Bool */;
-char var38 /* : Char */;
+long var30 /* : Int */;
+long var32 /* : Int */;
+short int var33 /* : Bool */;
+short int var35 /* : Bool */;
+int cltype36;
+int idtype37;
+const char* var_class_name38;
+short int var39 /* : Bool */;
char var40 /* : Char */;
-char var41 /* : Char */;
+char var42 /* : Char */;
char var43 /* : Char */;
-short int var44 /* : Bool */;
+char var45 /* : Char */;
short int var46 /* : Bool */;
-short int var47 /* : Bool */;
short int var48 /* : Bool */;
-long var49 /* : Int */;
-long var50 /* : Int */;
+short int var49 /* : Bool */;
+short int var50 /* : Bool */;
+long var51 /* : Int */;
long var52 /* : Int */;
-long var53 /* : Int */;
long var54 /* : Int */;
+long var55 /* : Int */;
long var56 /* : Int */;
-short int var57 /* : Bool */;
+long var58 /* : Int */;
+short int var59 /* : Bool */;
var_str = p0;
var_pos = p1;
var1 = var_str->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_str:String> */
/* <var12:Int> isa OTHER */
var15 = 1; /* easy <var12:Int> isa OTHER*/
if (!var15) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
var16 = var_myindex > var12;
/* <var_myindex:Int> isa OTHER */
var19 = 1; /* easy <var_myindex:Int> isa OTHER*/
if (!var19) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name22 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name22);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
-var22 = var_itsindex > var_myindex;
-var17 = var22;
+var23 = var_itsindex > var_myindex;
+var17 = var23;
goto RET_LABEL18;
RET_LABEL18:(void)0;
}
var11 = var17;
}
if (var11){
-var23 = 0;
-var = var23;
+var24 = 0;
+var = var24;
goto RET_LABEL;
} else {
}
-var24 = ((long (*)(val*))(var_str->class->vft[COLOR_string__String__index_from]))(var_str) /* index_from on <var_str:String>*/;
-var_itsindexfrom = var24;
+var25 = ((long (*)(val*))(var_str->class->vft[COLOR_string__String__index_from]))(var_str) /* index_from on <var_str:String>*/;
+var_itsindexfrom = var25;
{ /* Inline kernel#Int#+ (var_itsindex,var_itsindexfrom) */
-var27 = var_itsindex + var_itsindexfrom;
-var25 = var27;
-goto RET_LABEL26;
-RET_LABEL26:(void)0;
+var28 = var_itsindex + var_itsindexfrom;
+var26 = var28;
+goto RET_LABEL27;
+RET_LABEL27:(void)0;
}
-var_itsindex = var25;
-var28 = ((long (*)(val*))(self->class->vft[COLOR_string__String__index_from]))(self) /* index_from on <self:String>*/;
-{ /* Inline kernel#Int#+ (var_myindex,var28) */
-var31 = var_myindex + var28;
-var29 = var31;
-goto RET_LABEL30;
-RET_LABEL30:(void)0;
+var_itsindex = var26;
+var29 = ((long (*)(val*))(self->class->vft[COLOR_string__String__index_from]))(self) /* index_from on <self:String>*/;
+{ /* Inline kernel#Int#+ (var_myindex,var29) */
+var32 = var_myindex + var29;
+var30 = var32;
+goto RET_LABEL31;
+RET_LABEL31:(void)0;
}
-var_myindex = var29;
+var_myindex = var30;
for(;;) {
{ /* Inline kernel#Int#>= (var_itsindex,var_itsindexfrom) */
/* Covariant cast for argument 0 (i) <var_itsindexfrom:Int> isa OTHER */
/* <var_itsindexfrom:Int> isa OTHER */
-var34 = 1; /* easy <var_itsindexfrom:Int> isa OTHER*/
-if (!var34) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var35 = 1; /* easy <var_itsindexfrom:Int> isa OTHER*/
+if (!var35) {
+var_class_name38 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name38);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
-var37 = var_itsindex >= var_itsindexfrom;
-var32 = var37;
-goto RET_LABEL33;
-RET_LABEL33:(void)0;
+var39 = var_itsindex >= var_itsindexfrom;
+var33 = var39;
+goto RET_LABEL34;
+RET_LABEL34:(void)0;
}
-if (!var32) break;
+if (!var33) break;
{ /* Inline string#NativeString#[] (var_myitems,var_myindex) */
-var40 = var_myitems[var_myindex];
-var38 = var40;
-goto RET_LABEL39;
-RET_LABEL39:(void)0;
+var42 = var_myitems[var_myindex];
+var40 = var42;
+goto RET_LABEL41;
+RET_LABEL41:(void)0;
}
{ /* Inline string#NativeString#[] (var_itsitems,var_itsindex) */
-var43 = var_itsitems[var_itsindex];
-var41 = var43;
-goto RET_LABEL42;
-RET_LABEL42:(void)0;
+var45 = var_itsitems[var_itsindex];
+var43 = var45;
+goto RET_LABEL44;
+RET_LABEL44:(void)0;
}
-{ /* Inline kernel#Char#!= (var38,var41) */
-var46 = var38 == var41;
-var47 = !var46;
-var44 = var47;
-goto RET_LABEL45;
-RET_LABEL45:(void)0;
+{ /* Inline kernel#Char#!= (var40,var43) */
+var48 = var40 == var43;
+var49 = !var48;
+var46 = var49;
+goto RET_LABEL47;
+RET_LABEL47:(void)0;
}
-if (var44){
-var48 = 0;
-var = var48;
+if (var46){
+var50 = 0;
+var = var50;
goto RET_LABEL;
} else {
}
-var49 = 1;
-{ /* Inline kernel#Int#- (var_myindex,var49) */
-var52 = var_myindex - var49;
-var50 = var52;
-goto RET_LABEL51;
-RET_LABEL51:(void)0;
+var51 = 1;
+{ /* Inline kernel#Int#- (var_myindex,var51) */
+var54 = var_myindex - var51;
+var52 = var54;
+goto RET_LABEL53;
+RET_LABEL53:(void)0;
}
-var_myindex = var50;
-var53 = 1;
-{ /* Inline kernel#Int#- (var_itsindex,var53) */
-var56 = var_itsindex - var53;
-var54 = var56;
-goto RET_LABEL55;
-RET_LABEL55:(void)0;
+var_myindex = var52;
+var55 = 1;
+{ /* Inline kernel#Int#- (var_itsindex,var55) */
+var58 = var_itsindex - var55;
+var56 = var58;
+goto RET_LABEL57;
+RET_LABEL57:(void)0;
}
-var_itsindex = var54;
+var_itsindex = var56;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
-var57 = 1;
-var = var57;
+var59 = 1;
+var = var59;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var13 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var14 /* : Bool */;
char var15 /* : Char */;
char var17 /* : Char */;
/* <var_max:Int> isa OTHER */
var13 = 1; /* easy <var_max:Int> isa OTHER*/
if (!var13) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
var14 = var_index_from <= var_max;
short int var13 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var14 /* : Bool */;
char var15 /* : Char */;
char var17 /* : Char */;
/* <var_max:Int> isa OTHER */
var13 = 1; /* easy <var_max:Int> isa OTHER*/
if (!var13) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
var14 = var_index_from <= var_max;
short int var17 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var18 /* : Bool */;
long var19 /* : Int */;
long var20 /* : Int */;
short int var46 /* : Bool */;
int cltype47;
int idtype48;
-short int var49 /* : Bool */;
-long var50 /* : Int */;
+const char* var_class_name49;
+short int var50 /* : Bool */;
long var51 /* : Int */;
-long var53 /* : Int */;
-short int var54 /* : Bool */;
-short int var56 /* : Bool */;
-char* var57 /* : NativeString */;
-char var58 /* : Char */;
-char var60 /* : Char */;
-val* var61 /* : String */;
-long var63 /* : Int */;
+long var52 /* : Int */;
+long var54 /* : Int */;
+short int var55 /* : Bool */;
+short int var57 /* : Bool */;
+char* var58 /* : NativeString */;
+char var59 /* : Char */;
+char var61 /* : Char */;
+val* var62 /* : String */;
long var64 /* : Int */;
-long var66 /* : Int */;
+long var65 /* : Int */;
long var67 /* : Int */;
long var68 /* : Int */;
-long var70 /* : Int */;
+long var69 /* : Int */;
long var71 /* : Int */;
-long var73 /* : Int */;
+long var72 /* : Int */;
long var74 /* : Int */;
long var75 /* : Int */;
-long var77 /* : Int */;
-val* var78 /* : String */;
+long var76 /* : Int */;
+long var78 /* : Int */;
+val* var79 /* : String */;
var1 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
var2 = 0;
{ /* Inline kernel#Int#== (var1,var2) */
/* <var14:Int> isa OTHER */
var17 = 1; /* easy <var14:Int> isa OTHER*/
if (!var17) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
var18 = var11 <= var14;
/* <var43:Int> isa OTHER */
var46 = 1; /* easy <var43:Int> isa OTHER*/
if (!var46) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name49 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name49);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
-var49 = var40 <= var43;
-var44 = var49;
+var50 = var40 <= var43;
+var44 = var50;
goto RET_LABEL45;
RET_LABEL45:(void)0;
}
if (!var44) break;
-var50 = 1;
-{ /* Inline kernel#Int#- (var_end_pos,var50) */
-var53 = var_end_pos - var50;
-var51 = var53;
-goto RET_LABEL52;
-RET_LABEL52:(void)0;
-}
-var_end_pos = var51;
+var51 = 1;
+{ /* Inline kernel#Int#- (var_end_pos,var51) */
+var54 = var_end_pos - var51;
+var52 = var54;
+goto RET_LABEL53;
+RET_LABEL53:(void)0;
+}
+var_end_pos = var52;
{ /* Inline kernel#Int#== (var_end_pos,var_start_pos) */
-var56 = var_end_pos == var_start_pos;
-var54 = var56;
-goto RET_LABEL55;
-RET_LABEL55:(void)0;
-}
-if (var54){
-var57 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
-{ /* Inline string#NativeString#[] (var57,var_start_pos) */
-var60 = var57[var_start_pos];
-var58 = var60;
-goto RET_LABEL59;
-RET_LABEL59:(void)0;
+var57 = var_end_pos == var_start_pos;
+var55 = var57;
+goto RET_LABEL56;
+RET_LABEL56:(void)0;
}
-var61 = string__Char__to_s(var58);
-var = var61;
+if (var55){
+var58 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
+{ /* Inline string#NativeString#[] (var58,var_start_pos) */
+var61 = var58[var_start_pos];
+var59 = var61;
+goto RET_LABEL60;
+RET_LABEL60:(void)0;
+}
+var62 = string__Char__to_s(var59);
+var = var62;
goto RET_LABEL;
} else {
}
-CONTINUE_label62: (void)0;
+CONTINUE_label63: (void)0;
}
-BREAK_label62: (void)0;
-var63 = ((long (*)(val*))(self->class->vft[COLOR_string__String__index_from]))(self) /* index_from on <self:String>*/;
-{ /* Inline kernel#Int#- (var_start_pos,var63) */
-var66 = var_start_pos - var63;
-var64 = var66;
-goto RET_LABEL65;
-RET_LABEL65:(void)0;
+BREAK_label63: (void)0;
+var64 = ((long (*)(val*))(self->class->vft[COLOR_string__String__index_from]))(self) /* index_from on <self:String>*/;
+{ /* Inline kernel#Int#- (var_start_pos,var64) */
+var67 = var_start_pos - var64;
+var65 = var67;
+goto RET_LABEL66;
+RET_LABEL66:(void)0;
}
-var_start_pos = var64;
-var67 = ((long (*)(val*))(self->class->vft[COLOR_string__String__index_from]))(self) /* index_from on <self:String>*/;
-{ /* Inline kernel#Int#- (var_end_pos,var67) */
-var70 = var_end_pos - var67;
-var68 = var70;
-goto RET_LABEL69;
-RET_LABEL69:(void)0;
+var_start_pos = var65;
+var68 = ((long (*)(val*))(self->class->vft[COLOR_string__String__index_from]))(self) /* index_from on <self:String>*/;
+{ /* Inline kernel#Int#- (var_end_pos,var68) */
+var71 = var_end_pos - var68;
+var69 = var71;
+goto RET_LABEL70;
+RET_LABEL70:(void)0;
}
-var_end_pos = var68;
+var_end_pos = var69;
{ /* Inline kernel#Int#- (var_end_pos,var_start_pos) */
-var73 = var_end_pos - var_start_pos;
-var71 = var73;
-goto RET_LABEL72;
-RET_LABEL72:(void)0;
-}
-var74 = 1;
-{ /* Inline kernel#Int#+ (var71,var74) */
-var77 = var71 + var74;
-var75 = var77;
-goto RET_LABEL76;
-RET_LABEL76:(void)0;
-}
-var78 = ((val* (*)(val*, long, long))(self->class->vft[COLOR_string__AbstractString__substring]))(self, var_start_pos, var75) /* substring on <self:String>*/;
-var = var78;
+var74 = var_end_pos - var_start_pos;
+var72 = var74;
+goto RET_LABEL73;
+RET_LABEL73:(void)0;
+}
+var75 = 1;
+{ /* Inline kernel#Int#+ (var72,var75) */
+var78 = var72 + var75;
+var76 = var78;
+goto RET_LABEL77;
+RET_LABEL77:(void)0;
+}
+var79 = ((val* (*)(val*, long, long))(self->class->vft[COLOR_string__AbstractString__substring]))(self, var_start_pos, var76) /* substring on <self:String>*/;
+var = var79;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
char* var6 /* : NativeString */;
char var7 /* : Char */;
/* <var_imax:Int> isa OTHER */
var4 = 1; /* easy <var_imax:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
var5 = var_i <= var_imax;
short int var6 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var7 /* : Bool */;
short int var_ /* var : Bool */;
long var8 /* : Int */;
/* <var3:Int> isa OTHER */
var6 = 1; /* easy <var3:Int> isa OTHER*/
if (!var6) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
var7 = var2 > var3;
short int var /* : Bool */;
val* var_other /* var other: nullable Object */;
short int var1 /* : Bool */;
-short int var2 /* : Bool */;
int cltype;
int idtype;
+short int var2 /* : Bool */;
short int var3 /* : Bool */;
-short int var_ /* var : Bool */;
-val* var4 /* : null */;
-short int var5 /* : Bool */;
+long var4 /* : Int */;
+long var5 /* : Int */;
short int var6 /* : Bool */;
-long var7 /* : Int */;
-long var8 /* : Int */;
+short int var8 /* : Bool */;
short int var9 /* : Bool */;
-short int var11 /* : Bool */;
-short int var12 /* : Bool */;
-long var13 /* : Int */;
+long var10 /* : Int */;
long var_my_length /* var my_length: Int */;
-long var14 /* : Int */;
+long var11 /* : Int */;
+short int var12 /* : Bool */;
+short int var14 /* : Bool */;
short int var15 /* : Bool */;
-short int var17 /* : Bool */;
-short int var18 /* : Bool */;
-short int var19 /* : Bool */;
-long var20 /* : Int */;
+short int var16 /* : Bool */;
+long var17 /* : Int */;
long var_my_index /* var my_index: Int */;
-long var21 /* : Int */;
+long var18 /* : Int */;
long var_its_index /* var its_index: Int */;
-long var22 /* : Int */;
-long var24 /* : Int */;
+long var19 /* : Int */;
+long var21 /* : Int */;
long var_last_iteration /* var last_iteration: Int */;
-char* var25 /* : NativeString */;
+char* var22 /* : NativeString */;
char* var_itsitems /* var itsitems: NativeString */;
-char* var26 /* : NativeString */;
+char* var23 /* : NativeString */;
char* var_myitems /* var myitems: NativeString */;
-short int var27 /* : Bool */;
+short int var24 /* : Bool */;
+short int var26 /* : Bool */;
+int cltype27;
+int idtype28;
+const char* var_class_name;
short int var29 /* : Bool */;
-int cltype30;
-int idtype31;
-short int var32 /* : Bool */;
+char var30 /* : Char */;
+char var32 /* : Char */;
char var33 /* : Char */;
char var35 /* : Char */;
-char var36 /* : Char */;
-char var38 /* : Char */;
+short int var36 /* : Bool */;
+short int var38 /* : Bool */;
short int var39 /* : Bool */;
-short int var41 /* : Bool */;
-short int var42 /* : Bool */;
-short int var43 /* : Bool */;
+short int var40 /* : Bool */;
+long var41 /* : Int */;
+long var42 /* : Int */;
long var44 /* : Int */;
long var45 /* : Int */;
-long var47 /* : Int */;
+long var46 /* : Int */;
long var48 /* : Int */;
-long var49 /* : Int */;
-long var51 /* : Int */;
-short int var52 /* : Bool */;
+short int var49 /* : Bool */;
var_other = p0;
/* <var_other:nullable Object> isa String */
cltype = type_string__String.color;
idtype = type_string__String.id;
if(var_other == NULL) {
-var2 = 0;
+var1 = 0;
} else {
if(cltype >= var_other->type->table_size) {
-var2 = 0;
+var1 = 0;
} else {
-var2 = var_other->type->type_table[cltype] == idtype;
+var1 = var_other->type->type_table[cltype] == idtype;
}
}
-var3 = !var2;
-var_ = var3;
-if (var3){
-var1 = var_;
-} else {
-var4 = NULL;
-var5 = var_other == var4;
-var1 = var5;
-}
-if (var1){
-var6 = 0;
-var = var6;
+var2 = !var1;
+if (var2){
+var3 = 0;
+var = var3;
goto RET_LABEL;
} else {
}
-var7 = ((long (*)(val*))(self->class->vft[COLOR_kernel__Object__object_id]))(self) /* object_id on <self:String>*/;
-var8 = ((long (*)(val*))(var_other->class->vft[COLOR_kernel__Object__object_id]))(var_other) /* object_id on <var_other:nullable Object(String)>*/;
-{ /* Inline kernel#Int#== (var7,var8) */
-var11 = var7 == var8;
-var9 = var11;
-goto RET_LABEL10;
-RET_LABEL10:(void)0;
+var4 = ((long (*)(val*))(self->class->vft[COLOR_kernel__Object__object_id]))(self) /* object_id on <self:String>*/;
+var5 = ((long (*)(val*))(var_other->class->vft[COLOR_kernel__Object__object_id]))(var_other) /* object_id on <var_other:nullable Object(String)>*/;
+{ /* Inline kernel#Int#== (var4,var5) */
+var8 = var4 == var5;
+var6 = var8;
+goto RET_LABEL7;
+RET_LABEL7:(void)0;
}
-if (var9){
-var12 = 1;
-var = var12;
+if (var6){
+var9 = 1;
+var = var9;
goto RET_LABEL;
} else {
}
-var13 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
-var_my_length = var13;
-var14 = var_other->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_other:nullable Object(String)> */
-{ /* Inline kernel#Int#!= (var14,var_my_length) */
-var17 = var14 == var_my_length;
-var18 = !var17;
-var15 = var18;
-goto RET_LABEL16;
-RET_LABEL16:(void)0;
+var10 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
+var_my_length = var10;
+var11 = var_other->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_other:nullable Object(String)> */
+{ /* Inline kernel#Int#!= (var11,var_my_length) */
+var14 = var11 == var_my_length;
+var15 = !var14;
+var12 = var15;
+goto RET_LABEL13;
+RET_LABEL13:(void)0;
}
-if (var15){
-var19 = 0;
-var = var19;
+if (var12){
+var16 = 0;
+var = var16;
goto RET_LABEL;
} else {
}
-var20 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
-var_my_index = var20;
-var21 = var_other->attrs[COLOR_string__String___index_from].l; /* _index_from on <var_other:nullable Object(String)> */
-var_its_index = var21;
+var17 = self->attrs[COLOR_string__String___index_from].l; /* _index_from on <self:String> */
+var_my_index = var17;
+var18 = var_other->attrs[COLOR_string__String___index_from].l; /* _index_from on <var_other:nullable Object(String)> */
+var_its_index = var18;
{ /* Inline kernel#Int#+ (var_my_index,var_my_length) */
-var24 = var_my_index + var_my_length;
-var22 = var24;
-goto RET_LABEL23;
-RET_LABEL23:(void)0;
+var21 = var_my_index + var_my_length;
+var19 = var21;
+goto RET_LABEL20;
+RET_LABEL20:(void)0;
}
-var_last_iteration = var22;
-var25 = var_other->attrs[COLOR_string__AbstractString___items].str; /* _items on <var_other:nullable Object(String)> */
-var_itsitems = var25;
-var26 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
-var_myitems = var26;
+var_last_iteration = var19;
+var22 = var_other->attrs[COLOR_string__AbstractString___items].str; /* _items on <var_other:nullable Object(String)> */
+var_itsitems = var22;
+var23 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:String> */
+var_myitems = var23;
for(;;) {
{ /* Inline kernel#Int#< (var_my_index,var_last_iteration) */
/* Covariant cast for argument 0 (i) <var_last_iteration:Int> isa OTHER */
/* <var_last_iteration:Int> isa OTHER */
-var29 = 1; /* easy <var_last_iteration:Int> isa OTHER*/
-if (!var29) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var26 = 1; /* easy <var_last_iteration:Int> isa OTHER*/
+if (!var26) {
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var32 = var_my_index < var_last_iteration;
-var27 = var32;
-goto RET_LABEL28;
-RET_LABEL28:(void)0;
+var29 = var_my_index < var_last_iteration;
+var24 = var29;
+goto RET_LABEL25;
+RET_LABEL25:(void)0;
}
-if (!var27) break;
+if (!var24) break;
{ /* Inline string#NativeString#[] (var_myitems,var_my_index) */
-var35 = var_myitems[var_my_index];
+var32 = var_myitems[var_my_index];
+var30 = var32;
+goto RET_LABEL31;
+RET_LABEL31:(void)0;
+}
+{ /* Inline string#NativeString#[] (var_itsitems,var_its_index) */
+var35 = var_itsitems[var_its_index];
var33 = var35;
goto RET_LABEL34;
RET_LABEL34:(void)0;
}
-{ /* Inline string#NativeString#[] (var_itsitems,var_its_index) */
-var38 = var_itsitems[var_its_index];
-var36 = var38;
+{ /* Inline kernel#Char#!= (var30,var33) */
+var38 = var30 == var33;
+var39 = !var38;
+var36 = var39;
goto RET_LABEL37;
RET_LABEL37:(void)0;
}
-{ /* Inline kernel#Char#!= (var33,var36) */
-var41 = var33 == var36;
-var42 = !var41;
-var39 = var42;
-goto RET_LABEL40;
-RET_LABEL40:(void)0;
-}
-if (var39){
-var43 = 0;
-var = var43;
+if (var36){
+var40 = 0;
+var = var40;
goto RET_LABEL;
} else {
}
-var44 = 1;
-{ /* Inline kernel#Int#+ (var_my_index,var44) */
-var47 = var_my_index + var44;
-var45 = var47;
-goto RET_LABEL46;
-RET_LABEL46:(void)0;
+var41 = 1;
+{ /* Inline kernel#Int#+ (var_my_index,var41) */
+var44 = var_my_index + var41;
+var42 = var44;
+goto RET_LABEL43;
+RET_LABEL43:(void)0;
}
-var_my_index = var45;
-var48 = 1;
-{ /* Inline kernel#Int#+ (var_its_index,var48) */
-var51 = var_its_index + var48;
-var49 = var51;
-goto RET_LABEL50;
-RET_LABEL50:(void)0;
+var_my_index = var42;
+var45 = 1;
+{ /* Inline kernel#Int#+ (var_its_index,var45) */
+var48 = var_its_index + var45;
+var46 = var48;
+goto RET_LABEL47;
+RET_LABEL47:(void)0;
}
-var_its_index = var49;
+var_its_index = var46;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
-var52 = 1;
-var = var52;
+var49 = 1;
+var = var49;
goto RET_LABEL;
RET_LABEL:;
return var;
int cltype;
int idtype;
const struct type* type_struct;
+const char* var_class_name;
val* var_other /* var other: String */;
long var2 /* : Int */;
long var3 /* : Int */;
short int var19 /* : Bool */;
int cltype20;
int idtype21;
-short int var22 /* : Bool */;
-char var23 /* : Char */;
-char var25 /* : Char */;
-char var_my_curr_char /* var my_curr_char: Char */;
+const char* var_class_name22;
+short int var23 /* : Bool */;
+char var24 /* : Char */;
char var26 /* : Char */;
-char var28 /* : Char */;
+char var_my_curr_char /* var my_curr_char: Char */;
+char var27 /* : Char */;
+char var29 /* : Char */;
char var_its_curr_char /* var its_curr_char: Char */;
-short int var29 /* : Bool */;
-short int var31 /* : Bool */;
+short int var30 /* : Bool */;
short int var32 /* : Bool */;
short int var33 /* : Bool */;
-short int var35 /* : Bool */;
-int cltype36;
-int idtype37;
-short int var38 /* : Bool */;
-short int var39 /* : Bool */;
+short int var34 /* : Bool */;
+short int var36 /* : Bool */;
+int cltype37;
+int idtype38;
+const char* var_class_name39;
short int var40 /* : Bool */;
-long var41 /* : Int */;
-long var42 /* : Int */;
+short int var41 /* : Bool */;
+short int var42 /* : Bool */;
+long var43 /* : Int */;
long var44 /* : Int */;
-long var45 /* : Int */;
long var46 /* : Int */;
+long var47 /* : Int */;
long var48 /* : Int */;
-short int var49 /* : Bool */;
+long var50 /* : Int */;
short int var51 /* : Bool */;
-int cltype52;
-int idtype53;
-short int var54 /* : Bool */;
+short int var53 /* : Bool */;
+int cltype54;
+int idtype55;
+const char* var_class_name56;
+short int var57 /* : Bool */;
/* Covariant cast for argument 0 (other) <p0:String> isa OTHER */
/* <p0:String> isa OTHER */
type_struct = self->type->resolution_table->types[COLOR_kernel__Comparable_VTOTHER];
var1 = p0->type->type_table[cltype] == idtype;
}
if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/string.nit", 571);
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 571);
exit(1);
}
var_other = p0;
/* <var_max_iterations:Int> isa OTHER */
var19 = 1; /* easy <var_max_iterations:Int> isa OTHER*/
if (!var19) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name22 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name22);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var22 = var_curr_id_self < var_max_iterations;
-var17 = var22;
+var23 = var_curr_id_self < var_max_iterations;
+var17 = var23;
goto RET_LABEL18;
RET_LABEL18:(void)0;
}
if (!var17) break;
{ /* Inline string#NativeString#[] (var_my_items,var_curr_id_self) */
-var25 = var_my_items[var_curr_id_self];
-var23 = var25;
-goto RET_LABEL24;
-RET_LABEL24:(void)0;
+var26 = var_my_items[var_curr_id_self];
+var24 = var26;
+goto RET_LABEL25;
+RET_LABEL25:(void)0;
}
-var_my_curr_char = var23;
+var_my_curr_char = var24;
{ /* Inline string#NativeString#[] (var_its_items,var_curr_id_other) */
-var28 = var_its_items[var_curr_id_other];
-var26 = var28;
-goto RET_LABEL27;
-RET_LABEL27:(void)0;
+var29 = var_its_items[var_curr_id_other];
+var27 = var29;
+goto RET_LABEL28;
+RET_LABEL28:(void)0;
}
-var_its_curr_char = var26;
+var_its_curr_char = var27;
{ /* Inline kernel#Char#!= (var_my_curr_char,var_its_curr_char) */
-var31 = var_my_curr_char == var_its_curr_char;
-var32 = !var31;
-var29 = var32;
-goto RET_LABEL30;
-RET_LABEL30:(void)0;
+var32 = var_my_curr_char == var_its_curr_char;
+var33 = !var32;
+var30 = var33;
+goto RET_LABEL31;
+RET_LABEL31:(void)0;
}
-if (var29){
+if (var30){
{ /* Inline kernel#Char#< (var_my_curr_char,var_its_curr_char) */
/* Covariant cast for argument 0 (i) <var_its_curr_char:Char> isa OTHER */
/* <var_its_curr_char:Char> isa OTHER */
-var35 = 1; /* easy <var_its_curr_char:Char> isa OTHER*/
-if (!var35) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 455);
+var36 = 1; /* easy <var_its_curr_char:Char> isa OTHER*/
+if (!var36) {
+var_class_name39 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name39);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 437);
exit(1);
}
-var38 = var_my_curr_char < var_its_curr_char;
-var33 = var38;
-goto RET_LABEL34;
-RET_LABEL34:(void)0;
+var40 = var_my_curr_char < var_its_curr_char;
+var34 = var40;
+goto RET_LABEL35;
+RET_LABEL35:(void)0;
}
-if (var33){
-var39 = 1;
-var = var39;
+if (var34){
+var41 = 1;
+var = var41;
goto RET_LABEL;
} else {
}
-var40 = 0;
-var = var40;
+var42 = 0;
+var = var42;
goto RET_LABEL;
} else {
}
-var41 = 1;
-{ /* Inline kernel#Int#+ (var_curr_id_self,var41) */
-var44 = var_curr_id_self + var41;
-var42 = var44;
-goto RET_LABEL43;
-RET_LABEL43:(void)0;
+var43 = 1;
+{ /* Inline kernel#Int#+ (var_curr_id_self,var43) */
+var46 = var_curr_id_self + var43;
+var44 = var46;
+goto RET_LABEL45;
+RET_LABEL45:(void)0;
}
-var_curr_id_self = var42;
-var45 = 1;
-{ /* Inline kernel#Int#+ (var_curr_id_other,var45) */
-var48 = var_curr_id_other + var45;
-var46 = var48;
-goto RET_LABEL47;
-RET_LABEL47:(void)0;
+var_curr_id_self = var44;
+var47 = 1;
+{ /* Inline kernel#Int#+ (var_curr_id_other,var47) */
+var50 = var_curr_id_other + var47;
+var48 = var50;
+goto RET_LABEL49;
+RET_LABEL49:(void)0;
}
-var_curr_id_other = var46;
+var_curr_id_other = var48;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
{ /* Inline kernel#Int#< (var_my_length,var_its_length) */
/* Covariant cast for argument 0 (i) <var_its_length:Int> isa OTHER */
/* <var_its_length:Int> isa OTHER */
-var51 = 1; /* easy <var_its_length:Int> isa OTHER*/
-if (!var51) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var53 = 1; /* easy <var_its_length:Int> isa OTHER*/
+if (!var53) {
+var_class_name56 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name56);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var54 = var_my_length < var_its_length;
-var49 = var54;
-goto RET_LABEL50;
-RET_LABEL50:(void)0;
+var57 = var_my_length < var_its_length;
+var51 = var57;
+goto RET_LABEL52;
+RET_LABEL52:(void)0;
}
-var = var49;
+var = var51;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
long var6 /* : Int */;
long var_my_length /* var my_length: Int */;
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var5 = var_i >= var1;
RET_LABEL3:(void)0;
}
if (!var2) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 635);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 635);
exit(1);
}
var6 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:String> */
short int var14 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var15 /* : Bool */;
long var16 /* : Int */;
long var17 /* : Int */;
/* <var_strStart:Int> isa OTHER */
var14 = 1; /* easy <var_strStart:Int> isa OTHER*/
if (!var14) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var15 = var_i >= var_strStart;
short int var /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
long var_index /* var index: Int */;
char var_item /* var item: Char */;
long var1 /* : Int */;
short int var10 /* : Bool */;
int cltype11;
int idtype12;
-short int var13 /* : Bool */;
+const char* var_class_name13;
+short int var14 /* : Bool */;
short int var_ /* var : Bool */;
-long var14 /* : Int */;
-short int var15 /* : Bool */;
-short int var17 /* : Bool */;
-int cltype18;
-int idtype19;
-short int var20 /* : Bool */;
-char* var21 /* : NativeString */;
+long var15 /* : Int */;
+short int var16 /* : Bool */;
+short int var18 /* : Bool */;
+int cltype19;
+int idtype20;
+const char* var_class_name21;
+short int var22 /* : Bool */;
+char* var23 /* : NativeString */;
/* Covariant cast for argument 1 (item) <p1:Char> isa Sequence#0 */
/* <p1:Char> isa Sequence#0 */
var = 1; /* easy <p1:Char> isa Sequence#0*/
if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/string.nit", 688);
+var_class_name = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "Sequence#0", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 688);
exit(1);
}
var_index = p0;
/* <var7:Int> isa OTHER */
var10 = 1; /* easy <var7:Int> isa OTHER*/
if (!var10) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name13 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name13);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
-var13 = var_index >= var7;
-var8 = var13;
+var14 = var_index >= var7;
+var8 = var14;
goto RET_LABEL9;
RET_LABEL9:(void)0;
}
var_ = var8;
if (var8){
-var14 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
-{ /* Inline kernel#Int#< (var_index,var14) */
-/* Covariant cast for argument 0 (i) <var14:Int> isa OTHER */
-/* <var14:Int> isa OTHER */
-var17 = 1; /* easy <var14:Int> isa OTHER*/
-if (!var17) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var15 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
+{ /* Inline kernel#Int#< (var_index,var15) */
+/* Covariant cast for argument 0 (i) <var15:Int> isa OTHER */
+/* <var15:Int> isa OTHER */
+var18 = 1; /* easy <var15:Int> isa OTHER*/
+if (!var18) {
+var_class_name21 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name21);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var20 = var_index < var14;
-var15 = var20;
-goto RET_LABEL16;
-RET_LABEL16:(void)0;
+var22 = var_index < var15;
+var16 = var22;
+goto RET_LABEL17;
+RET_LABEL17:(void)0;
}
-var6 = var15;
+var6 = var16;
} else {
var6 = var_;
}
if (!var6) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 694);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 694);
exit(1);
}
-var21 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
-{ /* Inline string#NativeString#[]= (var21,var_index,var_item) */
-var21[var_index]=var_item;
-RET_LABEL22:(void)0;
+var23 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
+{ /* Inline string#NativeString#[]= (var23,var_index,var_item) */
+var23[var_index]=var_item;
+RET_LABEL24:(void)0;
}
RET_LABEL:;
}
short int var /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
char var_c /* var c: Char */;
long var1 /* : Int */;
long var2 /* : Int */;
short int var5 /* : Bool */;
int cltype6;
int idtype7;
-short int var8 /* : Bool */;
-long var9 /* : Int */;
+const char* var_class_name8;
+short int var9 /* : Bool */;
long var10 /* : Int */;
long var11 /* : Int */;
-long var13 /* : Int */;
-char* var14 /* : NativeString */;
-long var15 /* : Int */;
+long var12 /* : Int */;
+long var14 /* : Int */;
+char* var15 /* : NativeString */;
+long var16 /* : Int */;
val* var_ /* var : Buffer */;
-long var17 /* : Int */;
long var18 /* : Int */;
long var19 /* : Int */;
-long var21 /* : Int */;
+long var20 /* : Int */;
+long var22 /* : Int */;
/* Covariant cast for argument 0 (c) <p0:Char> isa SimpleCollection#0 */
/* <p0:Char> isa SimpleCollection#0 */
var = 1; /* easy <p0:Char> isa SimpleCollection#0*/
if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/string.nit", 698);
+var_class_name = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "SimpleCollection#0", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 698);
exit(1);
}
var_c = p0;
/* <var2:Int> isa OTHER */
var5 = 1; /* easy <var2:Int> isa OTHER*/
if (!var5) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name8 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name8);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
-var8 = var1 <= var2;
-var3 = var8;
+var9 = var1 <= var2;
+var3 = var9;
goto RET_LABEL4;
RET_LABEL4:(void)0;
}
if (var3){
-var9 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
-var10 = 5;
-{ /* Inline kernel#Int#+ (var9,var10) */
-var13 = var9 + var10;
-var11 = var13;
-goto RET_LABEL12;
-RET_LABEL12:(void)0;
+var10 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
+var11 = 5;
+{ /* Inline kernel#Int#+ (var10,var11) */
+var14 = var10 + var11;
+var12 = var14;
+goto RET_LABEL13;
+RET_LABEL13:(void)0;
}
-((void (*)(val*, long))(self->class->vft[COLOR_array__AbstractArray__enlarge]))(self, var11) /* enlarge on <self:Buffer>*/;
+((void (*)(val*, long))(self->class->vft[COLOR_array__AbstractArray__enlarge]))(self, var12) /* enlarge on <self:Buffer>*/;
} else {
}
-var14 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
-var15 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
-{ /* Inline string#NativeString#[]= (var14,var15,var_c) */
-var14[var15]=var_c;
-RET_LABEL16:(void)0;
+var15 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
+var16 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
+{ /* Inline string#NativeString#[]= (var15,var16,var_c) */
+var15[var16]=var_c;
+RET_LABEL17:(void)0;
}
var_ = self;
-var17 = var_->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_:Buffer> */
-var18 = 1;
-{ /* Inline kernel#Int#+ (var17,var18) */
-var21 = var17 + var18;
-var19 = var21;
-goto RET_LABEL20;
-RET_LABEL20:(void)0;
+var18 = var_->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_:Buffer> */
+var19 = 1;
+{ /* Inline kernel#Int#+ (var18,var19) */
+var22 = var18 + var19;
+var20 = var22;
+goto RET_LABEL21;
+RET_LABEL21:(void)0;
}
-var_->attrs[COLOR_array__AbstractArrayRead___length].l = var19; /* _length on <var_:Buffer> */
+var_->attrs[COLOR_array__AbstractArrayRead___length].l = var20; /* _length on <var_:Buffer> */
RET_LABEL:;
}
/* method string#Buffer#add for (self: Object, nullable Object) */
short int var3 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var4 /* : Bool */;
short int var5 /* : Bool */;
short int var7 /* : Bool */;
int cltype8;
int idtype9;
-short int var10 /* : Bool */;
-long var11 /* : Int */;
+const char* var_class_name10;
+short int var11 /* : Bool */;
long var12 /* : Int */;
-long var14 /* : Int */;
+long var13 /* : Int */;
long var15 /* : Int */;
long var16 /* : Int */;
-long var18 /* : Int */;
+long var17 /* : Int */;
long var19 /* : Int */;
long var20 /* : Int */;
-long var22 /* : Int */;
-char* var23 /* : NativeString */;
-char* var_a /* var a: NativeString */;
+long var21 /* : Int */;
+long var23 /* : Int */;
char* var24 /* : NativeString */;
-long var25 /* : Int */;
+char* var_a /* var a: NativeString */;
+char* var25 /* : NativeString */;
long var26 /* : Int */;
long var27 /* : Int */;
+long var28 /* : Int */;
var_cap = p0;
var = self->attrs[COLOR_string__Buffer___capacity].l; /* _capacity on <self:Buffer> */
var_c = var;
/* <var_c:Int> isa OTHER */
var3 = 1; /* easy <var_c:Int> isa OTHER*/
if (!var3) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
var4 = var_cap <= var_c;
/* <var_cap:Int> isa OTHER */
var7 = 1; /* easy <var_cap:Int> isa OTHER*/
if (!var7) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256);
+var_class_name10 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name10);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 260);
exit(1);
}
-var10 = var_c <= var_cap;
-var5 = var10;
+var11 = var_c <= var_cap;
+var5 = var11;
goto RET_LABEL6;
RET_LABEL6:(void)0;
}
if (!var5) break;
-var11 = 2;
-{ /* Inline kernel#Int#* (var_c,var11) */
-var14 = var_c * var11;
-var12 = var14;
-goto RET_LABEL13;
-RET_LABEL13:(void)0;
+var12 = 2;
+{ /* Inline kernel#Int#* (var_c,var12) */
+var15 = var_c * var12;
+var13 = var15;
+goto RET_LABEL14;
+RET_LABEL14:(void)0;
}
-var15 = 2;
-{ /* Inline kernel#Int#+ (var12,var15) */
-var18 = var12 + var15;
-var16 = var18;
-goto RET_LABEL17;
-RET_LABEL17:(void)0;
+var16 = 2;
+{ /* Inline kernel#Int#+ (var13,var16) */
+var19 = var13 + var16;
+var17 = var19;
+goto RET_LABEL18;
+RET_LABEL18:(void)0;
}
-var_c = var16;
+var_c = var17;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
-var19 = 1;
-{ /* Inline kernel#Int#+ (var_c,var19) */
-var22 = var_c + var19;
-var20 = var22;
-goto RET_LABEL21;
-RET_LABEL21:(void)0;
+var20 = 1;
+{ /* Inline kernel#Int#+ (var_c,var20) */
+var23 = var_c + var20;
+var21 = var23;
+goto RET_LABEL22;
+RET_LABEL22:(void)0;
}
-var23 = ((char* (*)(val*, long))(self->class->vft[COLOR_string__StringCapable__calloc_string]))(self, var20) /* calloc_string on <self:Buffer>*/;
-var_a = var23;
-var24 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
-var25 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
-var26 = 0;
+var24 = ((char* (*)(val*, long))(self->class->vft[COLOR_string__StringCapable__calloc_string]))(self, var21) /* calloc_string on <self:Buffer>*/;
+var_a = var24;
+var25 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
+var26 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
var27 = 0;
-{ /* Inline string#NativeString#copy_to (var24,var_a,var25,var26,var27) */
-memcpy(var_a+var27,var24+var26,var25);
-RET_LABEL28:(void)0;
+var28 = 0;
+{ /* Inline string#NativeString#copy_to (var25,var_a,var26,var27,var28) */
+memcpy(var_a+var28,var25+var27,var26);
+RET_LABEL29:(void)0;
}
self->attrs[COLOR_string__AbstractString___items].str = var_a; /* _items on <self:Buffer> */
self->attrs[COLOR_string__Buffer___capacity].l = var_c; /* _capacity on <self:Buffer> */
short int var /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
val* var_s /* var s: Collection[Char] */;
short int var1 /* : Bool */;
int cltype2;
short int var12 /* : Bool */;
int cltype13;
int idtype14;
-short int var15 /* : Bool */;
-long var16 /* : Int */;
+const char* var_class_name15;
+short int var16 /* : Bool */;
long var17 /* : Int */;
-long var19 /* : Int */;
-char* var20 /* : NativeString */;
+long var18 /* : Int */;
+long var20 /* : Int */;
char* var21 /* : NativeString */;
-long var22 /* : Int */;
+char* var22 /* : NativeString */;
long var23 /* : Int */;
+long var24 /* : Int */;
val* var_ /* var : Buffer */;
-long var25 /* : Int */;
long var26 /* : Int */;
-long var28 /* : Int */;
+long var27 /* : Int */;
+long var29 /* : Int */;
/* Covariant cast for argument 0 (s) <p0:Collection[Char]> isa Collection[Sequence#0] */
/* <p0:Collection[Char]> isa Collection[Sequence#0] */
var = 1; /* easy <p0:Collection[Char]> isa Collection[Sequence#0]*/
if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/string.nit", 716);
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "Collection[Sequence#0]", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 716);
exit(1);
}
var_s = p0;
/* <var7:Int> isa OTHER */
var12 = 1; /* easy <var7:Int> isa OTHER*/
if (!var12) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name15 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name15);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var15 = var5 < var7;
-var10 = var15;
+var16 = var5 < var7;
+var10 = var16;
goto RET_LABEL11;
RET_LABEL11:(void)0;
}
if (var10){
-var16 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:Buffer> */
-{ /* Inline kernel#Int#+ (var16,var_sl) */
-var19 = var16 + var_sl;
-var17 = var19;
-goto RET_LABEL18;
-RET_LABEL18:(void)0;
+var17 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:Buffer> */
+{ /* Inline kernel#Int#+ (var17,var_sl) */
+var20 = var17 + var_sl;
+var18 = var20;
+goto RET_LABEL19;
+RET_LABEL19:(void)0;
}
-((void (*)(val*, long))(self->class->vft[COLOR_array__AbstractArray__enlarge]))(self, var17) /* enlarge on <self:Buffer>*/;
+((void (*)(val*, long))(self->class->vft[COLOR_array__AbstractArray__enlarge]))(self, var18) /* enlarge on <self:Buffer>*/;
} else {
}
-var20 = ((char* (*)(val*))(var_s->class->vft[COLOR_string__AbstractString__items]))(var_s) /* items on <var_s:Collection[Char](String)>*/;
-var21 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
-var22 = var_s->attrs[COLOR_string__String___index_from].l; /* _index_from on <var_s:Collection[Char](String)> */
-var23 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:Buffer> */
-{ /* Inline string#NativeString#copy_to (var20,var21,var_sl,var22,var23) */
-memcpy(var21+var23,var20+var22,var_sl);
-RET_LABEL24:(void)0;
+var21 = ((char* (*)(val*))(var_s->class->vft[COLOR_string__AbstractString__items]))(var_s) /* items on <var_s:Collection[Char](String)>*/;
+var22 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
+var23 = var_s->attrs[COLOR_string__String___index_from].l; /* _index_from on <var_s:Collection[Char](String)> */
+var24 = self->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <self:Buffer> */
+{ /* Inline string#NativeString#copy_to (var21,var22,var_sl,var23,var24) */
+memcpy(var22+var24,var21+var23,var_sl);
+RET_LABEL25:(void)0;
}
var_ = self;
-var25 = var_->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_:Buffer> */
-{ /* Inline kernel#Int#+ (var25,var_sl) */
-var28 = var25 + var_sl;
-var26 = var28;
-goto RET_LABEL27;
-RET_LABEL27:(void)0;
+var26 = var_->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_:Buffer> */
+{ /* Inline kernel#Int#+ (var26,var_sl) */
+var29 = var26 + var_sl;
+var27 = var29;
+goto RET_LABEL28;
+RET_LABEL28:(void)0;
}
-var_->attrs[COLOR_array__AbstractArrayRead___length].l = var26; /* _length on <var_:Buffer> */
+var_->attrs[COLOR_array__AbstractArrayRead___length].l = var27; /* _length on <var_:Buffer> */
} else {
((void (*)(val*, val*))(self->class->vft[COLOR_string__Buffer__append]))(self, p0) /* append on <self:Buffer>*/;
}
int cltype;
int idtype;
const struct type* type_struct;
+const char* var_class_name;
val* var_s /* var s: String */;
long var2 /* : Int */;
long var_i /* var i: Int */;
short int var8 /* : Bool */;
int cltype9;
int idtype10;
-short int var11 /* : Bool */;
-short int var_ /* var : Bool */;
+const char* var_class_name11;
short int var12 /* : Bool */;
-short int var14 /* : Bool */;
-int cltype15;
-int idtype16;
-short int var17 /* : Bool */;
-val* var18 /* : nullable Object */;
-long var19 /* : Int */;
-char var21 /* : Char */;
-long var22 /* : Int */;
-long var_c1 /* var c1: Int */;
-val* var23 /* : nullable Object */;
+short int var_ /* var : Bool */;
+short int var13 /* : Bool */;
+short int var15 /* : Bool */;
+int cltype16;
+int idtype17;
+const char* var_class_name18;
+short int var19 /* : Bool */;
+val* var20 /* : nullable Object */;
+long var21 /* : Int */;
+char var23 /* : Char */;
long var24 /* : Int */;
-char var26 /* : Char */;
-long var27 /* : Int */;
+long var_c1 /* var c1: Int */;
+val* var25 /* : nullable Object */;
+long var26 /* : Int */;
+char var28 /* : Char */;
+long var29 /* : Int */;
long var_c2 /* var c2: Int */;
-short int var28 /* : Bool */;
short int var30 /* : Bool */;
-int cltype31;
-int idtype32;
-short int var33 /* : Bool */;
-short int var34 /* : Bool */;
-short int var35 /* : Bool */;
+short int var32 /* : Bool */;
+int cltype33;
+int idtype34;
+const char* var_class_name35;
+short int var36 /* : Bool */;
short int var37 /* : Bool */;
-int cltype38;
-int idtype39;
+short int var38 /* : Bool */;
short int var40 /* : Bool */;
-short int var41 /* : Bool */;
-long var42 /* : Int */;
-long var43 /* : Int */;
-long var45 /* : Int */;
-short int var46 /* : Bool */;
-short int var48 /* : Bool */;
-int cltype49;
-int idtype50;
-short int var51 /* : Bool */;
+int cltype41;
+int idtype42;
+const char* var_class_name43;
+short int var44 /* : Bool */;
+short int var45 /* : Bool */;
+long var46 /* : Int */;
+long var47 /* : Int */;
+long var49 /* : Int */;
+short int var50 /* : Bool */;
short int var52 /* : Bool */;
-short int var53 /* : Bool */;
+int cltype53;
+int idtype54;
+const char* var_class_name55;
+short int var56 /* : Bool */;
+short int var57 /* : Bool */;
+short int var58 /* : Bool */;
/* Covariant cast for argument 0 (s) <p0:String> isa OTHER */
/* <p0:String> isa OTHER */
type_struct = self->type->resolution_table->types[COLOR_kernel__Comparable_VTOTHER];
var1 = p0->type->type_table[cltype] == idtype;
}
if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/string.nit", 740);
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 740);
exit(1);
}
var_s = p0;
/* <var_l1:Int> isa OTHER */
var8 = 1; /* easy <var_l1:Int> isa OTHER*/
if (!var8) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name11 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name11);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var11 = var_i < var_l1;
-var6 = var11;
+var12 = var_i < var_l1;
+var6 = var12;
goto RET_LABEL7;
RET_LABEL7:(void)0;
}
{ /* Inline kernel#Int#< (var_i,var_l2) */
/* Covariant cast for argument 0 (i) <var_l2:Int> isa OTHER */
/* <var_l2:Int> isa OTHER */
-var14 = 1; /* easy <var_l2:Int> isa OTHER*/
-if (!var14) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var15 = 1; /* easy <var_l2:Int> isa OTHER*/
+if (!var15) {
+var_class_name18 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name18);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var17 = var_i < var_l2;
-var12 = var17;
-goto RET_LABEL13;
-RET_LABEL13:(void)0;
+var19 = var_i < var_l2;
+var13 = var19;
+goto RET_LABEL14;
+RET_LABEL14:(void)0;
}
-var5 = var12;
+var5 = var13;
} else {
var5 = var_;
}
if (!var5) break;
-var18 = ((val* (*)(val*, long))(self->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(self, var_i) /* [] on <self:Buffer>*/;
-{ /* Inline kernel#Char#ascii (var18) */
-var21 = ((struct instance_kernel__Char*)var18)->value; /* autounbox from nullable Object to Char */;
-var22 = (unsigned char)var21;
-var19 = var22;
-goto RET_LABEL20;
-RET_LABEL20:(void)0;
+var20 = ((val* (*)(val*, long))(self->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(self, var_i) /* [] on <self:Buffer>*/;
+{ /* Inline kernel#Char#ascii (var20) */
+var23 = ((struct instance_kernel__Char*)var20)->value; /* autounbox from nullable Object to Char */;
+var24 = (unsigned char)var23;
+var21 = var24;
+goto RET_LABEL22;
+RET_LABEL22:(void)0;
}
-var_c1 = var19;
-var23 = ((val* (*)(val*, long))(var_s->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_s, var_i) /* [] on <var_s:String>*/;
-{ /* Inline kernel#Char#ascii (var23) */
-var26 = ((struct instance_kernel__Char*)var23)->value; /* autounbox from nullable Object to Char */;
-var27 = (unsigned char)var26;
-var24 = var27;
-goto RET_LABEL25;
-RET_LABEL25:(void)0;
+var_c1 = var21;
+var25 = ((val* (*)(val*, long))(var_s->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_s, var_i) /* [] on <var_s:String>*/;
+{ /* Inline kernel#Char#ascii (var25) */
+var28 = ((struct instance_kernel__Char*)var25)->value; /* autounbox from nullable Object to Char */;
+var29 = (unsigned char)var28;
+var26 = var29;
+goto RET_LABEL27;
+RET_LABEL27:(void)0;
}
-var_c2 = var24;
+var_c2 = var26;
{ /* Inline kernel#Int#< (var_c1,var_c2) */
/* Covariant cast for argument 0 (i) <var_c2:Int> isa OTHER */
/* <var_c2:Int> isa OTHER */
-var30 = 1; /* easy <var_c2:Int> isa OTHER*/
-if (!var30) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var32 = 1; /* easy <var_c2:Int> isa OTHER*/
+if (!var32) {
+var_class_name35 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name35);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var33 = var_c1 < var_c2;
-var28 = var33;
-goto RET_LABEL29;
-RET_LABEL29:(void)0;
+var36 = var_c1 < var_c2;
+var30 = var36;
+goto RET_LABEL31;
+RET_LABEL31:(void)0;
}
-if (var28){
-var34 = 1;
-var = var34;
+if (var30){
+var37 = 1;
+var = var37;
goto RET_LABEL;
} else {
{ /* Inline kernel#Int#< (var_c2,var_c1) */
/* Covariant cast for argument 0 (i) <var_c1:Int> isa OTHER */
/* <var_c1:Int> isa OTHER */
-var37 = 1; /* easy <var_c1:Int> isa OTHER*/
-if (!var37) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var40 = 1; /* easy <var_c1:Int> isa OTHER*/
+if (!var40) {
+var_class_name43 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name43);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var40 = var_c2 < var_c1;
-var35 = var40;
-goto RET_LABEL36;
-RET_LABEL36:(void)0;
+var44 = var_c2 < var_c1;
+var38 = var44;
+goto RET_LABEL39;
+RET_LABEL39:(void)0;
}
-if (var35){
-var41 = 0;
-var = var41;
+if (var38){
+var45 = 0;
+var = var45;
goto RET_LABEL;
} else {
}
}
-var42 = 1;
-{ /* Inline kernel#Int#+ (var_i,var42) */
-var45 = var_i + var42;
-var43 = var45;
-goto RET_LABEL44;
-RET_LABEL44:(void)0;
+var46 = 1;
+{ /* Inline kernel#Int#+ (var_i,var46) */
+var49 = var_i + var46;
+var47 = var49;
+goto RET_LABEL48;
+RET_LABEL48:(void)0;
}
-var_i = var43;
+var_i = var47;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
{ /* Inline kernel#Int#< (var_l1,var_l2) */
/* Covariant cast for argument 0 (i) <var_l2:Int> isa OTHER */
/* <var_l2:Int> isa OTHER */
-var48 = 1; /* easy <var_l2:Int> isa OTHER*/
-if (!var48) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var52 = 1; /* easy <var_l2:Int> isa OTHER*/
+if (!var52) {
+var_class_name55 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name55);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var51 = var_l1 < var_l2;
-var46 = var51;
-goto RET_LABEL47;
-RET_LABEL47:(void)0;
+var56 = var_l1 < var_l2;
+var50 = var56;
+goto RET_LABEL51;
+RET_LABEL51:(void)0;
}
-if (var46){
-var52 = 1;
-var = var52;
+if (var50){
+var57 = 1;
+var = var57;
goto RET_LABEL;
} else {
-var53 = 0;
-var = var53;
+var58 = 0;
+var = var58;
goto RET_LABEL;
}
RET_LABEL:;
short int var3 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var4 /* : Bool */;
long var5 /* : Int */;
long var6 /* : Int */;
/* <var:Int> isa OTHER */
var3 = 1; /* easy <var:Int> isa OTHER*/
if (!var3) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var4 = var_cap >= var;
RET_LABEL2:(void)0;
}
if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 779);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 779);
exit(1);
}
var5 = 1;
short int var /* : Bool */;
val* var_o /* var o: nullable Object */;
short int var1 /* : Bool */;
-short int var2 /* : Bool */;
int cltype;
int idtype;
+short int var2 /* : Bool */;
short int var3 /* : Bool */;
-short int var_ /* var : Bool */;
-val* var4 /* : null */;
-short int var5 /* : Bool */;
-short int var6 /* : Bool */;
-long var7 /* : Int */;
+long var4 /* : Int */;
long var_l /* var l: Int */;
-long var8 /* : Int */;
+long var5 /* : Int */;
+short int var6 /* : Bool */;
+short int var8 /* : Bool */;
short int var9 /* : Bool */;
-short int var11 /* : Bool */;
-short int var12 /* : Bool */;
-short int var13 /* : Bool */;
-long var14 /* : Int */;
+short int var10 /* : Bool */;
+long var11 /* : Int */;
long var_i /* var i: Int */;
-char* var15 /* : NativeString */;
+char* var12 /* : NativeString */;
char* var_it /* var it: NativeString */;
-char* var16 /* : NativeString */;
+char* var13 /* : NativeString */;
char* var_oit /* var oit: NativeString */;
-short int var17 /* : Bool */;
+short int var14 /* : Bool */;
+short int var16 /* : Bool */;
+int cltype17;
+int idtype18;
+const char* var_class_name;
short int var19 /* : Bool */;
-int cltype20;
-int idtype21;
-short int var22 /* : Bool */;
+char var20 /* : Char */;
+char var22 /* : Char */;
char var23 /* : Char */;
char var25 /* : Char */;
-char var26 /* : Char */;
-char var28 /* : Char */;
+short int var26 /* : Bool */;
+short int var28 /* : Bool */;
short int var29 /* : Bool */;
-short int var31 /* : Bool */;
-short int var32 /* : Bool */;
-short int var33 /* : Bool */;
+short int var30 /* : Bool */;
+long var31 /* : Int */;
+long var32 /* : Int */;
long var34 /* : Int */;
-long var35 /* : Int */;
-long var37 /* : Int */;
-short int var38 /* : Bool */;
+short int var35 /* : Bool */;
var_o = p0;
/* <var_o:nullable Object> isa Buffer */
cltype = type_string__Buffer.color;
idtype = type_string__Buffer.id;
if(var_o == NULL) {
-var2 = 0;
+var1 = 0;
} else {
if(cltype >= var_o->type->table_size) {
-var2 = 0;
+var1 = 0;
} else {
-var2 = var_o->type->type_table[cltype] == idtype;
+var1 = var_o->type->type_table[cltype] == idtype;
}
}
-var3 = !var2;
-var_ = var3;
-if (var3){
-var1 = var_;
-} else {
-var4 = NULL;
-var5 = var_o == var4;
-var1 = var5;
-}
-if (var1){
-var6 = 0;
-var = var6;
+var2 = !var1;
+if (var2){
+var3 = 0;
+var = var3;
goto RET_LABEL;
} else {
}
-var7 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
-var_l = var7;
-var8 = ((long (*)(val*))(var_o->class->vft[COLOR_abstract_collection__Collection__length]))(var_o) /* length on <var_o:nullable Object(Buffer)>*/;
-{ /* Inline kernel#Int#!= (var8,var_l) */
-var11 = var8 == var_l;
-var12 = !var11;
-var9 = var12;
-goto RET_LABEL10;
-RET_LABEL10:(void)0;
+var4 = ((long (*)(val*))(self->class->vft[COLOR_abstract_collection__Collection__length]))(self) /* length on <self:Buffer>*/;
+var_l = var4;
+var5 = ((long (*)(val*))(var_o->class->vft[COLOR_abstract_collection__Collection__length]))(var_o) /* length on <var_o:nullable Object(Buffer)>*/;
+{ /* Inline kernel#Int#!= (var5,var_l) */
+var8 = var5 == var_l;
+var9 = !var8;
+var6 = var9;
+goto RET_LABEL7;
+RET_LABEL7:(void)0;
}
-if (var9){
-var13 = 0;
-var = var13;
+if (var6){
+var10 = 0;
+var = var10;
goto RET_LABEL;
} else {
}
-var14 = 0;
-var_i = var14;
-var15 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
-var_it = var15;
-var16 = var_o->attrs[COLOR_string__AbstractString___items].str; /* _items on <var_o:nullable Object(Buffer)> */
-var_oit = var16;
+var11 = 0;
+var_i = var11;
+var12 = self->attrs[COLOR_string__AbstractString___items].str; /* _items on <self:Buffer> */
+var_it = var12;
+var13 = var_o->attrs[COLOR_string__AbstractString___items].str; /* _items on <var_o:nullable Object(Buffer)> */
+var_oit = var13;
for(;;) {
{ /* Inline kernel#Int#< (var_i,var_l) */
/* Covariant cast for argument 0 (i) <var_l:Int> isa OTHER */
/* <var_l:Int> isa OTHER */
-var19 = 1; /* easy <var_l:Int> isa OTHER*/
-if (!var19) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var16 = 1; /* easy <var_l:Int> isa OTHER*/
+if (!var16) {
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
-var22 = var_i < var_l;
-var17 = var22;
-goto RET_LABEL18;
-RET_LABEL18:(void)0;
+var19 = var_i < var_l;
+var14 = var19;
+goto RET_LABEL15;
+RET_LABEL15:(void)0;
}
-if (!var17) break;
+if (!var14) break;
{ /* Inline string#NativeString#[] (var_it,var_i) */
-var25 = var_it[var_i];
+var22 = var_it[var_i];
+var20 = var22;
+goto RET_LABEL21;
+RET_LABEL21:(void)0;
+}
+{ /* Inline string#NativeString#[] (var_oit,var_i) */
+var25 = var_oit[var_i];
var23 = var25;
goto RET_LABEL24;
RET_LABEL24:(void)0;
}
-{ /* Inline string#NativeString#[] (var_oit,var_i) */
-var28 = var_oit[var_i];
-var26 = var28;
+{ /* Inline kernel#Char#!= (var20,var23) */
+var28 = var20 == var23;
+var29 = !var28;
+var26 = var29;
goto RET_LABEL27;
RET_LABEL27:(void)0;
}
-{ /* Inline kernel#Char#!= (var23,var26) */
-var31 = var23 == var26;
-var32 = !var31;
-var29 = var32;
-goto RET_LABEL30;
-RET_LABEL30:(void)0;
-}
-if (var29){
-var33 = 0;
-var = var33;
+if (var26){
+var30 = 0;
+var = var30;
goto RET_LABEL;
} else {
}
-var34 = 1;
-{ /* Inline kernel#Int#+ (var_i,var34) */
-var37 = var_i + var34;
-var35 = var37;
-goto RET_LABEL36;
-RET_LABEL36:(void)0;
+var31 = 1;
+{ /* Inline kernel#Int#+ (var_i,var31) */
+var34 = var_i + var31;
+var32 = var34;
+goto RET_LABEL33;
+RET_LABEL33:(void)0;
}
-var_i = var35;
+var_i = var32;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
-var38 = 1;
-var = var38;
+var35 = 1;
+var = var35;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var3 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var4 /* : Bool */;
long var5 /* : Int */;
long var7 /* : Int */;
short int var27 /* : Bool */;
int cltype28;
int idtype29;
-short int var30 /* : Bool */;
+const char* var_class_name30;
+short int var31 /* : Bool */;
short int var_ /* var : Bool */;
-long var31 /* : Int */;
-short int var32 /* : Bool */;
-short int var34 /* : Bool */;
-int cltype35;
-int idtype36;
-short int var37 /* : Bool */;
-long var38 /* : Int */;
+long var32 /* : Int */;
+short int var33 /* : Bool */;
+short int var35 /* : Bool */;
+int cltype36;
+int idtype37;
+const char* var_class_name38;
+short int var39 /* : Bool */;
long var40 /* : Int */;
-char var41 /* : Char */;
-val* var42 /* : nullable Object */;
-long var43 /* : Int */;
+long var42 /* : Int */;
+char var43 /* : Char */;
+val* var44 /* : nullable Object */;
long var45 /* : Int */;
-long var46 /* : Int */;
long var47 /* : Int */;
+long var48 /* : Int */;
long var49 /* : Int */;
+long var51 /* : Int */;
var_s = p0;
var_base = p1;
var_signed = p2;
/* <var:Int> isa OTHER */
var3 = 1; /* easy <var:Int> isa OTHER*/
if (!var3) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
var4 = self < var;
/* <var24:Int> isa OTHER */
var27 = 1; /* easy <var24:Int> isa OTHER*/
if (!var27) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name30 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name30);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
-var30 = var_pos >= var24;
-var25 = var30;
+var31 = var_pos >= var24;
+var25 = var31;
goto RET_LABEL26;
RET_LABEL26:(void)0;
}
var_ = var25;
if (var25){
-var31 = 0;
-{ /* Inline kernel#Int#> (var_n,var31) */
-/* Covariant cast for argument 0 (i) <var31:Int> isa OTHER */
-/* <var31:Int> isa OTHER */
-var34 = 1; /* easy <var31:Int> isa OTHER*/
-if (!var34) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var32 = 0;
+{ /* Inline kernel#Int#> (var_n,var32) */
+/* Covariant cast for argument 0 (i) <var32:Int> isa OTHER */
+/* <var32:Int> isa OTHER */
+var35 = 1; /* easy <var32:Int> isa OTHER*/
+if (!var35) {
+var_class_name38 = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name38);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
-var37 = var_n > var31;
-var32 = var37;
-goto RET_LABEL33;
-RET_LABEL33:(void)0;
+var39 = var_n > var32;
+var33 = var39;
+goto RET_LABEL34;
+RET_LABEL34:(void)0;
}
-var23 = var32;
+var23 = var33;
} else {
var23 = var_;
}
if (!var23) break;
{ /* Inline kernel#Int#% (var_n,var_base) */
-var40 = var_n % var_base;
-var38 = var40;
-goto RET_LABEL39;
-RET_LABEL39:(void)0;
+var42 = var_n % var_base;
+var40 = var42;
+goto RET_LABEL41;
+RET_LABEL41:(void)0;
}
-var41 = kernel__Int__to_c(var38);
-var42 = BOX_kernel__Char(var41); /* autobox from Char to nullable Object */
-((void (*)(val*, long, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence___91d_93d_61d]))(var_s, var_pos, var42) /* []= on <var_s:Buffer>*/;
+var43 = kernel__Int__to_c(var40);
+var44 = BOX_kernel__Char(var43); /* autobox from Char to nullable Object */
+((void (*)(val*, long, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence___91d_93d_61d]))(var_s, var_pos, var44) /* []= on <var_s:Buffer>*/;
{ /* Inline kernel#Int#/ (var_n,var_base) */
-var45 = var_n / var_base;
-var43 = var45;
-goto RET_LABEL44;
-RET_LABEL44:(void)0;
+var47 = var_n / var_base;
+var45 = var47;
+goto RET_LABEL46;
+RET_LABEL46:(void)0;
}
-var_n = var43;
-var46 = 1;
-{ /* Inline kernel#Int#- (var_pos,var46) */
-var49 = var_pos - var46;
-var47 = var49;
-goto RET_LABEL48;
-RET_LABEL48:(void)0;
+var_n = var45;
+var48 = 1;
+{ /* Inline kernel#Int#- (var_pos,var48) */
+var51 = var_pos - var48;
+var49 = var51;
+goto RET_LABEL50;
+RET_LABEL50:(void)0;
}
-var_pos = var47;
+var_pos = var49;
CONTINUE_label: (void)0;
}
BREAK_label: (void)0;
short int var49 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var50 /* : Bool */;
long var51 /* : Int */;
long var52 /* : Int */;
/* <var_nb:Int> isa OTHER */
var49 = 1; /* easy <var_nb:Int> isa OTHER*/
if (!var49) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 259);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 263);
exit(1);
}
var50 = var_sl > var_nb;
short int var5 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var6 /* : Bool */;
short int var_ /* var : Bool */;
char var7 /* : Char */;
short int var10 /* : Bool */;
int cltype11;
int idtype12;
-short int var13 /* : Bool */;
+const char* var_class_name13;
short int var14 /* : Bool */;
short int var15 /* : Bool */;
+short int var16 /* : Bool */;
var2 = '0';
{ /* Inline kernel#Char#>= (self,var2) */
/* Covariant cast for argument 0 (i) <var2:Char> isa OTHER */
/* <var2:Char> isa OTHER */
var5 = 1; /* easy <var2:Char> isa OTHER*/
if (!var5) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 456);
+var_class_name = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 438);
exit(1);
}
var6 = self >= var2;
/* <var7:Char> isa OTHER */
var10 = 1; /* easy <var7:Char> isa OTHER*/
if (!var10) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 454);
+var_class_name13 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name13);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 436);
exit(1);
}
-var13 = self <= var7;
-var8 = var13;
+var14 = self <= var7;
+var8 = var14;
goto RET_LABEL9;
RET_LABEL9:(void)0;
}
var1 = var_;
}
if (var1){
-var14 = 1;
-var = var14;
+var15 = 1;
+var = var15;
goto RET_LABEL;
} else {
}
-var15 = 0;
-var = var15;
+var16 = 0;
+var = var16;
goto RET_LABEL;
RET_LABEL:;
return var;
short int var6 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var7 /* : Bool */;
short int var_ /* var : Bool */;
char var8 /* : Char */;
short int var11 /* : Bool */;
int cltype12;
int idtype13;
-short int var14 /* : Bool */;
-short int var_15 /* var : Bool */;
-short int var16 /* : Bool */;
-char var17 /* : Char */;
-short int var18 /* : Bool */;
-short int var20 /* : Bool */;
-int cltype21;
-int idtype22;
-short int var23 /* : Bool */;
-short int var_24 /* var : Bool */;
-char var25 /* : Char */;
-short int var26 /* : Bool */;
+const char* var_class_name14;
+short int var15 /* : Bool */;
+short int var_16 /* var : Bool */;
+short int var17 /* : Bool */;
+char var18 /* : Char */;
+short int var19 /* : Bool */;
+short int var21 /* : Bool */;
+int cltype22;
+int idtype23;
+const char* var_class_name24;
+short int var25 /* : Bool */;
+short int var_26 /* var : Bool */;
+char var27 /* : Char */;
short int var28 /* : Bool */;
-int cltype29;
-int idtype30;
-short int var31 /* : Bool */;
-short int var32 /* : Bool */;
-short int var33 /* : Bool */;
+short int var30 /* : Bool */;
+int cltype31;
+int idtype32;
+const char* var_class_name33;
+short int var34 /* : Bool */;
+short int var35 /* : Bool */;
+short int var36 /* : Bool */;
var3 = 'a';
{ /* Inline kernel#Char#>= (self,var3) */
/* Covariant cast for argument 0 (i) <var3:Char> isa OTHER */
/* <var3:Char> isa OTHER */
var6 = 1; /* easy <var3:Char> isa OTHER*/
if (!var6) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 456);
+var_class_name = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 438);
exit(1);
}
var7 = self >= var3;
/* <var8:Char> isa OTHER */
var11 = 1; /* easy <var8:Char> isa OTHER*/
if (!var11) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 454);
+var_class_name14 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name14);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 436);
exit(1);
}
-var14 = self <= var8;
-var9 = var14;
+var15 = self <= var8;
+var9 = var15;
goto RET_LABEL10;
RET_LABEL10:(void)0;
}
} else {
var2 = var_;
}
-var_15 = var2;
+var_16 = var2;
if (var2){
-var1 = var_15;
-} else {
-var17 = 'A';
-{ /* Inline kernel#Char#>= (self,var17) */
-/* Covariant cast for argument 0 (i) <var17:Char> isa OTHER */
-/* <var17:Char> isa OTHER */
-var20 = 1; /* easy <var17:Char> isa OTHER*/
-if (!var20) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 456);
+var1 = var_16;
+} else {
+var18 = 'A';
+{ /* Inline kernel#Char#>= (self,var18) */
+/* Covariant cast for argument 0 (i) <var18:Char> isa OTHER */
+/* <var18:Char> isa OTHER */
+var21 = 1; /* easy <var18:Char> isa OTHER*/
+if (!var21) {
+var_class_name24 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name24);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 438);
exit(1);
}
-var23 = self >= var17;
-var18 = var23;
-goto RET_LABEL19;
-RET_LABEL19:(void)0;
+var25 = self >= var18;
+var19 = var25;
+goto RET_LABEL20;
+RET_LABEL20:(void)0;
}
-var_24 = var18;
-if (var18){
-var25 = 'Z';
-{ /* Inline kernel#Char#<= (self,var25) */
-/* Covariant cast for argument 0 (i) <var25:Char> isa OTHER */
-/* <var25:Char> isa OTHER */
-var28 = 1; /* easy <var25:Char> isa OTHER*/
-if (!var28) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 454);
+var_26 = var19;
+if (var19){
+var27 = 'Z';
+{ /* Inline kernel#Char#<= (self,var27) */
+/* Covariant cast for argument 0 (i) <var27:Char> isa OTHER */
+/* <var27:Char> isa OTHER */
+var30 = 1; /* easy <var27:Char> isa OTHER*/
+if (!var30) {
+var_class_name33 = type_kernel__Char.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name33);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 436);
exit(1);
}
-var31 = self <= var25;
-var26 = var31;
-goto RET_LABEL27;
-RET_LABEL27:(void)0;
+var34 = self <= var27;
+var28 = var34;
+goto RET_LABEL29;
+RET_LABEL29:(void)0;
}
-var16 = var26;
+var17 = var28;
} else {
-var16 = var_24;
+var17 = var_26;
}
-var1 = var16;
+var1 = var17;
}
if (var1){
-var32 = 1;
-var = var32;
+var35 = 1;
+var = var35;
goto RET_LABEL;
} else {
}
-var33 = 0;
-var = var33;
+var36 = 0;
+var = var36;
goto RET_LABEL;
RET_LABEL:;
return var;
}
if (var6){
if (var_e == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "lib/standard/string.nit", 997);
+fprintf(stderr, "Runtime error: %s", "Reciever is null");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 997);
exit(1);
} else {
var7 = ((val* (*)(val*))(var_e->class->vft[COLOR_string__Object__to_s]))(var_e) /* to_s on <var_e:nullable Object>*/;
}
if (var10){
if (var_e == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "lib/standard/string.nit", 1014);
+fprintf(stderr, "Runtime error: %s", "Reciever is null");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 1014);
exit(1);
} else {
var11 = ((val* (*)(val*))(var_e->class->vft[COLOR_string__Object__to_s]))(var_e) /* to_s on <var_e:nullable Object>*/;
}
if (var15){
if (var_e == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "lib/standard/string.nit", 1021);
+fprintf(stderr, "Runtime error: %s", "Reciever is null");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 1021);
exit(1);
} else {
var16 = ((val* (*)(val*))(var_e->class->vft[COLOR_string__Object__to_s]))(var_e) /* to_s on <var_e:nullable Object>*/;
short int var6 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var7 /* : Bool */;
val* var8 /* : nullable Object */;
val* var_e /* var e: nullable Object */;
/* <var_l:Int> isa OTHER */
var6 = 1; /* easy <var_l:Int> isa OTHER*/
if (!var6) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
var7 = var_i < var_l;
}
if (var10){
if (var_e == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "lib/standard/string.nit", 1037);
+fprintf(stderr, "Runtime error: %s", "Reciever is null");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 1037);
exit(1);
} else {
var11 = ((val* (*)(val*))(var_e->class->vft[COLOR_string__Object__to_s]))(var_e) /* to_s on <var_e:nullable Object>*/;
short int var4 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var5 /* : Bool */;
val* var6 /* : String */;
long var7 /* : Int */;
/* <var1:Int> isa OTHER */
var4 = 1; /* easy <var1:Int> isa OTHER*/
if (!var4) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 258);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 262);
exit(1);
}
var5 = var_length >= var1;
RET_LABEL3:(void)0;
}
if (!var2) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "lib/standard/string.nit", 1107);
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 1107);
exit(1);
}
var6 = NEW_string__String(&type_string__String);
}
var4 = self->attrs[COLOR_string__Sys___args_cache].val; /* _args_cache on <self:Sys> */
if (var4 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/string.nit", 1132);
+fprintf(stderr, "Runtime error: %s", "Cast failed");
+fprintf(stderr, " (%s:%d)\n", "lib/standard/string.nit", 1132);
exit(1);
}
var = var4;
short int var6 /* : Bool */;
int cltype;
int idtype;
+const char* var_class_name;
short int var7 /* : Bool */;
long var8 /* : Int */;
long var9 /* : Int */;
/* <var_argc:Int> isa OTHER */
var6 = 1; /* easy <var_argc:Int> isa OTHER*/
if (!var6) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 257);
+var_class_name = type_kernel__Int.name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 261);
exit(1);
}
var7 = var_i < var_argc;