CYCLUS
|
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 resize and initialized with nullValue. resize() can be used to enlarge or truncate an arrayValue.
The get() methods can be used to obtanis 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.
#include <pyne.h>
Public Types | |
typedef Json::ArrayIndex | ArrayIndex |
typedef ValueConstIterator | const_iterator |
typedef Json::Int | Int |
typedef Json::Int64 | Int64 |
typedef ValueIterator | iterator |
typedef Json::LargestInt | LargestInt |
typedef Json::LargestUInt | LargestUInt |
typedef std::vector< std::string > | Members |
typedef std::map< CZString, Value > | ObjectValues |
typedef Json::UInt | UInt |
typedef Json::UInt64 | UInt64 |
Public Member Functions | |
Value & | append (const Value &value) |
bool | asBool () const |
const char * | asCString () const |
double | asDouble () const |
float | asFloat () const |
Int | asInt () const |
Int64 | asInt64 () const |
LargestInt | asLargestInt () const |
LargestUInt | asLargestUInt () const |
std::string | asString () const |
UInt | asUInt () const |
UInt64 | asUInt64 () const |
iterator | begin () |
const_iterator | begin () const |
void | clear () |
int | compare (const Value &other) const |
bool | empty () const |
iterator | end () |
const_iterator | end () const |
Value | get (ArrayIndex index, const Value &defaultValue) const |
Value | get (const char *key, const Value &defaultValue) const |
Value | get (const std::string &key, const Value &defaultValue) const |
std::string | getComment (CommentPlacement placement) const |
Members | getMemberNames () const |
bool | hasComment (CommentPlacement placement) const |
bool | isArray () const |
bool | isBool () const |
bool | isConvertibleTo (ValueType other) const |
bool | isDouble () const |
bool | isInt () const |
bool | isIntegral () const |
bool | isMember (const char *key) const |
bool | isMember (const std::string &key) const |
bool | isNull () const |
bool | isNumeric () const |
bool | isObject () const |
bool | isString () const |
bool | isUInt () const |
bool | isValidIndex (ArrayIndex index) const |
bool | operator! () const |
bool | operator!= (const Value &other) const |
bool | operator< (const Value &other) const |
bool | operator<= (const Value &other) const |
Value & | operator= (const Value &other) |
bool | operator== (const Value &other) const |
bool | operator> (const Value &other) const |
bool | operator>= (const Value &other) const |
Value & | operator[] (ArrayIndex index) |
const Value & | operator[] (ArrayIndex index) const |
Value & | operator[] (const char *key) |
const Value & | operator[] (const char *key) const |
Value & | operator[] (const StaticString &key) |
Value & | operator[] (const std::string &key) |
const Value & | operator[] (const std::string &key) const |
Value & | operator[] (int index) |
const Value & | operator[] (int index) const |
Value | removeMember (const char *key) |
Value | removeMember (const std::string &key) |
void | resize (ArrayIndex size) |
void | setComment (const char *comment, CommentPlacement placement) |
void | setComment (const std::string &comment, CommentPlacement placement) |
ArrayIndex | size () const |
void | swap (Value &other) |
std::string | toStyledString () const |
ValueType | type () const |
Value (bool value) | |
Value (const char *beginValue, const char *endValue) | |
Value (const char *value) | |
Value (const StaticString &value) | |
Value (const std::string &value) | |
Value (const Value &other) | |
Value (double value) | |
Value (Int value) | |
Value (Int64 value) | |
Value (UInt value) | |
Value (UInt64 value) | |
Value (ValueType type=nullValue) | |
~Value () | |
Static Public Attributes | |
static const Int | maxInt = Int( UInt(-1)/2 ) |
static const Int64 | maxInt64 = Int64( UInt64(-1)/2 ) |
static const LargestInt | maxLargestInt = LargestInt( LargestUInt(-1)/2 ) |
static const LargestUInt | maxLargestUInt = LargestUInt(-1) |
static const UInt | maxUInt = UInt(-1) |
static const UInt64 | maxUInt64 = UInt64(-1) |
static const Int | minInt = Int( ~(UInt(-1)/2) ) |
static const Int64 | minInt64 = Int64( ~(UInt64(-1)/2) ) |
static const LargestInt | minLargestInt = LargestInt( ~(LargestUInt(-1)/2) ) |
static const Value | null |
typedef Json::Int Json::Value::Int |
typedef Json::Int64 Json::Value::Int64 |
typedef ValueIterator Json::Value::iterator |
typedef std::vector<std::string> Json::Value::Members |
typedef std::map<CZString, Value> Json::Value::ObjectValues |
typedef Json::UInt Json::Value::UInt |
typedef Json::UInt64 Json::Value::UInt64 |
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:
Default constructor initialization must be equivalent to: memset( this, 0, sizeof(Value) ) This optimization is used in ValueInternalMap fast allocator.
Json::Value::Value | ( | const char * | beginValue, |
const char * | endValue ) |
Json::Value::Value | ( | const StaticString & | 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:
Value::Int Json::Value::asInt | ( | ) | const |
Value::Int64 Json::Value::asInt64 | ( | ) | const |
LargestInt Json::Value::asLargestInt | ( | ) | const |
LargestUInt Json::Value::asLargestUInt | ( | ) | const |
Value::UInt Json::Value::asUInt | ( | ) | const |
Value::UInt64 Json::Value::asUInt64 | ( | ) | const |
Value::iterator Json::Value::begin | ( | ) |
Value::const_iterator Json::Value::begin | ( | ) | const |
void Json::Value::clear | ( | ) |
bool Json::Value::empty | ( | ) | const |
Value::iterator Json::Value::end | ( | ) |
Value::const_iterator Json::Value::end | ( | ) | const |
Value Json::Value::get | ( | ArrayIndex | index, |
const Value & | defaultValue ) const |
std::string Json::Value::getComment | ( | CommentPlacement | placement | ) | const |
Value::Members Json::Value::getMemberNames | ( | ) | const |
bool Json::Value::hasComment | ( | CommentPlacement | placement | ) | const |
bool Json::Value::isConvertibleTo | ( | ValueType | other | ) | const |
bool Json::Value::isMember | ( | const char * | key | ) | const |
bool Json::Value::isMember | ( | const std::string & | key | ) | const |
bool Json::Value::isValidIndex | ( | ArrayIndex | index | ) | const |
bool Json::Value::operator!= | ( | const Value & | other | ) | const |
Value & Json::Value::operator[] | ( | ArrayIndex | index | ) |
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.)
const Value & Json::Value::operator[] | ( | ArrayIndex | index | ) | const |
Value & Json::Value::operator[] | ( | const char * | key | ) |
const Value & Json::Value::operator[] | ( | const char * | key | ) | const |
Value & Json::Value::operator[] | ( | const StaticString & | 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:
Value & Json::Value::operator[] | ( | const std::string & | key | ) |
const Value & Json::Value::operator[] | ( | const std::string & | key | ) | const |
Value & Json::Value::operator[] | ( | int | index | ) |
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.)
const Value & Json::Value::operator[] | ( | int | index | ) | const |
Value Json::Value::removeMember | ( | const char * | key | ) |
Value Json::Value::removeMember | ( | const std::string & | key | ) |
Same as removeMember(const char*)
void Json::Value::resize | ( | ArrayIndex | size | ) |
void Json::Value::setComment | ( | const char * | comment, |
CommentPlacement | placement ) |
void Json::Value::setComment | ( | const std::string & | comment, |
CommentPlacement | placement ) |
ArrayIndex Json::Value::size | ( | ) | const |
void Json::Value::swap | ( | Value & | other | ) |
Maximum signed int value that can be stored in a Json::Value.
Maximum signed 64 bits int value that can be stored in a Json::Value.
|
static |
Maximum signed integer value that can be stored in a Json::Value.
|
static |
Maximum unsigned integer value that can be stored in a Json::Value.
Maximum unsigned int value that can be stored in a Json::Value.
Maximum unsigned 64 bits int value that can be stored in a Json::Value.
Minimum signed int value that can be stored in a Json::Value.
Minimum signed 64 bits int value that can be stored in a Json::Value.
|
static |
Minimum signed integer value that can be stored in a Json::Value.