diff options
| author | Carl Hetherington <cth@carlh.net> | 2018-07-21 15:16:18 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2018-07-21 15:16:18 +0100 |
| commit | cbd4450197a083bf58bda510e626f73ba583cb66 (patch) | |
| tree | 2be308772512539570beab36beab02bde72d6d4b /src/lib/content.cc | |
| parent | 1013175d5f6adfa0e6a7442e4c9aebb893787748 (diff) | |
Basics of multiple captions per content so that DCPContent can
hold subs and closed captions.
Diffstat (limited to 'src/lib/content.cc')
| -rw-r--r-- | src/lib/content.cc | 31 |
1 files changed, 29 insertions, 2 deletions
diff --git a/src/lib/content.cc b/src/lib/content.cc index d232f6e49..13c5794fe 100644 --- a/src/lib/content.cc +++ b/src/lib/content.cc @@ -402,7 +402,34 @@ Content::take_settings_from (shared_ptr<const Content> c) if (audio && c->audio) { audio->take_settings_from (c->audio); } - if (caption && c->caption) { - caption->take_settings_from (c->caption); + + list<shared_ptr<CaptionContent> >::iterator i = caption.begin (); + list<shared_ptr<CaptionContent> >::const_iterator j = c->caption.begin (); + while (i != caption.end() && j != c->caption.end()) { + (*i)->take_settings_from (*j); + ++i; + ++j; + } +} + +shared_ptr<CaptionContent> +Content::only_caption () const +{ + DCPOMATIC_ASSERT (caption.size() < 2); + if (caption.empty ()) { + return shared_ptr<CaptionContent> (); + } + return caption.front (); +} + +shared_ptr<CaptionContent> +Content::caption_of_original_type (CaptionType type) const +{ + BOOST_FOREACH (shared_ptr<CaptionContent> i, caption) { + if (i->original_type() == type) { + return i; + } } + + return shared_ptr<CaptionContent> (); } |
