summaryrefslogtreecommitdiffstats
path: root/editor/editor_dock_manager.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-05-14 18:09:51 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-05-14 18:09:51 +0200
commit380f63489f56271f3a6269c61205596214aaaeab (patch)
tree25701c9ab31ac03fdf2076969fc27135ae1b5905 /editor/editor_dock_manager.cpp
parentde329556f785e2bc33fc1db4a1485cafffbf7b96 (diff)
parentd8acd8caa6c22ba5864cc8007ac502db8a0a65d3 (diff)
downloadredot-engine-380f63489f56271f3a6269c61205596214aaaeab.tar.gz
Merge pull request #91728 from kitbdev/assimilate-split-container
Use `as_sortable_control()` in SplitContainer
Diffstat (limited to 'editor/editor_dock_manager.cpp')
-rw-r--r--editor/editor_dock_manager.cpp33
1 files changed, 20 insertions, 13 deletions
diff --git a/editor/editor_dock_manager.cpp b/editor/editor_dock_manager.cpp
index 4ba7832e76..2357a0e0ba 100644
--- a/editor/editor_dock_manager.cpp
+++ b/editor/editor_dock_manager.cpp
@@ -59,12 +59,13 @@ void DockSplitContainer::_update_visibility() {
}
is_updating = true;
bool any_visible = false;
- for (int i = 0; i < 2; i++) {
- Control *split = get_containable_child(i);
- if (split && split->is_visible()) {
- any_visible = true;
- break;
+ for (int i = 0; i < get_child_count(false); i++) {
+ Control *c = Object::cast_to<Control>(get_child(i, false));
+ if (!c || !c->is_visible() || c->is_set_as_top_level()) {
+ continue;
}
+ any_visible = c;
+ break;
}
set_visible(any_visible);
is_updating = false;
@@ -74,10 +75,13 @@ void DockSplitContainer::add_child_notify(Node *p_child) {
SplitContainer::add_child_notify(p_child);
Control *child_control = nullptr;
- for (int i = 0; i < 2; i++) {
- Control *split = get_containable_child(i);
- if (p_child == split) {
- child_control = split;
+ for (int i = 0; i < get_child_count(false); i++) {
+ Control *c = Object::cast_to<Control>(get_child(i, false));
+ if (!c || c->is_set_as_top_level()) {
+ continue;
+ }
+ if (p_child == c) {
+ child_control = c;
break;
}
}
@@ -93,10 +97,13 @@ void DockSplitContainer::remove_child_notify(Node *p_child) {
SplitContainer::remove_child_notify(p_child);
Control *child_control = nullptr;
- for (int i = 0; i < 2; i++) {
- Control *split = get_containable_child(i);
- if (p_child == split) {
- child_control = split;
+ for (int i = 0; i < get_child_count(false); i++) {
+ Control *c = Object::cast_to<Control>(get_child(i, false));
+ if (!c || c->is_set_as_top_level()) {
+ continue;
+ }
+ if (p_child == c) {
+ child_control = c;
break;
}
}