From: Carl Hetherington Date: Fri, 2 Apr 2021 21:04:27 +0000 (+0200) Subject: Stop some EnsureVisible() calls happening with out-of-range parameters. X-Git-Tag: v2.15.138~5^2~7 X-Git-Url: https://git.carlh.net/gitweb/?a=commitdiff_plain;h=bb9a4a46266f705142a8aca41a092445a02debf0;hp=f188fc8d92eaba89aaa63cfd7f5a2fc9836e94b6;p=dcpomatic.git Stop some EnsureVisible() calls happening with out-of-range parameters. --- diff --git a/src/wx/full_language_tag_dialog.cc b/src/wx/full_language_tag_dialog.cc index 2b3aeb7de..a26dcc0bb 100644 --- a/src/wx/full_language_tag_dialog.cc +++ b/src/wx/full_language_tag_dialog.cc @@ -173,7 +173,7 @@ private: { auto search = _search->GetValue(); _list->set_search (search.ToStdString()); - if (search.Length() > 0) { + if (search.Length() > 0 && _list->GetItemCount() > 0) { _list->EnsureVisible (0); } SearchChanged (_search->GetValue().ToStdString()); diff --git a/src/wx/language_tag_dialog.cc b/src/wx/language_tag_dialog.cc index c72c64b31..ca08996c6 100644 --- a/src/wx/language_tag_dialog.cc +++ b/src/wx/language_tag_dialog.cc @@ -116,7 +116,9 @@ LanguageTagDialog::set (dcp::LanguageTag tag) _custom.push_back (tag); selection = _presets.size() + _custom.size() - 1; populate_list (); - _list->EnsureVisible (_list->GetItemCount() - 1); + if (_list->GetItemCount() > 0) { + _list->EnsureVisible (_list->GetItemCount() - 1); + } } else { selection = _presets.size() + std::distance(_custom.begin(), iter); } @@ -125,7 +127,9 @@ LanguageTagDialog::set (dcp::LanguageTag tag) } _list->SetItemState (selection, wxLIST_STATE_SELECTED, wxLIST_STATE_SELECTED); - _list->EnsureVisible (selection); + if (static_cast(selection) < _list->GetItemCount()) { + _list->EnsureVisible (selection); + } }