forked from 51Degrees/common-cxx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathValueMetaData.hpp
188 lines (163 loc) · 4.8 KB
/
ValueMetaData.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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
/* *********************************************************************
* 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_VALUE_META_DATA_HPP
#define FIFTYONE_DEGREES_VALUE_META_DATA_HPP
#include <string>
#include <vector>
#include "EntityMetaData.hpp"
#include "value.h"
using namespace std;
namespace FiftyoneDegrees {
namespace Common {
/**
* Key used to store ValueMetaData in a Collection. A value name is not
* unique, however it is unique within the collection of values for a
* single property. For this reason, the key consists of the property
* name and the value name.
*/
class ValueMetaDataKey {
public:
/**
* @name Constructors
* @{
*/
/**
* Default constructor. This should not be used externally as it
* returns an invalid instance.
*/
ValueMetaDataKey();
/**
* Construct a new instance of ValueMetaDataKey from the unique
* combination of property and value names.
* @param propertyName the name of the property the value relates
* to
* @param valueName the name of the value
*/
ValueMetaDataKey(string propertyName, string valueName);
/**
* @}
* @name Getters
* @{
*/
/**
* Get the name of the property that the value keyed relates to.
* @return name of the property
*/
const string getPropertyName() const;
/**
* Get the name of the value which is being keyed.
* @return name of the value
*/
const string getValueName() const;
/**
* @}
* @name Operators
* @{
*/
/**
* Override the less than operator so the unique key can be used to
* order lists.
* @param other the other key to compare
* @return true if this key comes before the other key
*/
const bool operator< (ValueMetaDataKey other) const;
/**
* Override the equality operator so the unique key can be found in
* a generic collection.
* @param other the other key to compare
* @return true if both keys are equal
*/
const bool operator== (ValueMetaDataKey other) const;
/**
* @}
*/
private:
/** The name of the property the value relates to */
string propertyName;
/** The value as a string */
string valueName;
};
/**
* Meta data relating to a value populated by an engine implementation.
*/
class ValueMetaData : public EntityMetaData<ValueMetaDataKey> {
public:
/**
* @name Constructors
* @{
*/
/**
* Default constructor, should not be used externally as it
* produces an invalid instance
*/
ValueMetaData();
/**
* Construct a new instance of ValueMetaData from an existing
* instance. This copies the existing instance and does not hold a
* reference to it.
* @param value to copy
*/
ValueMetaData(ValueMetaData *value);
/**
* Create a new instance of ValueMetaData. This should only be used
* internally by the Collection class.
* @param key containing the value and property names
* @param description full description of the value
* @param url relating to the value
*/
ValueMetaData(
ValueMetaDataKey key,
string description,
string url);
/**
* @}
* @name Getters
* @{
*/
/**
* Get the name of the value. This is a string representation of
* the value itself.
* @return value name
*/
string getName();
/**
* Get the full description of the value.
* @return description string
*/
string getDescription();
/**
* Get the URL containing any extra information about the value.
* @return URL string
*/
string getUrl();
/**
* @}
*/
private:
/** Full description of the value */
string description;
/** URL containing more information on the value */
string url;
};
}
}
#endif