diff options
| author | Carl Hetherington <cth@carlh.net> | 2014-12-11 16:47:48 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2014-12-11 16:47:48 +0000 |
| commit | 5d117c316fe68686885a931bf028cbd8afa5c0e1 (patch) | |
| tree | 90b2e60eb06137b35d9683b349ece51a765e6f3b /src | |
| parent | fe47588e80b35c07fc25b1d9e79bc13b6e439ff0 (diff) | |
| parent | 6bd8be029c72180a41d70e590bf2cb85a77317bf (diff) | |
Merge.
Diffstat (limited to 'src')
| -rw-r--r-- | src/lib/dcp_subtitle_content.cc | 1 | ||||
| -rw-r--r-- | src/lib/player.cc | 8 | ||||
| -rw-r--r-- | src/lib/player_subtitles.h | 4 | ||||
| -rw-r--r-- | src/lib/subtitle_content.cc | 6 | ||||
| -rw-r--r-- | src/lib/subtitle_content.h | 6 | ||||
| -rw-r--r-- | src/lib/writer.cc | 4 | ||||
| -rw-r--r-- | src/lib/writer.h | 2 | ||||
| -rw-r--r-- | src/wx/subtitle_panel.cc | 3 |
8 files changed, 27 insertions, 7 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 7792f3ef6..f10fa58b2 100644 --- a/src/lib/subtitle_content.cc +++ b/src/lib/subtitle_content.cc @@ -90,7 +90,7 @@ SubtitleContent::SubtitleContent (shared_ptr<const Film> f, cxml::ConstNodePtr n _subtitle_x_scale = _subtitle_y_scale = node->number_child<float> ("SubtitleScale"); } - _subtitle_language = node->optional_string_child ("SubtitleLanguage"); + _subtitle_language = node->optional_string_child ("SubtitleLanguage").get_value_or (""); } SubtitleContent::SubtitleContent (shared_ptr<const Film> f, vector<shared_ptr<Content> > c) @@ -139,9 +139,13 @@ 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)); +<<<<<<< HEAD if (_subtitle_language) { root->add_child("SubtitleLanguage")->add_child_text (_subtitle_language.get ()); } +======= + root->add_child("SubtitleLanguage")->add_child_text (_subtitle_language); +>>>>>>> 30a2bb95980d74a33baeb18d18f2e4ac72d66845 } void diff --git a/src/lib/subtitle_content.h b/src/lib/subtitle_content.h index 39a3f32eb..e74164f77 100644 --- a/src/lib/subtitle_content.h +++ b/src/lib/subtitle_content.h @@ -84,10 +84,14 @@ public: return _subtitle_y_scale; } - boost::optional<std::string> subtitle_language () const { + 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 (); diff --git a/src/wx/subtitle_panel.cc b/src/wx/subtitle_panel.cc index bc6c8b749..3198723a5 100644 --- a/src/wx/subtitle_panel.cc +++ b/src/wx/subtitle_panel.cc @@ -160,6 +160,8 @@ SubtitlePanel::film_content_changed (int property) checked_set (_x_scale, scs ? int (rint (scs->subtitle_x_scale() * 100)) : 100); } else if (property == SubtitleContentProperty::SUBTITLE_Y_SCALE) { checked_set (_y_scale, scs ? int (rint (scs->subtitle_y_scale() * 100)) : 100); + } else if (property == SubtitleContentProperty::SUBTITLE_LANGUAGE) { + checked_set (_language, scs ? scs->subtitle_language() : ""); } } @@ -203,6 +205,7 @@ SubtitlePanel::setup_sensitivity () _y_offset->Enable (any_subs > 0 && use); _x_scale->Enable (any_subs > 0 && use); _y_scale->Enable (any_subs > 0 && use); + _language->Enable (any_subs > 0 && use); _stream->Enable (ffmpeg_subs == 1); _view_button->Enable (subrip_or_dcp_subs == 1); } |
