A string library for Zsh. Its founding function was parsing of JSON.
Parses the buffer ($1) with JSON and returns:
-
Fields for the given key (
$2) in the given hash ($3). -
The hash looks like follows:
1/1 → strings at the level 1 of the 1st object 1/2 → strings at the level 1 of the 2nd object … 2/1 → strings at 2nd level of the 1st object …
The strings are parseable with
"${(@Q)${(@z)value}", i.e.: they're concatenated and quoted strings found in the JSON.
Example:
{ "zi-ices": { "default": { "wait": "1", "lucid": "", "as": "program", "pick": "fzy", "make": "" }, "bgn": { "wait": "1", "lucid": "", "as": "null", "make": "", "sbin": "fzy;contrib/fzy-*" } } }Will result in:
local -A Strings Strings[1/1]="zi-ices" Strings[2/1]="default $'\0'--object--$'\0' bgn $'\0'--object--$'\0'" Strings[3/1]='wait 1 lucid \ as program pick fzy make \ ' Strings[3/2]='wait 1 lucid \ as null make \ sbin fzy\;contrib/fzy-\*'So that when you e.g.: expect a key bgn but don't know at which position, you can do:
local -A Strings @str-parse-json "$json" "zi-ices" Strings integer pos # (I) flag returns index at which the `bgn' string # has been found in the array – the result of the # (z)-split of the Strings[2/1] string pos=${${(@Q)${(@z)Strings[2/1]}}[(I)bgn]} if (( pos )) { local -A ices ices=( "${(@Q)${(@z)Strings[3/$(( (pos+1) / 2 ))]}}" ) # Use the `ices' hash holding the values of the `bgn' object … }Note that the $'\0' is correctly dequoted by Q flag into the null byte.
Arguments:
- The buffer with JSON.
- The key in the JSON that should be mapped to the result (i.e.: it's possible to map only a subset of the input). It must be the first key in the object to map.
- The name of the output hash parameter.
Consumes whole data from given file descriptor and stores the string under the given ($2) parameter, which is REPLY by default.
The reason to create this function is speed – it's much faster than read -d ''.
It can try hard to read the whole data by retrying multiple times (10 by default) and sleeping before each retry (not done by default).
Arguments:
- File descriptor (a number; use
1for stdin) to be read from. - Name of output variable (default:
REPLY). - Numer of retries (default:
10). - Sleep time after each retry (a float; default:
0).
Example:
exec {FD}< =( cat /etc/motd ) @str-read-all $FD print -r -- $REPLY …Returns a non-greedy match of the given pattern ($2) in the given string ($1).
- The string to match in.
- The pattern to match in the string.
Return value:
$REPLY– the matched string, if found,- return code:
0if there was a match found, otherwise1.
Example:
if @str-ng-match "abb" "a*b"; then print -r -- $REPLY fi Output: abReturns all non-greedy matches of the given pattern in the given list of strings.
Input:
$1…$n-1- the strings to match in,$n- the pattern to match in the strings.
Return value:
$reply– contains all the matches,$REPLY- holds the first match,- return code:
0if there was any match found, otherwise1.
Example:
arr=( a1xx ayy a2xx ) if @str-ng-matches ${arr[@]} "a*x"; then print -rl -- $reply fi Outout: a1x a2xReads an INI file.
Arguments:
- Path to the ini file to parse.
- Name of output hash (
INIby default). - Prefix for keys in the hash (can be empty).
Writes to given hash under keys built in following way: ${3}<section>_field. Values are the values from the ini file.
Reads a TOML file with support for single-level array.
- Path to the TOML file to parse.
- Name of output hash (
TOMLby default). - Prefix for keys in the hash (can be empty).
Writes to given hash under keys built in following way: ${3}<section>_field. Values are the values from the TOML file.
The values can be quoted and concatenated strings if they're an array. For example:
[sec] array = [ val1, "value 2", value&3 ]Then the fields of the hash will be:
TOML[<sec>_array]="val1 value\ 2 value\&3"To retrieve the array stored in such way, use the substitution "${(@Q)${(@z)TOML[<sec>_array]}}":
local -a array array=( "${(@Q)${(@z)TOML[<sec>_array]}}" )(The substitution first splits the input string as if Zsh would split it on the command line – with the (z) flag, and then removes one level of quoting with the (Q) flag).
Dumps the contents of the variable, whether it's being a scalar, an array or a hash. The contents of the hash are sorted on the keys numerically, i.e.: by using (on) flags.
An option -q can be provided: it'll enable quoting of the printed data with the q-flag (i.e.: backslash quoting).
Basically, the function Is an alternative to declare -p, with a different output format, more dump-like.
Arguments:
- The name of the variable of which contents should be dumped.
Example:
array=( "" "a value" "test" ) @str-dump -q arrayOutput:
'' a\ value testtypeset -A hash=( "a key" "a value" key value ) @str-dump -q hashOutput:
a\ key: a\ value key: value