Remove the try and check_statedir functions
This commit is contained in:
parent
9f2403dffa
commit
a010d0bb69
@ -42,28 +42,27 @@ mount_svcdir() {
|
|||||||
if [ -e "${RC_SVCDIR}"/deptree ]; then
|
if [ -e "${RC_SVCDIR}"/deptree ]; then
|
||||||
dotmp=true
|
dotmp=true
|
||||||
if ! mount -t tmpfs none "${RC_LIBDIR}"/tmp 2>/dev/null; then
|
if ! mount -t tmpfs none "${RC_LIBDIR}"/tmp 2>/dev/null; then
|
||||||
try mdconfig -a -t malloc -s 1m -u 1
|
mdconfig -a -t malloc -s 1m -u 1
|
||||||
try newfs /dev/md1
|
newfs /dev/md1
|
||||||
try mount /dev/md1 "${RC_LIBDIR}"/tmp
|
mount /dev/md1 "${RC_LIBDIR}"/tmp
|
||||||
release=true
|
release=true
|
||||||
fi
|
fi
|
||||||
cp -p "${RC_SVCDIR}"/deptree "${RC_SVCDIR}"/depconfig \
|
cp -p "${RC_SVCDIR}"/deptree "${RC_SVCDIR}"/depconfig \
|
||||||
"${RC_SVCDIR}"/nettree "${RC_LIBDIR}"/tmp 2>/dev/null
|
"${RC_SVCDIR}"/nettree "${RC_LIBDIR}"/tmp 2>/dev/null
|
||||||
fi
|
fi
|
||||||
if ! mount -t tmpfs -o rw,noexec,nosuid none "${RC_SVCDIR}" 2>/dev/null; then
|
if ! mount -t tmpfs -o rw,noexec,nosuid none "${RC_SVCDIR}" 2>/dev/null; then
|
||||||
try mdconfig -a -t malloc -s "${rc_svcsize:-1024}"k -u 0
|
mdconfig -a -t malloc -s "${rc_svcsize:-1024}"k -u 0
|
||||||
try newfs -b 4096 -i 1024 -n /dev/md0
|
newfs -b 4096 -i 1024 -n /dev/md0
|
||||||
try mount -o rw,noexec,nosuid /dev/md0 "${RC_SVCDIR}"
|
mount -o rw,noexec,nosuid /dev/md0 "${RC_SVCDIR}"
|
||||||
fi
|
fi
|
||||||
if ${dotmp}; then
|
if ${dotmp}; then
|
||||||
cp -p "${RC_LIBDIR}"/tmp/deptree "${RC_LIBDIR}"/tmp/depconfig \
|
cp -p "${RC_LIBDIR}"/tmp/deptree "${RC_LIBDIR}"/tmp/depconfig \
|
||||||
"${RC_LIBDIR}"/tmp/nettree "${RC_SVCDIR}" 2>/dev/null
|
"${RC_LIBDIR}"/tmp/nettree "${RC_SVCDIR}" 2>/dev/null
|
||||||
try umount "${RC_LIBDIR}"/tmp
|
umount "${RC_LIBDIR}"/tmp
|
||||||
${release} && try mdconfig -d -u 1
|
${release} && mdconfig -d -u 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
. "${RC_LIBDIR}"/sh/init-functions.sh
|
|
||||||
. "${RC_LIBDIR}"/sh/functions.sh
|
. "${RC_LIBDIR}"/sh/functions.sh
|
||||||
[ -r /etc/rc.conf ] && . /etc/rc.conf
|
[ -r /etc/rc.conf ] && . /etc/rc.conf
|
||||||
|
|
||||||
|
@ -66,8 +66,8 @@ mount_svcdir() {
|
|||||||
devtmp="/dev/ram1"
|
devtmp="/dev/ram1"
|
||||||
fs="ext2"
|
fs="ext2"
|
||||||
for x in ${devdir} ${devtmp}; do
|
for x in ${devdir} ${devtmp}; do
|
||||||
try dd if=/dev/zero of="${x}" bs=1k count="${rc_svcsize:-1024}"
|
dd if=/dev/zero of="${x}" bs=1k count="${rc_svcsize:-1024}"
|
||||||
try mkfs -t "${fs}" -i 1024 -vm0 "${x}" "${rc_svcsize:-1024}"
|
mkfs -t "${fs}" -i 1024 -vm0 "${x}" "${rc_svcsize:-1024}"
|
||||||
done
|
done
|
||||||
else
|
else
|
||||||
echo
|
echo
|
||||||
@ -80,22 +80,22 @@ mount_svcdir() {
|
|||||||
local dotmp=false
|
local dotmp=false
|
||||||
if [ -e "${RC_SVCDIR}"/deptree ]; then
|
if [ -e "${RC_SVCDIR}"/deptree ]; then
|
||||||
dotmp=true
|
dotmp=true
|
||||||
try mount -n -t "${fs}" -o rw "${devtmp}" "${RC_LIBDIR}"/tmp
|
mount -n -t "${fs}" -o rw "${devtmp}" "${RC_LIBDIR}"/tmp
|
||||||
cp -p "${RC_SVCDIR}"/deptree "${RC_SVCDIR}"/depconfig \
|
cp -p "${RC_SVCDIR}"/deptree "${RC_SVCDIR}"/depconfig \
|
||||||
"${RC_SVCDIR}"/nettree "${RC_LIBDIR}"/tmp 2>/dev/null
|
"${RC_SVCDIR}"/nettree "${RC_LIBDIR}"/tmp 2>/dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# If we have no entry in fstab for $svcdir, provide our own
|
# If we have no entry in fstab for $svcdir, provide our own
|
||||||
if fstabinfo --quiet "${RC_SVCDIR}"; then
|
if fstabinfo --quiet "${RC_SVCDIR}"; then
|
||||||
try mount -n "${RC_SVCDIR}"
|
mount -n "${RC_SVCDIR}"
|
||||||
else
|
else
|
||||||
try mount -n -t "${fs}" ${fsopts} "${devdir}" "${RC_SVCDIR}"
|
mount -n -t "${fs}" ${fsopts} "${devdir}" "${RC_SVCDIR}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ${dotmp}; then
|
if ${dotmp}; then
|
||||||
cp -p "${RC_LIBDIR}"/tmp/deptree "${RC_LIBDIR}"/tmp/depconfig \
|
cp -p "${RC_LIBDIR}"/tmp/deptree "${RC_LIBDIR}"/tmp/depconfig \
|
||||||
"${RC_LIBDIR}"/tmp/nettree "${RC_SVCDIR}" 2>/dev/null
|
"${RC_LIBDIR}"/tmp/nettree "${RC_SVCDIR}" 2>/dev/null
|
||||||
try umount -n "${RC_LIBDIR}"/tmp
|
umount -n "${RC_LIBDIR}"/tmp
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +128,6 @@ KV_to_int() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
. /etc/init.d/functions.sh
|
. /etc/init.d/functions.sh
|
||||||
. "${RC_LIBDIR}"/sh/init-functions.sh
|
|
||||||
. "${RC_LIBDIR}"/sh/rc-functions.sh
|
. "${RC_LIBDIR}"/sh/rc-functions.sh
|
||||||
[ -r /etc/conf.d/rc ] && . /etc/conf.d/rc
|
[ -r /etc/conf.d/rc ] && . /etc/conf.d/rc
|
||||||
[ -r /etc/rc.conf ] && . /etc/rc.conf
|
[ -r /etc/rc.conf ] && . /etc/rc.conf
|
||||||
@ -144,8 +143,6 @@ if [ -n "${dmesg_level}" -a "${RC_SYS}" != "VPS" ]; then
|
|||||||
dmesg -n "${dmesg_level}"
|
dmesg -n "${dmesg_level}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
check_statedir /proc
|
|
||||||
|
|
||||||
# By default VServer already has /proc mounted, but OpenVZ does not!
|
# By default VServer already has /proc mounted, but OpenVZ does not!
|
||||||
# However, some of our users have an old proc image in /proc
|
# However, some of our users have an old proc image in /proc
|
||||||
# NFC how they managed that, but the end result means we have to test if
|
# NFC how they managed that, but the end result means we have to test if
|
||||||
@ -169,9 +166,9 @@ if ${mountproc}; then
|
|||||||
[ "${RC_UNAME}" = "GNU/kFreeBSD" ] && proc="linprocfs"
|
[ "${RC_UNAME}" = "GNU/kFreeBSD" ] && proc="linprocfs"
|
||||||
ebegin "Mounting ${procfs} at /proc"
|
ebegin "Mounting ${procfs} at /proc"
|
||||||
if fstabinfo --quiet /proc; then
|
if fstabinfo --quiet /proc; then
|
||||||
try mount -n /proc
|
mount -n /proc
|
||||||
else
|
else
|
||||||
try mount -n -t "${procfs}" -o noexec,nosuid,nodev proc /proc
|
mount -n -t "${procfs}" -o noexec,nosuid,nodev proc /proc
|
||||||
fi
|
fi
|
||||||
eend $?
|
eend $?
|
||||||
fi
|
fi
|
||||||
@ -193,9 +190,9 @@ if [ "${RC_UNAME}" != "GNU/kFreeBSD" -a "${RC_SYS}" != "VPS" -a "${K26}" = "0" ]
|
|||||||
if ! mountinfo --quiet /sys; then
|
if ! mountinfo --quiet /sys; then
|
||||||
ebegin "Mounting sysfs at /sys"
|
ebegin "Mounting sysfs at /sys"
|
||||||
if fstabinfo --quiet /sys; then
|
if fstabinfo --quiet /sys; then
|
||||||
try mount -n /sys
|
mount -n /sys
|
||||||
else
|
else
|
||||||
try mount -n -t sysfs -o noexec,nosuid,nodev sysfs /sys
|
mount -n -t sysfs -o noexec,nosuid,nodev sysfs /sys
|
||||||
fi
|
fi
|
||||||
eend $?
|
eend $?
|
||||||
fi
|
fi
|
||||||
@ -204,7 +201,6 @@ if [ "${RC_UNAME}" != "GNU/kFreeBSD" -a "${RC_SYS}" != "VPS" -a "${K26}" = "0" ]
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
check_statedir /dev
|
|
||||||
devfs_mounted=
|
devfs_mounted=
|
||||||
if [ -e /dev/.devfsd ]; then
|
if [ -e /dev/.devfsd ]; then
|
||||||
# make sure devfs is actually mounted and it isnt a bogus file
|
# make sure devfs is actually mounted and it isnt a bogus file
|
||||||
@ -267,9 +263,9 @@ for x in "devpts /dev/pts 0755 ,gid=5,mode=0620" "tmpfs /dev/shm 1777 ,nodev"; d
|
|||||||
if [ -d "$2" ]; then
|
if [ -d "$2" ]; then
|
||||||
ebegin "Mounting $1 at $2"
|
ebegin "Mounting $1 at $2"
|
||||||
if fstabinfo --quiet "$2"; then
|
if fstabinfo --quiet "$2"; then
|
||||||
try mount -n "$2"
|
mount -n "$2"
|
||||||
else
|
else
|
||||||
try mount -n -t "$1" -o noexec,nosuid"$4" none "$2"
|
mount -n -t "$1" -o noexec,nosuid"$4" none "$2"
|
||||||
fi
|
fi
|
||||||
eend $?
|
eend $?
|
||||||
fi
|
fi
|
||||||
@ -280,7 +276,7 @@ if [ -f /sbin/livecd-functions.sh -a -n "${CDBOOT}" ]; then
|
|||||||
ebegin "Updating inittab"
|
ebegin "Updating inittab"
|
||||||
livecd_fix_inittab
|
livecd_fix_inittab
|
||||||
eend $?
|
eend $?
|
||||||
/sbin/telinit q &>/dev/null
|
telinit q &>/dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
. "${RC_LIBDIR}"/sh/init-common-post.sh
|
. "${RC_LIBDIR}"/sh/init-common-post.sh
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
DIR = $(RC_LIB)/sh
|
DIR = $(RC_LIB)/sh
|
||||||
INC = functions.sh init-functions.sh init-common-post.sh \
|
INC = functions.sh init-common-post.sh rc-functions.sh rc-mount.sh
|
||||||
rc-functions.sh rc-mount.sh
|
|
||||||
BIN = gendepends.sh net.sh rc-mount.sh rc-help.sh runscript.sh
|
BIN = gendepends.sh net.sh rc-mount.sh rc-help.sh runscript.sh
|
||||||
|
|
||||||
TOPDIR = ..
|
TOPDIR = ..
|
||||||
|
@ -1,88 +0,0 @@
|
|||||||
# Copyright 1999-2007 Gentoo Foundation
|
|
||||||
# Copyright 2007 Roy Marples
|
|
||||||
# All rights reserved
|
|
||||||
|
|
||||||
# Redistribution and use in source and binary forms, with or without
|
|
||||||
# modification, are permitted provided that the following conditions
|
|
||||||
# are met:
|
|
||||||
# 1. Redistributions of source code must retain the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer.
|
|
||||||
# 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer in the
|
|
||||||
# documentation and/or other materials provided with the distribution.
|
|
||||||
#
|
|
||||||
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
||||||
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
||||||
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
||||||
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
||||||
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
||||||
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
||||||
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
||||||
# SUCH DAMAGE.
|
|
||||||
|
|
||||||
# void try(command)
|
|
||||||
#
|
|
||||||
# Try to execute 'command', if it fails, drop to a shell.
|
|
||||||
#
|
|
||||||
try() {
|
|
||||||
local errstr
|
|
||||||
local retval=0
|
|
||||||
|
|
||||||
if [ -c /dev/null ]; then
|
|
||||||
errstr=$(eval $* 2>&1 >/dev/null)
|
|
||||||
else
|
|
||||||
errstr=$(eval $* 2>&1)
|
|
||||||
fi
|
|
||||||
retval=$?
|
|
||||||
if [ ${retval} -ne 0 ]; then
|
|
||||||
#splash "critical" &
|
|
||||||
eend 1
|
|
||||||
eerror "The \"$*\" command failed with error:"
|
|
||||||
eerror " ${errstr#*: }"
|
|
||||||
echo
|
|
||||||
eerror "Since this is a critical task, startup cannot continue."
|
|
||||||
echo
|
|
||||||
single_user
|
|
||||||
fi
|
|
||||||
|
|
||||||
return ${retval}
|
|
||||||
}
|
|
||||||
|
|
||||||
# bool check_statedir(dir)
|
|
||||||
#
|
|
||||||
# Check that 'dir' exists, if not, drop to a shell.
|
|
||||||
#
|
|
||||||
check_statedir() {
|
|
||||||
[ -z "$1" ] && return 0
|
|
||||||
|
|
||||||
if [ ! -d "$1" ]; then
|
|
||||||
if ! mkdir -p "$1" &>/dev/null; then
|
|
||||||
#splash "critical" &
|
|
||||||
echo
|
|
||||||
eerror "To function properly, \"$1\" needs to exist."
|
|
||||||
if yesno ${rc_force_auto:-${RC_FORCE_AUTO}}; then
|
|
||||||
eerror "Attempting to create \"$1\" for you ..."
|
|
||||||
if [ "${RC_UNAME}" = "Linux" ]; then
|
|
||||||
mount -o remount,rw /
|
|
||||||
else
|
|
||||||
mount -u -o rw /
|
|
||||||
fi
|
|
||||||
mkdir -p "$1"
|
|
||||||
fi
|
|
||||||
if [ ! -d "$1" ]; then
|
|
||||||
eerror "Please mount your root partition read/write, and execute:"
|
|
||||||
echo
|
|
||||||
eerror " # mkdir -p $1"
|
|
||||||
echo; echo
|
|
||||||
single_user
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ts=4 :
|
|
Loading…
Reference in New Issue
Block a user