-json_add_table() {
- local TYPE="$1"
- JSON_SEQ=$(($JSON_SEQ + 1))
- jshn_append JSON_STACK "$JSON_CUR"
- local table="JSON_$TYPE$JSON_SEQ"
- export -- "UP_$table=$JSON_CUR"
- export -- "KEYS_$table="
- jshn_append JSON_UNSET "KEYS_$table UP_$table"
- [ "$TYPE" = "ARRAY" ] && jshn_append JSON_UNSET "SEQ_$table"
- JSON_CUR="$table"
+_json_add_table() {
+ local name="$1"
+ local type="$2"
+ local itype="$3"
+ local cur new_cur
+
+ _json_get_var cur JSON_CUR
+ _json_inc JSON_SEQ seq
+
+ local table="JSON_$itype$seq"
+ _json_export "UP_$table" "$cur"
+ _json_export "KEYS_$table" ""
+ [ "$TYPE" = "ARRAY" ] && _json_export "KEYS_$table" ""
+ _json_stack_push "$table"
+
+ _json_get_var new_cur JSON_CUR
+ _json_add_generic object "$1" "$new_cur" "$cur"
+}
+
+_json_close_table() {
+ local stack new_stack
+
+ _json_get_var stack JSON_STACK
+ _json_set_var cur "${JSON_STACK##* }"
+ new_stack="${stack% *}"
+ [[ "$stack" == "$new_stack" ]] && new_stack=
+ _json_set_var JSON_STACK "$new_stack"
+}
+
+json_set_namespace() {
+ local _new="$1"
+ local _old="$2"
+
+ [ -n "$_old" ] && _set_var "$_old" "$JSON_PREFIX"
+ JSON_PREFIX="$_new"
+}
+
+json_cleanup() {
+ local unset
+
+ _json_get_var unset JSON_UNSET
+ [ -n "$unset" ] && eval "unset $unset"
+
+ unset \
+ ${JSON_PREFIX}JSON_SEQ \
+ ${JSON_PREFIX}JSON_STACK \
+ ${JSON_PREFIX}JSON_CUR \
+ ${JSON_PREFIX}JSON_UNSET \
+ ${JSON_PREFIX}KEYS_JSON_VAR \
+ ${JSON_PREFIX}TYPE_JSON_VAR
+}
+
+json_init() {
+ json_cleanup
+ export -- \
+ ${JSON_PREFIX}JSON_SEQ=0 \
+ ${JSON_PREFIX}JSON_STACK= \
+ ${JSON_PREFIX}JSON_CUR="JSON_VAR" \
+ ${JSON_PREFIX}JSON_UNSET="" \
+ ${JSON_PREFIX}KEYS_JSON_VAR= \
+ ${JSON_PREFIX}TYPE_JSON_VAR=