jshn.sh: Add pretty-printing to json_dump
authorPhilip Prindeville <philipp@redfish-solutions.com>
Fri, 14 Apr 2023 18:37:05 +0000 (12:37 -0600)
committerAlexander Couzens <lynxis@fe80.eu>
Sat, 15 Apr 2023 13:04:19 +0000 (15:04 +0200)
If a JSON file might be read by a human, say for debugging, it
could be useful to pretty-print it.  We do this in places by
calling "json_dump -i" but it shouldn't be necessary to know the
arguments to "jshn" (and indeed, that's not portable if we retool
the underlying implementation). Conversely output that's ephemeral
doesn't need to be pretty (say being piped as input to another
command).

Signed-off-by: Philip Prindeville <philipp@redfish-solutions.com>
sh/jshn.sh

index c97369230a93d144fbba06b5a8fa79c9acc41238..1d3055711820e5a21ea59cae49e7bf3f56b626d8 100644 (file)
@@ -199,6 +199,16 @@ json_add_fields() {
 
 # functions read access to json variables
 
+json_compact() {
+       JSON_NONEWLINE=1
+       JSON_INDENT=
+}
+
+json_pretty() {
+       JSON_NONEWLINE=
+       JSON_INDENT=1
+}
+
 json_load() {
        eval "`jshn -r "$1"`"
 }
@@ -208,7 +218,7 @@ json_load_file() {
 }
 
 json_dump() {
-       jshn "$@" ${JSON_PREFIX:+-p "$JSON_PREFIX"} -w 
+       jshn "$@" ${JSON_PREFIX:+-p "$JSON_PREFIX"} ${JSON_NONEWLINE:+-n} ${JSON_INDENT:+-i} -w
 }
 
 json_get_type() {