Merge pull request #22934 from SeleckyErik/issue-11457
GDscript function str2var now returns null on invalid input
This commit is contained in:
commit
19f2a188bb
1 changed files with 2 additions and 10 deletions
|
@ -758,22 +758,14 @@ void GDScriptFunctions::call(Function p_func, const Variant **p_args, int p_arg_
|
||||||
r_ret = Variant();
|
r_ret = Variant();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
r_ret = *p_args[0];
|
||||||
|
|
||||||
VariantParser::StreamString ss;
|
VariantParser::StreamString ss;
|
||||||
ss.s = *p_args[0];
|
ss.s = *p_args[0];
|
||||||
|
|
||||||
String errs;
|
String errs;
|
||||||
int line;
|
int line;
|
||||||
Error err = VariantParser::parse(&ss, r_ret, errs, line);
|
(void)VariantParser::parse(&ss, r_ret, errs, line);
|
||||||
|
|
||||||
if (err != OK) {
|
|
||||||
r_error.error = Variant::CallError::CALL_ERROR_INVALID_ARGUMENT;
|
|
||||||
r_error.argument = 0;
|
|
||||||
r_error.expected = Variant::STRING;
|
|
||||||
r_ret = "Parse error at line " + itos(line) + ": " + errs;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
case VAR_TO_BYTES: {
|
case VAR_TO_BYTES: {
|
||||||
VALIDATE_ARG_COUNT(1);
|
VALIDATE_ARG_COUNT(1);
|
||||||
|
|
Loading…
Reference in a new issue