summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2019-10-30 21:39:58 +0000
committerCarl Hetherington <cth@carlh.net>2019-10-30 22:43:55 +0100
commit0486d4d94900c7f2a2cab7885b3f162d1ad8290c (patch)
treeb50f8551027f49ab72956e8295e50064cf8ee183
parent265acfe3f904b4af4c37f6f0898f7c10f146ca42 (diff)
Fix dying butler on changing CPL from one without to one withv2.15.28
subtitles (#1641). Forward-port from da39ed1516f2463f8a9bf4795a94f23d420c9ca3 in master.
-rw-r--r--src/lib/dcp_decoder.cc10
1 files changed, 8 insertions, 2 deletions
diff --git a/src/lib/dcp_decoder.cc b/src/lib/dcp_decoder.cc
index 4b189189e..826b4e8d3 100644
--- a/src/lib/dcp_decoder.cc
+++ b/src/lib/dcp_decoder.cc
@@ -223,8 +223,14 @@ void
DCPDecoder::pass_texts (ContentTime next, dcp::Size size)
{
list<shared_ptr<TextDecoder> >::const_iterator decoder = text.begin ();
+ if (decoder == text.end()) {
+ /* It's possible that there is now a main subtitle but no TextDecoders, for example if
+ the CPL has just changed but the TextContent's texts have not been recreated yet.
+ */
+ return;
+ }
+
if ((*_reel)->main_subtitle()) {
- DCPOMATIC_ASSERT (decoder != text.end ());
pass_texts (
next,
(*_reel)->main_subtitle()->asset(),
@@ -235,8 +241,8 @@ DCPDecoder::pass_texts (ContentTime next, dcp::Size size)
);
++decoder;
}
+
BOOST_FOREACH (shared_ptr<dcp::ReelClosedCaptionAsset> i, (*_reel)->closed_captions()) {
- DCPOMATIC_ASSERT (decoder != text.end ());
pass_texts (
next, i->asset(), _dcp_content->reference_text(TEXT_CLOSED_CAPTION), i->entry_point().get_value_or(0), *decoder, size
);