1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
### jsoncons::jsonpath::jsonpath_expression::update
```cpp
template <typename BinaryOp>
void update(reference root, BinaryOp op); (1) (since 0.172.0)
```
(1) Evaluates the root value against the compiled JSONPath expression and calls a provided
callback repeatedly with the results.
#### Parameters
<table>
<tr>
<td>root</td>
<td>Root JSON value</td>
</tr>
<tr>
<td><code>op</code></td>
<td>A function object that accepts a path and a reference to a Json value.
It must have function call signature equivalent to
<br/><br/><code>void fun(const basic_path_node<Json::char_type>& path, Json& val);</code><br/><br/>
</tr>
</table>
The callback receives nodes with duplicates removed, and paths sorted in descending order.
### Examples
#### Update in place
```cpp
#include <jsoncons/json.hpp>
#include <jsoncons_ext/jsonpath/jsonpath.hpp>
using json = jsoncons::json;
namespace jsonpath = jsoncons::jsonpath;
int main()
{
auto expr = jsoncons::jsonpath::make_expression<json>("$.books[*]");
std::ifstream is(/*path_to_books_file*/);
json doc = json::parse(is);
auto callback = [](const jsonpath::path_node& /*path*/, json& book)
{
if (book.at("category") == "memoir" && !book.contains("price"))
{
book.try_emplace("price", 140.0);
}
};
expr.update(doc, callback);
}
```
Output:
```
{
"author": "Phillips, David Atlee",
"category": "memoir",
"price": 140.0,
"title": "The Night Watch"
}
```
|