Separate CPL choice for KDMs into a separate class.
authorCarl Hetherington <cth@carlh.net>
Thu, 19 Nov 2015 15:31:10 +0000 (15:31 +0000)
committerCarl Hetherington <cth@carlh.net>
Thu, 19 Nov 2015 15:59:01 +0000 (15:59 +0000)
src/wx/kdm_cpl_panel.cc [new file with mode: 0644]
src/wx/kdm_cpl_panel.h [new file with mode: 0644]
src/wx/kdm_dialog.cc
src/wx/kdm_dialog.h
src/wx/wscript

diff --git a/src/wx/kdm_cpl_panel.cc b/src/wx/kdm_cpl_panel.cc
new file mode 100644 (file)
index 0000000..96b9aa6
--- /dev/null
@@ -0,0 +1,140 @@
+/*
+    Copyright (C) 2015 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
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    This program 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 this program; if not, write to the Free Software
+    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+#include "kdm_cpl_panel.h"
+#include "wx_util.h"
+#include <libcxml/cxml.h>
+
+using std::vector;
+
+KDMCPLPanel::KDMCPLPanel (wxWindow* parent, vector<CPLSummary> cpls)
+       : wxPanel (parent, wxID_ANY)
+       , _cpls (cpls)
+{
+       wxBoxSizer* vertical = new wxBoxSizer (wxVERTICAL);
+
+       /* CPL choice */
+       wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL);
+       add_label_to_sizer (s, this, _("CPL"), true);
+       _cpl = new wxChoice (this, wxID_ANY);
+       s->Add (_cpl, 1, wxEXPAND);
+       _cpl_browse = new wxButton (this, wxID_ANY, _("Browse..."));
+       s->Add (_cpl_browse, 0);
+       vertical->Add (s, 0, wxEXPAND | wxTOP, DCPOMATIC_SIZER_GAP + 2);
+
+       /* CPL details */
+       wxFlexGridSizer* table = new wxFlexGridSizer (2, DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP);
+       add_label_to_sizer (table, this, _("DCP directory"), true);
+       _dcp_directory = new wxStaticText (this, wxID_ANY, "");
+       table->Add (_dcp_directory);
+       add_label_to_sizer (table, this, _("CPL ID"), true);
+       _cpl_id = new wxStaticText (this, wxID_ANY, "");
+       table->Add (_cpl_id);
+       add_label_to_sizer (table, this, _("CPL annotation text"), true);
+       _cpl_annotation_text = new wxStaticText (this, wxID_ANY, "");
+       table->Add (_cpl_annotation_text);
+       vertical->Add (table, 0, wxEXPAND | wxTOP, DCPOMATIC_SIZER_GAP + 2);
+
+       update_cpl_choice ();
+
+       _cpl->Bind        (wxEVT_COMMAND_CHOICE_SELECTED, boost::bind (&KDMCPLPanel::update_cpl_summary, this));
+       _cpl_browse->Bind (wxEVT_COMMAND_BUTTON_CLICKED,  boost::bind (&KDMCPLPanel::cpl_browse_clicked, this));
+
+       SetSizerAndFit (vertical);
+}
+
+void
+KDMCPLPanel::update_cpl_choice ()
+{
+       _cpl->Clear ();
+
+       for (vector<CPLSummary>::const_iterator i = _cpls.begin(); i != _cpls.end(); ++i) {
+               _cpl->Append (std_to_wx (i->cpl_id));
+
+               if (_cpls.size() > 0) {
+                       _cpl->SetSelection (0);
+               }
+       }
+
+       update_cpl_summary ();
+}
+
+void
+KDMCPLPanel::update_cpl_summary ()
+{
+       int const n = _cpl->GetSelection();
+       if (n == wxNOT_FOUND) {
+               return;
+       }
+
+       _dcp_directory->SetLabel (std_to_wx (_cpls[n].dcp_directory));
+       _cpl_id->SetLabel (std_to_wx (_cpls[n].cpl_id));
+       _cpl_annotation_text->SetLabel (std_to_wx (_cpls[n].cpl_annotation_text));
+}
+
+void
+KDMCPLPanel::cpl_browse_clicked ()
+{
+       wxFileDialog* d = new wxFileDialog (this, _("Select CPL XML file"), wxEmptyString, wxEmptyString, "*.xml");
+       if (d->ShowModal() == wxID_CANCEL) {
+               d->Destroy ();
+               return;
+       }
+
+       boost::filesystem::path cpl_file (wx_to_std (d->GetPath ()));
+       boost::filesystem::path dcp_dir = cpl_file.parent_path ();
+
+       d->Destroy ();
+
+       /* XXX: hack alert */
+       cxml::Document cpl_document ("CompositionPlaylist");
+       cpl_document.read_file (cpl_file);
+
+       try {
+               _cpls.push_back (
+                       CPLSummary (
+                               dcp_dir.filename().string(),
+                               cpl_document.string_child("Id").substr (9),
+                               cpl_document.string_child ("ContentTitleText"),
+                               cpl_file
+                               )
+                       );
+       } catch (cxml::Error) {
+               error_dialog (this, _("This is not a valid CPL file"));
+               return;
+       }
+
+       update_cpl_choice ();
+       _cpl->SetSelection (_cpls.size() - 1);
+       update_cpl_summary ();
+}
+
+boost::filesystem::path
+KDMCPLPanel::cpl () const
+{
+       int const item = _cpl->GetSelection ();
+       DCPOMATIC_ASSERT (item >= 0);
+       return _cpls[item].cpl_file;
+}
+
+bool
+KDMCPLPanel::has_selected () const
+{
+       return _cpl->GetSelection() != -1;
+}
diff --git a/src/wx/kdm_cpl_panel.h b/src/wx/kdm_cpl_panel.h
new file mode 100644 (file)
index 0000000..5f4e638
--- /dev/null
@@ -0,0 +1,44 @@
+/*
+    Copyright (C) 2015 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
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    This program 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 this program; if not, write to the Free Software
+    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+#include "lib/types.h"
+#include <boost/filesystem.hpp>
+#include <wx/wx.h>
+
+class KDMCPLPanel : public wxPanel
+{
+public:
+       KDMCPLPanel (wxWindow* parent, std::vector<CPLSummary> cpls);
+
+       boost::filesystem::path cpl () const;
+       bool has_selected () const;
+
+private:
+       void update_cpl_choice ();
+       void update_cpl_summary ();
+       void cpl_browse_clicked ();
+
+       wxChoice* _cpl;
+       wxButton* _cpl_browse;
+       wxStaticText* _dcp_directory;
+       wxStaticText* _cpl_id;
+       wxStaticText* _cpl_annotation_text;
+
+       std::vector<CPLSummary> _cpls;
+};
index 50c3b6848929487637f00b9398c7b86e4ab8b4ad..a996463c54a6114d5e1c5fb6fa368368b3157a11 100644 (file)
@@ -24,6 +24,7 @@
 #include "screens_panel.h"
 #include "kdm_timing_panel.h"
 #include "kdm_output_panel.h"
+#include "kdm_cpl_panel.h"
 #include "lib/cinema.h"
 #include "lib/config.h"
 #include "lib/film.h"
@@ -70,31 +71,8 @@ KDMDialog::KDMDialog (wxWindow* parent, boost::shared_ptr<const Film> film)
        h = new wxStaticText (this, wxID_ANY, _("CPL"));
        h->SetFont (subheading_font);
        vertical->Add (h, 0, wxALIGN_CENTER_VERTICAL | wxTOP, DCPOMATIC_SIZER_Y_GAP * 2);
-
-       /* CPL choice */
-       wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL);
-       add_label_to_sizer (s, this, _("CPL"), true);
-       _cpl = new wxChoice (this, wxID_ANY);
-       s->Add (_cpl, 1, wxEXPAND);
-       _cpl_browse = new wxButton (this, wxID_ANY, _("Browse..."));
-       s->Add (_cpl_browse, 0);
-       vertical->Add (s, 0, wxEXPAND | wxTOP, DCPOMATIC_SIZER_GAP + 2);
-
-       /* CPL details */
-       wxFlexGridSizer* table = new wxFlexGridSizer (2, DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP);
-       add_label_to_sizer (table, this, _("DCP directory"), true);
-       _dcp_directory = new wxStaticText (this, wxID_ANY, "");
-       table->Add (_dcp_directory);
-       add_label_to_sizer (table, this, _("CPL ID"), true);
-       _cpl_id = new wxStaticText (this, wxID_ANY, "");
-       table->Add (_cpl_id);
-       add_label_to_sizer (table, this, _("CPL annotation text"), true);
-       _cpl_annotation_text = new wxStaticText (this, wxID_ANY, "");
-       table->Add (_cpl_annotation_text);
-       vertical->Add (table, 0, wxEXPAND | wxTOP, DCPOMATIC_SIZER_GAP + 2);
-
-       _cpls = film->cpls ();
-       update_cpl_choice ();
+       _cpl = new KDMCPLPanel (this, film->cpls ());
+       vertical->Add (_cpl);
 
        /* Sub-heading: Output */
        h = new wxStaticText (this, wxID_ANY, _("Output"));
