summaryrefslogtreecommitdiff
path: root/src/dcp/subtitle.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2017-01-11 10:57:09 +0000
committerCarl Hetherington <cth@carlh.net>2017-01-11 10:58:11 +0000
commitf528fc50162db6fcecbaa2cd6121c7ee86a82777 (patch)
treeb5dec339a41dee33fb3ddbc31b1054e0008feffc /src/dcp/subtitle.cc
parentefb00e9649aa03a2c12bb6a63c5e7efdfd99506a (diff)
Replace DCP parser with basic version that uses libdcp.libdcp-again
Diffstat (limited to 'src/dcp/subtitle.cc')
-rw-r--r--src/dcp/subtitle.cc119
1 files changed, 0 insertions, 119 deletions
diff --git a/src/dcp/subtitle.cc b/src/dcp/subtitle.cc
deleted file mode 100644
index 68ca559..0000000
--- a/src/dcp/subtitle.cc
+++ /dev/null
@@ -1,119 +0,0 @@
-/*
- Copyright (C) 2012-2015 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
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-
-*/
-
-#include "../exceptions.h"
-#include "../raw_convert.h"
-#include "subtitle.h"
-#include <libcxml/cxml.h>
-#include <boost/lexical_cast.hpp>
-#include <boost/algorithm/string.hpp>
-
-using std::string;
-using std::vector;
-using std::list;
-using boost::optional;
-using boost::shared_ptr;
-using boost::lexical_cast;
-using boost::is_any_of;
-using namespace sub;
-
-dcp::Subtitle::Subtitle (boost::shared_ptr<const cxml::Node> node, optional<int> tcr)
-{
- if (tcr) {
- in = smpte_time (node, "TimeIn", tcr.get ()).get ();
- out = smpte_time (node, "TimeOut", tcr.get ()).get ();
- } else {
- in = interop_time (node, "TimeIn").get ();
- out = interop_time (node, "TimeOut").get ();
- }
-
- if (tcr) {
- fade_up_time = smpte_time (node, "FadeUpTime", tcr.get ()).get_value_or (Time::from_hmsf (0, 0, 0, 2, Rational (tcr.get(), 1)));
- fade_down_time = smpte_time (node, "FadeDownTime", tcr.get ()).get_value_or (Time::from_hmsf (0, 0, 0, 2, Rational (tcr.get (), 1)));
- } else {
- fade_up_time = interop_time (node, "FadeUpTime").get_value_or (Time::from_hms (0, 0, 0, 80));
- if (fade_up_time > Time::from_hms (0, 0, 8, 0)) {
- fade_up_time = Time::from_hms (0, 0, 8, 0);
- }
- fade_down_time = interop_time (node, "FadeDownTime").get_value_or (Time::from_hms (0, 0, 0, 80));
- if (fade_down_time > Time::from_hms (0, 0, 8, 0)) {
- fade_down_time = Time::from_hms (0, 0, 8, 0);
- }
- }
-}
-
-optional<Time>
-dcp::Subtitle::smpte_time (shared_ptr<const cxml::Node> node, string name, int tcr)
-{
- optional<string> u = node->optional_string_attribute (name);
- if (!u) {
- return optional<Time> ();
- }
-
- vector<string> b;
- split (b, u.get (), is_any_of (":"));
- if (b.size() != 4) {
- boost::throw_exception (DCPError ("unrecognised time specification " + u.get ()));
- }
-
- return Time::from_hmsf (
- raw_convert<int> (b[0]),
- raw_convert<int> (b[1]),
- raw_convert<int> (b[2]),
- raw_convert<int> (b[3]),
- Rational (tcr, 1)
- );
-}
-
-optional<Time>
-dcp::Subtitle::interop_time (shared_ptr<const cxml::Node> node, string name)
-{
- optional<string> u = node->optional_string_attribute (name);
- if (!u) {
- return optional<Time> ();
- }
-
- if (u.get().find (":") != string::npos) {
- /* HH:MM:SS:TTT or HH:MM:SS.sss */
- vector<string> b;
- split (b, u.get(), is_any_of (":."));
- if (b.size() != 4) {
- boost::throw_exception (DCPError ("unrecognised time specification " + u.get ()));
- }
-
- if (u.get().find (".") != string::npos) {
- return Time::from_hms (
- raw_convert<int> (b[0]),
- raw_convert<int> (b[1]),
- raw_convert<int> (b[2]),
- rint (raw_convert<double> ("." + b[3]) * 1000)
- );
- } else {
- return Time::from_hms (
- raw_convert<int> (b[0]),
- raw_convert<int> (b[1]),
- raw_convert<int> (b[2]),
- raw_convert<int> (b[3]) * 4
- );
- }
- } else {
- return Time::from_hms (0, 0, 0, raw_convert<int> (u.get ()) * 4);
- }
-}
-