summaryrefslogtreecommitdiff
path: root/src/lib/dcp_examiner.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2021-04-09 00:03:35 +0200
committerCarl Hetherington <cth@carlh.net>2021-04-09 00:03:35 +0200
commit4e9a15d558ecca660eb74f54b693d1e4a3aa7381 (patch)
tree45dd4160839ca9b40b866b5908736b7b7448c690 /src/lib/dcp_examiner.cc
parent37a6d1a768debea28c24174503d85903f7f90aa5 (diff)
Extract audio/subtitle language from imported DCPs.
Diffstat (limited to 'src/lib/dcp_examiner.cc')
-rw-r--r--src/lib/dcp_examiner.cc16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/lib/dcp_examiner.cc b/src/lib/dcp_examiner.cc
index ca851db2d..a0bc487d9 100644
--- a/src/lib/dcp_examiner.cc
+++ b/src/lib/dcp_examiner.cc
@@ -53,7 +53,10 @@ using std::cout;
using std::runtime_error;
using std::map;
using std::shared_ptr;
+using std::string;
using std::dynamic_pointer_cast;
+using boost::optional;
+
DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
: DCP (content, tolerant)
@@ -108,6 +111,15 @@ DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
_name = cpl->content_title_text ();
_content_kind = cpl->content_kind ();
+ auto try_to_parse_language = [](optional<string> lang) -> boost::optional<dcp::LanguageTag> {
+ try {
+ if (lang) {
+ return dcp::LanguageTag (*lang);
+ }
+ } catch (...) {}
+ return boost::none;
+ };
+
for (auto i: cpl->reels()) {
if (i->main_picture ()) {
@@ -159,6 +171,7 @@ DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
}
_audio_length += i->main_sound()->actual_duration();
+ _audio_language = try_to_parse_language (asset->language());
}
if (i->main_subtitle ()) {
@@ -169,6 +182,7 @@ DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
}
_text_count[static_cast<int>(TextType::OPEN_SUBTITLE)] = 1;
+ _open_subtitle_language = try_to_parse_language (i->main_subtitle()->language());
}
for (auto j: i->closed_captions()) {
@@ -183,7 +197,7 @@ DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
}
if (i->main_markers ()) {
- map<dcp::Marker, dcp::Time> rm = i->main_markers()->get();
+ auto rm = i->main_markers()->get();
_markers.insert (rm.begin(), rm.end());
}