diff options
author | Felix Fietkau <nbd@openwrt.org> | 2006-05-10 18:17:12 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2006-05-10 18:17:12 +0000 |
commit | d31393efd881be6725ad73c26e1e36c1050a77a8 (patch) | |
tree | cf9317d4956f03586d74c8190ed1f37346aa0674 | |
parent | 3b00d75ff57eb2288e2d582946515f23bd358e3f (diff) | |
download | mtk-20170518-d31393efd881be6725ad73c26e1e36c1050a77a8.zip mtk-20170518-d31393efd881be6725ad73c26e1e36c1050a77a8.tar.gz mtk-20170518-d31393efd881be6725ad73c26e1e36c1050a77a8.tar.bz2 |
add common functions for the new config file format
SVN-Revision: 3751
-rwxr-xr-x | openwrt/package/base-files/default/etc/functions.sh | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/openwrt/package/base-files/default/etc/functions.sh b/openwrt/package/base-files/default/etc/functions.sh index 526ca52..858dc28 100755 --- a/openwrt/package/base-files/default/etc/functions.sh +++ b/openwrt/package/base-files/default/etc/functions.sh @@ -11,3 +11,53 @@ if_valid () ( hotplug_dev() { env -i ACTION=$1 INTERFACE=$2 /sbin/hotplug net } + +config_cb() { + return 0 +} +option_cb() { + return 0 +} + +config () { + config_cb "$@" + _C=$((${_C:-0} + 1)) + export CONFIG_SECTION="${2:-cfg${_C}}" + export CONFIG_${CONFIG_SECTION}_TYPE="$1" +} + +option () { + local varname="$1" ; shift + export CONFIG_${CONFIG_SECTION}_${varname}="$*" + option_cb "$varname" "$*" +} + +config_clear() { + [ -z "$CONFIG_SECTION" ] && return + for oldsetting in `set | grep ^CONFIG_${CONFIG_SECTION}_ | \ + sed -e 's/\(.*\)=.*$/\1/'` ; do + unset $oldsetting + done + unset CONFIG_SECTION +} + +config_load() { + local CD="" + if [ \! -e "$1" -a -e "/etc/config/$1" ]; then + cd /etc/config && local CD=1 + fi + [ -e "$1" ] && . $1 + ${CD:+cd - >/dev/null} + ${CONFIG_SECTION:+config_cb} +} + +config_get() { + case "$3" in + "") eval "echo \${CONFIG_${1}_${2}}";; + *) eval "$1=\"\${CONFIG_${2}_${3}}\"";; + esac +} + +config_set() { + export CONFIG_${1}_${2}="${3}" +} |