Applied custom character filter patch for text validator
Corrected typo in spinbutt.tex git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@15135 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -158,6 +158,7 @@ All (GUI):
|
|||||||
- added (platform-dependent) scan code to wxKeyEvent (Bryce Denney)
|
- added (platform-dependent) scan code to wxKeyEvent (Bryce Denney)
|
||||||
- added wxTextCtrl::EmulateKeyPress()
|
- added wxTextCtrl::EmulateKeyPress()
|
||||||
- Added wxMouseCaptureChangedEvent
|
- Added wxMouseCaptureChangedEvent
|
||||||
|
- Added custom character filtering to wxTextValidator
|
||||||
|
|
||||||
wxMSW:
|
wxMSW:
|
||||||
|
|
||||||
|
@@ -44,7 +44,7 @@ direct input to member functions that take a
|
|||||||
|
|
||||||
\twocolwidtha{7cm}
|
\twocolwidtha{7cm}
|
||||||
\begin{twocollist}
|
\begin{twocollist}
|
||||||
\twocolitem{{\bf EVT\_SPIN(id, func)}}{Generated whenever an arros is pressed.}
|
\twocolitem{{\bf EVT\_SPIN(id, func)}}{Generated whenever an arrow is pressed.}
|
||||||
\twocolitem{{\bf EVT\_SPIN\_UP(id, func)}}{Generated when left/up arrow is pressed.}
|
\twocolitem{{\bf EVT\_SPIN\_UP(id, func)}}{Generated when left/up arrow is pressed.}
|
||||||
\twocolitem{{\bf EVT\_SPIN\_DOWN(id, func)}}{Generated when right/down arrow is pressed.}
|
\twocolitem{{\bf EVT\_SPIN\_DOWN(id, func)}}{Generated when right/down arrow is pressed.}
|
||||||
\end{twocollist}%
|
\end{twocollist}%
|
||||||
|
@@ -46,6 +46,10 @@ Constructor, taking a style and optional pointer to a wxString variable.
|
|||||||
checks if the user input is on the list, complaining if not.}
|
checks if the user input is on the list, complaining if not.}
|
||||||
\twocolitem{{\bf wxFILTER\_EXCLUDE\_LIST}}{Use an exclude list. The validator
|
\twocolitem{{\bf wxFILTER\_EXCLUDE\_LIST}}{Use an exclude list. The validator
|
||||||
checks if the user input is on the list, complaining if it is.}
|
checks if the user input is on the list, complaining if it is.}
|
||||||
|
\twocolitem{{\bf wxFILTER\_INCLUDE\_CHAR\_LIST}}{Use an include list. The validator
|
||||||
|
checks if each input character is in the list (one character per list element), complaining if not.}
|
||||||
|
\twocolitem{{\bf wxFILTER\_INCLUDE\_CHAR\_LIST}}{Use an include list. The validator
|
||||||
|
checks if each input character is in the list (one character per list element), complaining if it is.}
|
||||||
\end{twocollist}
|
\end{twocollist}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -29,6 +29,8 @@
|
|||||||
#define wxFILTER_NUMERIC 0x0008
|
#define wxFILTER_NUMERIC 0x0008
|
||||||
#define wxFILTER_INCLUDE_LIST 0x0010
|
#define wxFILTER_INCLUDE_LIST 0x0010
|
||||||
#define wxFILTER_EXCLUDE_LIST 0x0020
|
#define wxFILTER_EXCLUDE_LIST 0x0020
|
||||||
|
#define wxFILTER_INCLUDE_CHAR_LIST 0x0040
|
||||||
|
#define wxFILTER_EXCLUDE_CHAR_LIST 0x0080
|
||||||
|
|
||||||
class WXDLLEXPORT wxTextValidator: public wxValidator
|
class WXDLLEXPORT wxTextValidator: public wxValidator
|
||||||
{
|
{
|
||||||
@@ -70,6 +72,9 @@ public:
|
|||||||
// Filter keystrokes
|
// Filter keystrokes
|
||||||
void OnChar(wxKeyEvent& event);
|
void OnChar(wxKeyEvent& event);
|
||||||
|
|
||||||
|
bool IsInCharIncludeList(const wxString& val);
|
||||||
|
bool IsNotInCharExcludeList(const wxString& val);
|
||||||
|
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@@ -170,6 +170,18 @@ bool wxTextValidator::Validate(wxWindow *parent)
|
|||||||
|
|
||||||
errormsg = _("'%s' should be numeric.");
|
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 )
|
if ( !ok )
|
||||||
{
|
{
|
||||||
@@ -262,6 +274,8 @@ void wxTextValidator::OnChar(wxKeyEvent& event)
|
|||||||
if (
|
if (
|
||||||
!(keyCode < WXK_SPACE || keyCode == WXK_DELETE || keyCode > WXK_START) &&
|
!(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_ASCII) && !isascii(keyCode)) ||
|
||||||
((m_validatorStyle & wxFILTER_ALPHA) && !wxIsalpha(keyCode)) ||
|
((m_validatorStyle & wxFILTER_ALPHA) && !wxIsalpha(keyCode)) ||
|
||||||
((m_validatorStyle & wxFILTER_ALPHANUMERIC) && !wxIsalnum(keyCode)) ||
|
((m_validatorStyle & wxFILTER_ALPHANUMERIC) && !wxIsalnum(keyCode)) ||
|
||||||
@@ -295,5 +309,27 @@ static bool wxIsNumeric(const wxString& val)
|
|||||||
return TRUE;
|
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
|
#endif
|
||||||
// wxUSE_VALIDATORS
|
// wxUSE_VALIDATORS
|
||||||
|
Reference in New Issue
Block a user