summaryrefslogtreecommitdiff
path: root/openwrt/package/base-files/default/etc/functions.sh
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2006-05-10 18:17:12 +0000
committerFelix Fietkau <nbd@openwrt.org>2006-05-10 18:17:12 +0000
commit49003208ab2d0ec414faefe2079c97e0a72e394c (patch)
tree2131d39a69d99b1e57055cd81c856b053f0483be /openwrt/package/base-files/default/etc/functions.sh
parentbcee262e7ae1e35ff83fbf6e12b1dbd0251b8700 (diff)
downloadmtk-20170518-49003208ab2d0ec414faefe2079c97e0a72e394c.zip
mtk-20170518-49003208ab2d0ec414faefe2079c97e0a72e394c.tar.gz
mtk-20170518-49003208ab2d0ec414faefe2079c97e0a72e394c.tar.bz2
add common functions for the new config file format
SVN-Revision: 3751
Diffstat (limited to 'openwrt/package/base-files/default/etc/functions.sh')
-rwxr-xr-xopenwrt/package/base-files/default/etc/functions.sh50
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}"
+}