summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2014-12-11 15:20:33 +0000
committerCarl Hetherington <cth@carlh.net>2014-12-11 16:05:58 +0000
commit6bd8be029c72180a41d70e590bf2cb85a77317bf (patch)
treef31286d8a6f4aa990fce2af549e5eb3cb7909b34 /src/lib
parent5c93e50af883f02eadcf9a7bfe9cbfabbb3be844 (diff)
Add language property to SubtitleContent and use it in output DCP subtitle files.
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/dcp_subtitle_content.cc1
-rw-r--r--src/lib/player.cc8
-rw-r--r--src/lib/player_subtitles.h4
-rw-r--r--src/lib/subtitle_content.cc19
-rw-r--r--src/lib/subtitle_content.h12
-rw-r--r--src/lib/writer.cc4
-rw-r--r--src/lib/writer.h2
7 files changed, 44 insertions, 6 deletions
diff --git a/src/lib/dcp_subtitle_content.cc b/src/lib/dcp_subtitle_content.cc
index 7be96ceeb..798afbfc3 100644
--- a/src/lib/dcp_subtitle_content.cc
+++ b/src/lib/dcp_subtitle_content.cc
@@ -48,6 +48,7 @@ DCPSubtitleContent::examine (shared_ptr<Job> job, bool calculate_digest)
{
Content::examine (job, calculate_digest);
dcp::SubtitleContent sc (path (0), false);
+ _subtitle_language = sc.language ();
_length = DCPTime::from_seconds (sc.latest_subtitle_out().to_seconds ());
}
diff --git a/src/lib/player.cc b/src/lib/player.cc
index fabb5b211..396dc9906 100644
--- a/src/lib/player.cc
+++ b/src/lib/player.cc
@@ -50,6 +50,8 @@
#include <stdint.h>
#include <algorithm>
+#include "i18n.h"
+
#define LOG_GENERAL(...) _film->log()->log (String::compose (__VA_ARGS__), Log::TYPE_GENERAL);
using std::list;
@@ -549,6 +551,12 @@ Player::get_subtitles (DCPTime time, DCPTime length, bool starting)
continue;
}
+ /* XXX: this will break down if we have multiple subtitle content */
+ ps.language = subtitle_content->subtitle_language();
+ if (ps.language.empty ()) {
+ ps.language = _("Unknown");
+ }
+
shared_ptr<SubtitleDecoder> subtitle_decoder = dynamic_pointer_cast<SubtitleDecoder> ((*j)->decoder);
ContentTime const from = dcp_to_content_subtitle (*j, time);
/* XXX: this video_frame_rate() should be the rate that the subtitle content has been prepared for */
diff --git a/src/lib/player_subtitles.h b/src/lib/player_subtitles.h
index d0a3b4f65..804c87cb9 100644
--- a/src/lib/player_subtitles.h
+++ b/src/lib/player_subtitles.h
@@ -36,7 +36,9 @@ public:
/** ImageSubtitles, with their rectangles transformed as specified by their content */
std::list<ImageSubtitle> image;
- std::list<dcp::SubtitleString> text;
+ std::list<dcp::SubtitleString> text;
+
+ std::string language;
};
#endif
diff --git a/src/lib/subtitle_content.cc b/src/lib/subtitle_content.cc
index 5b370847b..df90a4a1a 100644
--- a/src/lib/subtitle_content.cc
+++ b/src/lib/subtitle_content.cc
@@ -38,6 +38,7 @@ int const SubtitleContentProperty::SUBTITLE_Y_OFFSET = 501;
int const SubtitleContentProperty::SUBTITLE_X_SCALE = 502;
int const SubtitleContentProperty::SUBTITLE_Y_SCALE = 503;
int const SubtitleContentProperty::USE_SUBTITLES = 504;
+int const SubtitleContentProperty::SUBTITLE_LANGUAGE = 505;
SubtitleContent::SubtitleContent (shared_ptr<const Film> f)
: Content (f)
@@ -88,6 +89,8 @@ SubtitleContent::SubtitleContent (shared_ptr<const Film> f, cxml::ConstNodePtr n
} else {
_subtitle_x_scale = _subtitle_y_scale = node->number_child<float> ("SubtitleScale");
}
+
+ _subtitle_language = node->optional_string_child ("SubtitleLanguage").get_value_or ("");
}
SubtitleContent::SubtitleContent (shared_ptr<const Film> f, vector<shared_ptr<Content> > c)
@@ -125,6 +128,7 @@ SubtitleContent::SubtitleContent (shared_ptr<const Film> f, vector<shared_ptr<Co
_subtitle_y_offset = ref->subtitle_y_offset ();
_subtitle_x_scale = ref->subtitle_x_scale ();
_subtitle_y_scale = ref->subtitle_y_scale ();
+ _subtitle_language = ref->subtitle_language ();
}
void
@@ -135,6 +139,7 @@ SubtitleContent::as_xml (xmlpp::Node* root) const
root->add_child("SubtitleYOffset")->add_child_text (raw_convert<string> (_subtitle_y_offset));
root->add_child("SubtitleXScale")->add_child_text (raw_convert<string> (_subtitle_x_scale));
root->add_child("SubtitleYScale")->add_child_text (raw_convert<string> (_subtitle_y_scale));
+ root->add_child("SubtitleLanguage")->add_child_text (_subtitle_language);
}
void
@@ -187,6 +192,16 @@ SubtitleContent::set_subtitle_y_scale (double s)
signal_changed (SubtitleContentProperty::SUBTITLE_Y_SCALE);
}
+void
+SubtitleContent::set_subtitle_language (string language)
+{
+ {
+ boost::mutex::scoped_lock lm (_mutex);
+ _subtitle_language = language;
+ }
+ signal_changed (SubtitleContentProperty::SUBTITLE_LANGUAGE);
+}
+
string
SubtitleContent::identifier () const
{
@@ -197,5 +212,9 @@ SubtitleContent::identifier () const
<< "_" << raw_convert<string> (subtitle_x_offset())
<< "_" << raw_convert<string> (subtitle_y_offset());
+ /* The language is for metadata only, and doesn't affect
+ how this content looks.
+ */
+
return s.str ();
}
diff --git a/src/lib/subtitle_content.h b/src/lib/subtitle_content.h
index c3c25232f..4cbef657a 100644
--- a/src/lib/subtitle_content.h
+++ b/src/lib/subtitle_content.h
@@ -1,5 +1,5 @@
/*
- Copyright (C) 2013 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2013-2014 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
@@ -30,6 +30,7 @@ public:
static int const SUBTITLE_X_SCALE;
static int const SUBTITLE_Y_SCALE;
static int const USE_SUBTITLES;
+ static int const SUBTITLE_LANGUAGE;
};
/** @class SubtitleContent
@@ -56,6 +57,7 @@ public:
void set_subtitle_y_offset (double);
void set_subtitle_x_scale (double);
void set_subtitle_y_scale (double);
+ void set_subtitle_language (std::string language);
bool use_subtitles () const {
boost::mutex::scoped_lock lm (_mutex);
@@ -82,6 +84,14 @@ public:
return _subtitle_y_scale;
}
+ std::string subtitle_language () const {
+ return _subtitle_language;
+ }
+
+protected:
+ /** subtitle language (e.g. "German") or empty if it is not known */
+ std::string _subtitle_language;
+
private:
friend struct ffmpeg_pts_offset_test;
diff --git a/src/lib/writer.cc b/src/lib/writer.cc
index 11a4f9d03..eca0b134a 100644
--- a/src/lib/writer.cc
+++ b/src/lib/writer.cc
@@ -615,9 +615,7 @@ Writer::write (PlayerSubtitles subs)
}
if (!_subtitle_content) {
- _subtitle_content.reset (
- new dcp::SubtitleContent (_film->name(), _film->isdcf_metadata().subtitle_language)
- );
+ _subtitle_content.reset (new dcp::SubtitleContent (_film->name(), subs.language));
}
for (list<dcp::SubtitleString>::const_iterator i = subs.text.begin(); i != subs.text.end(); ++i) {
diff --git a/src/lib/writer.h b/src/lib/writer.h
index f8aeb8c83..5efb14e50 100644
--- a/src/lib/writer.h
+++ b/src/lib/writer.h
@@ -94,7 +94,7 @@ public:
void write (boost::shared_ptr<const EncodedData>, int, Eyes);
void fake_write (int, Eyes);
void write (boost::shared_ptr<const AudioBuffers>);
- void write (PlayerSubtitles);
+ void write (PlayerSubtitles subs);
void repeat (int f, Eyes);
void finish ();