cd to script dir

This commit is contained in:
illiliti 2020-02-02 15:19:20 +03:00
parent 5bfcf716be
commit 1953b1760c

View File

@ -11,35 +11,41 @@ info() {
printf "info >> %s\n" "$@" printf "info >> %s\n" "$@"
} }
remove_tmpdir() {
# remove tmpdir # remove tmpdir
remove_tmpdir() {
rm -rf "$tmpdir" rm -rf "$tmpdir"
} }
check_requirements() { # change current directory to script directory if user haven't do it
check_currentdir() {
script_dir=$(dirname $(readlink -f -- "$0"))
[ "$PWD" = "$script_dir" ] || {
cd "$script_dir" || panic "failed to change directory"
}
}
# check needed files # check needed files
for f in ./config ./init ./busybox; do check_requirements() {
# TODO use system busybox
for f in ./init ./busybox $binaries; do
[ -e "$f" ] || panic "$f doesn't exists" [ -e "$f" ] || panic "$f doesn't exists"
done done
# TODO handle busybox requirements ( busybox --list | grep ash ) # TODO handle busybox requirements ( busybox --list | grep ash )
# source config
. ./config
} }
create_structure() {
# create FHS directory structure # create FHS directory structure
create_structure() {
for d in dev tmp var run etc usr/lib usr/bin mnt/root proc root sys; do for d in dev tmp var run etc usr/lib usr/bin mnt/root proc root sys; do
mkdir -p "${tmpdir}/${d}" mkdir -p "${tmpdir}/${d}"
done done
} }
create_symlinks() {
# some dynamically linked libraries and binaries compiled with hardcoded # some dynamically linked libraries and binaries compiled with hardcoded
# dependencies path. to make it worked we need create symlinks for them. # dependencies path. to make it worked we need create symlinks for them.
# also POSIX ln doesn't have --relative flag like in GNU ln. as workaround # also POSIX ln doesn't have --relative flag like in GNU ln. as workaround
# we change directory to tmpdir and make needed symlinks. # we change directory to tmpdir and make needed symlinks.
create_symlinks() {
( cd "$tmpdir" && { ( cd "$tmpdir" && {
ln -s usr/lib lib ln -s usr/lib lib
ln -s usr/lib lib64 ln -s usr/lib lib64
@ -61,22 +67,21 @@ create_symlinks() {
# TODO parse crypttab # TODO parse crypttab
#} #}
# handle device managers
use_mdev() {
# install mdev # install mdev
use_mdev() {
install -m644 mdev.conf -t "$tmpdir/etc" install -m644 mdev.conf -t "$tmpdir/etc"
install -Dm755 storage-device -t "$tmpdir/lib/mdev" install -Dm755 storage-device -t "$tmpdir/lib/mdev"
} }
use_mdevd() {
# install mdevd # install mdevd
use_mdevd() {
install_binaries mdevd mdevd-coldplug install_binaries mdevd mdevd-coldplug
install -m644 mdev.conf -t "$tmpdir/etc" install -m644 mdev.conf -t "$tmpdir/etc"
install -Dm755 storage-device -t "$tmpdir/lib/mdev" install -Dm755 storage-device -t "$tmpdir/lib/mdev"
} }
use_udev() {
# install udev # install udev
use_udev() {
install_binaries udevd udevadm dmsetup install_binaries udevd udevadm dmsetup
# FIXME rewrite this piece of crap # FIXME rewrite this piece of crap
find /usr/lib/udev -type f | grep -v "rc_keymaps\|hwdb.d" | cpio -pd "$tmpdir" >/dev/null 2>&1 find /usr/lib/udev -type f | grep -v "rc_keymaps\|hwdb.d" | cpio -pd "$tmpdir" >/dev/null 2>&1
@ -241,10 +246,22 @@ create_initramfs() {
[ "$?" = 0 ] || panic "failed to generate initramfs image" [ "$?" = 0 ] || panic "failed to generate initramfs image"
} }
# TODO cd to script directory # check root
[ "$(id -u)" = 0 ] || panic "must be run as root" [ "$(id -u)" = 0 ] || panic "must be run as root"
check_currentdir
# source config
. ./config || panic "./config doesn't exists"
# handle debug mode
[ "$debug" = 1 ] && {
# debug shell commands
set -x
# don't remove anything
trap : EXIT INT
}
# remove tmpdir on exit or unexpected error # remove tmpdir on exit or unexpected error
trap remove_tmpdir EXIT INT trap remove_tmpdir EXIT INT
@ -255,14 +272,6 @@ moddir="/lib/modules/"
check_requirements check_requirements
# handle debug mode
[ "$debug" = 1 ] && {
# debug shell commands
set -x
# don't remove anything
trap : EXIT INT
}
create_structure create_structure
create_symlinks create_symlinks
#parse_fstab #parse_fstab
@ -271,6 +280,7 @@ install_binaries $binaries
install_drivers install_drivers
install_files install_files
# handle device manager
case "$devmgr" in case "$devmgr" in
mdev) use_mdev ;; mdev) use_mdev ;;
mdevd) use_mdevd ;; mdevd) use_mdevd ;;