Arcane  4.1.12.0
Developer documentation
Loading...
Searching...
No Matches
GenericPointer< ValueType, Allocator > Class Template Reference

Represents a JSON Pointer. Use Pointer for UTF8 encoding and default allocator. More...

#include </__w/arcaneframework.github.io/arcaneframework.github.io/framework/arccore/src/common/arccore/common/internal/json/rapidjson/pointer.h>

Collaboration diagram for GenericPointer< ValueType, Allocator >:

Classes

struct  Token
 A token is the basic units of internal representation. More...
class  PercentEncodeStream
 A helper stream to encode character (UTF-8 code unit) into percent-encoded sequence. More...

Public Types

typedef ValueType::EncodingType EncodingType
 Encoding type from Value.
typedef ValueType::Ch Ch
 Character type from Value.
typedef GenericUri< ValueType, AllocatorUriType

Append token

Allocatorallocator
Allocatorallocator_
 The current allocator. It is either user-supplied or equal to ownAllocator_.
AllocatorownAllocator_
 Allocator owned by this Pointer.
ChnameBuffer_
 A buffer containing all names in tokens.
Tokentokens_
 A list of tokens.
size_t tokenCount_
 Number of tokens in tokens_.
size_t parseErrorOffset_
 Offset in code unit when parsing fail.
PointerParseErrorCode parseErrorCode_
 Parsing error code.
GenericPointer Append (const Token &token, Allocator *allocator=0) const
 Append a token and return a new Pointer.
GenericPointer Append (const Ch *name, SizeType length, Allocator *allocator=0) const
 Append a name token with length, and return a new Pointer.
