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
62
63
|
/*
* 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 HEXREGEXPVALIDATOR_H
#define HEXREGEXPVALIDATOR_H
#include "Validator.h"
namespace nux
{
class HexRegExpValidator : public Validator
{
public:
HexRegExpValidator(int Minimum = INT_MIN, int Maximum = INT_MAX);
HexRegExpValidator(const HexRegExpValidator &validator);
HexRegExpValidator &operator= (const HexRegExpValidator &rhs);
virtual ~HexRegExpValidator();
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 char *str);
void SetMinimum(int value);
int GetMinimum() const;
void SetMaximum(int value);
int GetMaximum() const;
std::string ToString(int i);
int ToInteger(const char *str);
private:
int m_Minimum;
int m_Maximum;
};
}
#endif // HEXREGEXPVALIDATOR_H
|