X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a994f81b947bd6ec0e7611988b3ebc1ae3e9df5a..cc77c86d1e71bae248f59f83904971d83e78c1a5:/include/wx/validate.h diff --git a/include/wx/validate.h b/include/wx/validate.h index 1cb97fe604..f4be5b093d 100644 --- a/include/wx/validate.h +++ b/include/wx/validate.h @@ -12,13 +12,23 @@ #ifndef _WX_VALIDATEH__ #define _WX_VALIDATEH__ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(__APPLE__) #pragma interface "validate.h" #endif +#if defined(wxUSE_VALIDATORS) && !wxUSE_VALIDATORS + // wxWindows is compiled without support for wxValidator, but we still + // want to be able to pass wxDefaultValidator to the functions which take + // a wxValidator parameter to avoid using "#if wxUSE_VALIDATORS" + // everywhere + class WXDLLEXPORT wxValidator; + #define wxDefaultValidator (*((wxValidator *)NULL)) +#else // wxUSE_VALIDATORS + #include "wx/event.h" class WXDLLEXPORT wxWindow; +class WXDLLEXPORT wxWindowBase; /* A validator has up to three purposes: @@ -36,13 +46,13 @@ class WXDLLEXPORT wxValidator : public wxEvtHandler { public: wxValidator(); - ~wxValidator(); + virtual ~wxValidator(); // Make a clone of this validator (or return NULL) - currently necessary // if you're passing a reference to a validator. // Another possibility is to always pass a pointer to a new validator // (so the calling code can use a copy constructor of the relevant class). - virtual wxValidator *Clone() const + virtual wxObject *Clone() const { return (wxValidator *)NULL; } bool Copy(const wxValidator& val) { m_validatorWindow = val.m_validatorWindow; return TRUE; } @@ -58,8 +68,8 @@ public: virtual bool TransferFromWindow() { return FALSE; }; // accessors - wxWindow *GetWindow() const { return m_validatorWindow; } - void SetWindow(wxWindow *win) { m_validatorWindow = win; } + wxWindow *GetWindow() const { return (wxWindow *)m_validatorWindow; } + void SetWindow(wxWindowBase *win) { m_validatorWindow = win; } // validators beep by default if invalid key is pressed, these functions // allow to change it @@ -67,15 +77,18 @@ public: static void SetBellOnError(bool doIt = TRUE) { ms_isSilent = doIt; } protected: - wxWindow *m_validatorWindow; + wxWindowBase *m_validatorWindow; private: static bool ms_isSilent; DECLARE_DYNAMIC_CLASS(wxValidator) + DECLARE_NO_COPY_CLASS(wxValidator) }; WXDLLEXPORT_DATA(extern const wxValidator) wxDefaultValidator; +#endif // wxUSE_VALIDATORS + #endif // _WX_VALIDATEH__