]> git.donarmstrong.com Git - flightcrew.git/blob - src/FlightCrew/Validators/Opf/DateValid.h
Imported Upstream version 0.7.2+dfsg
[flightcrew.git] / src / FlightCrew / Validators / Opf / DateValid.h
1 /************************************************************************\r
2 **\r
3 **  Copyright (C) 2010  Strahinja Markovic\r
4 **\r
5 **  This file is part of FlightCrew.\r
6 **\r
7 **  FlightCrew is free software: you can redistribute it and/or modify\r
8 **  it under the terms of the GNU Lesser General Public License as published\r
9 **  by the Free Software Foundation, either version 3 of the License, or\r
10 **  (at your option) any later version.\r
11 **\r
12 **  FlightCrew is distributed in the hope that it will be useful,\r
13 **  but WITHOUT ANY WARRANTY; without even the implied warranty of\r
14 **  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
15 **  GNU Lesser General Public License for more details.\r
16 **\r
17 **  You should have received a copy of the GNU Lesser General Public License\r
18 **  along with FlightCrew.  If not, see <http://www.gnu.org/licenses/>.\r
19 **\r
20 *************************************************************************/\r
21 \r
22 #pragma once\r
23 #ifndef DATEVALID_H\r
24 #define DATEVALID_H\r
25 \r
26 #include "../XmlValidator.h"\r
27 \r
28 namespace FlightCrew\r
29 {\r
30 \r
31 class DateValid : public XmlValidator\r
32 {\r
33 public:\r
34 \r
35     virtual std::vector< Result > ValidateXml( \r
36         const xc::DOMDocument &document,\r
37         const fs::path &filepath = fs::path() );\r
38 \r
39 private:\r
40 \r
41     /**\r
42      * Validates the date string format, but does not check\r
43      * that the date itself is valid.\r
44      *\r
45      * @param date_string The date string to validate.\r
46      * @return \c true when the string format is valid.\r
47      */\r
48     bool ValidDateString( const std::string &date_string );\r
49 \r
50     /**\r
51      * Validates the date itself. It assumes that the input date\r
52      * string already matches the correct format.\r
53      *\r
54      * @param date_string The date string to validate.\r
55      * @return \c true when the date is valid.\r
56      */\r
57     bool ValidDateTime( const std::string &date_string );\r
58 };\r
59 \r
60 } // namespace FlightCrew\r
61 \r
62 #endif // DATEVALID_H\r
63 \r