GDScript: Fix implicit cast to typed array when passing parameter

This commit is contained in:
Danil Alexeev 2024-07-07 13:43:09 +03:00
parent b97110cd30
commit b4cb7ec2bb
No known key found for this signature in database
GPG key ID: 124453E157DA8DC7
3 changed files with 25 additions and 3 deletions

View file

@ -550,9 +550,22 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
return _get_default_variant_for_data_type(return_type); return _get_default_variant_for_data_type(return_type);
} }
if (argument_types[i].kind == GDScriptDataType::BUILTIN) { if (argument_types[i].kind == GDScriptDataType::BUILTIN) {
Variant arg; if (argument_types[i].builtin_type == Variant::ARRAY && argument_types[i].has_container_element_type(0)) {
Variant::construct(argument_types[i].builtin_type, arg, &p_args[i], 1, r_err); const GDScriptDataType &arg_type = argument_types[i].container_element_types[0];
memnew_placement(&stack[i + 3], Variant(arg)); Array array(p_args[i]->operator Array(), arg_type.builtin_type, arg_type.native_type, arg_type.script_type);
memnew_placement(&stack[i + 3], Variant(array));
} else {
Variant variant;
Variant::construct(argument_types[i].builtin_type, variant, &p_args[i], 1, r_err);
if (unlikely(r_err.error)) {
r_err.error = Callable::CallError::CALL_ERROR_INVALID_ARGUMENT;
r_err.argument = i;
r_err.expected = argument_types[i].builtin_type;
call_depth--;
return _get_default_variant_for_data_type(return_type);
}
memnew_placement(&stack[i + 3], Variant(variant));
}
} else { } else {
memnew_placement(&stack[i + 3], Variant(*p_args[i])); memnew_placement(&stack[i + 3], Variant(*p_args[i]));
} }

View file

@ -0,0 +1,7 @@
# GH-93990
func test_param(array: Array[String]) -> void:
print(array.get_typed_builtin() == TYPE_STRING)
func test() -> void:
test_param(PackedStringArray())

View file

@ -0,0 +1,2 @@
GDTEST_OK
true