| # basic_json::array |
| |
| ```cpp |
| static basic_json array(initializer_list_t init = {}); |
| ``` |
| |
| Creates a JSON array value from a given initializer list. That is, given a list of values `a, b, c`, creates the JSON |
| value `#!json [a, b, c]`. If the initializer list is empty, the empty array `#!json []` is created. |
| |
| ## Parameters |
| |
| `init` (in) |
| : initializer list with JSON values to create an array from (optional) |
| |
| ## Return value |
| |
| JSON array value |
| |
| ## Exception safety |
| |
| Strong guarantee: if an exception is thrown, there are no changes in the JSON value. |
| |
| ## Complexity |
| |
| Linear in the size of `init`. |
| |
| ## Notes |
| |
| This function is only needed to express two edge cases that cannot be realized with the initializer list constructor |
| ([`basic_json(initializer_list_t, bool, value_t)`](basic_json.md)). These cases are: |
| |
| 1. creating an array whose elements are all pairs whose first element is a string -- in this case, the initializer list |
| constructor would create an object, taking the first elements as keys |
| 2. creating an empty array -- passing the empty initializer list to the initializer list constructor yields an empty |
| object |
| |
| ## Examples |
| |
| ??? example |
| |
| The following code shows an example for the `array` function. |
| |
| ```cpp |
| --8<-- "examples/array.cpp" |
| ``` |
| |
| Output: |
| |
| ```json |
| --8<-- "examples/array.output" |
| ``` |
| |
| ## Version history |
| |
| - Added in version 1.0.0. |