GDScript: Fix implicit cast to typed array when passing parameter
This commit is contained in:
parent
b97110cd30
commit
b4cb7ec2bb
@ -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]));
|
||||||
}
|
}
|
||||||
|
@ -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())
|
@ -0,0 +1,2 @@
|
|||||||
|
GDTEST_OK
|
||||||
|
true
|
Loading…
Reference in New Issue
Block a user