@@ -117,9 +95,6 @@ KDMDialog::KDMDialog (wxWindow* parent, boost::shared_ptr<const Film> film)
 
        _screens->ScreensChanged.connect (boost::bind (&KDMDialog::setup_sensitivity, this));
 
-       _cpl->Bind           (wxEVT_COMMAND_CHOICE_SELECTED, boost::bind (&KDMDialog::update_cpl_summary, this));
-       _cpl_browse->Bind    (wxEVT_COMMAND_BUTTON_CLICKED,  boost::bind (&KDMDialog::cpl_browse_clicked, this));
-
        setup_sensitivity ();
 
        SetSizer (overall_sizer);
@@ -133,7 +108,7 @@ KDMDialog::setup_sensitivity ()
        _screens->setup_sensitivity ();
        _output->setup_sensitivity ();
 
-       bool const sd = _cpl->GetSelection() != -1;
+       bool const sd = _cpl->has_selected ();
 
        wxButton* ok = dynamic_cast<wxButton *> (FindWindowById (wxID_OK, this));
        if (ok) {
@@ -144,75 +119,7 @@ KDMDialog::setup_sensitivity ()
 boost::filesystem::path
 KDMDialog::cpl () const
 {
-       int const item = _cpl->GetSelection ();
-       DCPOMATIC_ASSERT (item >= 0);
-       return _cpls[item].cpl_file;
-}
-
-void
-KDMDialog::update_cpl_choice ()
-{
-       _cpl->Clear ();
-
-       for (vector<CPLSummary>::const_iterator i = _cpls.begin(); i != _cpls.end(); ++i) {
-               _cpl->Append (std_to_wx (i->cpl_id));
-
-               if (_cpls.size() > 0) {
-                       _cpl->SetSelection (0);
-               }
-       }
-
-       update_cpl_summary ();
-}
-
-void
-KDMDialog::update_cpl_summary ()
-{
-       int const n = _cpl->GetSelection();
-       if (n == wxNOT_FOUND) {
-               return;
-       }
-
-       _dcp_directory->SetLabel (std_to_wx (_cpls[n].dcp_directory));
-       _cpl_id->SetLabel (std_to_wx (_cpls[n].cpl_id));
-       _cpl_annotation_text->SetLabel (std_to_wx (_cpls[n].cpl_annotation_text));
-}
-
-void
-KDMDialog::cpl_browse_clicked ()
-{
-       wxFileDialog* d = new wxFileDialog (this, _("Select CPL XML file"), wxEmptyString, wxEmptyString, "*.xml");
-       if (d->ShowModal() == wxID_CANCEL) {
-               d->Destroy ();
-               return;
-       }
-
-       boost::filesystem::path cpl_file (wx_to_std (d->GetPath ()));
-       boost::filesystem::path dcp_dir = cpl_file.parent_path ();
-
-       d->Destroy ();
-
-       /* XXX: hack alert */
-       cxml::Document cpl_document ("CompositionPlaylist");
-       cpl_document.read_file (cpl_file);
-
-       try {
-               _cpls.push_back (
-                       CPLSummary (
-                               dcp_dir.filename().string(),
-                               cpl_document.string_child("Id").substr (9),
-                               cpl_document.string_child ("ContentTitleText"),
-                               cpl_file
-                               )
-                       );
-       } catch (cxml::Error) {
-               error_dialog (this, _("This is not a valid CPL file"));
-               return;
-       }
-
-       update_cpl_choice ();
-       _cpl->SetSelection (_cpls.size() - 1);
-       update_cpl_summary ();
+       return _cpl->cpl ();
 }
 
 list<shared_ptr<Screen> >
index a9edd121a5a41b5161ad2b2da1446199af81c4c2..3ec21b41dd5b824dcbdf0ed5a849609b6fffff93 100644 (file)
@@ -30,6 +30,7 @@ class Film;
 class ScreensPanel;
 class KDMTimingPanel;
 class KDMOutputPanel;
+class KDMCPLPanel;
 struct CPLSummary;
 
 class KDMDialog : public wxDialog
@@ -51,18 +52,9 @@ public:
 
 private:
        void setup_sensitivity ();
-       void update_cpl_choice ();
-       void update_cpl_summary ();
-       void cpl_browse_clicked ();
 
        ScreensPanel* _screens;
        KDMTimingPanel* _timing;
+       KDMCPLPanel* _cpl;
        KDMOutputPanel* _output;
-       wxChoice* _cpl;
-       wxButton* _cpl_browse;
-       wxStaticText* _dcp_directory;
-       wxStaticText* _cpl_id;
-       wxStaticText* _cpl_annotation_text;
-
-       std::vector<CPLSummary> _cpls;
 };
index 7b106c6b0ec9c70feb2956cf869da2f89f9e9729..77fddc09579797fa96781cb98ddd9a217ae9eb85 100644 (file)
@@ -59,6 +59,7 @@ sources = """
           job_view.cc
           job_view_dialog.cc
           job_manager_view.cc
+          kdm_cpl_panel.cc
           kdm_dialog.cc
           kdm_output_panel.cc
           kdm_timing_panel.cc