summaryrefslogtreecommitdiff
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
commitd31393efd881be6725ad73c26e1e36c1050a77a8 (patch)
treecf9317d4956f03586d74c8190ed1f37346aa0674
parent3b00d75ff57eb2288e2d582946515f23bd358e3f (diff)
downloadmtk-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-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}"
+}