forked from 51Degrees/common-cxx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDate.hpp
101 lines (90 loc) · 2.62 KB
/
Date.hpp
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/* *********************************************************************
* This Original Work is copyright of 51 Degrees Mobile Experts Limited.
* Copyright 2019 51 Degrees Mobile Experts Limited, 5 Charlotte Close,
* Caversham, Reading, Berkshire, United Kingdom RG4 7BY.
*
* This Original Work is licensed under the European Union Public Licence (EUPL)
* v.1.2 and is subject to its terms as set out below.
*
* If a copy of the EUPL was not distributed with this file, You can obtain
* one at https://opensource.org/licenses/EUPL-1.2.
*
* The 'Compatible Licences' set out in the Appendix to the EUPL (as may be
* amended by the European Commission) shall be deemed incompatible for
* the purposes of the Work and the provisions of the compatibility
* clause in Article 5 of the EUPL shall not apply.
*
* If using the Work as, or as part of, a network application, by
* including the attribution notice(s) required under Article 5 of the EUPL
* in the end user terms of the application under an appropriate heading,
* such notice(s) shall fulfill the requirements of that article.
* ********************************************************************* */
#ifndef FIFTYONE_DEGREES_DATE_HPP
#define FIFTYONE_DEGREES_DATE_HPP
#include "date.h"
namespace FiftyoneDegrees {
namespace Common {
/**
* The Date class wraps the C #fiftyoneDegreesDate structure and is
* used to represent dates in engines. This is a memory efficient way
* to store a date.
*
* ## Usage Example
*
* ```
* FiftyoneDegrees::Common::Date *date;
* std::stringstream stream;
*
* // Format a string representation of a date in the format DD/MM/YYY
* stream << date->getDay() << "/"
* << date->getMonth() << "/"
* << date->getYear();
* string dateString = stream.str();
* ```
*/
class Date {
public:
/**
* @name Constructors
* @{
*/
/**
* Construct a "null" date with year, month and day all set to zero.
*/
Date();
/**
* Construct a date from a C date structure. This copies the date
* date structure so the argument can be freed after construction.
* @param date pointer to copy to the underlying date structure
*/
Date(const fiftyoneDegreesDate *date);
/**
* @}
* @name Getters
* @{
*/
/**
* Get the year
* @return year
*/
int getYear();
/**
* Get the month
* @return month
*/
int getMonth();
/**
* Get the day of the month
* @return day of the month
*/
int getDay();
/**
* @}
*/
private:
/** The underlying date structure. */
fiftyoneDegreesDate date;
};
}
}
#endif