X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/4f09c2f1f6c0d603d93c61b9f977156599862302..356535ffd7bc1343ce6bc2fc367f788cc2c1bd24:/package/base-files/default/etc/functions.sh diff --git a/package/base-files/default/etc/functions.sh b/package/base-files/default/etc/functions.sh index fbb5a160c..bf412df6d 100755 --- a/package/base-files/default/etc/functions.sh +++ b/package/base-files/default/etc/functions.sh @@ -1,16 +1,14 @@ #!/bin/sh +# Copyright (C) 2006 OpenWrt.org +# Copyright (C) 2006 Fokus Fraunhofer + alias debug=${DEBUG:-:} # newline -N=" +readonly N=" " -# valid interface? -if_valid () ( - ifconfig "$1" >&- 2>&- || - [ "${1%%[0-9]}" = "br" ] || - { debug "# missing interface '$1' ignored"; false; } -) +_C=0 hotplug_dev() { env -i ACTION=$1 INTERFACE=$2 /sbin/hotplug net @@ -20,59 +18,132 @@ append() { local var="$1" local value="$2" local sep="${3:- }" - eval "export ${var}=\"\${${var}:+\${${var}}${value:+$sep}}$value\"" + + eval "export -n -- \"$var=\${$var:+\${$var}\${value:+\$sep}}\$value\"" } -config_cb() { - return 0 -} -option_cb() { - return 0 +reset_cb() { + config_cb() { return 0; } + option_cb() { return 0; } } +reset_cb config () { - config_cb "$@" - _C=$((${_C:-0} + 1)) - export CONFIG_SECTION="${2:-cfg${_C}}" - export CONFIG_${CONFIG_SECTION}_TYPE="$1" + local cfgtype="$1" + local name="$2" + + _C=$((_C + 1)) + name="${name:-cfg${_C}}" + config_cb "$cfgtype" "$name" + CONFIG_SECTION="$name" + export -n "CONFIG_${CONFIG_SECTION}_TYPE=$cfgtype" } option () { - local varname="$1" ; shift - export CONFIG_${CONFIG_SECTION}_${varname}="$*" + local varname="$1"; shift + local value="$*" + + export -n "CONFIG_${CONFIG_SECTION}_${varname}=$value" option_cb "$varname" "$*" } +config_rename() { + local OLD="$1" + local NEW="$2" + local oldvar + local newvar + + [ "$OLD" -a "$NEW" ] || return + for oldvar in `set | grep ^CONFIG_${OLD}_ | \ + sed -e 's/\(.*\)=.*$/\1/'` ; do + newvar="CONFIG_${NEW}_${oldvar##CONFIG_${OLD}_}" + eval "export -n \"$newvar=\${$oldvar}\"" + unset "$oldvar" + done + + [ "$CONFIG_SECTION" = "$OLD" ] && CONFIG_SECTION="$NEW" +} + +config_unset() { + config_set "$1" "$2" "" +} + config_clear() { - [ -z "$CONFIG_SECTION" ] && return - for oldsetting in `set | grep ^CONFIG_${CONFIG_SECTION}_ | \ + local SECTION="$1" + local oldvar + + for oldvar in `set | grep ^CONFIG_${SECTION}_ | \ sed -e 's/\(.*\)=.*$/\1/'` ; do - unset $oldsetting + unset $oldvar 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} + local file="/etc/config/$1" + _C=0 + CONFIG_SECTION= + + [ -e "$file" ] && { + . $file + } || return 1 + ${CONFIG_SECTION:+config_cb} } config_get() { case "$3" in - "") eval "echo \${CONFIG_${1}_${2}}";; - *) eval "$1=\"\${CONFIG_${2}_${3}}\"";; + "") eval "echo \"\${CONFIG_${1}_${2}}\"";; + *) eval "export -n -- \"$1=\${CONFIG_${2}_${3}}\"";; esac } config_set() { - export CONFIG_${1}_${2}="${3}" + local section="$1" + local option="$2" + local value="$3" + export -n "CONFIG_${section}_${option}=$value" } load_modules() { sed 's/^[^#]/insmod &/' $* | ash 2>&- || : } + +include() { + local file + + for file in $(ls $1/*.sh 2>/dev/null); do + . $file + done +} + +find_mtd_part() { + local PART="$(grep "\"$1\"" /proc/mtd | awk -F: '{print $1}')" + + PART="${PART##mtd}" + echo "${PART:+/dev/mtdblock/$PART}" +} + +strtok() { # { [] ... } + local tmp + local val="$1" + local count=0 + + shift + + while [ $# -gt 1 ]; do + tmp="${val%%$2*}" + + [ "$tmp" = "$val" ] && break + + val="${val#$tmp$2}" + + export -n "$1=$tmp"; count=$((count+1)) + shift 2 + done + + if [ $# -gt 0 -a "$val" ]; then + export -n "$1=$val"; count=$((count+1)) + fi + + return $count +}