Merge pull request #64412 from MewPurPur/remove-remove-and-skip

Remove `Node.remove_and_skip` method
This commit is contained in:
Rémi Verschelde 2022-09-10 00:42:55 +02:00 committed by GitHub
commit 27e1323473
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 0 additions and 45 deletions

View File

@ -577,12 +577,6 @@
Queues a node for deletion at the end of the current frame. When deleted, all of its child nodes will be deleted as well. This method ensures it's safe to delete the node, contrary to [method Object.free]. Use [method Object.is_queued_for_deletion] to check whether a node will be deleted at the end of the frame. Queues a node for deletion at the end of the current frame. When deleted, all of its child nodes will be deleted as well. This method ensures it's safe to delete the node, contrary to [method Object.free]. Use [method Object.is_queued_for_deletion] to check whether a node will be deleted at the end of the frame.
</description> </description>
</method> </method>
<method name="remove_and_skip">
<return type="void" />
<description>
Removes a node and sets all its children as children of the parent node (if it exists). All event subscriptions that pass by the removed node will be unsubscribed.
</description>
</method>
<method name="remove_child"> <method name="remove_child">
<return type="void" /> <return type="void" />
<param index="0" name="node" type="Node" /> <param index="0" name="node" type="Node" />

View File

@ -1907,43 +1907,6 @@ Ref<Tween> Node::create_tween() {
return tween; return tween;
} }
void Node::remove_and_skip() {
ERR_FAIL_COND(!data.parent);
Node *new_owner = get_owner();
List<Node *> children;
while (true) {
bool clear = true;
for (int i = 0; i < data.children.size(); i++) {
Node *c_node = data.children[i];
if (!c_node->get_owner()) {
continue;
}
remove_child(c_node);
c_node->_propagate_replace_owner(this, nullptr);
children.push_back(c_node);
clear = false;
break;
}
if (clear) {
break;
}
}
while (!children.is_empty()) {
Node *c_node = children.front()->get();
data.parent->add_child(c_node);
c_node->_propagate_replace_owner(nullptr, new_owner);
children.pop_front();
}
data.parent->remove_child(this);
}
void Node::set_scene_file_path(const String &p_scene_file_path) { void Node::set_scene_file_path(const String &p_scene_file_path) {
data.scene_file_path = p_scene_file_path; data.scene_file_path = p_scene_file_path;
} }
@ -2803,7 +2766,6 @@ void Node::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_groups"), &Node::_get_groups); ClassDB::bind_method(D_METHOD("get_groups"), &Node::_get_groups);
ClassDB::bind_method(D_METHOD("set_owner", "owner"), &Node::set_owner); ClassDB::bind_method(D_METHOD("set_owner", "owner"), &Node::set_owner);
ClassDB::bind_method(D_METHOD("get_owner"), &Node::get_owner); ClassDB::bind_method(D_METHOD("get_owner"), &Node::get_owner);
ClassDB::bind_method(D_METHOD("remove_and_skip"), &Node::remove_and_skip);
ClassDB::bind_method(D_METHOD("get_index", "include_internal"), &Node::get_index, DEFVAL(false)); ClassDB::bind_method(D_METHOD("get_index", "include_internal"), &Node::get_index, DEFVAL(false));
ClassDB::bind_method(D_METHOD("print_tree"), &Node::print_tree); ClassDB::bind_method(D_METHOD("print_tree"), &Node::print_tree);
ClassDB::bind_method(D_METHOD("print_tree_pretty"), &Node::print_tree_pretty); ClassDB::bind_method(D_METHOD("print_tree_pretty"), &Node::print_tree_pretty);

View File

@ -356,7 +356,6 @@ public:
void set_unique_name_in_owner(bool p_enabled); void set_unique_name_in_owner(bool p_enabled);
bool is_unique_name_in_owner() const; bool is_unique_name_in_owner() const;
void remove_and_skip();
int get_index(bool p_include_internal = true) const; int get_index(bool p_include_internal = true) const;
Ref<Tween> create_tween(); Ref<Tween> create_tween();