#include "wx/defs.h"
-#if wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+#if wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
-#include "wx/textctrl.h"
#include "wx/validate.h"
#define wxFILTER_NONE 0x0000
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; }
// Filter keystrokes
void OnChar(wxKeyEvent& event);
-
DECLARE_EVENT_TABLE()
protected:
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)
};
#endif
- // wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+ // wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
#endif
// _WX_VALTEXTH__
#pragma hdrstop
#endif
-#if wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+#if wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
#include "wx/valtext.h"
return true;
}
+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;
// 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 ( !control->IsEnabled() )
+ if ( !m_validatorWindow->IsEnabled() )
return true;
- wxString val(control->GetValue());
+ wxTextEntry * const text = GetTextEntry();
+ if ( !text )
+ return false;
+
+ wxString val(text->GetValue());
bool ok = true;
// Called to transfer data to the window
bool wxTextValidator::TransferToWindow(void)
{
- if( !CheckValidator() )
- return false;
-
if ( m_stringValue )
{
- wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow;
- control->SetValue(* m_stringValue);
+ wxTextEntry * const text = GetTextEntry();
+ if ( !text )
+ return false;
+
+ text->SetValue(*m_stringValue);
}
return true;
// Called to transfer data to the window
bool wxTextValidator::TransferFromWindow(void)
{
- if( !CheckValidator() )
- return false;
-
if ( m_stringValue )
{
- wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow;
- *m_stringValue = control->GetValue();
+ wxTextEntry * const text = GetTextEntry();
+ if ( !text )
+ return false;
+
+ *m_stringValue = text->GetValue();
}
return true;
#endif
- // wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+ // wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)