summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2020-11-20 00:53:20 +0100
committerCarl Hetherington <cth@carlh.net>2020-11-20 23:47:03 +0100
commit4347d97b703cfddcd322051092ccfcd5b5a6b941 (patch)
tree30ee949b1cbf6cf6300c736c4e6663ffbe832616
parentbea1b9f9c77c721afd15bab392a86343f8d6b83a (diff)
Subtitle language handling tweaks; write multiple subtitle languages
to SMPTE extended metadata.
-rw-r--r--cscript4
-rw-r--r--src/lib/reel_writer.cc10
-rw-r--r--src/lib/subtitle_encoder.cc4
-rw-r--r--src/lib/writer.cc5
m---------test/data0
-rw-r--r--test/subtitle_language_test.cc77
-rw-r--r--test/wscript1
7 files changed, 94 insertions, 7 deletions
diff --git a/cscript b/cscript
index 44051acc0..69d41b39b 100644
--- a/cscript
+++ b/cscript
@@ -373,8 +373,8 @@ def dependencies(target, options):
(target.platform == 'osx' and target.bits == 64) or
(target.platform == 'windows')) else {}
- deps.append(('libdcp', 'd989a83', cpp_lib_options))
- deps.append(('libsub', 'f17a4fd', cpp_lib_options))
+ deps.append(('libdcp', 'f614b45', cpp_lib_options))
+ deps.append(('libsub', '97e8588', cpp_lib_options))
deps.append(('leqm-nrt', 'carl'))
deps.append(('rtaudio', 'carl'))
# We get our OpenSSL libraries from the environment, but we
diff --git a/src/lib/reel_writer.cc b/src/lib/reel_writer.cc
index c4df58fe7..345bcdeb3 100644
--- a/src/lib/reel_writer.cc
+++ b/src/lib/reel_writer.cc
@@ -597,7 +597,11 @@ ReelWriter::create_reel (list<ReferencedReelAsset> const & refs, list<shared_ptr
}
reel->add (reel_sound_asset);
- maybe_add_text<dcp::ReelSubtitleAsset> (_subtitle_asset, reel_picture_asset->actual_duration(), reel, refs, fonts, _film, _period);
+ shared_ptr<dcp::ReelSubtitleAsset> subtitle = maybe_add_text<dcp::ReelSubtitleAsset> (_subtitle_asset, reel_picture_asset->actual_duration(), reel, refs, fonts, _film, _period);
+ if (subtitle && !_film->subtitle_languages().empty()) {
+ subtitle->set_language (_film->subtitle_languages().front());
+ }
+
for (map<DCPTextTrack, shared_ptr<dcp::SubtitleAsset> >::const_iterator i = _closed_caption_assets.begin(); i != _closed_caption_assets.end(); ++i) {
shared_ptr<dcp::ReelClosedCaptionAsset> a = maybe_add_text<dcp::ReelClosedCaptionAsset> (
i->second, reel_picture_asset->actual_duration(), reel, refs, fonts, _film, _period
@@ -703,9 +707,9 @@ ReelWriter::write (PlayerText subs, TextType type, optional<DCPTextTrack> track,
s->set_content_title_text (_film->name ());
s->set_metadata (mxf_metadata());
if (type == TEXT_OPEN_SUBTITLE && !lang.empty()) {
- s->set_language (lang.front().to_string());
+ s->set_language (lang.front());
} else {
- s->set_language (track->language);
+ s->set_language (dcp::LanguageTag(track->language));
}
s->set_edit_rate (dcp::Fraction (_film->video_frame_rate (), 1));
s->set_reel_number (_reel_index + 1);
diff --git a/src/lib/subtitle_encoder.cc b/src/lib/subtitle_encoder.cc
index 5e76f5e73..61c4dc3ae 100644
--- a/src/lib/subtitle_encoder.cc
+++ b/src/lib/subtitle_encoder.cc
@@ -141,9 +141,9 @@ SubtitleEncoder::text (PlayerText subs, TextType type, optional<DCPTextTrack> tr
shared_ptr<dcp::SMPTESubtitleAsset> s (new dcp::SMPTESubtitleAsset());
s->set_content_title_text (_film->name());
if (!lang.empty()) {
- s->set_language (lang.front().to_string());
+ s->set_language (lang.front());
} else {
- s->set_language (track->language);
+ s->set_language (dcp::LanguageTag(track->language));
}
s->set_edit_rate (dcp::Fraction (_film->video_frame_rate(), 1));
s->set_reel_number (_reel_index + 1);
diff --git a/src/lib/writer.cc b/src/lib/writer.cc
index 79e5ad73b..a9700f4f5 100644
--- a/src/lib/writer.cc
+++ b/src/lib/writer.cc
@@ -620,6 +620,11 @@ Writer::finish ()
cpl->set_main_picture_stored_area (_film->frame_size());
cpl->set_main_picture_active_area (_film->active_area());
+ vector<dcp::LanguageTag> sl = _film->subtitle_languages();
+ if (sl.size() > 1) {
+ cpl->set_additional_subtitle_languages(std::vector<dcp::LanguageTag>(sl.begin() + 1, sl.end()));
+ }
+
shared_ptr<const dcp::CertificateChain> signer;
signer = Config::instance()->signer_chain ();
/* We did check earlier, but check again here to be on the safe side */
diff --git a/test/data b/test/data
-Subproject eebc165cf7df4af980e918bc3176d93521f5bee
+Subproject fddd3fd75d21d858d203ea615387ba3b668c9ae
diff --git a/test/subtitle_language_test.cc b/test/subtitle_language_test.cc
new file mode 100644
index 000000000..50efb71a1
--- /dev/null
+++ b/test/subtitle_language_test.cc
@@ -0,0 +1,77 @@
+/*
+ Copyright (C) 2020 Carl Hetherington <cth@carlh.net>
+
+ This file is part of DCP-o-matic.
+
+ DCP-o-matic 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.
+
+ DCP-o-matic 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 DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
+
+*/
+
+/** @file test/subtitle_language_test.cc
+ * @brief Test that subtitle language information is correctly written to DCPs.
+ */
+
+
+#include "lib/content_factory.h"
+#include "lib/film.h"
+#include "test.h"
+#include <dcp/language_tag.h>
+#include <boost/test/unit_test.hpp>
+#include <vector>
+
+
+using std::string;
+using std::vector;
+using boost::shared_ptr;
+
+
+BOOST_AUTO_TEST_CASE (subtitle_language_interop_test)
+{
+ string const name = "subtitle_language_interop_test";
+ shared_ptr<Film> film = new_test_film2 (name);
+ film->examine_and_add_content (content_factory("test/data/frames.srt").front());
+ BOOST_REQUIRE (!wait_for_jobs());
+
+ vector<dcp::LanguageTag> langs;
+ langs.push_back(dcp::LanguageTag("fr-FR"));
+ langs.push_back(dcp::LanguageTag("de-DE"));
+ film->set_subtitle_languages(langs);
+ film->set_interop (true);
+
+ film->make_dcp ();
+ BOOST_REQUIRE (!wait_for_jobs());
+
+ check_dcp (String::compose("test/data/%1", name), String::compose("build/test/%1/%2", name, film->dcp_name()));
+}
+
+
+BOOST_AUTO_TEST_CASE (subtitle_language_smpte_test)
+{
+ string const name = "subtitle_language_smpte_test";
+ shared_ptr<Film> film = new_test_film2 (name);
+ film->examine_and_add_content (content_factory("test/data/frames.srt").front());
+ BOOST_REQUIRE (!wait_for_jobs());
+
+ vector<dcp::LanguageTag> langs;
+ langs.push_back(dcp::LanguageTag("fr-FR"));
+ langs.push_back(dcp::LanguageTag("de-DE"));
+ film->set_subtitle_languages(langs);
+ film->set_interop (false);
+
+ film->make_dcp ();
+ BOOST_REQUIRE (!wait_for_jobs());
+
+ check_dcp (String::compose("test/data/%1", name), String::compose("build/test/%1/%2", name, film->dcp_name()));
+}
+
diff --git a/test/wscript b/test/wscript
index 9a3347be3..c9e9f2188 100644
--- a/test/wscript
+++ b/test/wscript
@@ -118,6 +118,7 @@ def build(bld):
ssa_subtitle_test.cc
stream_test.cc
subtitle_charset_test.cc
+ subtitle_language_test.cc
subtitle_metadata_test.cc
subtitle_reel_test.cc
subtitle_reel_number_test.cc