From 6dbc08668b990ebb6518d37501c6d777b9a5d127 Mon Sep 17 00:00:00 2001 From: hilfazer Date: Wed, 17 Jun 2020 16:45:05 +0200 Subject: [PATCH] Move Editable Children information from scene's root to instanced nodes --- editor/scene_tree_dock.cpp | 1 - scene/main/node.cpp | 21 ++++----------------- scene/main/node.h | 5 +---- 3 files changed, 5 insertions(+), 22 deletions(-) diff --git a/editor/scene_tree_dock.cpp b/editor/scene_tree_dock.cpp index e0326c77e489..dc627c41b5da 100644 --- a/editor/scene_tree_dock.cpp +++ b/editor/scene_tree_dock.cpp @@ -2146,7 +2146,6 @@ void SceneTreeDock::replace_node(Node *p_node, Node *p_by_node, bool p_keep_prop if (n == edited_scene) { edited_scene = newnode; editor->set_edited_scene(newnode); - newnode->set_editable_instances(n->get_editable_instances()); } //small hack to make collisionshapes and other kind of nodes to work diff --git a/scene/main/node.cpp b/scene/main/node.cpp index 05cd5910a611..8fd59bbb3023 100644 --- a/scene/main/node.cpp +++ b/scene/main/node.cpp @@ -1901,37 +1901,23 @@ String Node::get_editor_description() const { } void Node::set_editable_instance(Node *p_node, bool p_editable) { - ERR_FAIL_NULL(p_node); ERR_FAIL_COND(!is_a_parent_of(p_node)); - NodePath p = get_path_to(p_node); if (!p_editable) { - data.editable_instances.erase(p); + p_node->data.editable_instance = false; // Avoid this flag being needlessly saved; // also give more visual feedback if editable children is re-enabled set_display_folded(false); } else { - data.editable_instances[p] = true; + p_node->data.editable_instance = true; } } bool Node::is_editable_instance(const Node *p_node) const { - if (!p_node) return false; //easier, null is never editable :) ERR_FAIL_COND_V(!is_a_parent_of(p_node), false); - NodePath p = get_path_to(p_node); - return data.editable_instances.has(p); -} - -void Node::set_editable_instances(const HashMap &p_editable_instances) { - - data.editable_instances = p_editable_instances; -} - -HashMap Node::get_editable_instances() const { - - return data.editable_instances; + return p_node->data.editable_instance; } void Node::set_scene_instance_state(const Ref &p_state) { @@ -2970,6 +2956,7 @@ Node::Node() { data.use_placeholder = false; data.display_folded = false; data.ready_first = true; + data.editable_instance = false; orphan_node_count++; } diff --git a/scene/main/node.h b/scene/main/node.h index 6f5544d654b4..34aab308babb 100644 --- a/scene/main/node.h +++ b/scene/main/node.h @@ -91,8 +91,6 @@ class Node : public Object { Ref instance_state; Ref inherited_state; - HashMap editable_instances; - Node *parent; Node *owner; Vector children; // list of children @@ -139,6 +137,7 @@ class Node : public Object { bool use_placeholder; bool display_folded; + bool editable_instance; mutable NodePath *path_cache; @@ -325,8 +324,6 @@ class Node : public Object { void set_editable_instance(Node *p_node, bool p_editable); bool is_editable_instance(const Node *p_node) const; - void set_editable_instances(const HashMap &p_editable_instances); - HashMap get_editable_instances() const; /* NOTIFICATIONS */