Represents a JSON value. More...
#include <json/value.h>
as<T>
and is<T>
member function templates and specializations. More...
as
specializations are type conversions, and do not have a corresponding is
. More...
Represents a JSON value.
This class is a discriminated union wrapper that can represents 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 resized and initialized with nullValue. resize() can be used to enlarge or truncate an arrayValue.
The get() methods can be used to obtain default value in the case the required element does not exist.
It is possible to iterate over the list of member keys of an object using the getMemberNames() method.
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:
Represents a JSON value.
Definition: value.h:193
@ arrayValue
array value (ordered list)
Definition: value.h:114
@ objectValue
object value (collection of name/value pairs).
Definition: value.h:115
Default constructor initialization must be equivalent to: memset( this, 0, sizeof(Value) ) This optimization is used in ValueInternalMap fast allocator.
◆ Value() [2/14] Json::Value::Value ( Int value ) ◆ Value() [3/14] Json::Value::Value ( UInt value ) ◆ Value() [4/14] Json::Value::Value ( Int64 value ) ◆ Value() [5/14] Json::Value::Value ( UInt64 value ) ◆ Value() [6/14] Json::Value::Value ( double value ) ◆ Value() [7/14] Json::Value::Value ( const char * value )Copy til first 0. (NULL causes to seg-fault.)
◆ Value() [8/14] Json::Value::Value ( const char * begin, const char * end )Copy all, incl zeroes.
◆ Value() [9/14]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:
static StaticString foo("some text");
◆ Value() [10/14] Json::Value::Value ( const String & value ) ◆ Value() [11/14] Json::Value::Value ( bool value ) ◆ Value() [12/14] Json::Value::Value ( std::nullptr_t ptr ) delete ◆ Value() [13/14] Json::Value::Value ( const Value & other ) ◆ Value() [14/14] Json::Value::Value ( Value && other ) noexcept ◆ ~Value() ◆ __declspec() Json::Value::__declspec ( deprecated("Use setComment(String const&) instead.") ) const ◆ append() [1/2] Value & Json::Value::append ( const Value & value )Append value to array at the end.
Equivalent to jsonvalue[jsonvalue.size()] = value;
◆ append() [2/2] ◆ as() [1/10]template<>
bool Json::Value::as ( ) const inline ◆ as() [2/10]template<>
Int Json::Value::as ( ) const inline ◆ as() [3/10]template<>
UInt Json::Value::as ( ) const inline ◆ as() [4/10]template<>
Int64 Json::Value::as ( ) const inline ◆ as() [5/10]template<>
UInt64 Json::Value::as ( ) const inline ◆ as() [6/10]template<>
double Json::Value::as ( ) const inline ◆ as() [7/10]template<>
String Json::Value::as ( ) const inline ◆ as() [8/10]template<>
float Json::Value::as ( ) const inlineThese as
specializations are type conversions, and do not have a corresponding is
.
template<>
const char* Json::Value::as ( ) const inline ◆ as() [10/10]template<typename T >
T Json::Value::as ( ) const deleteThe as<T>
and is<T>
member function templates and specializations.
Embedded zeroes could cause you trouble!
◆ asDouble() double Json::Value::asDouble ( ) const ◆ asFloat() float Json::Value::asFloat ( ) const ◆ asInt() ◆ asInt64() ◆ asLargestInt() ◆ asLargestUInt() ◆ asString() String Json::Value::asString ( ) constEmbedded zeroes are possible.
◆ asUInt() ◆ asUInt64() ◆ begin() [1/2] ◆ begin() [2/2] ◆ clear() void Json::Value::clear ( )Remove all object members and array elements.
copy everything.
◆ copyPayload() void Json::Value::copyPayload ( const Value & other )copy values but leave comments and source offsets in place.
◆ demand() Value * Json::Value::demand ( char const * begin, char const * end )Most general and efficient version of object-mutators.
Return true if empty array, empty object, or null; otherwise, false.
◆ end() [1/2] ◆ end() [2/2] ◆ find() Value const * Json::Value::find ( char const * begin, char const * end ) constMost general and efficient version of isMember()const, get()const, and operator[]const.
If the array contains at least index+1 elements, returns the element value, otherwise returns defaultValue.
◆ get() [2/4] Value Json::Value::get ( const char * begin, const char * end, const Value & defaultValue ) constReturn the member named key if it exist, defaultValue otherwise.
Return the member named key if it exist, defaultValue otherwise.
Return the member named key if it exist, defaultValue otherwise.
Include delimiters and embedded newlines.
◆ getMemberNames()Return a list of the member names.
If null, return an empty list.
Get raw char* of string-value.
Insert value in array at specific index.
◆ insert() [2/2] ◆ is() [1/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [2/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [3/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [4/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [5/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [6/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [7/8]template<>
bool Json::Value::is ( ) const inline ◆ is() [8/8]template<typename T >
bool Json::Value::is ( ) const delete ◆ isArray() bool Json::Value::isArray ( ) const ◆ isBool() bool Json::Value::isBool ( ) const ◆ isConvertibleTo() bool Json::Value::isConvertibleTo ( ValueType other ) const ◆ isDouble() bool Json::Value::isDouble ( ) const ◆ isInt() bool Json::Value::isInt ( ) const ◆ isInt64() bool Json::Value::isInt64 ( ) const ◆ isIntegral() bool Json::Value::isIntegral ( ) const ◆ isMember() [1/3] ◆ isMember() [2/3] bool Json::Value::isMember ( const char * key ) constReturn true if the object has a member named key.
Return true if the object has a member named key.
Return true if index < size().
◆ nullSingleton() Value const & Json::Value::nullSingleton ( ) static ◆ operator bool() Json::Value::operator bool ( ) const explicitReturn !isNull()
◆ operator!=() bool Json::Value::operator!= ( const Value & other ) const ◆ operator<() bool Json::Value::operator< ( const Value & other ) constCompare payload only, not comments etc.
◆ operator<=() bool Json::Value::operator<= ( const Value & other ) const ◆ operator=() [1/2] Value & Json::Value::operator= ( const Value & other )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.)
◆ operator[]() [2/9]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.)
◆ operator[]() [3/9] Value & Json::Value::operator[] ( const char * key )Access an object value by name, create a null member if it does not exist.
Access an object value by name, returns null if there is no member with that name.
◆ operator[]() [5/9]Access an object value by name, create a null member if it does not exist.
If the object has no entry for that name, then the member name used to store the new entry is not duplicated. Example of use:
static const StaticString code("code");
object[code] = 1234;
◆ operator[]() [6/9]Access an object value by name, create a null member if it does not exist.
Access an object value by name, returns null if there is no member with that name.
Remove the indexed array element.
O(n) expensive operations. Update 'removed' iff removed.
Remove and return the named member.
Do nothing if it did not exist.
Remove the named map member.
Update 'removed' iff removed.
Resize the array to newSize elements.
New elements are initialized to null. May only be called on nullValue or arrayValue.
Comments must be //... or /* ... */.
◆ setComment() [2/2]Comments must be //... or /* ... */.
◆ setOffsetLimit() void Json::Value::setOffsetLimit ( ptrdiff_t limit ) ◆ setOffsetStart() void Json::Value::setOffsetStart ( ptrdiff_t start ) ◆ size()Number of values in array or object.
◆ swap() void Json::Value::swap ( Value & other )Swap everything.
◆ swapPayload() void Json::Value::swapPayload ( Value & other )Swap values but leave comments and source offsets in place.
◆ toStyledString() String Json::Value::toStyledString ( ) const ◆ type() ◆ ValueIteratorBase ◆ allocated_ unsigned int Json::Value::allocated_ ◆ defaultRealPrecision constexpr UInt Json::Value::defaultRealPrecision = 17 staticconstexprDefault precision for real value for string representation.
◆ maxInt constexpr Int Json::Value::maxInt = Int(UInt(-1) / 2) staticconstexprMaximum signed int value that can be stored in a Json::Value.
◆ maxInt64Maximum signed 64 bits int value that can be stored in a Json::Value.
◆ maxLargestIntMaximum signed integer value that can be stored in a Json::Value.
◆ maxLargestUIntMaximum unsigned integer value that can be stored in a Json::Value.
◆ maxUInt constexpr UInt Json::Value::maxUInt = UInt(-1) staticconstexprMaximum unsigned int value that can be stored in a Json::Value.
◆ maxUInt64Maximum unsigned 64 bits int value that can be stored in a Json::Value.
◆ maxUInt64AsDouble constexpr double Json::Value::maxUInt64AsDouble = 18446744073709551615.0 staticconstexpr ◆ minInt constexpr Int Json::Value::minInt = Int(~(UInt(-1) / 2)) staticconstexprMinimum signed int value that can be stored in a Json::Value.
◆ minInt64Minimum signed 64 bits int value that can be stored in a Json::Value.
◆ minLargestInt Initial value:=
Json::LargestInt LargestInt
Definition: value.h:206
Json::LargestUInt LargestUInt
Definition: value.h:207
Minimum signed integer value that can be stored in a Json::Value.
◆ null ◆ nullRef ◆ placement Initial value:{
void setComment(const char *comment, size_t len, CommentPlacement placement)
Comments must be //... or /* ... */.
Definition: value.h:570
CommentPlacement placement
Definition: value.h:566
std::basic_string< char, std::char_traits< char >, Allocator< char > > String
Definition: config.h:132
◆ value_type_ unsigned int Json::Value::value_type_The documentation for this class was generated from the following files:
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4