mirror of
https://github.com/godotengine/godot.git
synced 2026-01-03 18:11:19 +03:00
Clear owners when pruning even out of the tree
This commit is contained in:
@@ -252,7 +252,7 @@ void Node::_propagate_enter_tree() {
|
||||
// enter groups
|
||||
}
|
||||
|
||||
void Node::_propagate_after_exit_tree() {
|
||||
void Node::_propagate_after_exit_branch(bool p_exiting_tree) {
|
||||
// Clear owner if it was not part of the pruned branch
|
||||
if (data.owner) {
|
||||
bool found = false;
|
||||
@@ -275,11 +275,13 @@ void Node::_propagate_after_exit_tree() {
|
||||
|
||||
data.blocked++;
|
||||
for (int i = 0; i < data.children.size(); i++) {
|
||||
data.children[i]->_propagate_after_exit_tree();
|
||||
data.children[i]->_propagate_after_exit_branch(p_exiting_tree);
|
||||
}
|
||||
data.blocked--;
|
||||
|
||||
emit_signal(SceneStringNames::get_singleton()->tree_exited);
|
||||
if (p_exiting_tree) {
|
||||
emit_signal(SceneStringNames::get_singleton()->tree_exited);
|
||||
}
|
||||
}
|
||||
|
||||
void Node::_propagate_exit_tree() {
|
||||
@@ -1265,9 +1267,7 @@ void Node::remove_child(Node *p_child) {
|
||||
p_child->data.parent = nullptr;
|
||||
p_child->data.pos = -1;
|
||||
|
||||
if (data.inside_tree) {
|
||||
p_child->_propagate_after_exit_tree();
|
||||
}
|
||||
p_child->_propagate_after_exit_branch(data.inside_tree);
|
||||
}
|
||||
|
||||
int Node::get_child_count() const {
|
||||
|
||||
Reference in New Issue
Block a user