summaryrefslogtreecommitdiffstats
path: root/scene/gui/tab_bar.cpp
diff options
context:
space:
mode:
authorA Thousand Ships <96648715+AThousandShips@users.noreply.github.com>2024-02-18 14:15:13 +0100
committerA Thousand Ships <96648715+AThousandShips@users.noreply.github.com>2024-02-20 23:38:20 +0100
commita56c03d49584c81f67b24a508fbe87916b749275 (patch)
tree76ed918c3f6b4db875e0c318262df73ecf34f09b /scene/gui/tab_bar.cpp
parentb8f106acb24387d2f2c746a586edc0728fd10aaf (diff)
downloadredot-engine-a56c03d49584c81f67b24a508fbe87916b749275.tar.gz
Fix error spam when adding tabs to `TabBar` without deselect
`current` was allowed to be `-1` when deselection was disabled, causing errors in other methods when updating the size.
Diffstat (limited to 'scene/gui/tab_bar.cpp')
-rw-r--r--scene/gui/tab_bar.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/scene/gui/tab_bar.cpp b/scene/gui/tab_bar.cpp
index f87bccdfe7..d20fef8164 100644
--- a/scene/gui/tab_bar.cpp
+++ b/scene/gui/tab_bar.cpp
@@ -627,6 +627,10 @@ void TabBar::set_tab_count(int p_count) {
offset = MIN(offset, p_count - 1);
max_drawn_tab = MIN(max_drawn_tab, p_count - 1);
current = MIN(current, p_count - 1);
+ // Fix range if unable to deselect.
+ if (current == -1 && !_can_deselect()) {
+ current = 0;
+ }
_update_cache();
_ensure_no_over_offset();
@@ -1557,10 +1561,7 @@ bool TabBar::_can_deselect() const {
}
void TabBar::ensure_tab_visible(int p_idx) {
- if (!is_inside_tree() || !buttons_visible) {
- return;
- }
- if (p_idx == -1 && _can_deselect()) {
+ if (p_idx == -1 || !is_inside_tree() || !buttons_visible) {
return;
}
ERR_FAIL_INDEX(p_idx, tabs.size());