- list<shared_ptr<dcp::InteropLoadFont> > fonts = sc.load_font_nodes ();
- for (list<shared_ptr<dcp::InteropLoadFont> >::const_iterator i = fonts.begin(); i != fonts.end(); ++i) {
- _fonts.push_back (shared_ptr<Font> (new Font ((*i)->id)));
+ /* Default to turning these subtitles on */
+ only_text()->set_use (true);
+
+ _length = ContentTime::from_seconds (sc->latest_subtitle_out().as_seconds());
+
+ sc->fix_empty_font_ids ();
+
+ auto font_data = sc->font_data();
+ for (auto node: sc->load_font_nodes()) {
+ auto data = font_data.find(node->id);
+ if (data != font_data.end()) {
+ only_text()->add_font(make_shared<Font>(node->id, data->second));
+ } else {
+ only_text()->add_font(make_shared<Font>(node->id));
+ }
+ }
+
+ if (only_text()->fonts().empty()) {
+ only_text()->add_font(make_shared<Font>(""));