Note that newer libsub version is required.
[dcpomatic.git] / src / wx / file_picker_ctrl.cc
index 47b5dbca06a7e8ade9bb710d7de8076a2312c508..7aa0bfb40cc9d9031a238c7e3f39f2980773a34d 100644 (file)
 
 */
 
+
+#include "dcpomatic_button.h"
+#include "file_dialog.h"
 #include "file_picker_ctrl.h"
 #include "wx_util.h"
-#include "dcpomatic_button.h"
-#include <wx/wx.h>
-#include <wx/stdpaths.h>
+#include <dcp/warnings.h>
+LIBDCP_DISABLE_WARNINGS
 #include <wx/filepicker.h>
+#include <wx/stdpaths.h>
+#include <wx/wx.h>
+LIBDCP_ENABLE_WARNINGS
 #include <boost/filesystem.hpp>
 
+
 using namespace std;
 using namespace boost;
 
-FilePickerCtrl::FilePickerCtrl (wxWindow* parent, wxString prompt, wxString wildcard, bool open)
+
+FilePickerCtrl::FilePickerCtrl(
+       wxWindow* parent,
+       wxString prompt,
+       wxString wildcard,
+       bool open,
+       bool warn_overwrite,
+       std::string initial_path_key,
+       optional<std::string> initial_filename,
+       optional<filesystem::path> override_path
+       )
        : wxPanel (parent)
        , _prompt (prompt)
        , _wildcard (wildcard)
        , _open (open)
+       , _warn_overwrite (warn_overwrite)
+       , _initial_path_key(initial_path_key)
+       , _initial_filename(initial_filename)
+       , _override_path(override_path)
 {
        _sizer = new wxBoxSizer (wxHORIZONTAL);
 
@@ -46,42 +66,60 @@ FilePickerCtrl::FilePickerCtrl (wxWindow* parent, wxString prompt, wxString wild
 
        SetSizerAndFit (_sizer);
        _file->Bind (wxEVT_BUTTON, boost::bind (&FilePickerCtrl::browse_clicked, this));
+
+       set_filename(_initial_filename);
 }
 
+
 void
-FilePickerCtrl::SetPath (wxString p)
+FilePickerCtrl::set_filename(optional<string> filename)
 {
-       _path = p;
+       if (filename) {
+               _file->SetLabel(std_to_wx(*filename));
+       } else {
+               _file->SetLabel(_("None"));
+       }
+}
+
+
+void
+FilePickerCtrl::set_path(optional<boost::filesystem::path> path)
+{
+       _path = path;
 
-       if (!_path.IsEmpty ()) {
-               _file->SetLabel (std_to_wx (filesystem::path (wx_to_std (_path)).leaf().string()));
+       if (_path) {
+               set_filename(_path->filename().string());
        } else {
-               _file->SetLabel (_("(None)"));
+               set_filename({});
        }
 
        wxCommandEvent ev (wxEVT_FILEPICKER_CHANGED, wxID_ANY);
        GetEventHandler()->ProcessEvent (ev);
 }
 
-wxString
-FilePickerCtrl::GetPath () const
+
+boost::optional<boost::filesystem::path>
+FilePickerCtrl::path() const
 {
        return _path;
 }
 
+
 void
 FilePickerCtrl::browse_clicked ()
 {
-       wxFileDialog* d = new wxFileDialog (this, _prompt, wxEmptyString, wxEmptyString, _wildcard, _open ? wxFD_OPEN : wxFD_SAVE | wxFD_OVERWRITE_PROMPT);
-       d->SetPath (_path);
-       if (d->ShowModal () == wxID_OK) {
-               SetPath (d->GetPath ());
+       long style = _open ? wxFD_OPEN : wxFD_SAVE;
+       if (_warn_overwrite) {
+               style |= wxFD_OVERWRITE_PROMPT;
+       }
+       FileDialog dialog(this, _prompt, _wildcard, style, _initial_path_key, _initial_filename, _path);
+       if (dialog.show()) {
+               set_path(dialog.path());
        }
-       d->Destroy ();
 }
 
 void
-FilePickerCtrl::SetWildcard (wxString w)
+FilePickerCtrl::set_wildcard(wxString w)
 {
        _wildcard = w;
 }