summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2020-07-31 01:04:43 +0200
committerCarl Hetherington <cth@carlh.net>2020-07-31 01:04:43 +0200
commit9ff6d1b786c52d0aae485507d96ea67f3171b9fd (patch)
tree1b2aa1cb538aed9769961d27040106f2202c3935
parent4b5e05b9845d609524328a88a81011b364e03a8a (diff)
Fix crash on too-early update of closed caption dialog.
-rw-r--r--src/wx/closed_captions_dialog.cc23
1 files changed, 12 insertions, 11 deletions
diff --git a/src/wx/closed_captions_dialog.cc b/src/wx/closed_captions_dialog.cc
index 625652b8c..4519c4b7c 100644
--- a/src/wx/closed_captions_dialog.cc
+++ b/src/wx/closed_captions_dialog.cc
@@ -165,22 +165,23 @@ ClosedCaptionsDialog::update ()
if (!_current && !_tracks.empty()) {
/* We have no current one: get another */
shared_ptr<Butler> butler = _butler.lock ();
- DCPOMATIC_ASSERT (butler);
DCPOMATIC_ASSERT (_track->GetSelection() >= 0);
DCPOMATIC_ASSERT (_track->GetSelection() < int(_tracks.size()));
DCPTextTrack track = _tracks[_track->GetSelection()];
- while (true) {
- optional<TextRingBuffers::Data> d = butler->get_closed_caption ();
- if (!d) {
- break;
- }
- if (d->track == track) {
- _current = d;
- break;
+ if (butler) {
+ while (true) {
+ optional<TextRingBuffers::Data> d = butler->get_closed_caption ();
+ if (!d) {
+ break;
+ }
+ if (d->track == track) {
+ _current = d;
+ break;
+ }
}
- }
- _current_in_lines = false;
+ _current_in_lines = false;
+ }
}
if (_current && _current->period.contains(time)) {