2
0
Fork 0

Merge pull request #72794 from vnen/gdscript-no-onready-without-node

GDScript: Don't allow @onready without inheriting Node
4.0
Rémi Verschelde 2023-02-06 15:41:02 +07:00
commit 8a37fad281
No known key found for this signature in database
GPG Key ID: C3336907360768E1
5 changed files with 19 additions and 0 deletions

@ -3611,6 +3611,10 @@ bool GDScriptParser::icon_annotation(const AnnotationNode *p_annotation, Node *p
bool GDScriptParser::onready_annotation(const AnnotationNode *p_annotation, Node *p_node) {
ERR_FAIL_COND_V_MSG(p_node->type != Node::VARIABLE, false, R"("@onready" annotation can only be applied to class variables.)");
if (head && !ClassDB::is_parent_class(head->get_datatype().native_type, SNAME("Node"))) {
push_error(R"("@onready" can only be used in classes that inherit "Node".)", p_annotation);
}
VariableNode *variable = static_cast<VariableNode *>(p_node);
if (variable->onready) {
push_error(R"("@onready" annotation can only be used once per variable.)");

@ -0,0 +1,5 @@
extends RefCounted
func test():
var nope := $Node
print("Cannot use $ without a Node base")

@ -0,0 +1,2 @@
GDTEST_ANALYZER_ERROR
Cannot use shorthand "get_node()" notation ("$") on a class that isn't a node.

@ -0,0 +1,6 @@
extends RefCounted
@onready var nope := 0
func test():
print("Cannot use @onready without a Node base")

@ -0,0 +1,2 @@
GDTEST_ANALYZER_ERROR
"@onready" can only be used in classes that inherit "Node".