// that GTK+ < 2.4
#include "wx/generic/filepickerg.h"
-
-
//-----------------------------------------------------------------------------
// wxFileButton and wxDirButton shared code
// (cannot be a base class since they need to derive from wxGenericFileButton
\
virtual bool Destroy() \
{ \
- m_dialog->Destroy(); \
+ if (m_dialog) \
+ m_dialog->Destroy(); \
return wxButton::Destroy(); \
- }
+ } \
+ \
+ /* even if wx derive from wxGenericFileButton, i.e. from wxButton, our */ \
+ /* native GTK+ widget does not derive from GtkButton thus *all* uses */ \
+ /* GTK_BUTTON(m_widget) macro done by wxButton must be bypassed to */ \
+ /* avoid bunch of GTK+ warnings like: */ \
+ /* invalid cast from `GtkFileChooserButton' to `GtkButton' */ \
+ /* so, override wxButton::GTKGetWindow and return NULL as GTK+ doesn't */ \
+ /* give us access to the internal GdkWindow of a GtkFileChooserButton */ \
+protected: \
+ virtual GdkWindow * \
+ GTKGetWindow(wxArrayGdkWindows& WXUNUSED(windows)) const \
+ { return NULL; }
//-----------------------------------------------------------------------------
// event handler for the click
void OnDialogOK(wxCommandEvent &);
-
-public: // some overrides
-
- // GtkFileChooserButton does not support GTK_FILE_CHOOSER_ACTION_SAVE
- // so we replace it with GTK_FILE_CHOOSER_ACTION_OPEN; since wxFD_SAVE
- // is not supported, wxFD_OVERWRITE_PROMPT isn't too...
- virtual long GetDialogStyle() const
- {
- return (wxGenericFileButton::GetDialogStyle() &
- ~(wxFD_SAVE | wxFD_OVERWRITE_PROMPT)) | wxFD_OPEN;
- }
-
virtual void SetPath(const wxString &str);
// see macro defined above
protected:
wxDialog *m_dialog;
-private:
DECLARE_DYNAMIC_CLASS(wxFileButton)
};
bool m_bIgnoreNextChange;
- void UpdatePath(const char *gtkpath)
- { m_path = wxString::FromAscii(gtkpath); }
+ void GTKUpdatePath(const char *gtkpath);
private:
DECLARE_DYNAMIC_CLASS(wxDirButton)