#pragma hdrstop
#endif
-#if wxUSE_VALIDATORS && wxUSE_TEXTCTRL
+#if wxUSE_VALIDATORS && (wxUSE_TEXTCTRL || wxUSE_COMBOBOX)
#include "wx/valtext.h"
#ifndef WX_PRECOMP
#include <stdio.h>
#include "wx/textctrl.h"
+ #include "wx/combobox.h"
#include "wx/utils.h"
#include "wx/msgdlg.h"
#include "wx/intl.h"
#include <string.h>
#include <stdlib.h>
-#ifdef __SALFORDC__
- #include <clib.h>
-#endif
-
IMPLEMENT_DYNAMIC_CLASS(wxTextValidator, wxValidator)
BEGIN_EVENT_TABLE(wxTextValidator, wxValidator)
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)