json/doc/mkdocs/docs/api/basic_json/erase.md
Florian Albrechtskirchinger 5352856f04
Implement support for string_view (attempt no. 3) (#3423)
* Add key_compare member to ordered_map

* Replace == with key_compare in ordered_map

* Expose the actual comparison function used by object_t

nlohmann::ordered_map uses a different comparison function than the one
provided via template parameter.
* Introduce a type trait to detect if object_t has a key_compare member.
* Rename object_comparator_t to default_object_comparator_t.
* Add object_comparator_t to be conditionally defined as
  object_t::key_compare, if available, or default_object_comparator_t
  otherwise.
* Update the documentation accordingly.

Co-authored-by: Niels Lohmann <niels.lohmann@gmail.com>

* Add type traits to check if a type is usable as object key

Add type trait to check:
* if a type is a specialization of a template.
* if a type is a json_pointer.
* if a type is a basic_json::{const_,}iterator.
* if two types are comparable using a given comparison functor.
* if a type is comparable to basic_json::object_t::key_type.
* if a type has a member type is_transparent.
* if a type is usable as object key.
* if a type has an erase() function accepting a given KeyType.

Co-authored-by: Niels Lohmann <niels.lohmann@gmail.com>

* Rework basic_json element access to accept more key types

Rework basic_json element access member functions and operators to
accept any type that meets the requirements defined by type trait
detail::is_usable_as_key_type.

Member functions and operators:
* at()
* operator[]
* value()
* erase()
* find()
* count()
* contains()

Update documentation to reflect these changes.

Add unit tests to excercise the new functions using std::string_view.

Co-authored-by: Niels Lohmann <niels.lohmann@gmail.com>

Co-authored-by: Niels Lohmann <niels.lohmann@gmail.com>
2022-04-29 21:40:02 +02:00

6.9 KiB

nlohmann::basic_json::erase

// (1)
iterator erase(iterator pos);
const_iterator erase(const_iterator pos);

// (2)
iterator erase(iterator first, iterator last);
const_iterator erase(const_iterator first, const_iterator last);

// (3)
size_type erase(const typename object_t::key_type& key);

// (4)
template<typename KeyType>
size_type erase(KeyType&& key);

// (5)
void erase(const size_type idx);
  1. Removes an element from a JSON value specified by iterator pos. The iterator pos must be valid and dereferenceable. Thus, the end() iterator (which is valid, but is not dereferenceable) cannot be used as a value for pos.

    If called on a primitive type other than #!json null, the resulting JSON value will be #!json null.

  2. Remove an element range specified by [first; last) from a JSON value. The iterator first does not need to be dereferenceable if first == last: erasing an empty range is a no-op.

    If called on a primitive type other than #!json null, the resulting JSON value will be #!json null.

  3. Removes an element from a JSON object by key.

  4. See 3. This overload is only available if KeyType is comparable with #!cpp typename object_t::key_type and #!cpp typename object_comparator_t::is_transparent denotes a type.

  5. Removes an element from a JSON array by index.

Template parameters

KeyType
A type for an object key other than json_pointer that is comparable with string_t using object_comparator_t. This can also be a string view (C++17).

Parameters

pos (in)
iterator to the element to remove
first (in)
iterator to the beginning of the range to remove
last (in)
iterator past the end of the range to remove
key (in)
object key of the elements to remove
idx (in)
array index of the element to remove

Return value

  1. Iterator following the last removed element. If the iterator pos refers to the last element, the end() iterator is returned.
  2. Iterator following the last removed element. If the iterator last refers to the last element, the end() iterator is returned.
  3. Number of elements removed. If ObjectType is the default std::map type, the return value will always be 0 (key was not found) or 1 (key was found).
  4. See 3.
  5. (none)

Exception safety

Strong exception safety: if an exception occurs, the original value stays intact.

Exceptions

  1. The function can throw the following exceptions:
    • Throws type_error.307 if called on a null value; example: "cannot use erase() with null"
    • Throws invalid_iterator.202 if called on an iterator which does not belong to the current JSON value; example: "iterator does not fit current value"
    • Throws invalid_iterator.205 if called on a primitive type with invalid iterator (i.e., any iterator which is not begin()); example: "iterator out of range"
  2. The function can throw the following exceptions:
    • Throws type_error.307 if called on a null value; example: "cannot use erase() with null"
    • Throws invalid_iterator.203 if called on iterators which does not belong to the current JSON value; example: "iterators do not fit current value"
    • Throws invalid_iterator.204 if called on a primitive type with invalid iterators (i.e., if first != begin() and last != end()); example: "iterators out of range"
  3. The function can throw the following exceptions:
    • Throws type_error.307 when called on a type other than JSON object; example: "cannot use erase() with null"
  4. See 3.
  5. The function can throw the following exceptions:
    • Throws type_error.307 when called on a type other than JSON object; example: "cannot use erase() with null"
    • Throws out_of_range.401 when idx >= size(); example: "array index 17 is out of range"

Complexity

  1. The complexity depends on the type: - objects: amortized constant - arrays: linear in distance between pos and the end of the container - strings and binary: linear in the length of the member - other types: constant
  2. The complexity depends on the type: - objects: log(size()) + std::distance(first, last) - arrays: linear in the distance between first and last, plus linear in the distance between last and end of the container - strings and binary: linear in the length of the member - other types: constant
  3. log(size()) + count(key)
  4. log(size()) + count(key)
  5. Linear in distance between idx and the end of the container.

Notes

  1. Invalidates iterators and references at or after the point of the erase, including the end() iterator.
  2. (none)
  3. References and iterators to the erased elements are invalidated. Other references and iterators are not affected.
  4. See 3.
  5. (none)

Examples

??? example "Example: (1) remove element given an iterator"

The example shows the effect of `erase()` for different JSON types using an iterator.

```cpp
--8<-- "examples/erase__IteratorType.cpp"
```

Output:

```json
--8<-- "examples/erase__IteratorType.output"
```

??? example "Example: (2) remove elements given an iterator range"

The example shows the effect of `erase()` for different JSON types using an iterator range.

```cpp
--8<-- "examples/erase__IteratorType_IteratorType.cpp"
```

Output:

```json
--8<-- "examples/erase__IteratorType_IteratorType.output"
```

??? example "Example: (3) remove element from a JSON object given a key"

The example shows the effect of `erase()` for different JSON types using an object key.

```cpp
--8<-- "examples/erase__key_type.cpp"
```

Output:

```json
--8<-- "examples/erase__key_type.output"
```

??? example "Example: (5) remove element from a JSON array given an index"

The example shows the effect of `erase()` using an array index.

```cpp
--8<-- "examples/erase__size_type.cpp"
```

Output:

```json
--8<-- "examples/erase__size_type.output"
```

Version history

  1. Added in version 1.0.0. Added support for binary types in version 3.8.0.
  2. Added in version 1.0.0. Added support for binary types in version 3.8.0.
  3. Added in version 1.0.0.
  4. Added in version 3.11.0.
  5. Added in version 1.0.0.