Fix thinko in previous.
[dcpomatic.git] / src / tools / dcpomatic.cc
index 181ac83c46301d1346700c080ccd2a1e8d76e06a..193611f30e0a8de8bdba6729241e9edc243e91ce 100644 (file)
@@ -22,7 +22,7 @@
  *  @brief The main DCP-o-matic GUI.
  */
 
-#include "wx/controls.h"
+#include "wx/standard_controls.h"
 #include "wx/film_viewer.h"
 #include "wx/film_editor.h"
 #include "wx/job_manager_view.h"
 #include "wx/paste_dialog.h"
 #include "wx/focus_manager.h"
 #include "wx/initial_setup_dialog.h"
+#include "wx/send_i18n_dialog.h"
+#include "wx/i18n_hook.h"
 #include "lib/film.h"
+#include "lib/emailer.h"
 #include "lib/config.h"
 #include "lib/util.h"
 #include "lib/video_content.h"
@@ -55,6 +58,7 @@
 #include "lib/version.h"
 #include "lib/signal_manager.h"
 #include "lib/log.h"
+#include "lib/screen.h"
 #include "lib/job_manager.h"
 #include "lib/exceptions.h"
 #include "lib/cinema.h"
@@ -75,6 +79,7 @@
 #include "lib/audio_content.h"
 #include "lib/check_content_change_job.h"
 #include "lib/text_content.h"
+#include "lib/dcpomatic_log.h"
 #include <dcp/exceptions.h>
 #include <dcp/raw_convert.h>
 #include <wx/generic/aboutdlgg.h>
@@ -224,6 +229,7 @@ enum {
        ID_tools_encoding_servers,
        ID_tools_manage_templates,
        ID_tools_check_for_updates,
+       ID_tools_send_translations,
        ID_tools_restore_default_preferences,
        ID_help_report_a_problem,
        /* IDs for shortcuts (with no associated menu item) */
@@ -310,6 +316,7 @@ public:
                Bind (wxEVT_MENU, boost::bind (&DOMFrame::tools_encoding_servers, this),  ID_tools_encoding_servers);
                Bind (wxEVT_MENU, boost::bind (&DOMFrame::tools_manage_templates, this),  ID_tools_manage_templates);
                Bind (wxEVT_MENU, boost::bind (&DOMFrame::tools_check_for_updates, this), ID_tools_check_for_updates);
+               Bind (wxEVT_MENU, boost::bind (&DOMFrame::tools_send_translations, this), ID_tools_send_translations);
                Bind (wxEVT_MENU, boost::bind (&DOMFrame::tools_restore_default_preferences, this), ID_tools_restore_default_preferences);
                Bind (wxEVT_MENU, boost::bind (&DOMFrame::help_about, this),              wxID_ABOUT);
                Bind (wxEVT_MENU, boost::bind (&DOMFrame::help_report_a_problem, this),   ID_help_report_a_problem);
@@ -322,7 +329,7 @@ public:
                wxPanel* overall_panel = new wxPanel (this, wxID_ANY);
 
                _film_viewer.reset (new FilmViewer (overall_panel));
-               _controls = new Controls (overall_panel, _film_viewer);
+               _controls = new StandardControls (overall_panel, _film_viewer, true);
                _film_editor = new FilmEditor (overall_panel, _film_viewer);
                JobManagerView* job_manager_view = new JobManagerView (overall_panel, false);
 
@@ -401,6 +408,7 @@ public:
                film->set_name (path.filename().generic_string());
                film->write_metadata ();
                set_film (film);
+               dcpomatic_log = film->log ();
        }
 
        void load_film (boost::filesystem::path file)
@@ -436,6 +444,7 @@ public:
                _film = film;
                _film_viewer->set_film (_film);
                _film_editor->set_film (_film);
