Fix crash of queue_free() when main loop is not SceneTree
(cherry picked from commit 3b08d0e852
)
This commit is contained in:
parent
6d030f93b7
commit
3b869e8027
|
@ -2887,10 +2887,14 @@ void Node::print_stray_nodes() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Node::queue_delete() {
|
void Node::queue_delete() {
|
||||||
|
// There are users which instantiate multiple scene trees for their games.
|
||||||
|
// Use the node's own tree to handle its deletion when relevant.
|
||||||
if (is_inside_tree()) {
|
if (is_inside_tree()) {
|
||||||
get_tree()->queue_delete(this);
|
get_tree()->queue_delete(this);
|
||||||
} else {
|
} else {
|
||||||
SceneTree::get_singleton()->queue_delete(this);
|
SceneTree *tree = SceneTree::get_singleton();
|
||||||
|
ERR_FAIL_NULL_MSG(tree, "Can't queue free a node when no SceneTree is available.");
|
||||||
|
tree->queue_delete(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue