|
rippled
|
Represents a JSON value. More...
#include <json_value.h>

Classes | |
| class | CZString |
| union | ValueHolder |
Public Types | |
| using | Members = std::vector< std::string > |
| using | iterator = ValueIterator |
| using | const_iterator = ValueConstIterator |
| using | UInt = Json::UInt |
| using | Int = Json::Int |
| using | ArrayIndex = UInt |
| using | ObjectValues = std::map< CZString, Value > |
Public Member Functions | |
| Value (ValueType type=nullValue) | |
| Create a default Value of the given type. | |
| Value (Int value) | |
| Value (UInt value) | |
| Value (double value) | |
| Value (char const *value) | |
| Value (xrpl::Number const &value) | |
| Value (StaticString const &value) | |
| Constructs a value from a static string. | |
| Value (std::string const &value) | |
| Value (bool value) | |
| Value (Value const &other) | |
| ~Value () | |
| Value & | operator= (Value const &other) |
| Value & | operator= (Value &&other) |
| Value (Value &&other) noexcept | |
| void | swap (Value &other) noexcept |
| Swap values. | |
| ValueType | type () const |
| char const * | asCString () const |
| std::string | asString () const |
| Returns the unquoted string value. | |
| Int | asInt () const |
| UInt | asUInt () const |
| double | asDouble () const |
| bool | asBool () const |
| UInt | asAbsUInt () const |
| Correct absolute value from int or unsigned int. | |
| bool | isNull () const |
| isNull() tests to see if this field is null. | |
| bool | isBool () const |
| bool | isInt () const |
| bool | isUInt () const |
| bool | isIntegral () const |
| bool | isDouble () const |
| bool | isNumeric () const |
| bool | isString () const |
| bool | isArray () const |
| bool | isArrayOrNull () const |
| bool | isObject () const |
| bool | isObjectOrNull () const |
| bool | isConvertibleTo (ValueType other) const |
| UInt | size () const |
| Number of values in array or object. | |
| operator bool () const | |
| Returns false if this is an empty array, empty object, empty string, or null. | |
| void | clear () |
| Remove all object members and array elements. | |
| Value & | operator[] (UInt index) |
| Access an array element (zero based index ). | |
| Value const & | operator[] (UInt index) const |
| Access an array element (zero based index ) (You may need to say 'value[0u]' to get your compiler to distinguish this from the operator[] which takes a string.) | |
| Value | get (UInt index, Value const &defaultValue) const |
| If the array contains at least index+1 elements, returns the element value, otherwise returns defaultValue. | |
| bool | isValidIndex (UInt index) const |
| Return true if index < size(). | |
| Value & | append (Value const &value) |
| Append value to array at the end. | |
| Value & | append (Value &&value) |
| Value & | operator[] (char const *key) |
| Access an object value by name, create a null member if it does not exist. | |
| Value const & | operator[] (char const *key) const |
| Access an object value by name, returns null if there is no member with that name. | |
| Value & | operator[] (std::string const &key) |
| Access an object value by name, create a null member if it does not exist. | |
| Value const & | operator[] (std::string const &key) const |
| Access an object value by name, returns null if there is no member with that name. | |
| Value & | operator[] (StaticString const &key) |
| Access an object value by name, create a null member if it does not exist. | |
| Value const & | operator[] (StaticString const &key) const |
| Value | get (char const *key, Value const &defaultValue) const |
| Return the member named key if it exist, defaultValue otherwise. | |
| Value | get (std::string const &key, Value const &defaultValue) const |
| Return the member named key if it exist, defaultValue otherwise. | |
| Value | removeMember (char const *key) |
| Remove and return the named member. | |
| Value | removeMember (std::string const &key) |
| Same as removeMember(const char*) | |
| bool | isMember (char const *key) const |
| Return true if the object has a member named key. | |
| bool | isMember (std::string const &key) const |
| Return true if the object has a member named key. | |
| bool | isMember (StaticString const &key) const |
| Return true if the object has a member named key. | |
| Members | getMemberNames () const |
| Return a list of the member names. | |
| std::string | toStyledString () const |
| const_iterator | begin () const |
| const_iterator | end () const |
| iterator | begin () |
| iterator | end () |
Static Public Attributes | |
| static Value const | null |
| static constexpr Int | minInt = std::numeric_limits<Int>::min() |
| static constexpr Int | maxInt = std::numeric_limits<Int>::max() |
| static constexpr UInt | maxUInt = std::numeric_limits<UInt>::max() |
Private Member Functions | |
| Value & | resolveReference (char const *key, bool isStatic) |
Private Attributes | |
| union Json::Value::ValueHolder | value_ |
| ValueType | type_: 8 |
| int | allocated_: 1 {} |
Friends | |
| class | ValueIteratorBase |
| bool | operator== (Value const &, Value const &) |
| bool | operator< (Value const &, Value const &) |
Represents a JSON value.
This class is a discriminated union wrapper that can represent a:
The type of the held value is represented by a ValueType and can be obtained using type().
values of an objectValue or arrayValue can be accessed using operator[]() methods. Non const methods will automatically create the a nullValue element if it does not exist. The sequence of an arrayValue will be automatically resize and initialized with nullValue. resize() can be used to enlarge or truncate an arrayValue.
The get() methods can be used to obtain a default value in the case the required element does not exist.
It is possible to iterate over the list of a objectValue values using the getMemberNames() method.
Definition at line 129 of file json_value.h.
| using Json::Value::Members = std::vector<std::string> |
Definition at line 134 of file json_value.h.
| using Json::Value::iterator = ValueIterator |
Definition at line 135 of file json_value.h.
Definition at line 136 of file json_value.h.
| using Json::Value::UInt = Json::UInt |
Definition at line 137 of file json_value.h.
| using Json::Value::Int = Json::Int |
Definition at line 138 of file json_value.h.
| using Json::Value::ArrayIndex = UInt |
Definition at line 139 of file json_value.h.
| using Json::Value::ObjectValues = std::map<CZString, Value> |
Definition at line 174 of file json_value.h.
Create a default Value of the given type.
This is a very useful constructor. To create an empty array, pass arrayValue. To create an empty object, pass objectValue. Another Value can then be set to this one by assignment. This is useful since clear() and resize() will not alter types.
Examples:
Definition at line 164 of file json_value.cpp.
| Json::Value::Value | ( | Int | value | ) |
Definition at line 200 of file json_value.cpp.
| Json::Value::Value | ( | UInt | value | ) |
Definition at line 205 of file json_value.cpp.
| Json::Value::Value | ( | double | value | ) |
Definition at line 210 of file json_value.cpp.
| Json::Value::Value | ( | char const * | value | ) |
Definition at line 215 of file json_value.cpp.
| Json::Value::Value | ( | xrpl::Number const & | value | ) |
Definition at line 220 of file json_value.cpp.
| Json::Value::Value | ( | StaticString const & | value | ) |
Constructs a value from a static string.
Like other value string constructor but do not duplicate the string for internal storage. The given string must remain alive after the call to this constructor. Example of usage:
Definition at line 232 of file json_value.cpp.
| Json::Value::Value | ( | std::string const & | value | ) |
Definition at line 226 of file json_value.cpp.
| Json::Value::Value | ( | bool | value | ) |
Definition at line 237 of file json_value.cpp.
| Json::Value::Value | ( | Value const & | other | ) |
Definition at line 242 of file json_value.cpp.
| Json::Value::~Value | ( | ) |
Definition at line 279 of file json_value.cpp.
|
noexcept |
Definition at line 317 of file json_value.cpp.
Definition at line 310 of file json_value.cpp.
Definition at line 325 of file json_value.cpp.
|
noexcept |
Swap values.
Definition at line 333 of file json_value.cpp.
| ValueType Json::Value::type | ( | ) | const |
Definition at line 347 of file json_value.cpp.
| char const * Json::Value::asCString | ( | ) | const |
Definition at line 469 of file json_value.cpp.
| std::string Json::Value::asString | ( | ) | const |
Returns the unquoted string value.
Definition at line 476 of file json_value.cpp.
| Value::Int Json::Value::asInt | ( | ) | const |
Definition at line 512 of file json_value.cpp.
| Value::UInt Json::Value::asUInt | ( | ) | const |
Definition at line 613 of file json_value.cpp.
| double Json::Value::asDouble | ( | ) | const |
Definition at line 656 of file json_value.cpp.
| bool Json::Value::asBool | ( | ) | const |
Definition at line 690 of file json_value.cpp.
| UInt Json::Value::asAbsUInt | ( | ) | const |
Correct absolute value from int or unsigned int.
Definition at line 555 of file json_value.cpp.
| bool Json::Value::isNull | ( | ) | const |
isNull() tests to see if this field is null.
Don't use this method to test for emptiness: use empty().
Definition at line 1059 of file json_value.cpp.
| bool Json::Value::isBool | ( | ) | const |
Definition at line 1065 of file json_value.cpp.
| bool Json::Value::isInt | ( | ) | const |
Definition at line 1071 of file json_value.cpp.
| bool Json::Value::isUInt | ( | ) | const |
Definition at line 1077 of file json_value.cpp.
| bool Json::Value::isIntegral | ( | ) | const |
Definition at line 1083 of file json_value.cpp.
| bool Json::Value::isDouble | ( | ) | const |
Definition at line 1089 of file json_value.cpp.
| bool Json::Value::isNumeric | ( | ) | const |
Definition at line 1095 of file json_value.cpp.
| bool Json::Value::isString | ( | ) | const |
Definition at line 1101 of file json_value.cpp.
| bool Json::Value::isArray | ( | ) | const |
Definition at line 1107 of file json_value.cpp.
| bool Json::Value::isArrayOrNull | ( | ) | const |
Definition at line 1113 of file json_value.cpp.
| bool Json::Value::isObject | ( | ) | const |
Definition at line 1119 of file json_value.cpp.
| bool Json::Value::isObjectOrNull | ( | ) | const |
Definition at line 1125 of file json_value.cpp.
| bool Json::Value::isConvertibleTo | ( | ValueType | other | ) | const |
Definition at line 724 of file json_value.cpp.
| Value::UInt Json::Value::size | ( | ) | const |
Number of values in array or object.
Definition at line 775 of file json_value.cpp.
|
explicit |
Returns false if this is an empty array, empty object, empty string, or null.
Definition at line 809 of file json_value.cpp.
| void Json::Value::clear | ( | ) |
Remove all object members and array elements.
Definition at line 825 of file json_value.cpp.
Access an array element (zero based index ).
If the array contains less than index element, then null value are inserted in the array so that its size is index+1. (You may need to say 'value[0u]' to get your compiler to distinguish this from the operator[] which takes a string.)
Definition at line 844 of file json_value.cpp.
Access an array element (zero based index ) (You may need to say 'value[0u]' to get your compiler to distinguish this from the operator[] which takes a string.)
Definition at line 864 of file json_value.cpp.
If the array contains at least index+1 elements, returns the element value, otherwise returns defaultValue.
Definition at line 910 of file json_value.cpp.
| bool Json::Value::isValidIndex | ( | UInt | index | ) | const |
Return true if index < size().
Definition at line 917 of file json_value.cpp.
Append value to array at the end.
Equivalent to jsonvalue[jsonvalue.size()] = value;
Definition at line 966 of file json_value.cpp.
Definition at line 972 of file json_value.cpp.
| Value & Json::Value::operator[] | ( | char const * | key | ) |
Access an object value by name, create a null member if it does not exist.
Definition at line 883 of file json_value.cpp.
| Value const & Json::Value::operator[] | ( | char const * | key | ) | const |
Access an object value by name, returns null if there is no member with that name.
Definition at line 923 of file json_value.cpp.
| Value & Json::Value::operator[] | ( | std::string const & | key | ) |
Access an object value by name, create a null member if it does not exist.
Definition at line 942 of file json_value.cpp.
| Value const & Json::Value::operator[] | ( | std::string const & | key | ) | const |
Access an object value by name, returns null if there is no member with that name.
Definition at line 948 of file json_value.cpp.
| Value & Json::Value::operator[] | ( | StaticString const & | key | ) |
Access an object value by name, create a null member if it does not exist.
If the object as no entry for that name, then the member name used to store the new entry is not duplicated. Example of use:
Definition at line 954 of file json_value.cpp.
| Value const & Json::Value::operator[] | ( | StaticString const & | key | ) | const |
Definition at line 960 of file json_value.cpp.
Return the member named key if it exist, defaultValue otherwise.
Definition at line 978 of file json_value.cpp.
| Value Json::Value::get | ( | std::string const & | key, |
| Value const & | defaultValue | ||
| ) | const |
Return the member named key if it exist, defaultValue otherwise.
Definition at line 985 of file json_value.cpp.
| Value Json::Value::removeMember | ( | char const * | key | ) |
Remove and return the named member.
Do nothing if it did not exist.
Definition at line 991 of file json_value.cpp.
| Value Json::Value::removeMember | ( | std::string const & | key | ) |
Same as removeMember(const char*)
Definition at line 1011 of file json_value.cpp.
| bool Json::Value::isMember | ( | char const * | key | ) | const |
Return true if the object has a member named key.
Definition at line 1017 of file json_value.cpp.
| bool Json::Value::isMember | ( | std::string const & | key | ) | const |
Return true if the object has a member named key.
Definition at line 1027 of file json_value.cpp.
| bool Json::Value::isMember | ( | StaticString const & | key | ) | const |
Return true if the object has a member named key.
Definition at line 1033 of file json_value.cpp.
| Value::Members Json::Value::getMemberNames | ( | ) | const |
Return a list of the member names.
If null, return an empty list.
Definition at line 1039 of file json_value.cpp.
| std::string Json::Value::toStyledString | ( | ) | const |
Definition at line 1131 of file json_value.cpp.
| Value::const_iterator Json::Value::begin | ( | ) | const |
Definition at line 1138 of file json_value.cpp.
| Value::const_iterator Json::Value::end | ( | ) | const |
Definition at line 1156 of file json_value.cpp.
| Value::iterator Json::Value::begin | ( | ) |
Definition at line 1174 of file json_value.cpp.
| Value::iterator Json::Value::end | ( | ) |
Definition at line 1191 of file json_value.cpp.
|
private |
Definition at line 889 of file json_value.cpp.
|
friend |
Definition at line 131 of file json_value.h.
Definition at line 421 of file json_value.cpp.
Definition at line 365 of file json_value.cpp.
|
static |
Definition at line 141 of file json_value.h.
|
staticconstexpr |
Definition at line 142 of file json_value.h.
|
staticconstexpr |
Definition at line 143 of file json_value.h.
|
staticconstexpr |
Definition at line 144 of file json_value.h.
|
private |
|
private |
Definition at line 423 of file json_value.h.
|
private |
Definition at line 424 of file json_value.h.