diff options
author | Santiago Lapresta <santiago.lapresta@gmail.com> | 2014-12-22 23:05:35 +0100 |
---|---|---|
committer | Santiago Lapresta <santiago.lapresta@gmail.com> | 2014-12-22 23:05:35 +0100 |
commit | 84d3203dd1fe741a76c4ecdd1ca3d8fe7c1a0268 (patch) | |
tree | 91dffa8d1e5de96b6617bf42fe3d204654e16b5f | |
parent | 54a0470c4262711e3897355906906160aab16752 (diff) |
Define `map_values`
-rw-r--r-- | builtin.c | 1 | ||||
-rw-r--r-- | docs/content/3.manual/manual.yml | 13 |
2 files changed, 11 insertions, 3 deletions
@@ -950,6 +950,7 @@ static block bind_bytecoded_builtins(block b) { static const char* const jq_builtins[] = { "def break: error(\"break\");", "def map(f): [.[] | f];", + "def map_values(f): .[] |= f;", "def select(f): if f then . else empty end;", "def sort_by(f): _sort_by_impl(map([f]));", "def group_by(f): _group_by_impl(map([f]));", diff --git a/docs/content/3.manual/manual.yml b/docs/content/3.manual/manual.yml index 42c6c98c..7002b47a 100644 --- a/docs/content/3.manual/manual.yml +++ b/docs/content/3.manual/manual.yml @@ -777,20 +777,27 @@ sections: null and objects would, but with the given message as the error's value. - - title: "`map(x)`" + - title: "`map(x)`, `map_values(x)`" body: | For any filter `x`, `map(x)` will run that filter for each element of the input array, and produce the outputs a new array. `map(.+1)` will increment each element of an array of numbers. - + + Similarly, `map_values(x)` will run that filter for each element, + but it will return an object when an object is passed. + `map(x)` is equivalent to `[.[] | x]`. In fact, this is how - it's defined. + it's defined. Similarly, `map_values(x)` is defined as `.[] |= x`. examples: - program: 'map(.+1)' input: '[1,2,3]' output: ['[2,3,4]'] + + - program: 'map_values(.+1)' + input: '{"a": 1, "b": 2, "c": 3}' + output: ['{"a": 2, "b": 3, "c": 4}'] - title: "`paths`, `paths(node_filter)`, `leaf_paths`" body: | |