utils: fix build error with g++
[project/libubox.git] / sh / jshn.sh
index dab40e4..7b0155d 100644 (file)
@@ -90,7 +90,6 @@ _json_close_table() {
 
        _json_get_var _s_cur JSON_CUR
        _json_get_var "${JSON_PREFIX}JSON_CUR" "U_$_s_cur"
-       unset "${JSON_PREFIX}U_$_s_cur"
 }
 
 json_set_namespace() {
@@ -105,7 +104,7 @@ json_cleanup() {
        local unset tmp
 
        _json_get_var unset JSON_UNSET
-       for tmp in $unset JSON_VAR; do
+       for tmp in $unset J_V; do
                unset \
                        ${JSON_PREFIX}U_$tmp \
                        ${JSON_PREFIX}K_$tmp \
@@ -125,8 +124,8 @@ json_init() {
        json_cleanup
        export -n ${JSON_PREFIX}JSON_SEQ=0
        export -- \
-               ${JSON_PREFIX}JSON_CUR="JSON_VAR" \
-               ${JSON_PREFIX}K_JSON_VAR=
+               ${JSON_PREFIX}JSON_CUR="J_V" \
+               ${JSON_PREFIX}K_J_V=
 }
 
 json_add_object() {
@@ -169,12 +168,22 @@ json_add_double() {
        _json_add_generic double "$1" "$2" "$cur"
 }
 
+json_add_null() {
+       local cur
+       _json_get_var cur JSON_CUR
+       _json_add_generic null "$1" "" "$cur"
+}
+
 # functions read access to json variables
 
 json_load() {
        eval "`jshn -r "$1"`"
 }
 
+json_load_file() {
+       eval "`jshn -R "$1"`"
+}
+
 json_dump() {
        jshn "$@" ${JSON_PREFIX:+-p "$JSON_PREFIX"} -w 
 }
@@ -250,13 +259,12 @@ json_select() {
        local cur
 
        [ -z "$1" ] && {
-               _json_set_var JSON_CUR "JSON_VAR"
+               _json_set_var JSON_CUR "J_V"
                return 0
        }
        [[ "$1" == ".." ]] && {
                _json_get_var cur JSON_CUR
                _json_get_var cur "U_$cur"
-               unset "${JSON_PREFIX}U_$cur"
                _json_set_var JSON_CUR "$cur"
                return 0
        }
@@ -264,7 +272,6 @@ json_select() {
        case "$type" in
                object|array)
                        json_get_var cur "$target"
-                       _json_get_var "${JSON_PREFIX}U_$cur" JSON_CUR
                        _json_set_var JSON_CUR "$cur"
                ;;
                *)
@@ -281,3 +288,28 @@ json_is_a() {
        json_get_type type "$1"
        [ "$type" = "$2" ]
 }
+
+json_for_each_item() {
+       [ "$#" -ge 2 ] || return 0
+       local function="$1"; shift
+       local target="$1"; shift
+       local type val
+
+       json_get_type type "$target"
+       case "$type" in
+               object|array)
+                       local keys key
+                       json_select "$target"
+                       json_get_keys keys
+                       for key in $keys; do
+                               json_get_var val "$key"
+                               eval "$function \"\$val\" \"\$key\" \"\$@\""
+                       done
+                       json_select ..
+               ;;
+               *)
+                       json_get_var val "$target"
+                       eval "$function \"\$val\" \"\" \"\$@\""
+               ;;
+       esac
+}