This commit is contained in:
gingerBill
2022-11-21 11:30:21 +00:00
parent 4c40495742
commit 0b33df4e9d

View File

@@ -765,16 +765,13 @@ i64 check_distance_between_types(CheckerContext *c, Operand *operand, Type *type
}
// TODO(bill): Determine which rule is a better on in practice
#if 1
if (dst->Union.variants.count == 1) {
Type *vt = dst->Union.variants[0];
i64 score = check_distance_between_types(c, operand, vt);
if (score >= 0) {
return score+2;
}
if (dst->Union.variants.count == 1) {
Type *vt = dst->Union.variants[0];
i64 score = check_distance_between_types(c, operand, vt);
if (score >= 0) {
return score+2;
}
#else
// NOTE(bill): check to see you can assign to it with one of the variants?
} else if (is_type_untyped(src)) {
i64 prev_lowest_score = -1;
i64 lowest_score = -1;
for_array(i, dst->Union.variants) {
@@ -798,7 +795,7 @@ i64 check_distance_between_types(CheckerContext *c, Operand *operand, Type *type
return lowest_score+2;
}
}
#endif
}
}
if (is_type_relative_pointer(dst)) {