1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: interface of wxValidator
4 // Author: wxWidgets team
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
12 wxValidator is the base class for a family of validator classes that
13 mediate between a class of control, and application data.
15 A validator has three major roles:
17 -# To transfer data from a C++ variable or own storage to and from a
19 -# To validate data in a control, and show an appropriate error message.
20 -# To filter events (such as keystrokes), thereby changing the behaviour
21 of the associated control.
23 Validators can be plugged into controls dynamically.
25 To specify a default, "null" validator, use ::wxDefaultValidator.
27 For more information, please see @ref overview_validator.
30 If you wish to create a validator class in wxPython you should derive the
31 class from @c wxPyValidator in order to get Python-aware capabilities for
32 the various virtual methods.
41 @see @ref overview_validator, wxTextValidator, wxGenericValidator
43 class wxValidator
: public wxEvtHandler
54 virtual ~wxValidator();
57 All validator classes must implement the Clone() function, which
58 returns an identical copy of itself.
60 This is because validators are passed to control constructors as
61 references which must be copied. Unlike objects such as pens and
62 brushes, it does not make sense to have a reference counting scheme to
63 do this cloning because all validators should have separate data.
65 @return This base function returns @NULL.
67 virtual wxObject
* Clone() const;
70 Returns the window associated with the validator.
72 wxWindow
* GetWindow() const;
75 This functions switches on or turns off the error sound produced by the
76 validators if an invalid key is pressed.
78 static void SetBellOnError(bool doIt
= true);
81 Associates a window with the validator.
83 This function is automatically called by wxWidgets when creating a wxWindow-derived
84 class instance which takes a wxValidator reference.
88 new wxTextCtrl(this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0,
89 wxTextValidator(wxFILTER_ALPHA, &g_data.m_string));
91 will automatically link the wxTextValidator instance with the wxTextCtrl
94 void SetWindow(wxWindow
* window
);
97 This overridable function is called when the value in the window must
98 be transferred to the validator.
100 @return @false if there is a problem.
102 virtual bool TransferFromWindow();
105 This overridable function is called when the value associated with the
106 validator must be transferred to the window.
108 @return @false if there is a problem.
110 virtual bool TransferToWindow();
113 This overridable function is called when the value in the associated
114 window must be validated.
117 The parent of the window associated with the validator.
119 @return @false if the value in the window is not valid; you may pop up
122 virtual bool Validate(wxWindow
* parent
);
126 An empty, "null" wxValidator instance.
128 wxValidator wxDefaultValidator
;