parent
4cb0887660
commit
f7de816f8b
2 changed files with 13 additions and 21 deletions
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue