1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
/*
* Copyright 2010 Inalogic® Inc.
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License, as
* published by the Free Software Foundation; either version 2.1 or 3.0
* of the License.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranties of
* MERCHANTABILITY, SATISFACTORY QUALITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the applicable version of the GNU Lesser General Public
* License for more details.
*
* You should have received a copy of both the GNU Lesser General Public
* License along with this program. If not, see <http://www.gnu.org/licenses/>
*
* Authored by: Jay Taoko <jaytaoko@inalogic.com>
*
*/
#ifndef INTEGERVALIDATOR_H
#define INTEGERVALIDATOR_H
#include "Validator.h"
namespace nux
{
class IntegerValidator : public Validator
{
public:
IntegerValidator (int Minimum = INT_MIN, int Maximum = INT_MAX);
IntegerValidator (const IntegerValidator &validator);
IntegerValidator &operator= (const IntegerValidator &rhs);
virtual ~IntegerValidator();
virtual Validator *Clone() const; //Virtual Constructor Idiom
/*!
@return The input value clamped to the range [m_Minimum, m_Maximum].
*/
int GetClampedValue (int i) const;
virtual void Alternative (const TCHAR *str);
void SetMinimum (int value);
int GetMinimum() const;
void SetMaximum (int value);
int GetMaximum() const;
NString ToString (int i);
int ToInteger (const TCHAR *str);
private:
int m_Minimum;
int m_Maximum;
};
}
#endif // INTEGERVALIDATOR_H
|