fix variadic parameter with default value error check

This commit is contained in:
Laytan
2024-08-21 15:11:16 +02:00
parent c77e8ca401
commit 63cd9a031a

View File

@@ -1781,6 +1781,11 @@ gb_internal Type *check_get_params(CheckerContext *ctx, Scope *scope, Ast *_para
success = false;
}
if (default_value != nullptr) {
error(type_expr, "A variadic parameter may not have a default value");
success = false;
}
GB_ASSERT(original_type_expr->kind == Ast_Ellipsis);
type_expr = ast_array_type(type_expr->file(), original_type_expr->Ellipsis.token, nullptr, type_expr);
}
@@ -1819,8 +1824,6 @@ gb_internal Type *check_get_params(CheckerContext *ctx, Scope *scope, Ast *_para
if (default_value != nullptr) {
if (type_expr != nullptr && type_expr->kind == Ast_TypeidType) {
error(type_expr, "A type parameter may not have a default value");
} else if (is_variadic) {
error(type_expr, "A variadic parameter may not have a default value");
} else {
param_value = handle_parameter_value(ctx, type, nullptr, default_value, true);
}