mirror of
https://github.com/Ed94/Odin.git
synced 2026-06-25 15:05:00 -07:00
Add suggestion for #3961
This commit is contained in:
@@ -1559,11 +1559,30 @@ gb_internal Type *determine_type_from_polymorphic(CheckerContext *ctx, Type *pol
|
||||
return poly_type;
|
||||
}
|
||||
if (show_error) {
|
||||
ERROR_BLOCK();
|
||||
gbString pts = type_to_string(poly_type);
|
||||
gbString ots = type_to_string(operand.type, true);
|
||||
defer (gb_string_free(pts));
|
||||
defer (gb_string_free(ots));
|
||||
error(operand.expr, "Cannot determine polymorphic type from parameter: '%s' to '%s'", ots, pts);
|
||||
|
||||
Type *pt = poly_type;
|
||||
while (pt && pt->kind == Type_Generic && pt->Generic.specialized) {
|
||||
pt = pt->Generic.specialized;
|
||||
}
|
||||
if (is_type_slice(pt) &&
|
||||
(is_type_dynamic_array(operand.type) || is_type_array(operand.type))) {
|
||||
Ast *expr = unparen_expr(operand.expr);
|
||||
if (expr->kind == Ast_CompoundLit) {
|
||||
gbString es = type_to_string(base_any_array_type(operand.type));
|
||||
error_line("\tSuggestion: Try using a slice compound literal instead '[]%s{...}'\n", es);
|
||||
gb_string_free(es);
|
||||
} else {
|
||||
gbString os = expr_to_string(operand.expr);
|
||||
error_line("\tSuggestion: Try slicing the value with '%s[:]'\n", os);
|
||||
gb_string_free(os);
|
||||
}
|
||||
}
|
||||
}
|
||||
return t_invalid;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user