1. validator fixes: don't eat TAB. Added new SetBellOnError() function to
suppress _annoying_ bell. 2. Docs and samples updated to reflect this. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@1791 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -6,26 +6,26 @@
|
||||
// Created: 04/01/98
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) Julian Smart and Markus Holzem
|
||||
// Licence: wxWindows license
|
||||
// Licence: wxWindows license
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifdef __GNUG__
|
||||
#pragma implementation "valtext.h"
|
||||
#pragma implementation "valtext.h"
|
||||
#endif
|
||||
|
||||
// For compilers that support precompilation, includes "wx.h".
|
||||
#include "wx/wxprec.h"
|
||||
|
||||
#ifdef __BORLANDC__
|
||||
#pragma hdrstop
|
||||
#pragma hdrstop
|
||||
#endif
|
||||
|
||||
#ifndef WX_PRECOMP
|
||||
#include <stdio.h>
|
||||
#include "wx/textctrl.h"
|
||||
#include "wx/utils.h"
|
||||
#include "wx/msgdlg.h"
|
||||
#include "wx/intl.h"
|
||||
#include <stdio.h>
|
||||
#include "wx/textctrl.h"
|
||||
#include "wx/utils.h"
|
||||
#include "wx/msgdlg.h"
|
||||
#include "wx/intl.h"
|
||||
#endif
|
||||
|
||||
#include "wx/valtext.h"
|
||||
@@ -35,14 +35,14 @@
|
||||
#include <stdlib.h>
|
||||
|
||||
#ifdef __SALFORDC__
|
||||
#include <clib.h>
|
||||
#include <clib.h>
|
||||
#endif
|
||||
|
||||
#if !USE_SHARED_LIBRARY
|
||||
IMPLEMENT_DYNAMIC_CLASS(wxTextValidator, wxValidator)
|
||||
|
||||
BEGIN_EVENT_TABLE(wxTextValidator, wxValidator)
|
||||
EVT_CHAR(wxTextValidator::OnChar)
|
||||
EVT_CHAR(wxTextValidator::OnChar)
|
||||
END_EVENT_TABLE()
|
||||
#endif
|
||||
|
||||
@@ -50,13 +50,13 @@ static bool wxIsNumeric(const wxString& val);
|
||||
|
||||
wxTextValidator::wxTextValidator(long style, wxString *val)
|
||||
{
|
||||
m_validatorStyle = style ;
|
||||
m_stringValue = val ;
|
||||
m_validatorStyle = style ;
|
||||
m_stringValue = val ;
|
||||
/*
|
||||
m_refData = new wxVTextRefData;
|
||||
|
||||
M_VTEXTDATA->m_validatorStyle = style ;
|
||||
M_VTEXTDATA->m_stringValue = val ;
|
||||
M_VTEXTDATA->m_validatorStyle = style ;
|
||||
M_VTEXTDATA->m_stringValue = val ;
|
||||
*/
|
||||
}
|
||||
|
||||
@@ -69,23 +69,23 @@ bool wxTextValidator::Copy(const wxTextValidator& val)
|
||||
{
|
||||
wxValidator::Copy(val);
|
||||
|
||||
m_validatorStyle = val.m_validatorStyle ;
|
||||
m_stringValue = val.m_stringValue ;
|
||||
m_validatorStyle = val.m_validatorStyle ;
|
||||
m_stringValue = val.m_stringValue ;
|
||||
|
||||
wxNode *node = val.m_includeList.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_includeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
node = val.m_excludeList.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_excludeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
wxNode *node = val.m_includeList.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_includeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
node = val.m_excludeList.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_excludeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
@@ -95,227 +95,214 @@ wxTextValidator::~wxTextValidator()
|
||||
|
||||
static bool wxIsAlpha(const wxString& val)
|
||||
{
|
||||
int i;
|
||||
for ( i = 0; i < (int)val.Length(); i++)
|
||||
{
|
||||
if (!isalpha(val[i]))
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
int i;
|
||||
for ( i = 0; i < (int)val.Length(); i++)
|
||||
{
|
||||
if (!isalpha(val[i]))
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static bool wxIsAlphaNumeric(const wxString& val)
|
||||
{
|
||||
int i;
|
||||
for ( i = 0; i < (int)val.Length(); i++)
|
||||
{
|
||||
if (!isalnum(val[i]))
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
int i;
|
||||
for ( i = 0; i < (int)val.Length(); i++)
|
||||
{
|
||||
if (!isalnum(val[i]))
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// Called when the value in the window must be validated.
|
||||
// This function can pop up an error message.
|
||||
bool wxTextValidator::Validate(wxWindow *parent)
|
||||
{
|
||||
if ( !m_validatorWindow )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)) )
|
||||
return FALSE;
|
||||
if ( !m_stringValue )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)) )
|
||||
return FALSE;
|
||||
if ( !m_stringValue )
|
||||
return FALSE;
|
||||
|
||||
wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ;
|
||||
wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ;
|
||||
|
||||
// If window is disabled, don't validate
|
||||
if ( !control->Enabled() )
|
||||
return FALSE;
|
||||
// If window is disabled, don't validate
|
||||
if ( !control->Enabled() )
|
||||
return FALSE;
|
||||
|
||||
wxString val(control->GetValue());
|
||||
wxString val(control->GetValue());
|
||||
|
||||
if ( m_validatorStyle & wxFILTER_INCLUDE_LIST )
|
||||
{
|
||||
if ( !m_includeList.Member(val) )
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
char buf[512];
|
||||
sprintf(buf, _("%s is invalid."), (const char *)val);
|
||||
wxMessageBox(buf, _("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent);
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
if ( m_validatorStyle & wxFILTER_EXCLUDE_LIST )
|
||||
{
|
||||
if ( m_excludeList.Member(val) )
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
char buf[512];
|
||||
sprintf(buf, _("%s is invalid."), (const char *)val);
|
||||
wxMessageBox(buf, _("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent);
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_ASCII) && !val.IsAscii() )
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
char buf[512];
|
||||
sprintf(buf, _("%s should only contain ASCII characters."), (const char *)val);
|
||||
wxMessageBox(buf, _("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent);
|
||||
return FALSE;
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_ALPHA) && !wxIsAlpha(val) )
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
char buf[512];
|
||||
sprintf(buf, _("%s should only contain alphabetic characters."), (const char *)val);
|
||||
wxMessageBox(buf, _("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent);
|
||||
return FALSE;
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_ALPHANUMERIC) && !wxIsAlphaNumeric(val))
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
char buf[512];
|
||||
sprintf(buf, _("%s should only contain alphabetic or numeric characters."), (const char *)val);
|
||||
wxMessageBox(buf,_("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent);
|
||||
return FALSE;
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_NUMERIC) && !wxIsNumeric(val))
|
||||
bool ok = true;
|
||||
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
char buf[512];
|
||||
sprintf(buf, _("%s should be numeric."), (const char *)val);
|
||||
wxMessageBox(buf, _("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent);
|
||||
return FALSE;
|
||||
}
|
||||
// this format string should contian exactly one '%s'
|
||||
const char *errormsg = _("'%s' is invalid");
|
||||
|
||||
return TRUE ;
|
||||
if ( m_validatorStyle & wxFILTER_INCLUDE_LIST )
|
||||
{
|
||||
if ( !m_includeList.Member(val) )
|
||||
{
|
||||
ok = false;
|
||||
}
|
||||
}
|
||||
else if ( m_validatorStyle & wxFILTER_EXCLUDE_LIST )
|
||||
{
|
||||
if ( m_excludeList.Member(val) )
|
||||
{
|
||||
ok = false;
|
||||
}
|
||||
}
|
||||
else if ( (m_validatorStyle & wxFILTER_ASCII) && !val.IsAscii() )
|
||||
{
|
||||
ok = false;
|
||||
|
||||
errormsg = _("'%s' should only contain ASCII characters.");
|
||||
}
|
||||
else if ( (m_validatorStyle & wxFILTER_ALPHA) && !wxIsAlpha(val) )
|
||||
{
|
||||
ok = false;
|
||||
|
||||
errormsg = _("'%s' should only contain alphabetic characters.");
|
||||
}
|
||||
else if ( (m_validatorStyle & wxFILTER_ALPHANUMERIC) && !wxIsAlphaNumeric(val))
|
||||
{
|
||||
ok = false;
|
||||
|
||||
errormsg = _("'%s' should only contain alphabetic or numeric characters.");
|
||||
}
|
||||
else if ( (m_validatorStyle & wxFILTER_NUMERIC) && !wxIsNumeric(val))
|
||||
{
|
||||
ok = false;
|
||||
|
||||
errormsg = _("'%s' should be numeric.");
|
||||
}
|
||||
|
||||
if ( !ok )
|
||||
{
|
||||
m_validatorWindow->SetFocus();
|
||||
|
||||
wxString buf;
|
||||
buf.Printf(errormsg, val.c_str());
|
||||
|
||||
wxMessageBox(buf, _("Validation conflict"),
|
||||
wxOK | wxICON_EXCLAMATION, parent);
|
||||
}
|
||||
|
||||
return ok;
|
||||
}
|
||||
|
||||
// Called to transfer data to the window
|
||||
bool wxTextValidator::TransferToWindow(void)
|
||||
{
|
||||
if ( !m_validatorWindow )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)) )
|
||||
return FALSE;
|
||||
if ( !m_stringValue )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)) )
|
||||
return FALSE;
|
||||
if ( !m_stringValue )
|
||||
return FALSE;
|
||||
|
||||
wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ;
|
||||
control->SetValue(* m_stringValue) ;
|
||||
wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ;
|
||||
control->SetValue(* m_stringValue) ;
|
||||
|
||||
return TRUE;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// Called to transfer data to the window
|
||||
bool wxTextValidator::TransferFromWindow(void)
|
||||
{
|
||||
if ( !m_validatorWindow )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)) )
|
||||
return FALSE;
|
||||
if ( !m_stringValue )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow )
|
||||
return FALSE;
|
||||
if ( !m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)) )
|
||||
return FALSE;
|
||||
if ( !m_stringValue )
|
||||
return FALSE;
|
||||
|
||||
wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ;
|
||||
* m_stringValue = control->GetValue() ;
|
||||
wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ;
|
||||
* m_stringValue = control->GetValue() ;
|
||||
|
||||
return TRUE;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void wxTextValidator::SetIncludeList(const wxStringList& list)
|
||||
{
|
||||
/*
|
||||
if ( !M_VTEXTDATA )
|
||||
return;
|
||||
if ( !M_VTEXTDATA )
|
||||
return;
|
||||
*/
|
||||
|
||||
m_includeList.Clear();
|
||||
// TODO: replace with =
|
||||
wxNode *node = list.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_includeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
m_includeList.Clear();
|
||||
// TODO: replace with =
|
||||
wxNode *node = list.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_includeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
}
|
||||
|
||||
void wxTextValidator::SetExcludeList(const wxStringList& list)
|
||||
{
|
||||
/*
|
||||
if ( !M_VTEXTDATA )
|
||||
return;
|
||||
if ( !M_VTEXTDATA )
|
||||
return;
|
||||
*/
|
||||
|
||||
m_excludeList.Clear();
|
||||
// TODO: replace with =
|
||||
wxNode *node = list.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_excludeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
m_excludeList.Clear();
|
||||
// TODO: replace with =
|
||||
wxNode *node = list.First() ;
|
||||
while ( node )
|
||||
{
|
||||
char *s = (char *)node->Data();
|
||||
m_excludeList.Add(s);
|
||||
node = node->Next();
|
||||
}
|
||||
}
|
||||
|
||||
void wxTextValidator::OnChar(wxKeyEvent& event)
|
||||
{
|
||||
/*
|
||||
if ( !M_VTEXTDATA )
|
||||
return;
|
||||
if ( !M_VTEXTDATA )
|
||||
return;
|
||||
*/
|
||||
|
||||
if ( !m_validatorWindow )
|
||||
return;
|
||||
if ( m_validatorWindow )
|
||||
{
|
||||
int keyCode = event.KeyCode();
|
||||
|
||||
wxTextCtrl *textCtrl = (wxTextCtrl *)m_validatorWindow;
|
||||
// we don't filter special keys and Delete
|
||||
if (
|
||||
!(keyCode < WXK_SPACE || keyCode == WXK_DELETE || keyCode > WXK_START) &&
|
||||
(
|
||||
((m_validatorStyle & wxFILTER_ASCII) && !isascii(keyCode)) ||
|
||||
((m_validatorStyle & wxFILTER_ALPHA) && !isalpha(keyCode)) ||
|
||||
((m_validatorStyle & wxFILTER_ALPHANUMERIC) && !isalnum(keyCode)) ||
|
||||
((m_validatorStyle & wxFILTER_NUMERIC) && !isdigit(keyCode)
|
||||
&& keyCode != '.' && keyCode != '-')
|
||||
)
|
||||
)
|
||||
{
|
||||
if ( !wxValidator::IsSilent() )
|
||||
wxBell();
|
||||
|
||||
int keyCode = event.KeyCode();
|
||||
if (keyCode == WXK_DELETE || keyCode == WXK_RETURN || keyCode == WXK_BACK ||
|
||||
keyCode == WXK_HOME || keyCode == WXK_LEFT || keyCode == WXK_UP ||
|
||||
keyCode == WXK_RIGHT || keyCode == WXK_DOWN || keyCode == WXK_PRIOR ||
|
||||
keyCode == WXK_NEXT || keyCode == WXK_END || keyCode == WXK_HOME)
|
||||
{
|
||||
textCtrl->wxTextCtrl::OnChar(event);
|
||||
return ;
|
||||
}
|
||||
// eat message
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if ( (m_validatorStyle & wxFILTER_ASCII) && !isascii(keyCode) )
|
||||
{
|
||||
wxBell();
|
||||
return;
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_ALPHA) && !isalpha(keyCode) )
|
||||
{
|
||||
wxBell();
|
||||
return;
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_ALPHANUMERIC) && !isalnum(keyCode) )
|
||||
{
|
||||
wxBell();
|
||||
return;
|
||||
}
|
||||
if ( (m_validatorStyle & wxFILTER_NUMERIC) && !isdigit(keyCode) && keyCode != '.' && keyCode != '-')
|
||||
{
|
||||
wxBell();
|
||||
return;
|
||||
}
|
||||
|
||||
textCtrl->wxTextCtrl::OnChar(event);
|
||||
event.Skip();
|
||||
}
|
||||
|
||||
static bool wxIsNumeric(const wxString& val)
|
||||
{
|
||||
int i;
|
||||
for ( i = 0; i < (int)val.Length(); i++)
|
||||
{
|
||||
if ((!isdigit(val[i])) && (val[i] != '.'))
|
||||
if(!((i == 0) && (val[i] == '-')))
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
int i;
|
||||
for ( i = 0; i < (int)val.Length(); i++)
|
||||
{
|
||||
if ((!isdigit(val[i])) && (val[i] != '.'))
|
||||
if(!((i == 0) && (val[i] == '-')))
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user