template<typename T>
 RAPIDJSON_DISABLEIF_RETURN ((internal::NotExpr< internal::IsSame< typename internal::RemoveConst< T >::Type, Ch > >),(GenericPointer)) Append(T *name
 Append a name token without length, and return a new Pointer.

Constructors and destructor.

 GenericPointer (Allocator *allocator=0)
 Default constructor.
 GenericPointer (const Ch *source, Allocator *allocator=0)
 Constructor that parses a string or URI fragment representation.
 GenericPointer (const Ch *source, size_t length, Allocator *allocator=0)
 Constructor that parses a string or URI fragment representation, with length of the source string.
 GenericPointer (const Token *tokens, size_t tokenCount)
 Constructor with user-supplied tokens.
 GenericPointer (const GenericPointer &rhs)
 Copy constructor.
 GenericPointer (const GenericPointer &rhs, Allocator *allocator)
 Copy constructor.
 ~GenericPointer ()
 Destructor.
GenericPointeroperator= (const GenericPointer &rhs)
 Assignment operator.
GenericPointerSwap (GenericPointer &other) RAPIDJSON_NOEXCEPT
 Swap the content of this pointer with an other.
void swap (GenericPointer &a, GenericPointer &b) RAPIDJSON_NOEXCEPT
 free-standing swap function helper

Detailed Description

template<typename ValueType, typename Allocator = CrtAllocator>
class GenericPointer< ValueType, Allocator >

Represents a JSON Pointer. Use Pointer for UTF8 encoding and default allocator.

This class implements RFC 6901 "JavaScript Object Notation (JSON) Pointer" (https://tools.ietf.org/html/rfc6901).

A JSON pointer is for identifying a specific value in a JSON document (GenericDocument). It can simplify coding of DOM tree manipulation, because it can access multiple-level depth of DOM tree with single API call.

After it parses a string representation (e.g. "/foo/0" or URI fragment representation (e.g. "#/foo/0") into its internal representation (tokens), it can be used to resolve a specific value in multiple documents, or sub-tree of documents.

Contrary to GenericValue, Pointer can be copy constructed and copy assigned. Apart from assignment, a Pointer cannot be modified after construction.

Although Pointer is very convenient, please aware that constructing Pointer involves parsing and dynamic memory allocation. A special constructor with user- supplied tokens eliminates these.

GenericPointer depends on GenericDocument and GenericValue.

Template Parameters
ValueTypeThe value type of the DOM tree. E.g. GenericValue<UTF8<> >
AllocatorThe allocator type for allocating memory for internal representation.
Note
GenericPointer uses same encoding of ValueType. However, Allocator of GenericPointer is independent of Allocator of Value.

Definition at line 75 of file pointer.h.

Member Typedef Documentation

◆ Ch

template<typename ValueType, typename Allocator = CrtAllocator>
typedef ValueType::Ch GenericPointer< ValueType, Allocator >::Ch

Character type from Value.

Definition at line 78 of file pointer.h.

◆ EncodingType

template<typename ValueType, typename Allocator = CrtAllocator>
typedef ValueType::EncodingType GenericPointer< ValueType, Allocator >::EncodingType

Encoding type from Value.

Definition at line 77 of file pointer.h.

◆ UriType

template<typename ValueType, typename Allocator = CrtAllocator>
typedef GenericUri<ValueType, Allocator> GenericPointer< ValueType, Allocator >::UriType

Definition at line 79 of file pointer.h.

Constructor & Destructor Documentation

◆ GenericPointer() [1/6]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::GenericPointer ( Allocator * allocator = 0)
inline

Default constructor.

Definition at line 105 of file pointer.h.

◆ GenericPointer() [2/6]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::GenericPointer ( const Ch * source,
Allocator * allocator = 0 )
inlineexplicit

Constructor that parses a string or URI fragment representation.

Parameters
sourceA null-terminated, string or URI fragment representation of JSON pointer.
allocatorUser supplied allocator for this pointer. If no allocator is provided, it creates a self-owned one.

Definition at line 112 of file pointer.h.

◆ GenericPointer() [3/6]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::GenericPointer ( const Ch * source,
size_t length,
Allocator * allocator = 0 )
inline

Constructor that parses a string or URI fragment representation, with length of the source string.

Parameters
sourceA string or URI fragment representation of JSON pointer.
lengthLength of source.
allocatorUser supplied allocator for this pointer. If no allocator is provided, it creates a self-owned one.
Note
Slightly faster than the overload without length.

Definition at line 135 of file pointer.h.

◆ GenericPointer() [4/6]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::GenericPointer ( const Token * tokens,
size_t tokenCount )
inline

Constructor with user-supplied tokens.

This constructor let user supplies const array of tokens. This prevents the parsing process and eliminates allocation. This is preferred for memory constrained environments.

Parameters
tokensAn constant array of tokens representing the JSON pointer.
tokenCountNumber of tokens.

Example

#define NAME(s) { s, sizeof(s) / sizeof(s[0]) - 1, kPointerInvalidIndex }
#define INDEX(i) { #i, sizeof(#i) - 1, i }
static const Pointer::Token kTokens[] = { NAME("foo"), INDEX(123) };
static const Pointer p(kTokens, sizeof(kTokens) / sizeof(kTokens[0]));
// Equivalent to static const Pointer p("/foo/123");
#undef NAME
#undef INDEX

Definition at line 161 of file pointer.h.

◆ GenericPointer() [5/6]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::GenericPointer ( const GenericPointer< ValueType, Allocator > & rhs)
inline

Copy constructor.

Definition at line 164 of file pointer.h.

◆ GenericPointer() [6/6]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::GenericPointer ( const GenericPointer< ValueType, Allocator > & rhs,
Allocator * allocator )
inline

Copy constructor.

Definition at line 169 of file pointer.h.

◆ ~GenericPointer()

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer< ValueType, Allocator >::~GenericPointer ( )
inline

Destructor.

Definition at line 174 of file pointer.h.

Member Function Documentation

◆ Append() [1/2]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer GenericPointer< ValueType, Allocator >::Append ( const Ch * name,
SizeType length,
Allocator * allocator = 0 ) const
inline

Append a name token with length, and return a new Pointer.

Parameters
nameName to be appended.
lengthLength of name.
allocatorAllocator for the newly return Pointer.
Returns
A new Pointer with appended token.

Definition at line 260 of file pointer.h.

◆ Append() [2/2]

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer GenericPointer< ValueType, Allocator >::Append ( const Token & token,
Allocator * allocator = 0 ) const
inline

Append a token and return a new Pointer.

Parameters
tokenToken to be appended.
allocatorAllocator for the newly return Pointer.
Returns
A new Pointer with appended token.

Definition at line 242 of file pointer.h.

Referenced by GenericPointer< Value, CrtAllocator >::Append(), and GenericPointer< Value, CrtAllocator >::RAPIDJSON_DISABLEIF_RETURN().

Here is the caller graph for this function:

◆ operator=()

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer & GenericPointer< ValueType, Allocator >::operator= ( const GenericPointer< ValueType, Allocator > & rhs)
inline

Assignment operator.

Definition at line 181 of file pointer.h.

◆ RAPIDJSON_DISABLEIF_RETURN()

template<typename ValueType, typename Allocator = CrtAllocator>
template<typename T>
GenericPointer< ValueType, Allocator >::RAPIDJSON_DISABLEIF_RETURN ( (internal::NotExpr< internal::IsSame< typename internal::RemoveConst< T >::Type, Ch > >) ,
(GenericPointer< ValueType, Allocator >)  )

Append a name token without length, and return a new Pointer.

Parameters
nameName (const Ch*) to be appended.
allocatorAllocator for the newly return Pointer.
Returns
A new Pointer with appended token.

◆ Swap()

template<typename ValueType, typename Allocator = CrtAllocator>
GenericPointer & GenericPointer< ValueType, Allocator >::Swap ( GenericPointer< ValueType, Allocator > & other)
inline

Swap the content of this pointer with an other.

Parameters
otherThe pointer to swap with.
Note
Constant complexity.

Definition at line 206 of file pointer.h.

◆ swap

template<typename ValueType, typename Allocator = CrtAllocator>
void swap ( GenericPointer< ValueType, Allocator > & a,
GenericPointer< ValueType, Allocator > & b )
friend

free-standing swap function helper

Helper function to enable support for common swap implementation pattern based on std::swap:

void swap(MyClass& a, MyClass& b) {
using std::swap;
swap(a.pointer, b.pointer);
// ...
}
friend void swap(GenericPointer &a, GenericPointer &b) RAPIDJSON_NOEXCEPT
free-standing swap function helper
Definition pointer.h:229
See also
Swap()

Definition at line 229 of file pointer.h.

Member Data Documentation

◆ allocator

template<typename ValueType, typename Allocator = CrtAllocator>
Allocator* GenericPointer< ValueType, Allocator >::allocator

Definition at line 273 of file pointer.h.

◆ allocator_

template<typename ValueType, typename Allocator = CrtAllocator>
Allocator* GenericPointer< ValueType, Allocator >::allocator_

The current allocator. It is either user-supplied or equal to ownAllocator_.

Definition at line 1168 of file pointer.h.

Referenced by GenericPointer< Value, CrtAllocator >::Append().

◆ nameBuffer_

template<typename ValueType, typename Allocator = CrtAllocator>
Ch* GenericPointer< ValueType, Allocator >::nameBuffer_

A buffer containing all names in tokens.

Definition at line 1170 of file pointer.h.

Referenced by GenericPointer< Value, CrtAllocator >::operator=().

◆ ownAllocator_

template<typename ValueType, typename Allocator = CrtAllocator>
Allocator* GenericPointer< ValueType, Allocator >::ownAllocator_

Allocator owned by this Pointer.

Definition at line 1169 of file pointer.h.

◆ parseErrorCode_

template<typename ValueType, typename Allocator = CrtAllocator>
PointerParseErrorCode GenericPointer< ValueType, Allocator >::parseErrorCode_

Parsing error code.

Definition at line 1174 of file pointer.h.

Referenced by GenericPointer< Value, CrtAllocator >::operator=().

◆ parseErrorOffset_

template<typename ValueType, typename Allocator = CrtAllocator>
size_t GenericPointer< ValueType, Allocator >::parseErrorOffset_

Offset in code unit when parsing fail.

Definition at line 1173 of file pointer.h.

Referenced by GenericPointer< Value, CrtAllocator >::operator=().

◆ tokenCount_

template<typename ValueType, typename Allocator = CrtAllocator>
size_t GenericPointer< ValueType, Allocator >::tokenCount_

Number of tokens in tokens_.

Definition at line 1172 of file pointer.h.

Referenced by GenericPointer< Value, CrtAllocator >::operator=().

◆ tokens_

template<typename ValueType, typename Allocator = CrtAllocator>
Token* GenericPointer< ValueType, Allocator >::tokens_

The documentation for this class was generated from the following files: