Fix parsing of arguments in constant expressions

Fixes #8006
This commit is contained in:
Bojidar Marinov 2019-07-03 17:28:50 +03:00
parent 4cb0887660
commit f7de816f8b
No known key found for this signature in database
GPG key ID: 4D546A8F1E091856
2 changed files with 13 additions and 21 deletions

View file

@ -125,7 +125,7 @@ bool GDScriptParser::_enter_indent_block(BlockNode *p_block) {
} }
} }
bool GDScriptParser::_parse_arguments(Node *p_parent, Vector<Node *> &p_args, bool p_static, bool p_can_codecomplete) { bool GDScriptParser::_parse_arguments(Node *p_parent, Vector<Node *> &p_args, bool p_static, bool p_can_codecomplete, bool p_parsing_constant) {
if (tokenizer->get_token() == GDScriptTokenizer::TK_PARENTHESIS_CLOSE) { if (tokenizer->get_token() == GDScriptTokenizer::TK_PARENTHESIS_CLOSE) {
tokenizer->advance(); tokenizer->advance();
@ -149,7 +149,7 @@ bool GDScriptParser::_parse_arguments(Node *p_parent, Vector<Node *> &p_args, bo
return false; return false;
} }
Node *arg = _parse_expression(p_parent, p_static); Node *arg = _parse_expression(p_parent, p_static, false, p_parsing_constant);
if (!arg) { if (!arg) {
return false; return false;
} }
@ -639,7 +639,7 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
id->name = identifier; id->name = identifier;
op->arguments.push_back(id); op->arguments.push_back(id);
if (!_parse_arguments(op, op->arguments, p_static, true)) if (!_parse_arguments(op, op->arguments, p_static, true, p_parsing_constant))
return NULL; return NULL;
expr = op; expr = op;
@ -731,7 +731,7 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
completion_node = op; completion_node = op;
} }
if (!replaced) { if (!replaced) {
if (!_parse_arguments(op, op->arguments, p_static, true)) if (!_parse_arguments(op, op->arguments, p_static, true, p_parsing_constant))
return NULL; return NULL;
expr = op; expr = op;
} }
@ -1112,7 +1112,7 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
} }
} else { } else {
tokenizer->advance(); tokenizer->advance();
if (!_parse_arguments(op, op->arguments, p_static)) { if (!_parse_arguments(op, op->arguments, p_static, false, p_parsing_constant)) {
return NULL; return NULL;
} }
} }
@ -1164,13 +1164,6 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
tokenizer->advance(); tokenizer->advance();
IdentifierNode *id = alloc_node<IdentifierNode>(); IdentifierNode *id = alloc_node<IdentifierNode>();
if (tokenizer->get_token() == GDScriptTokenizer::TK_BUILT_IN_FUNC) {
//small hack so built in funcs don't obfuscate methods
id->name = GDScriptFunctions::get_func_name(tokenizer->get_token_built_in_func());
tokenizer->advance();
} else {
StringName identifier; StringName identifier;
if (_get_completable_identifier(COMPLETION_METHOD, identifier)) { if (_get_completable_identifier(COMPLETION_METHOD, identifier)) {
completion_node = op; completion_node = op;
@ -1178,7 +1171,6 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
} }
id->name = identifier; id->name = identifier;
}
op->arguments.push_back(expr); // call what op->arguments.push_back(expr); // call what
op->arguments.push_back(id); // call func op->arguments.push_back(id); // call func
@ -1188,7 +1180,7 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
_make_completable_call(0); _make_completable_call(0);
completion_node = op; completion_node = op;
} }
if (!_parse_arguments(op, op->arguments, p_static, true)) if (!_parse_arguments(op, op->arguments, p_static, true, p_parsing_constant))
return NULL; return NULL;
expr = op; expr = op;

View file

@ -582,7 +582,7 @@ private:
#endif // DEBUG_ENABLED #endif // DEBUG_ENABLED
bool _recover_from_completion(); bool _recover_from_completion();
bool _parse_arguments(Node *p_parent, Vector<Node *> &p_args, bool p_static, bool p_can_codecomplete = false); bool _parse_arguments(Node *p_parent, Vector<Node *> &p_args, bool p_static, bool p_can_codecomplete = false, bool p_parsing_constant = false);
bool _enter_indent_block(BlockNode *p_block = NULL); bool _enter_indent_block(BlockNode *p_block = NULL);
bool _parse_newline(); bool _parse_newline();
Node *_parse_expression(Node *p_parent, bool p_static, bool p_allow_assign = false, bool p_parsing_constant = false); Node *_parse_expression(Node *p_parent, bool p_static, bool p_allow_assign = false, bool p_parsing_constant = false);