+               _controls->set_film (_film);
                if (_video_waveform_dialog) {
                        _video_waveform_dialog->Destroy ();
                        _video_waveform_dialog = 0;
@@ -480,7 +489,7 @@ private:
                                new_film (d->path(), d->template_name());
                        } catch (boost::filesystem::filesystem_error& e) {
 #ifdef DCPOMATIC_WINDOWS
-                               string bad_chars = "<>:\"/\\|?*";
+                               string bad_chars = "<>:\"/|?*";
                                string const filename = d->path().string();
                                string found_bad_chars;
                                for (size_t i = 0; i < bad_chars.length(); ++i) {
@@ -491,7 +500,7 @@ private:
                                wxString message = _("Could not create folder to store film.");
                                if (!found_bad_chars.empty()) {
                                        message += "  ";
-                                       message += wxString::Format (_("Try removing the %s characters from your folder name.", std_to_wx(found_bad_chars).data()));
+                                       message += wxString::Format (_("Try removing the %s characters from your folder name."), std_to_wx(found_bad_chars).data());
                                }
                                error_dialog (this, message, std_to_wx(e.what()));
 #else
@@ -823,7 +832,7 @@ private:
                try {
                        kdm = _film->make_kdm (
                                Config::instance()->decryption_chain()->leaf(),
-                               vector<dcp::Certificate> (),
+                               vector<string>(),
                                d->cpl (),
                                dcp::LocalTime ("2012-01-01T01:00:00+00:00"),
                                dcp::LocalTime ("2112-01-01T01:00:00+00:00"),
@@ -872,7 +881,7 @@ private:
        {
                ContentList vc = _film_editor->content_panel()->selected_video ();
                for (ContentList::iterator i = vc.begin(); i != vc.end(); ++i) {
-                       (*i)->video->scale_and_crop_to_fit_width ();
+                       (*i)->video->scale_and_crop_to_fit_width (_film);
                }
        }
 
@@ -880,7 +889,7 @@ private:
        {
                ContentList vc = _film_editor->content_panel()->selected_video ();
                for (ContentList::iterator i = vc.begin(); i != vc.end(); ++i) {
-                       (*i)->video->scale_and_crop_to_fit_height ();
+                       (*i)->video->scale_and_crop_to_fit_height (_film);
                }
        }
 
@@ -971,6 +980,26 @@ private:
                _update_news_requested = true;
        }
 
+       void tools_send_translations ()
+       {
+               SendI18NDialog* d = new SendI18NDialog (this);
+               if (d->ShowModal() == wxID_OK) {
+                       string body;
+                       body += d->name() + "\n";
+                       body += d->language() + "\n";
+                       map<string, string> translations = I18NHook::translations ();
+                       for (map<string, string>::const_iterator i = translations.begin(); i != translations.end(); ++i) {
+                               body += i->first + "\n" + i->second + "\n";
+                       }
+                       list<string> to;
+                       to.push_back ("carl@dcpomatic.com");
+                       Emailer emailer (d->email(), to, "DCP-o-matic translations", body);
+                       emailer.send ("main.carlh.net", 2525);
+               }
+
+               d->Destroy ();
+       }
+
        void help_about ()
        {
                AboutDialog* d = new AboutDialog (this);
@@ -1197,6 +1226,7 @@ private:
                add_item (tools, _("Encoding servers..."), ID_tools_encoding_servers, 0);
                add_item (tools, _("Manage templates..."), ID_tools_manage_templates, 0);
                add_item (tools, _("Check for updates"), ID_tools_check_for_updates, 0);
+               add_item (tools, _("Send translations..."), ID_tools_send_translations, 0);
                tools->AppendSeparator ();
                add_item (tools, _("Restore default preferences"), ID_tools_restore_default_preferences, ALWAYS);
 
@@ -1331,7 +1361,7 @@ private:
 
        FilmEditor* _film_editor;
        boost::shared_ptr<FilmViewer> _film_viewer;
-       Controls* _controls;
+       StandardControls* _controls;
        VideoWaveformDialog* _video_waveform_dialog;
        HintsDialog* _hints_dialog;
        ServersListDialog* _servers_list_dialog;
@@ -1370,107 +1400,112 @@ public:
 private:
 
        bool OnInit ()
-       try
        {
-               wxInitAllImageHandlers ();
+               wxSplashScreen* splash = 0;
+               try {
+                       wxInitAllImageHandlers ();
 
-               Config::FailedToLoad.connect (boost::bind (&App::config_failed_to_load, this));
-               Config::Warning.connect (boost::bind (&App::config_warning, this, _1));
+                       Config::FailedToLoad.connect (boost::bind (&App::config_failed_to_load, this));
+                       Config::Warning.connect (boost::bind (&App::config_warning, this, _1));
 
-               wxSplashScreen* splash = maybe_show_splash ();
+                       splash = maybe_show_splash ();
 
-               SetAppName (_("DCP-o-matic"));
+                       SetAppName (_("DCP-o-matic"));
 
-               if (!wxApp::OnInit()) {
-                       return false;
-               }
+                       if (!wxApp::OnInit()) {
+                               return false;
+                       }
 
 #ifdef DCPOMATIC_LINUX
-               unsetenv ("UBUNTU_MENUPROXY");
+                       unsetenv ("UBUNTU_MENUPROXY");
 #endif
 
 #ifdef __WXOSX__
-               ProcessSerialNumber serial;
-               GetCurrentProcess (&serial);
-               TransformProcessType (&serial, kProcessTransformToForegroundApplication);
+                       ProcessSerialNumber serial;
+                       GetCurrentProcess (&serial);
+                       TransformProcessType (&serial, kProcessTransformToForegroundApplication);
 #endif
 
-               dcpomatic_setup_path_encoding ();
+                       dcpomatic_setup_path_encoding ();
 
-               /* Enable i18n; this will create a Config object
-                  to look for a force-configured language.  This Config
-                  object will be wrong, however, because dcpomatic_setup
-                  hasn't yet been called and there aren't any filters etc.
-                  set up yet.
-               */
-               dcpomatic_setup_i18n ();
+                       /* Enable i18n; this will create a Config object
+                          to look for a force-configured language.  This Config
+                          object will be wrong, however, because dcpomatic_setup
+                          hasn't yet been called and there aren't any filters etc.
+                          set up yet.
+                       */
+                       dcpomatic_setup_i18n ();
 
-               /* Set things up, including filters etc.
-                  which will now be internationalised correctly.
-               */
-               dcpomatic_setup ();
+                       /* Set things up, including filters etc.
+                          which will now be internationalised correctly.
+                       */
+                       dcpomatic_setup ();
 
-               /* Force the configuration to be re-loaded correctly next
-                  time it is needed.
-               */
-               Config::drop ();
+                       /* Force the configuration to be re-loaded correctly next
+                          time it is needed.
+                       */
+                       Config::drop ();
 
-               Config::BadSignerChain.connect (boost::bind (&App::config_bad_signer_chain, this));
+                       Config::BadSignerChain.connect (boost::bind (&App::config_bad_signer_chain, this));
 
-               _frame = new DOMFrame (_("DCP-o-matic"));
-               SetTopWindow (_frame);
-               _frame->Maximize ();
-               if (splash) {
-                       splash->Destroy ();
-               }
+                       _frame = new DOMFrame (_("DCP-o-matic"));
+                       SetTopWindow (_frame);
+                       _frame->Maximize ();
+                       if (splash) {
+                               splash->Destroy ();
+                               splash = 0;
+                       }
 
-               if (!Config::instance()->nagged(Config::NAG_INITIAL_SETUP)) {
-                       InitialSetupDialog* d = new InitialSetupDialog ();
-                       d->ShowModal ();
-                       d->Destroy ();
-                       Config::instance()->set_nagged(Config::NAG_INITIAL_SETUP, true);
-               }
+                       if (!Config::instance()->nagged(Config::NAG_INITIAL_SETUP)) {
+                               InitialSetupDialog* d = new InitialSetupDialog ();
+                               d->ShowModal ();
+                               d->Destroy ();
+                               Config::instance()->set_nagged(Config::NAG_INITIAL_SETUP, true);
+                       }
 
-               _frame->Show ();
+                       _frame->Show ();
 
-               if (!_film_to_load.empty() && boost::filesystem::is_directory (_film_to_load)) {
-                       try {
-                               _frame->load_film (_film_to_load);
-                       } catch (exception& e) {
-                               error_dialog (0, std_to_wx (String::compose (wx_to_std (_("Could not load film %1 (%2)")), _film_to_load)), std_to_wx(e.what()));
+                       if (!_film_to_load.empty() && boost::filesystem::is_directory (_film_to_load)) {
+                               try {
+                                       _frame->load_film (_film_to_load);
+                               } catch (exception& e) {
+                                       error_dialog (0, std_to_wx (String::compose (wx_to_std (_("Could not load film %1 (%2)")), _film_to_load)), std_to_wx(e.what()));
+                               }
                        }
-               }
 
-               if (!_film_to_create.empty ()) {
-                       _frame->new_film (_film_to_create, optional<string> ());
-                       if (!_content_to_add.empty ()) {
-                               BOOST_FOREACH (shared_ptr<Content> i, content_factory (_frame->film(), _content_to_add)) {
-                                       _frame->film()->examine_and_add_content (i);
+                       if (!_film_to_create.empty ()) {
+                               _frame->new_film (_film_to_create, optional<string> ());
+                               if (!_content_to_add.empty ()) {
+                                       BOOST_FOREACH (shared_ptr<Content> i, content_factory(_content_to_add)) {
+                                               _frame->film()->examine_and_add_content (i);
+                                       }
+                               }
+                               if (!_dcp_to_add.empty ()) {
+                                       _frame->film()->examine_and_add_content(shared_ptr<DCPContent>(new DCPContent(_dcp_to_add)));
                                }
                        }
-                       if (!_dcp_to_add.empty ()) {
-                               _frame->film()->examine_and_add_content (shared_ptr<DCPContent> (new DCPContent (_frame->film(), _dcp_to_add)));
-                       }
-               }
 
-               signal_manager = new wxSignalManager (this);
-               Bind (wxEVT_IDLE, boost::bind (&App::idle, this));
+                       signal_manager = new wxSignalManager (this);
+                       Bind (wxEVT_IDLE, boost::bind (&App::idle, this));
 
-               Bind (wxEVT_TIMER, boost::bind (&App::check, this));
-               _timer.reset (new wxTimer (this));
-               _timer->Start (1000);
+                       Bind (wxEVT_TIMER, boost::bind (&App::check, this));
+                       _timer.reset (new wxTimer (this));
+                       _timer->Start (1000);
 
-               if (Config::instance()->check_for_updates ()) {
-                       UpdateChecker::instance()->run ();
+                       if (Config::instance()->check_for_updates ()) {
+                               UpdateChecker::instance()->run ();
+                       }
+               }
+               catch (exception& e)
+               {
+                       if (splash) {
+                               splash->Destroy ();
+                       }
+                       error_dialog (0, wxString::Format ("DCP-o-matic could not start."), std_to_wx(e.what()));
                }
 
                return true;
        }
-       catch (exception& e)
-       {
-               error_dialog (0, wxString::Format ("DCP-o-matic could not start."), std_to_wx(e.what()));
-               return true;
-       }
 
        void OnInitCmdLine (wxCmdLineParser& parser)
        {