git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@49591
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
-#if wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+#if wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
-#include "wx/textctrl.h"
#include "wx/validate.h"
#define wxFILTER_NONE 0x0000
#include "wx/validate.h"
#define wxFILTER_NONE 0x0000
inline long GetStyle() const { return m_validatorStyle; }
inline void SetStyle(long style) { m_validatorStyle = style; }
inline long GetStyle() const { return m_validatorStyle; }
inline void SetStyle(long style) { m_validatorStyle = style; }
+ wxTextEntry *GetTextEntry();
void SetIncludes(const wxArrayString& includes) { m_includes = includes; }
inline wxArrayString& GetIncludes() { return m_includes; }
void SetIncludes(const wxArrayString& includes) { m_includes = includes; }
inline wxArrayString& GetIncludes() { return m_includes; }
// Filter keystrokes
void OnChar(wxKeyEvent& event);
// Filter keystrokes
void OnChar(wxKeyEvent& event);
DECLARE_EVENT_TABLE()
protected:
DECLARE_EVENT_TABLE()
protected:
wxArrayString m_includes;
wxArrayString m_excludes;
wxArrayString m_includes;
wxArrayString m_excludes;
- bool CheckValidator() const
- {
- wxCHECK_MSG( m_validatorWindow, false,
- _T("No window associated with validator") );
- wxCHECK_MSG( m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)), false,
- _T("wxTextValidator is only for wxTextCtrl's") );
-
- return true;
- }
-
private:
// Cannot use
// DECLARE_NO_COPY_CLASS(wxTextValidator)
private:
// Cannot use
// DECLARE_NO_COPY_CLASS(wxTextValidator)
- // wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+ // wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
-#if wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+#if wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
+wxTextEntry *wxTextValidator::GetTextEntry()
+{
+#if wxUSE_TEXTCTRL
+ if (m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)))
+ {
+ return (wxTextCtrl*)m_validatorWindow;
+ }
+#endif
+#if wxUSE_COMBOBOX
+ if (m_validatorWindow->IsKindOf(CLASSINFO(wxComboBox)))
+ {
+ return (wxComboBox*)m_validatorWindow;
+ }
+#endif
+
+ wxFAIL_MSG(
+ _T("wxTextValidator can only be used with wxTextCtrl or wxComboBox")
+ );
+
+ return NULL;
+}
+
static bool wxIsAlpha(const wxString& val)
{
int i;
static bool wxIsAlpha(const wxString& val)
{
int i;
// This function can pop up an error message.
bool wxTextValidator::Validate(wxWindow *parent)
{
// This function can pop up an error message.
bool wxTextValidator::Validate(wxWindow *parent)
{
- if( !CheckValidator() )
- return false;
-
- wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow;
-
// If window is disabled, simply return
// If window is disabled, simply return
- if ( !control->IsEnabled() )
+ if ( !m_validatorWindow->IsEnabled() )
- wxString val(control->GetValue());
+ wxTextEntry * const text = GetTextEntry();
+ if ( !text )
+ return false;
+
+ wxString val(text->GetValue());
// Called to transfer data to the window
bool wxTextValidator::TransferToWindow(void)
{
// Called to transfer data to the window
bool wxTextValidator::TransferToWindow(void)
{
- if( !CheckValidator() )
- return false;
-
- wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow;
- control->SetValue(* m_stringValue);
+ wxTextEntry * const text = GetTextEntry();
+ if ( !text )
+ return false;
+
+ text->SetValue(*m_stringValue);
// Called to transfer data to the window
bool wxTextValidator::TransferFromWindow(void)
{
// Called to transfer data to the window
bool wxTextValidator::TransferFromWindow(void)
{
- if( !CheckValidator() )
- return false;
-
- wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow;
- *m_stringValue = control->GetValue();
+ wxTextEntry * const text = GetTextEntry();
+ if ( !text )
+ return false;
+
+ *m_stringValue = text->GetValue();
- // wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+ // wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)