#include "wx/dirdlg.h"
-extern WXDLLIMPEXP_DATA_CORE(const wxEventType) wxEVT_COMMAND_DIRPICKER_CHANGED;
-extern WXDLLIMPEXP_DATA_CORE(const wxEventType) wxEVT_COMMAND_FILEPICKER_CHANGED;
+wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_CORE, wxEVT_COMMAND_DIRPICKER_CHANGED, wxFileDirPickerEvent );
+wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_CORE, wxEVT_COMMAND_FILEPICKER_CHANGED, wxFileDirPickerEvent );
//-----------------------------------------------------------------------------
public wxFileDirPickerWidgetBase
{
public:
- wxGenericFileDirButton() { }
+ wxGenericFileDirButton() { Init(); }
wxGenericFileDirButton(wxWindow *parent,
wxWindowID id,
const wxString& label = wxFilePickerWidgetLabel,
const wxValidator& validator = wxDefaultValidator,
const wxString& name = wxFilePickerWidgetNameStr)
{
+ Init();
Create(parent, id, label, path, message, wildcard,
pos, size, style, validator, name);
}
- virtual ~wxGenericFileDirButton() {}
-
virtual wxControl *AsControl() { return this; }
-public: // overrideable
+public: // overridable
virtual wxDialog *CreateDialog() = 0;
virtual wxEventType GetEventType() const = 0;
+ virtual void SetInitialDirectory(const wxString& dir);
+
public:
bool Create(wxWindow *parent, wxWindowID id,
protected:
wxString m_message, m_wildcard;
+
+ // we just store the style passed to the ctor here instead of passing it to
+ // wxButton as some of our bits can conflict with wxButton styles and it
+ // just doesn't make sense to use picker styles for wxButton anyhow
+ long m_pickerStyle;
+
+ // Initial directory set by SetInitialDirectory() call or empty.
+ wxString m_initialDir;
+
+private:
+ // common part of all ctors
+ void Init() { m_pickerStyle = -1; }
};
pos, size, style, validator, name);
}
-public: // overrideable
+public: // overridable
virtual long GetDialogStyle() const
{
+ // the derived class must initialize it if it doesn't use the
+ // non-default wxGenericFileDirButton ctor
+ wxASSERT_MSG( m_pickerStyle != -1,
+ "forgot to initialize m_pickerStyle?" );
+
+
long filedlgstyle = 0;
- if (this->HasFlag(wxFLP_OPEN))
+ if ( m_pickerStyle & wxFLP_OPEN )
filedlgstyle |= wxFD_OPEN;
- if (this->HasFlag(wxFLP_SAVE))
+ if ( m_pickerStyle & wxFLP_SAVE )
filedlgstyle |= wxFD_SAVE;
- if (this->HasFlag(wxFLP_OVERWRITE_PROMPT))
+ if ( m_pickerStyle & wxFLP_OVERWRITE_PROMPT )
filedlgstyle |= wxFD_OVERWRITE_PROMPT;
- if (this->HasFlag(wxFLP_FILE_MUST_EXIST))
+ if ( m_pickerStyle & wxFLP_FILE_MUST_EXIST )
filedlgstyle |= wxFD_FILE_MUST_EXIST;
- if (this->HasFlag(wxFLP_CHANGE_DIR))
+ if ( m_pickerStyle & wxFLP_CHANGE_DIR )
filedlgstyle |= wxFD_CHANGE_DIR;
return filedlgstyle;
}
- virtual wxDialog *CreateDialog()
- {
- wxFileDialog *p = new wxFileDialog(GetDialogParent(), m_message,
- wxEmptyString, wxEmptyString,
- m_wildcard, GetDialogStyle());
-
- // this sets both the default folder and the default file of the dialog
- p->SetPath(m_path);
- return p;
- }
+ virtual wxDialog *CreateDialog();
wxEventType GetEventType() const
{ return wxEVT_COMMAND_FILEPICKER_CHANGED; }
void UpdatePathFromDialog(wxDialog *p)
{ m_path = wxStaticCast(p, wxFileDialog)->GetPath(); }
+ // Set the initial directory for the dialog but without overriding the
+ // directory of the currently selected file, if any.
+ void DoSetInitialDirectory(wxFileDialog* dialog, const wxString& dir);
+
private:
DECLARE_DYNAMIC_CLASS(wxGenericFileButton)
};
pos, size, style, validator, name);
}
-public: // overrideable
+public: // overridable
virtual long GetDialogStyle() const
{
long dirdlgstyle = wxDD_DEFAULT_STYLE;
- if (this->HasFlag(wxDIRP_DIR_MUST_EXIST))
+ if ( m_pickerStyle & wxDIRP_DIR_MUST_EXIST )
dirdlgstyle |= wxDD_DIR_MUST_EXIST;
- if (this->HasFlag(wxDIRP_CHANGE_DIR))
+ if ( m_pickerStyle & wxDIRP_CHANGE_DIR )
dirdlgstyle |= wxDD_CHANGE_DIR;
return dirdlgstyle;
}
- virtual wxDialog *CreateDialog()
- {
- return new wxDirDialog(GetDialogParent(), m_message, m_path,
- GetDialogStyle());
- }
+ virtual wxDialog *CreateDialog();
wxEventType GetEventType() const
{ return wxEVT_COMMAND_DIRPICKER_CHANGED; }