Merge pull request #8014 from AlexHolly/fix-remove-and-skip

fix remove_and_skip()
This commit is contained in:
Rémi Verschelde 2017-03-18 10:32:14 +01:00 committed by GitHub
commit 5b6900ed9b

15
scene/main/node.cpp Normal file → Executable file
View file

@ -2020,12 +2020,13 @@ void Node::remove_and_skip() {
bool clear = true;
for (int i = 0; i < data.children.size(); i++) {
if (!data.children[i]->get_owner())
Node *c_node = data.children[i];
if (!c_node->get_owner())
continue;
remove_child(data.children[i]);
data.children[i]->_propagate_replace_owner(this, NULL);
children.push_back(data.children[i]);
remove_child(c_node);
c_node->_propagate_replace_owner(this, NULL);
children.push_back(c_node);
clear = false;
break;
}
@ -2036,9 +2037,9 @@ void Node::remove_and_skip() {
while (!children.empty()) {
Node *c = children.front()->get();
data.parent->add_child(c);
c->_propagate_replace_owner(NULL, new_owner);
Node *c_node = children.front()->get();
data.parent->add_child(c_node);
c_node->_propagate_replace_owner(NULL, new_owner);
children.pop_front();
}