jshn: support using characters in elements that do not conform to shell variable restrictions
This commit is contained in:
parent
dee81b4f79
commit
a1a97eb11e
2 changed files with 16 additions and 7 deletions
15
jshn.c
15
jshn.c
|
@ -150,14 +150,19 @@ static char *get_keys(const char *prefix)
|
||||||
return getenv(keys);
|
return getenv(keys);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void get_var(const char *prefix, const char *name, char **var, char **type)
|
static void get_var(const char *prefix, const char **name, char **var, char **type)
|
||||||
{
|
{
|
||||||
char *tmpname;
|
char *tmpname, *varname;
|
||||||
|
|
||||||
tmpname = alloca(strlen(prefix) + 1 + strlen(name) + 1 + sizeof("TYPE_"));
|
tmpname = alloca(strlen(prefix) + 1 + strlen(*name) + 1 + sizeof("TYPE_"));
|
||||||
sprintf(tmpname, "TYPE_%s_%s", prefix, name);
|
sprintf(tmpname, "TYPE_%s_%s", prefix, *name);
|
||||||
*var = getenv(tmpname + 5);
|
*var = getenv(tmpname + 5);
|
||||||
*type = getenv(tmpname);
|
*type = getenv(tmpname);
|
||||||
|
|
||||||
|
memcpy(tmpname, "NAME", 4);
|
||||||
|
varname = getenv(tmpname);
|
||||||
|
if (varname)
|
||||||
|
*name = varname;
|
||||||
}
|
}
|
||||||
|
|
||||||
static json_object *jshn_add_objects(json_object *obj, const char *prefix, bool array);
|
static json_object *jshn_add_objects(json_object *obj, const char *prefix, bool array);
|
||||||
|
@ -167,7 +172,7 @@ static void jshn_add_object_var(json_object *obj, bool array, const char *prefix
|
||||||
json_object *new;
|
json_object *new;
|
||||||
char *var, *type;
|
char *var, *type;
|
||||||
|
|
||||||
get_var(prefix, name, &var, &type);
|
get_var(prefix, &name, &var, &type);
|
||||||
if (!var || !type)
|
if (!var || !type)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -19,11 +19,15 @@ json_add_generic() {
|
||||||
local val="$3"
|
local val="$3"
|
||||||
local cur="${4:-$JSON_CUR}"
|
local cur="${4:-$JSON_CUR}"
|
||||||
|
|
||||||
[ "${cur%%[0-9]*}" = "JSON_ARRAY" ] && {
|
if [ "${cur%%[0-9]*}" = "JSON_ARRAY" ]; then
|
||||||
eval "local aseq=\"\${SEQ_$cur}\""
|
eval "local aseq=\"\${SEQ_$cur}\""
|
||||||
var=$(( ${aseq:-0} + 1 ))
|
var=$(( ${aseq:-0} + 1 ))
|
||||||
export -- "SEQ_$cur=$var"
|
export -- "SEQ_$cur=$var"
|
||||||
}
|
else
|
||||||
|
local name="$(echo -n "$var" | tr -C '[a-zA-Z_]' _)"
|
||||||
|
[[ "$name" == "$var" ]] || export -- "NAME_${cur}_${name}=$var"
|
||||||
|
var="$name"
|
||||||
|
fi
|
||||||
|
|
||||||
export -- "${cur}_$var=$val"
|
export -- "${cur}_$var=$val"
|
||||||
export -- "TYPE_${cur}_$var=$type"
|
export -- "TYPE_${cur}_$var=$type"
|
||||||
|
|
Loading…
Reference in a new issue