| # basic_json::diff |
| |
| ```cpp |
| static basic_json diff(const basic_json& source, |
| const basic_json& target); |
| ``` |
| |
| Creates a [JSON Patch](http://jsonpatch.com) so that value `source` can be changed into the value `target` by calling |
| [`patch`](patch.md) function. |
| |
| For two JSON values `source` and `target`, the following code yields always `#!cpp true`: |
| ```cpp |
| source.patch(diff(source, target)) == target; |
| ``` |
| |
| ## Parameters |
| |
| `source` (in) |
| : JSON value to compare from |
| |
| `target` (in) |
| : JSON value to compare against |
| |
| ## Return value |
| |
| a JSON patch to convert the `source` to `target` |
| |
| ## Exception safety |
| |
| Strong guarantee: if an exception is thrown, there are no changes in the JSON value. |
| |
| ## Complexity |
| |
| Linear in the lengths of `source` and `target`. |
| |
| ## Note |
| |
| Currently, only `remove`, `add`, and `replace` operations are generated. |
| |
| ## Example |
| |
| ??? example |
| |
| The following code shows how a JSON patch is created as a diff for two JSON values. |
| |
| ```cpp |
| --8<-- "examples/diff.cpp" |
| ``` |
| |
| Output: |
| |
| ```json |
| --8<-- "examples/diff.output" |
| ``` |
| |
| ## Version history |
| |
| - Added in version 2.0.0. |