From 6b13c8482a7d8b639ba4c8bdbfed349ee8d68482 Mon Sep 17 00:00:00 2001 From: Yuri Sizov Date: Wed, 13 Jan 2021 00:24:48 +0300 Subject: [PATCH] Prevent signal disconnection attempts on invalid references --- scene/gui/graph_edit.cpp | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/scene/gui/graph_edit.cpp b/scene/gui/graph_edit.cpp index 70c1c10cafb..9731d65c379 100644 --- a/scene/gui/graph_edit.cpp +++ b/scene/gui/graph_edit.cpp @@ -414,7 +414,14 @@ void GraphEdit::remove_child_notify(Node *p_child) { Control::remove_child_notify(p_child); - if (is_inside_tree()) { + if (p_child == top_layer) { + top_layer = nullptr; + minimap = nullptr; + } else if (p_child == connections_layer) { + connections_layer = nullptr; + } + + if (top_layer != nullptr && is_inside_tree()) { top_layer->call_deferred("raise"); // Top layer always on top! } @@ -422,8 +429,14 @@ void GraphEdit::remove_child_notify(Node *p_child) { if (gn) { gn->disconnect("offset_changed", this, "_graph_node_moved"); gn->disconnect("raise_request", this, "_graph_node_raised"); - gn->disconnect("item_rect_changed", connections_layer, "update"); - gn->disconnect("item_rect_changed", minimap, "update"); + + // In case of the whole GraphEdit being destroyed these references can already be freed. + if (connections_layer != nullptr && connections_layer->is_inside_tree()) { + gn->disconnect("item_rect_changed", connections_layer, "update"); + } + if (minimap != nullptr && minimap->is_inside_tree()) { + gn->disconnect("item_rect_changed", minimap, "update"); + } } }