X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e90867579b360e61904846d6a1ff2bdf260572bf..0474c6efc6a81b4b548d049a6804c080134a6a3f:/src/common/valtext.cpp diff --git a/src/common/valtext.cpp b/src/common/valtext.cpp index 483b71d075..e527198cbc 100644 --- a/src/common/valtext.cpp +++ b/src/common/valtext.cpp @@ -5,8 +5,8 @@ // Modified by: // Created: 04/01/98 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem -// Licence: wxWindows license +// Copyright: (c) Julian Smart +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifdef __GNUG__ @@ -61,6 +61,7 @@ wxTextValidator::wxTextValidator(long style, wxString *val) } wxTextValidator::wxTextValidator(const wxTextValidator& val) + : wxValidator() { Copy(val); } @@ -72,19 +73,19 @@ bool wxTextValidator::Copy(const wxTextValidator& val) m_validatorStyle = val.m_validatorStyle ; m_stringValue = val.m_stringValue ; - wxNode *node = val.m_includeList.First() ; + wxStringList::Node *node = val.m_includeList.GetFirst() ; while ( node ) { - wxChar *s = (wxChar *)node->Data(); + wxChar *s = node->GetData(); m_includeList.Add(s); - node = node->Next(); + node = node->GetNext(); } - node = val.m_excludeList.First() ; + node = val.m_excludeList.GetFirst() ; while ( node ) { - wxChar *s = (wxChar *)node->Data(); + wxChar *s = node->GetData(); m_excludeList.Add(s); - node = node->Next(); + node = node->GetNext(); } return TRUE; } @@ -170,6 +171,18 @@ bool wxTextValidator::Validate(wxWindow *parent) errormsg = _("'%s' should be numeric."); } + else if ( (m_validatorStyle & wxFILTER_INCLUDE_CHAR_LIST) && !IsInCharIncludeList(val)) + { + //it's only ok to have the members of the list + errormsg = _("'%s' is invalid"); + ok = FALSE; + } + else if ( (m_validatorStyle & wxFILTER_EXCLUDE_CHAR_LIST) && !IsNotInCharExcludeList(val)) + { + // it's only ok to have non-members of the list + errormsg = _("'%s' is invalid"); + ok = FALSE; + } if ( !ok ) { @@ -220,12 +233,12 @@ void wxTextValidator::SetIncludeList(const wxStringList& list) m_includeList.Clear(); // TODO: replace with = - wxNode *node = list.First() ; + wxStringList::Node *node = list.GetFirst(); while ( node ) { - wxChar *s = (wxChar *)node->Data(); + wxChar *s = node->GetData(); m_includeList.Add(s); - node = node->Next(); + node = node->GetNext(); } } @@ -238,12 +251,12 @@ void wxTextValidator::SetExcludeList(const wxStringList& list) m_excludeList.Clear(); // TODO: replace with = - wxNode *node = list.First() ; + wxStringList::Node *node = list.GetFirst() ; while ( node ) { - wxChar *s = (wxChar *)node->Data(); + wxChar *s = node->GetData(); m_excludeList.Add(s); - node = node->Next(); + node = node->GetNext(); } } @@ -256,12 +269,14 @@ void wxTextValidator::OnChar(wxKeyEvent& event) if ( m_validatorWindow ) { - int keyCode = (int)event.KeyCode(); + int keyCode = event.GetKeyCode(); // we don't filter special keys and Delete if ( !(keyCode < WXK_SPACE || keyCode == WXK_DELETE || keyCode > WXK_START) && ( + ((m_validatorStyle & wxFILTER_INCLUDE_CHAR_LIST) && !IsInCharIncludeList(wxString((char) keyCode, 1))) || + ((m_validatorStyle & wxFILTER_EXCLUDE_CHAR_LIST) && !IsNotInCharExcludeList(wxString((char) keyCode, 1))) || ((m_validatorStyle & wxFILTER_ASCII) && !isascii(keyCode)) || ((m_validatorStyle & wxFILTER_ALPHA) && !wxIsalpha(keyCode)) || ((m_validatorStyle & wxFILTER_ALPHANUMERIC) && !wxIsalnum(keyCode)) || @@ -295,5 +310,27 @@ static bool wxIsNumeric(const wxString& val) return TRUE; } +bool wxTextValidator::IsInCharIncludeList(const wxString& val) +{ + size_t i; + for ( i = 0; i < val.Length(); i++) + { + if (!m_includeList.Member((wxString) val[i])) + return FALSE; + } + return TRUE; +} + +bool wxTextValidator::IsNotInCharExcludeList(const wxString& val) +{ + size_t i; + for ( i = 0; i < val.Length(); i++) + { + if (m_excludeList.Member((wxString) val[i])) + return FALSE; + } + return TRUE; +} + #endif // wxUSE_VALIDATORS