Merge pull request #59694 from vnen/gdscript-better-call-super
This commit is contained in:
commit
5ba3b993d5
2 changed files with 13 additions and 5 deletions
|
@ -2426,6 +2426,10 @@ void GDScriptAnalyzer::reduce_call(GDScriptParser::CallNode *p_call, bool p_is_a
|
||||||
base_type = parser->current_class->base_type;
|
base_type = parser->current_class->base_type;
|
||||||
base_type.is_meta_type = false;
|
base_type.is_meta_type = false;
|
||||||
is_self = true;
|
is_self = true;
|
||||||
|
|
||||||
|
if (p_call->callee == nullptr && !lambda_stack.is_empty()) {
|
||||||
|
push_error("Cannot use `super()` inside a lambda.", p_call);
|
||||||
|
}
|
||||||
} else if (callee_type == GDScriptParser::Node::IDENTIFIER) {
|
} else if (callee_type == GDScriptParser::Node::IDENTIFIER) {
|
||||||
base_type = parser->current_class->get_datatype();
|
base_type = parser->current_class->get_datatype();
|
||||||
base_type.is_meta_type = false;
|
base_type.is_meta_type = false;
|
||||||
|
@ -2494,12 +2498,12 @@ void GDScriptAnalyzer::reduce_call(GDScriptParser::CallNode *p_call, bool p_is_a
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_self && parser->current_function != nullptr && parser->current_function->is_static && !is_static) {
|
if (is_self && parser->current_function != nullptr && parser->current_function->is_static && !is_static) {
|
||||||
push_error(vformat(R"*(Cannot call non-static function "%s()" from static function "%s()".)*", p_call->function_name, parser->current_function->identifier->name), p_call->callee);
|
push_error(vformat(R"*(Cannot call non-static function "%s()" from static function "%s()".)*", p_call->function_name, parser->current_function->identifier->name), p_call);
|
||||||
} else if (!is_self && base_type.is_meta_type && !is_static) {
|
} else if (!is_self && base_type.is_meta_type && !is_static) {
|
||||||
base_type.is_meta_type = false; // For `to_string()`.
|
base_type.is_meta_type = false; // For `to_string()`.
|
||||||
push_error(vformat(R"*(Cannot call non-static function "%s()" on the class "%s" directly. Make an instance instead.)*", p_call->function_name, base_type.to_string()), p_call->callee);
|
push_error(vformat(R"*(Cannot call non-static function "%s()" on the class "%s" directly. Make an instance instead.)*", p_call->function_name, base_type.to_string()), p_call);
|
||||||
} else if (is_self && !is_static && !lambda_stack.is_empty()) {
|
} else if (is_self && !is_static && !lambda_stack.is_empty()) {
|
||||||
push_error(vformat(R"*(Cannot call non-static function "%s()" from a lambda function.)*", p_call->function_name), p_call->callee);
|
push_error(vformat(R"*(Cannot call non-static function "%s()" from a lambda function.)*", p_call->function_name), p_call);
|
||||||
}
|
}
|
||||||
|
|
||||||
call_type = return_type;
|
call_type = return_type;
|
||||||
|
@ -2539,7 +2543,7 @@ void GDScriptAnalyzer::reduce_call(GDScriptParser::CallNode *p_call, bool p_is_a
|
||||||
}
|
}
|
||||||
|
|
||||||
if (call_type.is_coroutine && !p_is_await && !p_is_root) {
|
if (call_type.is_coroutine && !p_is_await && !p_is_root) {
|
||||||
push_error(vformat(R"*(Function "%s()" is a coroutine, so it must be called with "await".)*", p_call->function_name), p_call->callee);
|
push_error(vformat(R"*(Function "%s()" is a coroutine, so it must be called with "await".)*", p_call->function_name), p_call);
|
||||||
}
|
}
|
||||||
|
|
||||||
p_call->set_datatype(call_type);
|
p_call->set_datatype(call_type);
|
||||||
|
|
|
@ -2752,7 +2752,11 @@ GDScriptParser::ExpressionNode *GDScriptParser::parse_call(ExpressionNode *p_pre
|
||||||
pop_multiline();
|
pop_multiline();
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
call->function_name = current_function->identifier->name;
|
if (current_function->identifier) {
|
||||||
|
call->function_name = current_function->identifier->name;
|
||||||
|
} else {
|
||||||
|
call->function_name = SNAME("<anonymous>");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
consume(GDScriptTokenizer::Token::PERIOD, R"(Expected "." or "(" after "super".)");
|
consume(GDScriptTokenizer::Token::PERIOD, R"(Expected "." or "(" after "super".)");
|
||||||
make_completion_context(COMPLETION_SUPER_METHOD, call, true);
|
make_completion_context(COMPLETION_SUPER_METHOD, call, true);
|
||||||
|
|
Loading…
Reference in a new issue