Emit no audio from DCPs if none is mapped
[dcpomatic.git] / src / wx / player_information.cc
index 9a569c00cc127226dd0d3c6c3db76cef9df1d812..057d26740498becf89fa3b4fcc814648a8bd9f19 100644 (file)
@@ -18,6 +18,7 @@
 
 */
 
+
 #include "player_information.h"
 #include "wx_util.h"
 #include "film_viewer.h"
 #include "lib/dcp_content.h"
 #include "lib/film.h"
 
+
 using std::cout;
+using std::dynamic_pointer_cast;
+using std::shared_ptr;
 using std::string;
-using boost::shared_ptr;
-using boost::weak_ptr;
-using boost::dynamic_pointer_cast;
+using std::weak_ptr;
 using boost::optional;
 
+
 /* This should be even */
 static int const dcp_lines = 6;
 
-PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr<FilmViewer> viewer)
+
+PlayerInformation::PlayerInformation(wxWindow* parent, FilmViewer const& viewer)
        : wxPanel (parent)
        , _viewer (viewer)
        , _sizer (new wxBoxSizer (wxHORIZONTAL))
@@ -51,7 +55,7 @@ PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr<FilmViewer> vie
        DCPOMATIC_ASSERT ((dcp_lines % 2) == 0);
 
        {
-               wxSizer* s = new wxBoxSizer (wxVERTICAL);
+               auto s = new wxBoxSizer (wxVERTICAL);
                add_label_to_sizer(s, this, _("DCP"), false, 0)->SetFont(title_font);
                for (int i = 0; i < dcp_lines / 2; ++i) {
                        _dcp[i] = add_label_to_sizer(s, this, wxT(""), false, 0);
@@ -60,7 +64,7 @@ PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr<FilmViewer> vie
        }
 
        {
-               wxSizer* s = new wxBoxSizer (wxVERTICAL);
+               auto s = new wxBoxSizer (wxVERTICAL);
                add_label_to_sizer(s, this, wxT(" "), false, 0);
                for (int i = dcp_lines / 2; i < dcp_lines; ++i) {
                        _dcp[i] = add_label_to_sizer(s, this, wxT(""), false, 0);
@@ -69,7 +73,21 @@ PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr<FilmViewer> vie
        }
 
        {
-               wxSizer* s = new wxBoxSizer (wxVERTICAL);
+               _kdm_panel = new wxPanel(this, wxID_ANY);
+               auto s = new wxBoxSizer(wxVERTICAL);
+               add_label_to_sizer(s, _kdm_panel, _("KDM"), false, 0)->SetFont(title_font);
+               auto g = new wxGridBagSizer(0, DCPOMATIC_SIZER_GAP);
+               add_label_to_sizer(g, _kdm_panel, _("Valid from"), true, wxGBPosition(0, 0));
+               _kdm_from = add_label_to_sizer(g, _kdm_panel, wxT(""), false, wxGBPosition(0, 1));
+               add_label_to_sizer(g, _kdm_panel, _("Valid to"), true, wxGBPosition(1, 0));
+               _kdm_to = add_label_to_sizer(g, _kdm_panel, wxT(""), false, wxGBPosition(1, 1));
+               s->Add(g, 1, wxEXPAND | wxLEFT, DCPOMATIC_SIZER_GAP);
+               _kdm_panel->SetSizer(s);
+               _sizer->Add(_kdm_panel, 1, wxEXPAND | wxALL, 6);
+       }
+
+       {
+               auto s = new wxBoxSizer (wxVERTICAL);
                add_label_to_sizer(s, this, _("Performance"), false, 0)->SetFont(title_font);
                _dropped = add_label_to_sizer(s, this, wxT(""), false, 0);
                _decode_resolution = add_label_to_sizer(s, this, wxT(""), false, 0);
@@ -85,32 +103,26 @@ PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr<FilmViewer> vie
        _timer->Start (500);
 }
 
+
 void
 PlayerInformation::periodic_update ()
 {
-       shared_ptr<FilmViewer> fv = _viewer.lock ();
-       if (fv) {
-               wxString s = wxString::Format(_("Dropped frames: %d"), fv->dropped() + fv->errored());
-               if (fv->errored() == 1) {
-                       s += wxString::Format(_(" (%d error)"), fv->errored());
-               } else if (fv->errored() > 1) {
-                       s += wxString::Format(_(" (%d errors)"), fv->errored());
-               }
-               checked_set (_dropped, s);
+       auto s = wxString::Format(_("Dropped frames: %d"), _viewer.dropped() + _viewer.errored());
+       if (_viewer.errored() == 1) {
+               s += wxString::Format(_(" (%d error)"), _viewer.errored());
+       } else if (_viewer.errored() > 1) {
+               s += wxString::Format(_(" (%d errors)"), _viewer.errored());
        }
+       checked_set (_dropped, s);
 }
 
+
 void
 PlayerInformation::triggered_update ()
 {
-       shared_ptr<FilmViewer> fv = _viewer.lock ();
-       if (!fv) {
-               return;
-       }
-
        shared_ptr<DCPContent> dcp;
-       if (fv->film()) {
-               ContentList content = fv->film()->content();
+       if (_viewer.film()) {
+               auto content = _viewer.film()->content();
                if (content.size() == 1) {
                        dcp = dynamic_pointer_cast<DCPContent>(content.front());
                }
@@ -122,11 +134,20 @@ PlayerInformation::triggered_update ()
                        checked_set (_dcp[r], wxT(""));
                }
                checked_set (_decode_resolution, wxT(""));
+               _kdm_panel->Hide();
                return;
        }
 
        int r = 0;
-       checked_set (_dcp[r++], std_to_wx(dcp->name()));
+       checked_set(_dcp[r], std_to_wx(dcp->name()));
+       wxString tooltip;
+       for (auto directory: dcp->directories()) {
+               tooltip += std_to_wx(directory.string()) + "\n";
+       }
+       if (!tooltip.empty()) {
+               _dcp[r]->SetToolTip(tooltip.substr(0, tooltip.length() - 1));
+       }
+       ++r;
 
        if (dcp->needs_assets()) {
                checked_set (_dcp[r], _("Needs OV"));
@@ -140,12 +161,18 @@ PlayerInformation::triggered_update ()
 
        DCPOMATIC_ASSERT (dcp->video);
 
-       checked_set (_dcp[r++], wxString::Format(_("Size: %dx%d"), dcp->video->size().width, dcp->video->size().height));
+       auto const size = dcp->video->size();
+
+       if (size) {
+               checked_set(_dcp[r++], wxString::Format(_("Size: %dx%d"), size->width, size->height));
+       } else {
+               checked_set(_dcp[r++], _("Size: unknown"));
+       }
        if (dcp->video_frame_rate()) {
                checked_set (_dcp[r++], wxString::Format(_("Frame rate: %d"), (int) lrint(*dcp->video_frame_rate())));
        }
        if (dcp->audio && !dcp->audio->streams().empty()) {
-               checked_set (_dcp[r++], wxString::Format(_("Audio channels: %d"), dcp->audio->streams().front()->channels()));
+               checked_set(_dcp[r++], wxString::Format(_("Audio channels: %d"), dcp->active_audio_channels()));
        }
        if (!dcp->text.empty()) {
                checked_set (_dcp[r++], _("Subtitles: yes"));
@@ -157,24 +184,39 @@ PlayerInformation::triggered_update ()
        vfr = dcp->video_frame_rate ();
        DCPOMATIC_ASSERT (vfr);
 
-       string const len = String::compose(
+       auto const len = String::compose(
                wx_to_std(_("Length: %1 (%2 frames)")),
-               time_to_hmsf(dcp->full_length(fv->film()), lrint(*vfr)),
-               dcp->full_length(fv->film()).frames_round(*vfr)
+               time_to_hmsf(dcp->full_length(_viewer.film()), lrint(*vfr)),
+               dcp->full_length(_viewer.film()).frames_round(*vfr)
                );
 
        checked_set (_dcp[r++], std_to_wx(len));
 
-       dcp::Size decode = dcp->video->size();
-       optional<int> reduction = fv->dcp_decode_reduction();
-       if (reduction) {
-               decode.width /= pow(2, *reduction);
-               decode.height /= pow(2, *reduction);
+       auto decode = size;
+       auto reduction = _viewer.dcp_decode_reduction();
+       if (reduction && decode) {
+               decode->width /= pow(2, *reduction);
+               decode->height /= pow(2, *reduction);
        }
 
-       checked_set (_decode_resolution, wxString::Format(_("Decode resolution: %dx%d"), decode.width, decode.height));
+       if (decode) {
+               checked_set(_decode_resolution, wxString::Format(_("Decode resolution: %dx%d"), decode->width, decode->height));
+       } else {
+               checked_set(_decode_resolution, _("Decode resolution: unknown"));
+       }
 
        DCPOMATIC_ASSERT(r <= dcp_lines);
 
+       if (dcp->encrypted() && dcp->kdm()) {
+               _kdm_panel->Show();
+               auto const kdm = *dcp->kdm();
+               auto const before = kdm.not_valid_before();
+               checked_set(_kdm_from, wxString::Format(_("%s %s"), std_to_wx(before.date()), std_to_wx(before.time_of_day(true, false))));
+               auto const after = kdm.not_valid_after();
+               checked_set(_kdm_to, wxString::Format(_("%s %s"), std_to_wx(after.date()), std_to_wx(after.time_of_day(true, false))));
+       } else {
+               _kdm_panel->Hide();
+       }
+
        _sizer->Layout ();
 }