| 1 | # Copyright 1999-2005 Gentoo Foundation |
|---|
| 2 | # Distributed under the terms of the GNU General Public License v2 |
|---|
| 3 | # $Header$ |
|---|
| 4 | |
|---|
| 5 | RC_GOT_FUNCTIONS="yes" |
|---|
| 6 | |
|---|
| 7 | # daemontools dir |
|---|
| 8 | SVCDIR="/var/lib/supervise" |
|---|
| 9 | |
|---|
| 10 | # Check /etc/conf.d/rc for a description of these ... |
|---|
| 11 | svcdir="/var/lib/init.d" |
|---|
| 12 | svclib="/lib/rcscripts" |
|---|
| 13 | svcmount="no" |
|---|
| 14 | svcfstype="tmpfs" |
|---|
| 15 | svcsize=1024 |
|---|
| 16 | |
|---|
| 17 | # Different types of dependencies |
|---|
| 18 | deptypes="need use" |
|---|
| 19 | # Different types of order deps |
|---|
| 20 | ordtypes="before after" |
|---|
| 21 | |
|---|
| 22 | # |
|---|
| 23 | # Internal variables |
|---|
| 24 | # |
|---|
| 25 | |
|---|
| 26 | # Dont output to stdout? |
|---|
| 27 | RC_QUIET_STDOUT="no" |
|---|
| 28 | RC_VERBOSE=${RC_VERBOSE:-no} |
|---|
| 29 | |
|---|
| 30 | # Should we use color? |
|---|
| 31 | RC_NOCOLOR=${RC_NOCOLOR:-no} |
|---|
| 32 | # Can the terminal handle endcols? |
|---|
| 33 | RC_ENDCOL="yes" |
|---|
| 34 | |
|---|
| 35 | # |
|---|
| 36 | # Default values for rc system |
|---|
| 37 | # |
|---|
| 38 | RC_TTY_NUMBER=11 |
|---|
| 39 | RC_NET_STRICT_CHECKING="no" |
|---|
| 40 | RC_PARALLEL_STARTUP="no" |
|---|
| 41 | RC_USE_CONFIG_PROFILE="yes" |
|---|
| 42 | |
|---|
| 43 | # |
|---|
| 44 | # Default values for e-message indentation and dots |
|---|
| 45 | # |
|---|
| 46 | RC_INDENTATION='' |
|---|
| 47 | RC_DEFAULT_INDENT=2 |
|---|
| 48 | #RC_DOT_PATTERN=' .' |
|---|
| 49 | RC_DOT_PATTERN='' |
|---|
| 50 | |
|---|
| 51 | # Override defaults with user settings ... |
|---|
| 52 | [ -f /etc/conf.d/rc ] && source /etc/conf.d/rc |
|---|
| 53 | |
|---|
| 54 | # void import_addon(char *addon) |
|---|
| 55 | # |
|---|
| 56 | # Import code from the specified addon if it exists |
|---|
| 57 | # |
|---|
| 58 | import_addon() { |
|---|
| 59 | local addon=${svclib}/addons/$1 |
|---|
| 60 | if [[ -r ${addon} ]] ; then |
|---|
| 61 | source "${addon}" |
|---|
| 62 | return 0 |
|---|
| 63 | fi |
|---|
| 64 | return 1 |
|---|
| 65 | } |
|---|
| 66 | |
|---|
| 67 | # void splash(...) |
|---|
| 68 | # |
|---|
| 69 | # Notify bootsplash/splashutils/gensplash/whatever about |
|---|
| 70 | # important events. |
|---|
| 71 | # |
|---|
| 72 | splash() { |
|---|
| 73 | return 0 |
|---|
| 74 | } |
|---|
| 75 | # This will override the splash() function... |
|---|
| 76 | if ! import_addon splash-functions.sh ; then |
|---|
| 77 | [ -f /sbin/splash-functions.sh ] && source /sbin/splash-functions.sh |
|---|
| 78 | fi |
|---|
| 79 | |
|---|
| 80 | # void profiling(...) |
|---|
| 81 | # |
|---|
| 82 | # Notify bootsplash/whatever about important events. |
|---|
| 83 | # |
|---|
| 84 | profiling() { |
|---|
| 85 | return 0 |
|---|
| 86 | } |
|---|
| 87 | import_addon profiling-functions.sh |
|---|
| 88 | |
|---|
| 89 | # void bootlog(...) |
|---|
| 90 | # |
|---|
| 91 | # Notify bootlogger about important events. |
|---|
| 92 | bootlog() { |
|---|
| 93 | return 0 |
|---|
| 94 | } |
|---|
| 95 | import_addon bootlogger.sh |
|---|
| 96 | |
|---|
| 97 | # void get_bootconfig() |
|---|
| 98 | # |
|---|
| 99 | # Get the BOOTLEVEL and SOFTLEVEL by setting |
|---|
| 100 | # 'bootlevel' and 'softlevel' via kernel |
|---|
| 101 | # parameters. |
|---|
| 102 | # |
|---|
| 103 | get_bootconfig() { |
|---|
| 104 | local copt= |
|---|
| 105 | local newbootlevel= |
|---|
| 106 | local newsoftlevel= |
|---|
| 107 | |
|---|
| 108 | if [[ -r /proc/cmdline ]] ; then |
|---|
| 109 | for copt in $(</proc/cmdline) ; do |
|---|
| 110 | case "${copt%=*}" in |
|---|
| 111 | bootlevel) |
|---|
| 112 | newbootlevel=${copt##*=} |
|---|
| 113 | ;; |
|---|
| 114 | softlevel) |
|---|
| 115 | newsoftlevel=${copt##*=} |
|---|
| 116 | ;; |
|---|
| 117 | esac |
|---|
| 118 | done |
|---|
| 119 | fi |
|---|
| 120 | |
|---|
| 121 | if [[ -n ${newbootlevel} ]] ; then |
|---|
| 122 | export BOOTLEVEL=${newbootlevel} |
|---|
| 123 | else |
|---|
| 124 | export BOOTLEVEL="boot" |
|---|
| 125 | fi |
|---|
| 126 | |
|---|
| 127 | if [[ -n ${newsoftlevel} ]] ; then |
|---|
| 128 | export DEFAULTLEVEL=${newsoftlevel} |
|---|
| 129 | else |
|---|
| 130 | export DEFAULTLEVEL="default" |
|---|
| 131 | fi |
|---|
| 132 | |
|---|
| 133 | return 0 |
|---|
| 134 | } |
|---|
| 135 | |
|---|
| 136 | setup_defaultlevels() { |
|---|
| 137 | get_bootconfig |
|---|
| 138 | |
|---|
| 139 | if get_bootparam "noconfigprofile" ; then |
|---|
| 140 | export RC_USE_CONFIG_PROFILE="no" |
|---|
| 141 | |
|---|
| 142 | elif get_bootparam "configprofile" ; then |
|---|
| 143 | export RC_USE_CONFIG_PROFILE="yes" |
|---|
| 144 | fi |
|---|
| 145 | |
|---|
| 146 | if [ "${RC_USE_CONFIG_PROFILE}" = "yes" -a -n "${DEFAULTLEVEL}" ] && \ |
|---|
| 147 | [ -d "/etc/runlevels/${BOOTLEVEL}.${DEFAULTLEVEL}" -o \ |
|---|
| 148 | -L "/etc/runlevels/${BOOTLEVEL}.${DEFAULTLEVEL}" ] |
|---|
| 149 | then |
|---|
| 150 | export BOOTLEVEL="${BOOTLEVEL}.${DEFAULTLEVEL}" |
|---|
| 151 | fi |
|---|
| 152 | |
|---|
| 153 | if [ -z "${SOFTLEVEL}" ] ; then |
|---|
| 154 | if [ -f "${svcdir}/softlevel" ] ; then |
|---|
| 155 | export SOFTLEVEL="$(< ${svcdir}/softlevel)" |
|---|
| 156 | else |
|---|
| 157 | export SOFTLEVEL="${BOOTLEVEL}" |
|---|
| 158 | fi |
|---|
| 159 | fi |
|---|
| 160 | |
|---|
| 161 | return 0 |
|---|
| 162 | } |
|---|
| 163 | |
|---|
| 164 | # void get_libdir(void) |
|---|
| 165 | # |
|---|
| 166 | # prints the current libdir {lib,lib32,lib64} |
|---|
| 167 | # |
|---|
| 168 | get_libdir() { |
|---|
| 169 | if [ -n "${CONF_LIBDIR_OVERRIDE}" ] ; then |
|---|
| 170 | CONF_LIBDIR="${CONF_LIBDIR_OVERRIDE}" |
|---|
| 171 | elif [ -x "/usr/bin/portageq" ] ; then |
|---|
| 172 | CONF_LIBDIR="$(/usr/bin/portageq envvar CONF_LIBDIR)" |
|---|
| 173 | fi |
|---|
| 174 | echo ${CONF_LIBDIR:=lib} |
|---|
| 175 | } |
|---|
| 176 | |
|---|
| 177 | # void esyslog(char* priority, char* tag, char* message) |
|---|
| 178 | # |
|---|
| 179 | # use the system logger to log a message |
|---|
| 180 | # |
|---|
| 181 | esyslog() { |
|---|
| 182 | local pri= |
|---|
| 183 | local tag= |
|---|
| 184 | |
|---|
| 185 | if [ -x /usr/bin/logger ] |
|---|
| 186 | then |
|---|
| 187 | pri="$1" |
|---|
| 188 | tag="$2" |
|---|
| 189 | |
|---|
| 190 | shift 2 |
|---|
| 191 | [[ -z "$*" ]] && return 0 |
|---|
| 192 | |
|---|
| 193 | /usr/bin/logger -p "${pri}" -t "${tag}" -- "$*" |
|---|
| 194 | fi |
|---|
| 195 | |
|---|
| 196 | return 0 |
|---|
| 197 | } |
|---|
| 198 | |
|---|
| 199 | # void eindent(int num) |
|---|
| 200 | # |
|---|
| 201 | # increase the indent used for e-commands. |
|---|
| 202 | # |
|---|
| 203 | eindent() { |
|---|
| 204 | local i=$1 |
|---|
| 205 | (( i > 0 )) || (( i = RC_DEFAULT_INDENT )) |
|---|
| 206 | esetdent $(( ${#RC_INDENTATION} + i )) |
|---|
| 207 | } |
|---|
| 208 | |
|---|
| 209 | # void eoutdent(int num) |
|---|
| 210 | # |
|---|
| 211 | # decrease the indent used for e-commands. |
|---|
| 212 | # |
|---|
| 213 | eoutdent() { |
|---|
| 214 | local i=$1 |
|---|
| 215 | (( i > 0 )) || (( i = RC_DEFAULT_INDENT )) |
|---|
| 216 | esetdent $(( ${#RC_INDENTATION} - i )) |
|---|
| 217 | } |
|---|
| 218 | |
|---|
| 219 | # void esetdent(int num) |
|---|
| 220 | # |
|---|
| 221 | # hard set the indent used for e-commands. |
|---|
| 222 | # num defaults to 0 |
|---|
| 223 | # |
|---|
| 224 | esetdent() { |
|---|
| 225 | local i=$1 |
|---|
| 226 | (( i < 0 )) && (( i = 0 )) |
|---|
| 227 | RC_INDENTATION=$(printf "%${i}s" '') |
|---|
| 228 | } |
|---|
| 229 | |
|---|
| 230 | # void einfo(char* message) |
|---|
| 231 | # |
|---|
| 232 | # show an informative message (with a newline) |
|---|
| 233 | # |
|---|
| 234 | einfo() { |
|---|
| 235 | einfon "$*\n" |
|---|
| 236 | LAST_E_CMD=einfo |
|---|
| 237 | return 0 |
|---|
| 238 | } |
|---|
| 239 | |
|---|
| 240 | # void einfon(char* message) |
|---|
| 241 | # |
|---|
| 242 | # show an informative message (without a newline) |
|---|
| 243 | # |
|---|
| 244 | einfon() { |
|---|
| 245 | [[ ${RC_QUIET_STDOUT} == yes ]] && return 0 |
|---|
| 246 | [[ ${RC_ENDCOL} != yes && ${LAST_E_CMD} == ebegin ]] && echo |
|---|
| 247 | echo -ne " ${GOOD}*${NORMAL} ${RC_INDENTATION}$*" |
|---|
| 248 | LAST_E_CMD=einfon |
|---|
| 249 | return 0 |
|---|
| 250 | } |
|---|
| 251 | |
|---|
| 252 | # void ewarn(char* message) |
|---|
| 253 | # |
|---|
| 254 | # show a warning message + log it |
|---|
| 255 | # |
|---|
| 256 | ewarn() { |
|---|
| 257 | if [[ ${RC_QUIET_STDOUT} == yes ]]; then |
|---|
| 258 | echo " $*" |
|---|
| 259 | else |
|---|
| 260 | [[ ${RC_ENDCOL} != yes && ${LAST_E_CMD} == ebegin ]] && echo |
|---|
| 261 | echo -e " ${WARN}*${NORMAL} ${RC_INDENTATION}$*" |
|---|
| 262 | fi |
|---|
| 263 | |
|---|
| 264 | # Log warnings to system log |
|---|
| 265 | esyslog "daemon.warning" "rc-scripts" "$*" |
|---|
| 266 | |
|---|
| 267 | LAST_E_CMD=ewarn |
|---|
| 268 | return 0 |
|---|
| 269 | } |
|---|
| 270 | |
|---|
| 271 | # void eerror(char* message) |
|---|
| 272 | # |
|---|
| 273 | # show an error message + log it |
|---|
| 274 | # |
|---|
| 275 | eerror() { |
|---|
| 276 | if [[ ${RC_QUIET_STDOUT} == yes ]]; then |
|---|
| 277 | echo " $*" >/dev/stderr |
|---|
| 278 | else |
|---|
| 279 | [[ ${RC_ENDCOL} != yes && ${LAST_E_CMD} == ebegin ]] && echo |
|---|
| 280 | echo -e " ${BAD}*${NORMAL} ${RC_INDENTATION}$*" |
|---|
| 281 | fi |
|---|
| 282 | |
|---|
| 283 | # Log errors to system log |
|---|
| 284 | esyslog "daemon.err" "rc-scripts" "$*" |
|---|
| 285 | |
|---|
| 286 | LAST_E_CMD=eerror |
|---|
| 287 | return 0 |
|---|
| 288 | } |
|---|
| 289 | |
|---|
| 290 | # void ebegin(char* message) |
|---|
| 291 | # |
|---|
| 292 | # show a message indicating the start of a process |
|---|
| 293 | # |
|---|
| 294 | ebegin() { |
|---|
| 295 | local msg="$*" dots spaces=${RC_DOT_PATTERN//?/ } |
|---|
| 296 | [[ ${RC_QUIET_STDOUT} == yes ]] && return 0 |
|---|
| 297 | |
|---|
| 298 | if [[ -n ${RC_DOT_PATTERN} ]]; then |
|---|
| 299 | dots=$(printf "%$(( COLS - 3 - ${#RC_INDENTATION} - ${#msg} - 7 ))s" '') |
|---|
| 300 | dots=${dots//${spaces}/${RC_DOT_PATTERN}} |
|---|
| 301 | msg="${msg}${dots}" |
|---|
| 302 | else |
|---|
| 303 | msg="${msg} ..." |
|---|
| 304 | fi |
|---|
| 305 | einfon "${msg}" |
|---|
| 306 | [[ ${RC_ENDCOL} == yes ]] && echo |
|---|
| 307 | |
|---|
| 308 | LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} )) |
|---|
| 309 | LAST_E_CMD=ebegin |
|---|
| 310 | return 0 |
|---|
| 311 | } |
|---|
| 312 | |
|---|
| 313 | # void _eend(int error, char *efunc, char* errstr) |
|---|
| 314 | # |
|---|
| 315 | # indicate the completion of process, called from eend/ewend |
|---|
| 316 | # if error, show errstr via efunc |
|---|
| 317 | # |
|---|
| 318 | # This function is private to functions.sh. Do not call it from a |
|---|
| 319 | # script. |
|---|
| 320 | # |
|---|
| 321 | _eend() { |
|---|
| 322 | local retval=${1:-0} efunc=${2:-eerror} msg |
|---|
| 323 | shift 2 |
|---|
| 324 | |
|---|
| 325 | if [[ ${retval} == 0 ]]; then |
|---|
| 326 | [[ ${RC_QUIET_STDOUT} == yes ]] && return 0 |
|---|
| 327 | msg="${BRACKET}[ ${GOOD}ok${BRACKET} ]${NORMAL}" |
|---|
| 328 | else |
|---|
| 329 | if [[ -c /dev/null ]]; then |
|---|
| 330 | rc_splash "stop" &>/dev/null & |
|---|
| 331 | else |
|---|
| 332 | rc_splash "stop" & |
|---|
| 333 | fi |
|---|
| 334 | if [[ -n "$*" ]]; then |
|---|
| 335 | ${efunc} "$*" |
|---|
| 336 | fi |
|---|
| 337 | msg="${BRACKET}[ ${BAD}!!${BRACKET} ]${NORMAL}" |
|---|
| 338 | fi |
|---|
| 339 | |
|---|
| 340 | if [[ ${RC_ENDCOL} == yes ]]; then |
|---|
| 341 | echo -e "${ENDCOL} ${msg}" |
|---|
| 342 | else |
|---|
| 343 | [[ ${LAST_E_CMD} == ebegin ]] || LAST_E_LEN=0 |
|---|
| 344 | printf "%$(( COLS - LAST_E_LEN - 6 ))s%b\n" '' "${msg}" |
|---|
| 345 | fi |
|---|
| 346 | |
|---|
| 347 | return ${retval} |
|---|
| 348 | } |
|---|
| 349 | |
|---|
| 350 | # void eend(int error, char* errstr) |
|---|
| 351 | # |
|---|
| 352 | # indicate the completion of process |
|---|
| 353 | # if error, show errstr via eerror |
|---|
| 354 | # |
|---|
| 355 | eend() { |
|---|
| 356 | local retval=${1:-0} |
|---|
| 357 | shift |
|---|
| 358 | |
|---|
| 359 | _eend ${retval} eerror "$*" |
|---|
| 360 | |
|---|
| 361 | LAST_E_CMD=eend |
|---|
| 362 | return $retval |
|---|
| 363 | } |
|---|
| 364 | |
|---|
| 365 | # void ewend(int error, char* errstr) |
|---|
| 366 | # |
|---|
| 367 | # indicate the completion of process |
|---|
| 368 | # if error, show errstr via ewarn |
|---|
| 369 | # |
|---|
| 370 | ewend() { |
|---|
| 371 | local retval=${1:-0} |
|---|
| 372 | shift |
|---|
| 373 | |
|---|
| 374 | _eend ${retval} ewarn "$*" |
|---|
| 375 | |
|---|
| 376 | LAST_E_CMD=ewend |
|---|
| 377 | return $retval |
|---|
| 378 | } |
|---|
| 379 | |
|---|
| 380 | # v-e-commands honor RC_VERBOSE which defaults to no. |
|---|
| 381 | # The condition is negated so the return value will be zero. |
|---|
| 382 | veinfo() { [[ "${RC_VERBOSE}" != yes ]] || einfo "$@"; } |
|---|
| 383 | veinfon() { [[ "${RC_VERBOSE}" != yes ]] || einfon "$@"; } |
|---|
| 384 | vewarn() { [[ "${RC_VERBOSE}" != yes ]] || ewarn "$@"; } |
|---|
| 385 | veerror() { [[ "${RC_VERBOSE}" != yes ]] || eerror "$@"; } |
|---|
| 386 | vebegin() { [[ "${RC_VERBOSE}" != yes ]] || ebegin "$@"; } |
|---|
| 387 | veend() { |
|---|
| 388 | [[ "${RC_VERBOSE}" == yes ]] && { eend "$@"; return $?; } |
|---|
| 389 | return ${1:-0} |
|---|
| 390 | } |
|---|
| 391 | veend() { |
|---|
| 392 | [[ "${RC_VERBOSE}" == yes ]] && { ewend "$@"; return $?; } |
|---|
| 393 | return ${1:-0} |
|---|
| 394 | } |
|---|
| 395 | |
|---|
| 396 | # char *KV_major(string) |
|---|
| 397 | # |
|---|
| 398 | # Return the Major (X of X.Y.Z) kernel version |
|---|
| 399 | # |
|---|
| 400 | KV_major() { |
|---|
| 401 | [[ -z $1 ]] && return 1 |
|---|
| 402 | |
|---|
| 403 | local KV=$@ |
|---|
| 404 | echo ${KV%%.*} |
|---|
| 405 | } |
|---|
| 406 | |
|---|
| 407 | # char *KV_minor(string) |
|---|
| 408 | # |
|---|
| 409 | # Return the Minor (Y of X.Y.Z) kernel version |
|---|
| 410 | # |
|---|
| 411 | KV_minor() { |
|---|
| 412 | [[ -z $1 ]] && return 1 |
|---|
| 413 | |
|---|
| 414 | local KV=$@ |
|---|
| 415 | KV=${KV#*.} |
|---|
| 416 | echo ${KV%%.*} |
|---|
| 417 | } |
|---|
| 418 | |
|---|
| 419 | # char *KV_micro(string) |
|---|
| 420 | # |
|---|
| 421 | # Return the Micro (Z of X.Y.Z) kernel version. |
|---|
| 422 | # |
|---|
| 423 | KV_micro() { |
|---|
| 424 | [[ -z $1 ]] && return 1 |
|---|
| 425 | |
|---|
| 426 | local KV=$@ |
|---|
| 427 | KV=${KV#*.*.} |
|---|
| 428 | echo ${KV%%[^[:digit:]]*} |
|---|
| 429 | } |
|---|
| 430 | |
|---|
| 431 | # int KV_to_int(string) |
|---|
| 432 | # |
|---|
| 433 | # Convert a string type kernel version (2.4.0) to an int (132096) |
|---|
| 434 | # for easy compairing or versions ... |
|---|
| 435 | # |
|---|
| 436 | KV_to_int() { |
|---|
| 437 | [[ -z $1 ]] && return 1 |
|---|
| 438 | |
|---|
| 439 | local KV_MAJOR=$(KV_major "$1") |
|---|
| 440 | local KV_MINOR=$(KV_minor "$1") |
|---|
| 441 | local KV_MICRO=$(KV_micro "$1") |
|---|
| 442 | local KV_int=$(( KV_MAJOR * 65536 + KV_MINOR * 256 + KV_MICRO )) |
|---|
| 443 | |
|---|
| 444 | # We make version 2.2.0 the minimum version we will handle as |
|---|
| 445 | # a sanity check ... if its less, we fail ... |
|---|
| 446 | if [[ ${KV_int} -ge 131584 ]] ; then |
|---|
| 447 | echo "${KV_int}" |
|---|
| 448 | return 0 |
|---|
| 449 | fi |
|---|
| 450 | |
|---|
| 451 | return 1 |
|---|
| 452 | } |
|---|
| 453 | |
|---|
| 454 | # int get_KV() |
|---|
| 455 | # |
|---|
| 456 | # Return the kernel version (major, minor and micro concated) as an integer. |
|---|
| 457 | # Assumes X and Y of X.Y.Z are numbers. Also assumes that some leading |
|---|
| 458 | # portion of Z is a number. |
|---|
| 459 | # e.g. 2.4.25, 2.6.10, 2.6.4-rc3, 2.2.40-poop, 2.0.15+foo |
|---|
| 460 | # |
|---|
| 461 | get_KV() { |
|---|
| 462 | local KV=$(uname -r) |
|---|
| 463 | |
|---|
| 464 | echo $(KV_to_int "${KV}") |
|---|
| 465 | |
|---|
| 466 | return $? |
|---|
| 467 | } |
|---|
| 468 | |
|---|
| 469 | # bool get_bootparam(param) |
|---|
| 470 | # |
|---|
| 471 | # return 0 if gentoo=param was passed to the kernel |
|---|
| 472 | # |
|---|
| 473 | # EXAMPLE: if get_bootparam "nodevfs" ; then .... |
|---|
| 474 | # |
|---|
| 475 | get_bootparam() { |
|---|
| 476 | local x copt params retval=1 |
|---|
| 477 | |
|---|
| 478 | [ ! -r "/proc/cmdline" ] && return 1 |
|---|
| 479 | |
|---|
| 480 | for copt in $(< /proc/cmdline) |
|---|
| 481 | do |
|---|
| 482 | if [ "${copt%=*}" = "gentoo" ] |
|---|
| 483 | then |
|---|
| 484 | params="$(gawk -v PARAMS="${copt##*=}" ' |
|---|
| 485 | BEGIN { |
|---|
| 486 | split(PARAMS, nodes, ",") |
|---|
| 487 | for (x in nodes) |
|---|
| 488 | print nodes[x] |
|---|
| 489 | }')" |
|---|
| 490 | |
|---|
| 491 | # Parse gentoo option |
|---|
| 492 | for x in ${params} |
|---|
| 493 | do |
|---|
| 494 | if [ "${x}" = "$1" ] |
|---|
| 495 | then |
|---|
| 496 | # echo "YES" |
|---|
| 497 | retval=0 |
|---|
| 498 | fi |
|---|
| 499 | done |
|---|
| 500 | fi |
|---|
| 501 | done |
|---|
| 502 | |
|---|
| 503 | return ${retval} |
|---|
| 504 | } |
|---|
| 505 | |
|---|
| 506 | # Safer way to list the contents of a directory, |
|---|
| 507 | # as it do not have the "empty dir bug". |
|---|
| 508 | # |
|---|
| 509 | # char *dolisting(param) |
|---|
| 510 | # |
|---|
| 511 | # print a list of the directory contents |
|---|
| 512 | # |
|---|
| 513 | # NOTE: quote the params if they contain globs. |
|---|
| 514 | # also, error checking is not that extensive ... |
|---|
| 515 | # |
|---|
| 516 | dolisting() { |
|---|
| 517 | local x= |
|---|
| 518 | local y= |
|---|
| 519 | local tmpstr= |
|---|
| 520 | local mylist= |
|---|
| 521 | local mypath="$*" |
|---|
| 522 | |
|---|
| 523 | if [ "${mypath%/\*}" != "${mypath}" ] |
|---|
| 524 | then |
|---|
| 525 | mypath="${mypath%/\*}" |
|---|
| 526 | fi |
|---|
| 527 | |
|---|
| 528 | for x in ${mypath} |
|---|
| 529 | do |
|---|
| 530 | [ ! -e "${x}" ] && continue |
|---|
| 531 | |
|---|
| 532 | if [ ! -d "${x}" ] && ( [ -L "${x}" -o -f "${x}" ] ) |
|---|
| 533 | then |
|---|
| 534 | mylist="${mylist} $(ls "${x}" 2> /dev/null)" |
|---|
| 535 | else |
|---|
| 536 | [ "${x%/}" != "${x}" ] && x="${x%/}" |
|---|
| 537 | |
|---|
| 538 | cd "${x}"; tmpstr="$(ls)" |
|---|
| 539 | |
|---|
| 540 | for y in ${tmpstr} |
|---|
| 541 | do |
|---|
| 542 | mylist="${mylist} ${x}/${y}" |
|---|
| 543 | done |
|---|
| 544 | fi |
|---|
| 545 | done |
|---|
| 546 | |
|---|
| 547 | echo "${mylist}" |
|---|
| 548 | } |
|---|
| 549 | |
|---|
| 550 | # void save_options(char *option, char *optstring) |
|---|
| 551 | # |
|---|
| 552 | # save the settings ("optstring") for "option" |
|---|
| 553 | # |
|---|
| 554 | save_options() { |
|---|
| 555 | local myopts="$1" |
|---|
| 556 | |
|---|
| 557 | shift |
|---|
| 558 | if [ ! -d "${svcdir}/options/${myservice}" ] |
|---|
| 559 | then |
|---|
| 560 | mkdir -p -m 0755 "${svcdir}/options/${myservice}" |
|---|
| 561 | fi |
|---|
| 562 | |
|---|
| 563 | echo "$*" > "${svcdir}/options/${myservice}/${myopts}" |
|---|
| 564 | |
|---|
| 565 | return 0 |
|---|
| 566 | } |
|---|
| 567 | |
|---|
| 568 | # char *get_options(char *option) |
|---|
| 569 | # |
|---|
| 570 | # get the "optstring" for "option" that was saved |
|---|
| 571 | # by calling the save_options function |
|---|
| 572 | # |
|---|
| 573 | get_options() { |
|---|
| 574 | if [ -f "${svcdir}/options/${myservice}/$1" ] |
|---|
| 575 | then |
|---|
| 576 | echo "$(< ${svcdir}/options/${myservice}/$1)" |
|---|
| 577 | fi |
|---|
| 578 | |
|---|
| 579 | return 0 |
|---|
| 580 | } |
|---|
| 581 | |
|---|
| 582 | # char *add_suffix(char * configfile) |
|---|
| 583 | # |
|---|
| 584 | # Returns a config file name with the softlevel suffix |
|---|
| 585 | # appended to it. For use with multi-config services. |
|---|
| 586 | add_suffix() { |
|---|
| 587 | if [ "${RC_USE_CONFIG_PROFILE}" = "yes" -a -e "$1.${DEFAULTLEVEL}" ] |
|---|
| 588 | then |
|---|
| 589 | echo "$1.${DEFAULTLEVEL}" |
|---|
| 590 | else |
|---|
| 591 | echo "$1" |
|---|
| 592 | fi |
|---|
| 593 | |
|---|
| 594 | return 0 |
|---|
| 595 | } |
|---|
| 596 | |
|---|
| 597 | # char *get_base_ver() |
|---|
| 598 | # |
|---|
| 599 | # get the version of baselayout that this system is running |
|---|
| 600 | # |
|---|
| 601 | get_base_ver() { |
|---|
| 602 | [[ ! -r /etc/gentoo-release ]] && return 0 |
|---|
| 603 | local ver=$(</etc/gentoo-release) |
|---|
| 604 | echo ${ver##* } |
|---|
| 605 | } |
|---|
| 606 | |
|---|
| 607 | # Network filesystems list for common use in rc-scripts. |
|---|
| 608 | # This variable is used in is_net_fs and other places such as |
|---|
| 609 | # localmount. |
|---|
| 610 | NET_FS_LIST="afs cifs coda davfs gfs ncpfs nfs nfs4 shfs smbfs" |
|---|
| 611 | |
|---|
| 612 | # bool is_net_fs(path) |
|---|
| 613 | # |
|---|
| 614 | # return 0 if path is the mountpoint of a networked filesystem |
|---|
| 615 | # |
|---|
| 616 | # EXAMPLE: if is_net_fs / ; then ... |
|---|
| 617 | # |
|---|
| 618 | is_net_fs() { |
|---|
| 619 | local fstype |
|---|
| 620 | # /proc/mounts is always accurate but may not always be available |
|---|
| 621 | if [[ -e /proc/mounts ]]; then |
|---|
| 622 | fstype=$( sed -n -e '/^rootfs/!s:.* '"$1"' \([^ ]*\).*:\1:p' /proc/mounts ) |
|---|
| 623 | else |
|---|
| 624 | fstype=$( mount | sed -n -e 's:.* on '"$1"' type \([^ ]*\).*:\1:p' ) |
|---|
| 625 | fi |
|---|
| 626 | [[ " ${NET_FS_LIST} " == *" ${fstype} "* ]] |
|---|
| 627 | return $? |
|---|
| 628 | } |
|---|
| 629 | |
|---|
| 630 | # bool is_uml_sys() |
|---|
| 631 | # |
|---|
| 632 | # return 0 if the currently running system is User Mode Linux |
|---|
| 633 | # |
|---|
| 634 | # EXAMPLE: if is_uml_sys ; then ... |
|---|
| 635 | # |
|---|
| 636 | is_uml_sys() { |
|---|
| 637 | grep -qs 'UML' /proc/cpuinfo |
|---|
| 638 | return $? |
|---|
| 639 | } |
|---|
| 640 | |
|---|
| 641 | # bool is_vserver_sys() |
|---|
| 642 | # |
|---|
| 643 | # return 0 if the currently running system is a Linux VServer |
|---|
| 644 | # |
|---|
| 645 | # EXAMPLE: if is_vserver_sys ; then ... |
|---|
| 646 | # |
|---|
| 647 | is_vserver_sys() { |
|---|
| 648 | grep -qs '^s_context:[[:space:]]*[1-9]' /proc/self/status |
|---|
| 649 | return $? |
|---|
| 650 | } |
|---|
| 651 | |
|---|
| 652 | # bool is_xenU_sys() |
|---|
| 653 | # |
|---|
| 654 | # return 0 if the currently running system is an unprivileged Xen domain |
|---|
| 655 | # |
|---|
| 656 | # EXAMPLE: if is_xenU_sys ; then ... |
|---|
| 657 | # |
|---|
| 658 | is_xenU_sys() { |
|---|
| 659 | [[ -d /proc/xen && ! -f /proc/xen/privcmd ]] |
|---|
| 660 | } |
|---|
| 661 | |
|---|
| 662 | # bool get_mount_fstab(path) |
|---|
| 663 | # |
|---|
| 664 | # return the parameters to pass to the mount command generated from fstab |
|---|
| 665 | # |
|---|
| 666 | # EXAMPLE: cmd=$( get_mount_fstab /proc ) |
|---|
| 667 | # cmd=${cmd:--t proc none /proc} |
|---|
| 668 | # mount -n ${cmd} |
|---|
| 669 | # |
|---|
| 670 | get_mount_fstab() { |
|---|
| 671 | awk '$1 ~ "^#" { next } |
|---|
| 672 | $2 == "'$*'" { if (found++ == 0) { print "-t "$3,"-o "$4,$1,$2 } } |
|---|
| 673 | END { if (found > 1) { print "More than one entry for '$*' found in /etc/fstab!" > "/dev/stderr" } } |
|---|
| 674 | ' /etc/fstab |
|---|
| 675 | } |
|---|
| 676 | |
|---|
| 677 | # char *reverse_list(list) |
|---|
| 678 | # |
|---|
| 679 | # Returns the reversed order of list |
|---|
| 680 | # |
|---|
| 681 | reverse_list() { |
|---|
| 682 | for (( i = $# ; i > 0 ; --i )); do |
|---|
| 683 | echo -n "${!i} " |
|---|
| 684 | done |
|---|
| 685 | } |
|---|
| 686 | |
|---|
| 687 | # void start_addon(addon) |
|---|
| 688 | # |
|---|
| 689 | # Starts addon. |
|---|
| 690 | # |
|---|
| 691 | start_addon() { |
|---|
| 692 | local addon=$1 |
|---|
| 693 | (import_addon ${addon}-start.sh) |
|---|
| 694 | return 0 |
|---|
| 695 | } |
|---|
| 696 | |
|---|
| 697 | # void start_volumes() |
|---|
| 698 | # |
|---|
| 699 | # Starts all volumes in RC_VOLUME_ORDER. |
|---|
| 700 | # |
|---|
| 701 | start_volumes() { |
|---|
| 702 | local x= |
|---|
| 703 | |
|---|
| 704 | for x in ${RC_VOLUME_ORDER}; do |
|---|
| 705 | start_addon "${x}" |
|---|
| 706 | done |
|---|
| 707 | |
|---|
| 708 | return 0 |
|---|
| 709 | } |
|---|
| 710 | |
|---|
| 711 | # void stop_addon(addon) |
|---|
| 712 | # |
|---|
| 713 | # Stops addon. |
|---|
| 714 | # |
|---|
| 715 | stop_addon() { |
|---|
| 716 | local addon=$1 |
|---|
| 717 | (import_addon ${addon}-stop.sh) |
|---|
| 718 | return 0 |
|---|
| 719 | } |
|---|
| 720 | |
|---|
| 721 | # void stop_volumes() |
|---|
| 722 | # |
|---|
| 723 | # Stops all volumes in RC_VOLUME_ORDER (reverse order). |
|---|
| 724 | # |
|---|
| 725 | stop_volumes() { |
|---|
| 726 | local x= |
|---|
| 727 | |
|---|
| 728 | for x in $(reverse_list ${RC_VOLUME_ORDER}); do |
|---|
| 729 | stop_addon "${x}" |
|---|
| 730 | done |
|---|
| 731 | |
|---|
| 732 | return 0 |
|---|
| 733 | } |
|---|
| 734 | |
|---|
| 735 | # bool is_older_than(reference, files/dirs to check) |
|---|
| 736 | # |
|---|
| 737 | # return 0 if any of the files/dirs are newer than |
|---|
| 738 | # the reference file |
|---|
| 739 | # |
|---|
| 740 | # EXAMPLE: if is_older_than a.out *.o ; then ... |
|---|
| 741 | is_older_than() { |
|---|
| 742 | local x= |
|---|
| 743 | local ref="$1" |
|---|
| 744 | shift |
|---|
| 745 | |
|---|
| 746 | for x in "$@" ; do |
|---|
| 747 | [[ ${x} -nt ${ref} ]] && return 0 |
|---|
| 748 | |
|---|
| 749 | if [[ -d ${x} ]] ; then |
|---|
| 750 | is_older_than "${ref}" "${x}"/* && return 0 |
|---|
| 751 | fi |
|---|
| 752 | done |
|---|
| 753 | |
|---|
| 754 | return 1 |
|---|
| 755 | } |
|---|
| 756 | |
|---|
| 757 | |
|---|
| 758 | ############################################################################## |
|---|
| 759 | # # |
|---|
| 760 | # This should be the last code in here, please add all functions above!! # |
|---|
| 761 | # # |
|---|
| 762 | # *** START LAST CODE *** # |
|---|
| 763 | # # |
|---|
| 764 | ############################################################################## |
|---|
| 765 | |
|---|
| 766 | if [ -z "${EBUILD}" ] ; then |
|---|
| 767 | # Setup a basic $PATH. Just add system default to existing. |
|---|
| 768 | # This should solve both /sbin and /usr/sbin not present when |
|---|
| 769 | # doing 'su -c foo', or for something like: PATH= rcscript start |
|---|
| 770 | PATH="/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/sbin:${PATH}" |
|---|
| 771 | |
|---|
| 772 | if [ "$(/sbin/consoletype 2> /dev/null)" = "serial" ] ; then |
|---|
| 773 | # We do not want colors/endcols on serial terminals |
|---|
| 774 | RC_NOCOLOR="yes" |
|---|
| 775 | RC_ENDCOL="no" |
|---|
| 776 | fi |
|---|
| 777 | |
|---|
| 778 | for arg in "$@" ; do |
|---|
| 779 | case "${arg}" in |
|---|
| 780 | # Lastly check if the user disabled it with --nocolor argument |
|---|
| 781 | --nocolor|-nc) |
|---|
| 782 | RC_NOCOLOR="yes" |
|---|
| 783 | ;; |
|---|
| 784 | esac |
|---|
| 785 | done |
|---|
| 786 | |
|---|
| 787 | if [ -r "/proc/cmdline" ] ; then |
|---|
| 788 | setup_defaultlevels |
|---|
| 789 | fi |
|---|
| 790 | else |
|---|
| 791 | # Should we use colors ? |
|---|
| 792 | if [[ $* != *depend* ]]; then |
|---|
| 793 | # Check user pref in portage |
|---|
| 794 | RC_NOCOLOR="$(portageq envvar NOCOLOR 2>/dev/null)" |
|---|
| 795 | [ "${RC_NOCOLOR}" = "true" ] && RC_NOCOLOR="yes" |
|---|
| 796 | else |
|---|
| 797 | # We do not want colors during emerge depend |
|---|
| 798 | RC_NOCOLOR="yes" |
|---|
| 799 | # No output is seen during emerge depend, so this is not needed. |
|---|
| 800 | RC_ENDCOL="no" |
|---|
| 801 | fi |
|---|
| 802 | fi |
|---|
| 803 | |
|---|
| 804 | if [[ -n ${EBUILD} && $* == *depend* ]]; then |
|---|
| 805 | # We do not want stty to run during emerge depend |
|---|
| 806 | COLS=80 |
|---|
| 807 | else |
|---|
| 808 | # Setup COLS and ENDCOL so eend can line up the [ ok ] |
|---|
| 809 | COLS=${COLUMNS:-0} # bash's internal COLUMNS variable |
|---|
| 810 | (( COLS == 0 )) && COLS=$(stty size 2>/dev/null | cut -d' ' -f2) |
|---|
| 811 | (( COLS > 0 )) || (( COLS = 80 )) # width of [ ok ] == 7 |
|---|
| 812 | fi |
|---|
| 813 | |
|---|
| 814 | if [[ ${RC_ENDCOL} == yes ]]; then |
|---|
| 815 | ENDCOL=$'\e[A\e['$(( COLS - 7 ))'G' |
|---|
| 816 | else |
|---|
| 817 | ENDCOL='' |
|---|
| 818 | fi |
|---|
| 819 | |
|---|
| 820 | # Setup the colors so our messages all look pretty |
|---|
| 821 | if [[ ${RC_NOCOLOR} == yes ]]; then |
|---|
| 822 | unset GOOD WARN BAD NORMAL HILITE BRACKET |
|---|
| 823 | else |
|---|
| 824 | GOOD=$'\e[32;01m' |
|---|
| 825 | WARN=$'\e[33;01m' |
|---|
| 826 | BAD=$'\e[31;01m' |
|---|
| 827 | NORMAL=$'\e[0m' |
|---|
| 828 | HILITE=$'\e[36;01m' |
|---|
| 829 | BRACKET=$'\e[34;01m' |
|---|
| 830 | fi |
|---|
| 831 | |
|---|
| 832 | ############################################################################## |
|---|
| 833 | # # |
|---|
| 834 | # *** END LAST CODE *** # |
|---|
| 835 | # # |
|---|
| 836 | # This should be the last code in here, please add all functions above!! # |
|---|
| 837 | # # |
|---|
| 838 | ############################################################################## |
|---|
| 839 | |
|---|
| 840 | |
|---|
| 841 | # vim:ts=4 |
|---|