mirror of
https://github.com/nlohmann/json.git
synced 2025-07-28 12:02:00 +03:00
Consolidate documentation (#3071)
* 🔥 consolidate documentation * ♻️ overwork std specializations * 🚚 move images files to mkdocs * ♻️ fix URLs * 🔧 tweak MkDocs configuration * 🔧 add namespaces * 📝 document deprecations * 📝 document documentation generation * 🚸 improve search * 🚸 add examples * 🚧 start adding documentation for macros * 📝 add note for https://github.com/nlohmann/json/issues/874#issuecomment-1001699139 * 📝 overwork example handling * 📝 fix Markdown tables
This commit is contained in:
@ -1,4 +1,4 @@
|
||||
# basic_json::operator[]
|
||||
# <small>nlohmann::basic_json::</small>operator[]
|
||||
|
||||
```cpp
|
||||
// (1)
|
||||
@ -18,8 +18,8 @@ reference operator[](const json_pointer& ptr);
|
||||
const_reference operator[](const json_pointer& ptr) const;
|
||||
```
|
||||
|
||||
1. Returns a reference to the element at specified location `idx`.
|
||||
2. Returns a reference to the element at with specified key `key`.
|
||||
1. Returns a reference to the array element at specified location `idx`.
|
||||
2. Returns a reference to the object element at with specified key `key`.
|
||||
3. Returns a reference to the element at with specified JSON pointer `ptr`.
|
||||
|
||||
## Template parameters
|
||||
@ -44,6 +44,10 @@ const_reference operator[](const json_pointer& ptr) const;
|
||||
2. reference to the element at key `key`
|
||||
3. reference to the element pointed to by `ptr`
|
||||
|
||||
## Exception safety
|
||||
|
||||
Strong exception safety: if an exception occurs, the original value stays intact.
|
||||
|
||||
## Exceptions
|
||||
|
||||
1. The function can throw the following exceptions:
|
||||
@ -62,6 +66,12 @@ const_reference operator[](const json_pointer& ptr) const;
|
||||
- Throws [`out_of_range.404`](../../home/exceptions.md#jsonexceptionout_of_range404) if the JSON pointer `ptr` can
|
||||
not be resolved.
|
||||
|
||||
## Complexity
|
||||
|
||||
1. Constant if `idx` is in the range of the array. Otherwise, linear in `idx - size()`.
|
||||
2. Logarithmic in the size of the container.
|
||||
3. Constant
|
||||
|
||||
## Notes
|
||||
|
||||
!!! danger
|
||||
@ -80,26 +90,16 @@ const_reference operator[](const json_pointer& ptr) const;
|
||||
|
||||
In particular:
|
||||
|
||||
- If the JSON pointer points to an object key that does not exist, it is created an filled with a `#!json null`
|
||||
- If the JSON pointer points to an object key that does not exist, it is created and filled with a `#!json null`
|
||||
value before a reference to it is returned.
|
||||
- If the JSON pointer points to an array index that does not exist, it is created an filled with a `#!json null`
|
||||
- If the JSON pointer points to an array index that does not exist, it is created and filled with a `#!json null`
|
||||
value before a reference to it is returned. All indices between the current maximum and the given index are also
|
||||
filled with `#!json null`.
|
||||
- The special value `-` is treated as a synonym for the index past the end.
|
||||
|
||||
## Exception safety
|
||||
## Examples
|
||||
|
||||
Strong exception safety: if an exception occurs, the original value stays intact.
|
||||
|
||||
## Complexity
|
||||
|
||||
1. Constant if `idx` is in the range of the array. Otherwise linear in `idx - size()`.
|
||||
2. Logarithmic in the size of the container.
|
||||
3. Constant
|
||||
|
||||
## Example
|
||||
|
||||
??? example
|
||||
??? example "Example (1): access specified array element"
|
||||
|
||||
The example below shows how array elements can be read and written using `[]` operator. Note the addition of
|
||||
`#!json null` values.
|
||||
@ -114,7 +114,7 @@ Strong exception safety: if an exception occurs, the original value stays intact
|
||||
--8<-- "examples/operatorarray__size_type.output"
|
||||
```
|
||||
|
||||
??? example
|
||||
??? example "Example (1): access specified array element"
|
||||
|
||||
The example below shows how array elements can be read using the `[]` operator.
|
||||
|
||||
@ -128,7 +128,7 @@ Strong exception safety: if an exception occurs, the original value stays intact
|
||||
--8<-- "examples/operatorarray__size_type_const.output"
|
||||
```
|
||||
|
||||
??? example
|
||||
??? example "Example (2): access specified object element"
|
||||
|
||||
The example below shows how object elements can be read and written using the `[]` operator.
|
||||
|
||||
@ -142,7 +142,7 @@ Strong exception safety: if an exception occurs, the original value stays intact
|
||||
--8<-- "examples/operatorarray__key_type.output"
|
||||
```
|
||||
|
||||
??? example
|
||||
??? example "Example (2): access specified object element"
|
||||
|
||||
The example below shows how object elements can be read using the `[]` operator.
|
||||
|
||||
@ -156,7 +156,7 @@ Strong exception safety: if an exception occurs, the original value stays intact
|
||||
--8<-- "examples/operatorarray__key_type_const.output"
|
||||
```
|
||||
|
||||
??? example
|
||||
??? example "Example (3): access specified element via JSON Pointer"
|
||||
|
||||
The example below shows how values can be read and written using JSON Pointers.
|
||||
|
||||
@ -170,7 +170,7 @@ Strong exception safety: if an exception occurs, the original value stays intact
|
||||
--8<-- "examples/operatorjson_pointer.output"
|
||||
```
|
||||
|
||||
??? example
|
||||
??? example "Example (3): access specified element via JSON Pointer"
|
||||
|
||||
The example below shows how values can be read using JSON Pointers.
|
||||
|
||||
@ -184,6 +184,11 @@ Strong exception safety: if an exception occurs, the original value stays intact
|
||||
--8<-- "examples/operatorjson_pointer_const.output"
|
||||
```
|
||||
|
||||
## See also
|
||||
|
||||
- see [`at`](at.md) for access by reference with range checking
|
||||
- see [`value`](value.md) for access with default value
|
||||
|
||||
## Version history
|
||||
|
||||
1. Added in version 1.0.0.
|
||||
|
Reference in New Issue
Block a user