diff options
author | Felix Fietkau <nbd@openwrt.org> | 2007-02-26 20:04:04 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2007-02-26 20:04:04 +0000 |
commit | 0c9d637c2bed952041141f397c7ec35287156cad (patch) | |
tree | acecda110ad48b648a8f3a3666786581034f00e2 /package/base-files/files/etc/functions.sh | |
parent | 4f62fd89c002d8191a7d0a222e93f5a8eeb9bc42 (diff) | |
download | upstream-0c9d637c2bed952041141f397c7ec35287156cad.tar.gz upstream-0c9d637c2bed952041141f397c7ec35287156cad.tar.bz2 upstream-0c9d637c2bed952041141f397c7ec35287156cad.zip |
Integrate basic UCI config file validation support
Needs more testing and validation is not enforced yet
Code contributed by Fraunhofer Fokus
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@6391 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files/files/etc/functions.sh')
-rwxr-xr-x | package/base-files/files/etc/functions.sh | 37 |
1 files changed, 19 insertions, 18 deletions
diff --git a/package/base-files/files/etc/functions.sh b/package/base-files/files/etc/functions.sh index 5c353a3d01..84121c5458 100755 --- a/package/base-files/files/etc/functions.sh +++ b/package/base-files/files/etc/functions.sh @@ -9,6 +9,7 @@ N=" " _C=0 +NO_EXPORT=1 hotplug_dev() { env -i ACTION=$1 INTERFACE=$2 /sbin/hotplug net @@ -19,7 +20,7 @@ append() { local value="$2" local sep="${3:- }" - eval "export -n -- \"$var=\${$var:+\${$var}\${value:+\$sep}}\$value\"" + eval "export ${NO_EXPORT:+-n} -- \"$var=\${$var:+\${$var}\${value:+\$sep}}\$value\"" } reset_cb() { @@ -32,19 +33,19 @@ config () { local cfgtype="$1" local name="$2" - CONFIG_NUM_SECTIONS=$(($CONFIG_NUM_SECTIONS + 1)) + export ${NO_EXPORT:+-n} CONFIG_NUM_SECTIONS=$(($CONFIG_NUM_SECTIONS + 1)) name="${name:-cfg$CONFIG_NUM_SECTIONS}" append CONFIG_SECTIONS "$name" config_cb "$cfgtype" "$name" - CONFIG_SECTION="$name" - export -n "CONFIG_${CONFIG_SECTION}_TYPE=$cfgtype" + export ${NO_EXPORT:+-n} CONFIG_SECTION="$name" + export ${NO_EXPORT:+-n} "CONFIG_${CONFIG_SECTION}_TYPE=$cfgtype" } option () { local varname="$1"; shift local value="$*" - export -n "CONFIG_${CONFIG_SECTION}_${varname}=$value" + export ${NO_EXPORT:+-n} "CONFIG_${CONFIG_SECTION}_${varname}=$value" option_cb "$varname" "$*" } @@ -58,12 +59,12 @@ config_rename() { for oldvar in `set | grep ^CONFIG_${OLD}_ | \ sed -e 's/\(.*\)=.*$/\1/'` ; do newvar="CONFIG_${NEW}_${oldvar##CONFIG_${OLD}_}" - eval "export -n \"$newvar=\${$oldvar}\"" + eval "export ${NO_EXPORT:+-n} \"$newvar=\${$oldvar}\"" unset "$oldvar" done - CONFIG_SECTIONS="$(echo " $CONFIG_SECTIONS " | sed -e "s, $OLD , $NEW ,")" + export ${NO_EXPORT:+-n} CONFIG_SECTIONS="$(echo " $CONFIG_SECTIONS " | sed -e "s, $OLD , $NEW ,")" - [ "$CONFIG_SECTION" = "$OLD" ] && CONFIG_SECTION="$NEW" + [ "$CONFIG_SECTION" = "$OLD" ] && export ${NO_EXPORT:+-n} CONFIG_SECTION="$NEW" } config_unset() { @@ -74,8 +75,8 @@ config_clear() { local SECTION="$1" local oldvar - CONFIG_SECTIONS="$(echo " $CONFIG_SECTIONS " | sed -e "s, $OLD , ,")" - CONFIG_SECTIONS="${SECTION:+$CONFIG_SECTIONS}" + export ${NO_EXPORT:+-n} CONFIG_SECTIONS="$(echo " $CONFIG_SECTIONS " | sed -e "s, $OLD , ,")" + export ${NO_EXPORT:+-n} CONFIG_SECTIONS="${SECTION:+$CONFIG_SECTIONS}" for oldvar in `set | grep ^CONFIG_${SECTION:+${SECTION}_} | \ sed -e 's/\(.*\)=.*$/\1/'` ; do @@ -84,11 +85,11 @@ config_clear() { } config_load() { - local file="/etc/config/$1" + local file="$UCI_ROOT/etc/config/$1" _C=0 - CONFIG_SECTIONS= - CONFIG_NUM_SECTIONS=0 - CONFIG_SECTION= + export ${NO_EXPORT:+-n} CONFIG_SECTIONS= + export ${NO_EXPORT:+-n} CONFIG_NUM_SECTIONS=0 + export ${NO_EXPORT:+-n} CONFIG_SECTION= [ -e "$file" ] && { . $file @@ -100,7 +101,7 @@ config_load() { config_get() { case "$3" in "") eval "echo \"\${CONFIG_${1}_${2}}\"";; - *) eval "export -n -- \"$1=\${CONFIG_${2}_${3}}\"";; + *) eval "export ${NO_EXPORT:+-n} -- \"$1=\${CONFIG_${2}_${3}}\"";; esac } @@ -108,7 +109,7 @@ config_set() { local section="$1" local option="$2" local value="$3" - export -n "CONFIG_${section}_${option}=$value" + export ${NO_EXPORT:+-n} "CONFIG_${section}_${option}=$value" } config_foreach() { @@ -155,12 +156,12 @@ strtok() { # <string> { <variable> [<separator>] ... } val="${val#$tmp$2}" - export -n "$1=$tmp"; count=$((count+1)) + export ${NO_EXPORT:+-n} "$1=$tmp"; count=$((count+1)) shift 2 done if [ $# -gt 0 -a "$val" ]; then - export -n "$1=$val"; count=$((count+1)) + export ${NO_EXPORT:+-n} "$1=$val"; count=$((count+1)) fi return $count |