summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-07-09 10:05:33 +0100
committerCarl Hetherington <cth@carlh.net>2018-07-09 10:05:33 +0100
commit802add97be4d2ed2d9b741598fc43f18ae827c04 (patch)
tree685c391d54b966ccb4730c0c11ab8131425ce519 /src
parent1e9887577ddfdf68dec7db1485ae99b5967853d6 (diff)
Adapt for changes to libdcp API.
Diffstat (limited to 'src')
-rw-r--r--src/dcp_reader.cc44
1 files changed, 26 insertions, 18 deletions
diff --git a/src/dcp_reader.cc b/src/dcp_reader.cc
index 6103470..a3ee8e5 100644
--- a/src/dcp_reader.cc
+++ b/src/dcp_reader.cc
@@ -1,5 +1,5 @@
/*
- Copyright (C) 2014-2017 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2014-2018 Carl Hetherington <cth@carlh.net>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -32,6 +32,7 @@ using std::string;
using std::exception;
using boost::shared_ptr;
using boost::optional;
+using boost::dynamic_pointer_cast;
using namespace sub;
static Time
@@ -71,13 +72,20 @@ DCPReader::DCPReader (boost::filesystem::path file)
}
- BOOST_FOREACH (dcp::SubtitleString const & i, sc->subtitles ()) {
+ BOOST_FOREACH (shared_ptr<dcp::Subtitle> i, sc->subtitles ()) {
+
+ /* We don't deal with image subs */
+ shared_ptr<dcp::SubtitleString> is = dynamic_pointer_cast<dcp::SubtitleString>(i);
+ if (!is) {
+ continue;
+ }
+
RawSubtitle rs;
- rs.text = i.text ();
- rs.font = i.font ();
- rs.font_size = FontSize::from_proportional (i.size() / (72.0 * 11.0));
+ rs.text = is->text ();
+ rs.font = is->font ();
+ rs.font_size = FontSize::from_proportional (is->size() / (72.0 * 11.0));
- switch (i.effect ()) {
+ switch (is->effect ()) {
case dcp::BORDER:
rs.effect = BORDER;
break;
@@ -88,14 +96,14 @@ DCPReader::DCPReader (boost::filesystem::path file)
break;
}
- rs.effect_colour = dcp_to_sub_colour (i.effect_colour());
+ rs.effect_colour = dcp_to_sub_colour (is->effect_colour());
- rs.colour = dcp_to_sub_colour (i.colour());
- rs.bold = i.bold ();
- rs.italic = i.italic ();
- rs.underline = i.underline ();
+ rs.colour = dcp_to_sub_colour (is->colour());
+ rs.bold = is->bold ();
+ rs.italic = is->italic ();
+ rs.underline = is->underline ();
- switch (i.h_align()) {
+ switch (is->h_align()) {
case dcp::HALIGN_LEFT:
rs.horizontal_position.reference = LEFT_OF_SCREEN;
break;
@@ -107,8 +115,8 @@ DCPReader::DCPReader (boost::filesystem::path file)
break;
}
- rs.vertical_position.proportional = i.v_position();
- switch (i.v_align()) {
+ rs.vertical_position.proportional = is->v_position();
+ switch (is->v_align()) {
case dcp::VALIGN_TOP:
rs.vertical_position.reference = TOP_OF_SCREEN;
break;
@@ -120,11 +128,11 @@ DCPReader::DCPReader (boost::filesystem::path file)
break;
}
- rs.from = dcp_to_sub_time (i.in ());
- rs.to = dcp_to_sub_time (i.out ());
+ rs.from = dcp_to_sub_time (is->in ());
+ rs.to = dcp_to_sub_time (is->out ());
- rs.fade_up = dcp_to_sub_time (i.fade_up_time ());
- rs.fade_down = dcp_to_sub_time (i.fade_down_time ());
+ rs.fade_up = dcp_to_sub_time (is->fade_up_time ());
+ rs.fade_down = dcp_to_sub_time (is->fade_down_time ());
_subs.push_back (rs);
}