/home/docs/checkouts/readthedocs.org/user_builds/advanced-micro-devices-composable-kernel/checkouts/develop/include/rapidjson/error/error.h Source File

/home/docs/checkouts/readthedocs.org/user_builds/advanced-micro-devices-composable-kernel/checkouts/develop/include/rapidjson/error/error.h Source File#

Composable Kernel: /home/docs/checkouts/readthedocs.org/user_builds/advanced-micro-devices-composable-kernel/checkouts/develop/include/rapidjson/error/error.h Source File
error.h
Go to the documentation of this file.
1 // Tencent is pleased to support the open source community by making RapidJSON available.
2 //
3 // Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip.
4 //
5 // Licensed under the MIT License (the "License"); you may not use this file except
6 // in compliance with the License. You may obtain a copy of the License at
7 //
8 // http://opensource.org/licenses/MIT
9 //
10 // Unless required by applicable law or agreed to in writing, software distributed
11 // under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
12 // CONDITIONS OF ANY KIND, either express or implied. See the License for the
13 // specific language governing permissions and limitations under the License.
14 
15 #ifndef RAPIDJSON_ERROR_ERROR_H_
16 #define RAPIDJSON_ERROR_ERROR_H_
17 
18 #include "../rapidjson.h"
19 
20 #ifdef __clang__
21 RAPIDJSON_DIAG_PUSH
22 RAPIDJSON_DIAG_OFF(padded)
23 #endif
24 
30 // RAPIDJSON_ERROR_CHARTYPE
31 
33 
38 #ifndef RAPIDJSON_ERROR_CHARTYPE
39 #define RAPIDJSON_ERROR_CHARTYPE char
40 #endif
41 
43 // RAPIDJSON_ERROR_STRING
44 
46 
51 #ifndef RAPIDJSON_ERROR_STRING
52 #define RAPIDJSON_ERROR_STRING(x) x
53 #endif
54 
56 
58 // ParseErrorCode
59 
61 
65 {
67 
70 
72 
76 
78 
84 
88 
91 };
92 
94 
108 {
110  typedef bool (ParseResult::*BooleanType)() const;
111 
112  public:
114  ParseResult() : code_(kParseErrorNone), offset_(0) {}
116  ParseResult(ParseErrorCode code, size_t offset) : code_(code), offset_(offset) {}
117 
119  ParseErrorCode Code() const { return code_; }
121  size_t Offset() const { return offset_; }
122 
124  operator BooleanType() const { return !IsError() ? &ParseResult::IsError : NULL; }
126  bool IsError() const { return code_ != kParseErrorNone; }
127 
128  bool operator==(const ParseResult& that) const { return code_ == that.code_; }
129  bool operator==(ParseErrorCode code) const { return code_ == code; }
130  friend bool operator==(ParseErrorCode code, const ParseResult& err)
131  {
132  return code == err.code_;
133  }
134 
135  bool operator!=(const ParseResult& that) const { return !(*this == that); }
136  bool operator!=(ParseErrorCode code) const { return !(*this == code); }
137  friend bool operator!=(ParseErrorCode code, const ParseResult& err) { return err != code; }
138 
140  void Clear() { Set(kParseErrorNone); }
142  void Set(ParseErrorCode code, size_t offset = 0)
143  {
144  code_ = code;
145  offset_ = offset;
146  }
147 
148  private:
149  ParseErrorCode code_;
150  size_t offset_;
151 };
152 
154 
163 typedef const RAPIDJSON_ERROR_CHARTYPE* (*GetParseErrorFunc)(ParseErrorCode);
164 
166 // ValidateErrorCode
167 
169 
173 {
176 
182 
186 
192 
200 
203 
210 
215 };
216 
218 
227 typedef const RAPIDJSON_ERROR_CHARTYPE* (*GetValidateErrorFunc)(ValidateErrorCode);
228 
230 // SchemaErrorCode
231 
233 
237 {
239 
255 };
256 
258 
267 typedef const RAPIDJSON_ERROR_CHARTYPE* (*GetSchemaErrorFunc)(SchemaErrorCode);
268 
270 // PointerParseErrorCode
271 
273 
277 {
279 
285 };
286 
288 
297 typedef const RAPIDJSON_ERROR_CHARTYPE* (*GetPointerParseErrorFunc)(PointerParseErrorCode);
298 
300 
301 #ifdef __clang__
302 RAPIDJSON_DIAG_POP
303 #endif
304 
305 #endif // RAPIDJSON_ERROR_ERROR_H_
#define RAPIDJSON_NAMESPACE_BEGIN
provide custom rapidjson namespace (opening expression)
Definition: rapidjson.h:121
#define RAPIDJSON_NAMESPACE_END
provide custom rapidjson namespace (closing expression)
Definition: rapidjson.h:124
ValidateErrorCode
Error codes when validating.
Definition: error.h:173
SchemaErrorCode
Error codes when validating.
Definition: error.h:237
#define RAPIDJSON_ERROR_CHARTYPE
Character type of error messages.
Definition: error.h:39
ParseErrorCode
Error code of parsing.
Definition: error.h:65
PointerParseErrorCode
Error code of JSON pointer parsing.
Definition: error.h:277
@ kValidateErrorMinProperties
Object has less members than 'minProperties' value.
Definition: error.h:194
@ kValidateErrorExclusiveMinimum
Number is less than or equal to the 'minimum' value.
Definition: error.h:181
@ kValidateErrorAdditionalItems
Definition: error.h:190
@ kValidateErrorMaxProperties
Object has more members than 'maxProperties' value.
Definition: error.h:193
@ kValidateErrorOneOfMatch
Definition: error.h:205
@ kValidateErrorRequired
Object is missing one or more members required by the schema.
Definition: error.h:195
@ kValidateErrorDependencies
Object has missing property or schema dependencies.
Definition: error.h:199
@ kValidateErrorUniqueItems
Array has duplicate items but 'uniqueItems' is true.
Definition: error.h:189
@ kValidateErrorReadOnly
Definition: error.h:211
@ kValidateErrorEnum
Property has a value that is not one of its allowed enumerated values.
Definition: error.h:201
@ kValidateErrorExclusiveMaximum
Number is greater than or equal to the 'maximum' value.
Definition: error.h:179
@ kValidateErrorType
Property has a type that is not allowed by the schema.
Definition: error.h:202
@ kValidateErrorOneOf
Property did not match any of the sub-schemas specified by 'oneOf'.
Definition: error.h:204
@ kValidateErrorMinLength
String is longer than the 'maxLength' value.
Definition: error.h:184
@ kValidateErrors
Top level error code when kValidateContinueOnErrorsFlag set.
Definition: error.h:174
@ kValidateErrorMaxLength
String is longer than the 'maxLength' value.
Definition: error.h:183
@ kValidateErrorWriteOnly
Definition: error.h:213
@ kValidateErrorAnyOf
Property did not match any of the sub-schemas specified by 'anyOf'.
Definition: error.h:208
@ kValidateErrorPattern
String does not match the 'pattern' regular expression.
Definition: error.h:185
@ kValidateErrorMaximum
Number is greater than the 'maximum' value.
Definition: error.h:178
@ kValidateErrorMaxItems
Array is longer than the 'maxItems' value.
Definition: error.h:187
@ kValidateErrorMinimum
Number is less than the 'minimum' value.
Definition: error.h:180
@ kValidateErrorMultipleOf
Number is not a multiple of the 'multipleOf' value.
Definition: error.h:177
@ kValidateErrorNone
No error.
Definition: error.h:175
@ kValidateErrorMinItems
Array is shorter than the 'minItems' value.
Definition: error.h:188
@ kValidateErrorNot
Property matched the sub-schema specified by 'not'.
Definition: error.h:209
@ kValidateErrorAdditionalProperties
Definition: error.h:196
@ kValidateErrorPatternProperties
See other errors.
Definition: error.h:198
@ kValidateErrorAllOf
Property did not match all of the sub-schemas specified by 'allOf'.
Definition: error.h:207
@ kSchemaErrorStartUnknown
Definition: error.h:240
@ kSchemaErrorSpecIllegal
Both JSON schema draft and OpenAPI version found in document.
Definition: error.h:253
@ kSchemaErrorSpecUnsupported
JSON schema draft or OpenAPI version is not supported.
Definition: error.h:252
@ kSchemaErrorRefPlainName
$ref fragment must be a JSON pointer
Definition: error.h:242
@ kSchemaErrorRefNoRemoteProvider
$ref is remote but there is no remote provider
Definition: error.h:247
@ kSchemaErrorSpecUnknown
JSON schema draft or OpenAPI version is not recognized.
Definition: error.h:251
@ kSchemaErrorRefUnknown
$ref does not resolve to a location in the target document
Definition: error.h:245
@ kSchemaErrorNone
No error.
Definition: error.h:238
@ kSchemaErrorRefPointerInvalid
$ref fragment is not a valid JSON pointer at offset
Definition: error.h:244
@ kSchemaErrorRefNoRemoteSchema
Definition: error.h:248
@ kSchemaErrorRefCyclical
$ref is cyclical
Definition: error.h:246
@ kSchemaErrorRefInvalid
$ref must not be an empty string
Definition: error.h:243
@ kSchemaErrorRegexInvalid
Invalid regular expression in 'pattern' or 'patternProperties'.
Definition: error.h:250
@ kSchemaErrorReadOnlyAndWriteOnly
Property must not be both 'readOnly' and 'writeOnly'.
Definition: error.h:254
@ kParseErrorDocumentEmpty
The document is empty.
Definition: error.h:68
@ kParseErrorNumberMissFraction
Miss fraction part in number.
Definition: error.h:86
@ kParseErrorStringInvalidEncoding
Invalid encoding in string.
Definition: error.h:83
@ kParseErrorValueInvalid
Invalid value.
Definition: error.h:71
@ kParseErrorDocumentRootNotSingular
The document root must not follow by other values.
Definition: error.h:69
@ kParseErrorUnspecificSyntaxError
Unspecific syntax error.
Definition: error.h:90
@ kParseErrorObjectMissCommaOrCurlyBracket
Missing a comma or '}' after an object member.
Definition: error.h:75
@ kParseErrorObjectMissColon
Missing a colon after a name of object member.
Definition: error.h:74
@ kParseErrorStringMissQuotationMark
Missing a closing quotation mark in string.
Definition: error.h:82
@ kParseErrorTermination
Parsing was terminated.
Definition: error.h:89
@ kParseErrorNumberMissExponent
Miss exponent in number.
Definition: error.h:87
@ kParseErrorStringEscapeInvalid
Invalid escape character in string.
Definition: error.h:81
@ kParseErrorArrayMissCommaOrSquareBracket
Missing a comma or ']' after an array element.
Definition: error.h:77
@ kParseErrorNone
No error.
Definition: error.h:66
@ kParseErrorStringUnicodeSurrogateInvalid
The surrogate pair in string is invalid.
Definition: error.h:80
@ kParseErrorObjectMissName
Missing a name for object member.
Definition: error.h:73
@ kParseErrorNumberTooBig
Number too big to be stored in double.
Definition: error.h:85
@ kParseErrorStringUnicodeEscapeInvalidHex
Incorrect hex digit after \u escape in string.
Definition: error.h:79
@ kPointerParseErrorInvalidEscape
Invalid escape.
Definition: error.h:281
@ kPointerParseErrorTokenMustBeginWithSolidus
A token must begin with a '/'.
Definition: error.h:280
@ kPointerParseErrorNone
The parse is successful.
Definition: error.h:278
@ kPointerParseErrorCharacterMustPercentEncode
Definition: error.h:283
@ kPointerParseErrorInvalidPercentEncoding
Invalid percent encoding in URI fragment.
Definition: error.h:282
Result of parsing (wraps ParseErrorCode)
Definition: error.h:108
friend bool operator!=(ParseErrorCode code, const ParseResult &err)
Definition: error.h:137
ParseErrorCode Code() const
Get the error code.
Definition: error.h:119
ParseResult(ParseErrorCode code, size_t offset)
Constructor to set an error.
Definition: error.h:116
bool operator==(const ParseResult &that) const
Definition: error.h:128
friend bool operator==(ParseErrorCode code, const ParseResult &err)
Definition: error.h:130
bool operator==(ParseErrorCode code) const
Definition: error.h:129
void Clear()
Reset error code.
Definition: error.h:140
bool(ParseResult::* BooleanType)() const
! Unspecified boolean type
Definition: error.h:110
bool operator!=(const ParseResult &that) const
Definition: error.h:135
void Set(ParseErrorCode code, size_t offset=0)
Update error code and offset.
Definition: error.h:142
ParseResult()
Default constructor, no error.
Definition: error.h:114
bool IsError() const
Whether the result is an error.
Definition: error.h:126
size_t Offset() const
Get the error offset, if IsError(), 0 otherwise.
Definition: error.h:121
bool operator!=(ParseErrorCode code) const
Definition: error.h:136