Update and clean up some functions

This commit is contained in:
natemaia 2018-12-14 01:47:39 -08:00
parent c815cb7f02
commit f96435486a
5 changed files with 99 additions and 58 deletions

View File

@ -10,7 +10,7 @@
# immutable globals # immutable globals
readonly VER="1.7.28" # Installer version readonly VER="1.7.29" # Installer version
readonly DIST="ArchLabs" # Linux distributor readonly DIST="ArchLabs" # Linux distributor
readonly MNT="/mnt" # Install mountpoint readonly MNT="/mnt" # Install mountpoint
readonly ERR="/tmp/errlog" # Built-in error log readonly ERR="/tmp/errlog" # Built-in error log
@ -43,8 +43,9 @@ main()
preinstall_checks 1 || return 1 preinstall_checks 1 || return 1
elif (( SELECTED == 6 )); then elif (( SELECTED == 6 )); then
preinstall_checks || return 1 preinstall_checks || return 1
elif (( SELECTED == 2 || SELECTED == 5 )) && [[ $WARN != true ]]; then elif [[ $WARN != true ]] && (( SELECTED == 2 || SELECTED == 5 )); then
msgbox "$_PrepTitle" "$_WarnMount" && WARN=true msgbox "$_PrepTitle" "$_WarnMount"
WARN=true
fi fi
fi fi
@ -56,14 +57,17 @@ main()
5) mnt_menu || SELECTED=$((SELECTED - 1)) ;; 5) mnt_menu || SELECTED=$((SELECTED - 1)) ;;
6) cfg_menu || SELECTED=$((SELECTED - 1)) ;; 6) cfg_menu || SELECTED=$((SELECTED - 1)) ;;
7) show_cfg ;; 7) show_cfg ;;
8) install ;; 8) install ;;
*) yesno "$_CloseInst" "$_CloseInstBody" "Exit" "Back" && die *) yesno "$_CloseInst" "$_CloseInstBody" "Exit" "Back" && die
esac esac
} }
# source all the lib files # source all the lib files
for i in /usr/share/archlabs/installer/lib/?*.sh; do for i in /usr/share/archlabs/installer/lib/?*.sh; do
. "$i" || { printf "\nFailed to source library file %s\n" "$i"; die 1; } if ! . "$i" 2>/dev/null; then
printf "\nFailed to source library file %s\n" "$i"
die 1
fi
done done
# trap Ctrl-C to properly exit # trap Ctrl-C to properly exit

View File

@ -48,16 +48,14 @@ declare -gA WM_SESSIONS=(
[cinnamon]='cinnamon-session' [cinnamon]='cinnamon-session'
) )
# additional packages installed for the given window manager # additional packages installed for each wm/de
rp="rofi archlabs-polybar"
declare -gA WM_EXT=( declare -gA WM_EXT=(
[gnome]="gnome-extra" [gnome]="gnome-extra"
[bspwm]="sxhkd archlabs-skel-bspwm $rp" [bspwm]="sxhkd archlabs-skel-bspwm rofi archlabs-polybar"
[i3-gaps]="i3status perl-anyevent-i3 archlabs-skel-i3-gaps $rp"
[openbox]="obconf archlabs-skel-openbox jgmenu tint2 conky $rp"
[xfce4]="xfce4-goodies xfce4-pulseaudio-plugin archlabs-skel-xfce4" [xfce4]="xfce4-goodies xfce4-pulseaudio-plugin archlabs-skel-xfce4"
[i3-gaps]="i3status perl-anyevent-i3 archlabs-skel-i3-gaps rofi archlabs-polybar"
[openbox]="obconf archlabs-skel-openbox jgmenu archlabs-polybar tint2 conky rofi"
) )
unset rp
# files the user can edit during the final stage of install # files the user can edit during the final stage of install
declare -gA EDIT_FILES=( declare -gA EDIT_FILES=(
@ -70,7 +68,7 @@ declare -gA EDIT_FILES=(
[8]="/etc/crypttab" [8]="/etc/crypttab"
[9]="/etc/default/grub" [9]="/etc/default/grub"
[10]="/etc/pacman.conf" [10]="/etc/pacman.conf"
[11]="" # login files populated later, /home/USER?/FILES? ... lightdm? [11]="" # login files.. Populated later once login method is chosen
) )
# } # }

View File

@ -352,11 +352,23 @@ suckless_install()
# install and setup dwm # install and setup dwm
printf "\n%s\n\n" "Installing and setting up dwm." printf "\n%s\n\n" "Installing and setting up dwm."
mkdir -pv $MNT/home/$NEWUSER/suckless mkdir -pv $MNT/home/$NEWUSER/suckless
for i in dwm dmenu st; do for i in dwm dmenu st; do
p="/home/$NEWUSER/suckless/$i" p="/home/$NEWUSER/suckless/$i"
chrun "git clone https://bitbucket.org/natemaia/$i $p && { cd $p; rm -f $p/config.h 2>/dev/null; make clean install && make clean; }" chrun "git clone https://bitbucket.org/natemaia/$i $p"
e=$?
if (( e == 0 )); then
chrun "cd $p; rm -f config.h; make clean install; make clean"
else
printf "\n\nFailed to clone dwm repo\n\n"
fi
done done
printf "\n\n%s\n\n" "To configure dwm edit /home/$NEWUSER/suckless/dwm/config.h and recompile with 'sudo make clean install'"
if [[ -d /home/$NEWUSER/suckless/dwm ]]; then
printf "\n\n%s" "To configure dwm edit /home/$NEWUSER/suckless/dwm/config.h"
printf "\n%s\n\n" "You can then recompile it with 'sudo make clean install'"
fi
sleep 2 sleep 2
} }

View File

@ -6,7 +6,7 @@
# this file is not meant to be run directly # this file is not meant to be run directly
# sourcing this file in a non bash shell is not advised # sourcing this file in a non bash shell is not advised
# shellcheck disable=2154,2153,2046 # shellcheck disable=2154,2155,2153,2046
declare -Agr FS_CMDS=( declare -Agr FS_CMDS=(
[ext2]="mkfs.ext2 -q" [ext3]="mkfs.ext3 -q" [ext4]="mkfs.ext4 -q" [ext2]="mkfs.ext2 -q" [ext3]="mkfs.ext3 -q" [ext4]="mkfs.ext4 -q"
@ -107,7 +107,11 @@ select_device()
{ {
local dev local dev
local msg local msg
[[ $1 == 'boot' ]] && msg="$_DevSelTitle for bootloader\n" || umount_dir $MNT if [[ $1 == 'boot' ]]; then
msg="$_DevSelTitle for bootloader\n"
else
umount_dir $MNT
fi
if [[ $DEV_COUNT -eq 1 && $SYS_DEVS ]]; then if [[ $DEV_COUNT -eq 1 && $SYS_DEVS ]]; then
DEVICE="$(awk '{print $1}' <<< "$SYS_DEVS")" DEVICE="$(awk '{print $1}' <<< "$SYS_DEVS")"
@ -124,6 +128,7 @@ select_device()
# if the device selected was for bootloader, set the BOOT_DEVICE # if the device selected was for bootloader, set the BOOT_DEVICE
[[ $1 == 'boot' ]] && BOOT_DEVICE="$DEVICE" [[ $1 == 'boot' ]] && BOOT_DEVICE="$DEVICE"
return 0 return 0
} }
@ -131,14 +136,19 @@ confirm_mount()
{ {
local part="$1" local part="$1"
local mount="$2" local mount="$2"
local msg="Partition: $part\n"
[[ $mount == "$MNT" ]] && msg+="Mountpoint: / (root)" || msg+="Mountpoint: ${mount#$MNT}" if [[ $mount == "$MNT" ]]; then
local msg="Partition: $part\nMountpoint: / (root)"
else
local msg="Partition: $part\nMountpoint: ${mount#$MNT}"
fi
if [[ $(mount) == *"$mount"* ]]; then if [[ $(mount) == *"$mount"* ]]; then
infobox "$_MntTitle" "$_MntSucc\n$msg\n" 1 && decr_count "$part" infobox "$_MntTitle" "$_MntSucc\n$msg\n" 1; decr_count "$part"
else else
infobox "$_MntTitle" "$_MntFail\n$msg\n" 1 && return 1 infobox "$_MntTitle" "$_MntFail\n$msg\n" 1; return 1
fi fi
return 0 return 0
} }
@ -146,8 +156,7 @@ check_cryptlvm()
{ {
local dev="" local dev=""
local part="$1" local part="$1"
local devs local devs="$(lsblk -lno NAME,FSTYPE,TYPE)"
devs="$(lsblk -lno NAME,FSTYPE,TYPE)"
# Identify if $part is "crypt" (LUKS on LVM, or LUKS alone) # Identify if $part is "crypt" (LUKS on LVM, or LUKS alone)
if [[ $(lsblk -lno TYPE "$part") =~ 'crypt' ]]; then if [[ $(lsblk -lno TYPE "$part") =~ 'crypt' ]]; then
@ -263,8 +272,7 @@ mount_partition()
{ {
local part="$1" local part="$1"
local mountp="${MNT}$2" local mountp="${MNT}$2"
local fs local fs="$(lsblk -lno FSTYPE $part)"
fs="$(lsblk -lno FSTYPE $part)"
mkdir -p "$mountp" mkdir -p "$mountp"

View File

@ -6,7 +6,7 @@
# this file is not meant to be run directly # this file is not meant to be run directly
# sourcing this file in a non bash shell is not advised # sourcing this file in a non bash shell is not advised
# shellcheck disable=2154 # shellcheck disable=2154,2034
chrun() chrun()
{ {
@ -33,24 +33,36 @@ ssd()
# returns 0 (true) when the device passed ($1) is NOT a rotational device # returns 0 (true) when the device passed ($1) is NOT a rotational device
local dev=$1 local dev=$1
dev=${dev#/dev/} dev=${dev#/dev/}
[[ $dev =~ nvme ]] && dev=${dev%p[0-9]*} || dev=${dev%[0-9]*}
if [[ $dev =~ nvme ]]; then
dev=${dev%p[0-9]*}
else
dev=${dev%[0-9]*}
fi
[[ $(cat /sys/block/$dev/queue/rotational) -eq 0 ]] || return 1 [[ $(cat /sys/block/$dev/queue/rotational) -eq 0 ]] || return 1
} }
die() die()
{ {
# die peacefully
local exitcode=0 if (( $# >= 1 )); then
(( $# == 0 )) || exitcode=$1 local exitcode=$1
else
local exitcode=0
fi
tput cnorm tput cnorm
if [[ -d $MNT ]] && command cd /; then if [[ -d $MNT ]] && command cd /; then
umount_dir $MNT umount_dir $MNT
if (( exitcode == 127 )); then if (( exitcode == 127 )); then
# umount -l /run/archiso/bootmnt umount -l /run/archiso/bootmnt
systemctl -i reboot systemctl -i reboot
fi fi
fi fi
rm -fv /tmp/.ai_* rm -fv /tmp/.ai_*
exit $exitcode exit $exitcode
} }
@ -131,33 +143,40 @@ system_identify()
if [[ -d $efidir ]]; then if [[ -d $efidir ]]; then
SYS="UEFI" SYS="UEFI"
[[ $(cat $efidir/fw_platform_size) == 64 ]] && export IS_64BIT=true [[ $(cat $efidir/fw_platform_size) == 64 ]] && export IS_64BIT=true
grep -q $efidir/efivars <<< "$(mount)" || mount -t efivarfs efivarfs $efidir/efivars
if ! grep -q $efidir/efivars <<< "$(mount)"; then
mount -t efivarfs efivarfs $efidir/efivars
fi
else else
SYS="BIOS" SYS="BIOS"
fi fi
# shellcheck disable=2034
declare -g BT="$DIST Installer - $SYS (x86_64) - Version $VER" declare -g BT="$DIST Installer - $SYS (x86_64) - Version $VER"
return 0
} }
system_checks() system_checks()
{ {
[[ $(whoami) == "root" ]] || { infobox "$_ErrTitle" "$_NotRoot\n$_Exit" && die 1; } if [[ $(whoami) != "root" ]]; then
grep -qw 'lm' /proc/cpuinfo || { infobox "$_ErrTitle" "$_Not64Bit\n$_Exit" && die 1; } infobox "$_ErrTitle" "$_NotRoot\n$_Exit"
die 1
elif ! grep -qw 'lm' /proc/cpuinfo; then
infobox "$_ErrTitle" "$_Not64Bit\n$_Exit"
die 1
fi
if grep -qw 'BCM4352' <<< "$(lspci -vnn -d 14e4:)"; then if grep -qw 'BCM4352' <<< "$(lspci -vnn -d 14e4:)"; then
rmmod bcma >/dev/null 2>&1 rmmod bcma >/dev/null 2>&1
rmmod wl >/dev/null 2>&1 rmmod wl >/dev/null 2>&1
modprobe wl >/dev/null 2>&1 modprobe wl >/dev/null 2>&1
export BROADCOM_WL=true BROADCOM_WL=true
printf "\nLoading wifi kernel modules please wait...\n" printf "\nLoading wifi kernel modules please wait...\n"
sleep 2 sleep 2
fi fi
if ! curl -s --head 'https://www.archlinux.org/mirrorlist/all/' | sed '1q' | grep -qw '200'; then if ! curl -s --head 'https://www.archlinux.org/mirrorlist/all/' | sed '1q' | grep -qw '200'; then
if [[ $(systemctl is-active NetworkManager) == "active" ]] && hash nmtui >/dev/null 2>&1; then if [[ $(systemctl is-active NetworkManager) == "active" ]] && hash nmtui >/dev/null 2>&1; then
tput civis; nmtui-connect tput civis
nmtui-connect
if ! curl -s --head 'https://www.archlinux.org/mirrorlist/all/' | sed '1q' | grep -qw '200'; then if ! curl -s --head 'https://www.archlinux.org/mirrorlist/all/' | sed '1q' | grep -qw '200'; then
infobox "$_ErrTitle" "$_NoNetwork" 3 infobox "$_ErrTitle" "$_NoNetwork" 3
die 1 die 1
@ -170,34 +189,41 @@ system_checks()
preinstall_checks() preinstall_checks()
{ {
[[ $(lsblk -o MOUNTPOINT) =~ $MNT ]] || { msgbox "$_ErrTitle" "$_ErrNoMount"; export SELECTED=4; return 1; } if ! [[ $(lsblk -o MOUNTPOINT) =~ $MNT ]]; then
if [[ $# -eq 1 ]]; then msgbox "$_ErrTitle" "$_ErrNoMount"
[[ $CONFIG_DONE == true ]] || { msgbox "$_ErrTitle" "$_ErrNoConfig"; export SELECTED=5; return 1; } SELECTED=4
return 1
elif [[ $# -eq 1 && $CONFIG_DONE != true ]]; then
msgbox "$_ErrTitle" "$_ErrNoConfig"
SELECTED=5
return 1
fi fi
return 0 return 0
} }
echeck() echeck()
{ {
# return if the last process exited normally
local last_exit_code=$? local last_exit_code=$?
(( last_exit_code == 0 )) && return 0 if (( last_exit_code == 0 )); then
local msg="\nThe command exited abnormally: $1" return 0
fi
# get error message from logfile and strip any non-printable characters,
# escape sequences, and other messy text
local err local err
err="$(sed 's/[^[:print:]]//g; s/\[[0-9\;:]*\?m//g; s/==> //g; s/] ERROR:/]\nERROR:/g' "$ERR")" err="$(sed 's/[^[:print:]]//g; s/\[[0-9\;:]*\?m//g; s/==> //g; s/] ERROR:/]\nERROR:/g' "$ERR")"
[[ $err != "" ]] && msgbox "$_ErrTitle" "$msg\n\nWith the following error message:\n\n$err"
msg="$([[ $err == "" ]] && printf "%s" "$msg")\n$_ErrChoice" if [[ $err != "" ]]; then
if [[ -e $DBG && $TERM == 'linux' ]]; then msgbox "$_ErrTitle" "\nThe command exited abnormally: $1\n\nWith the following error message:\n\n$err"
msg="$([[ $err == "" ]] && printf "%s" "$msg")\n$_ErrChoiceConsole"
yesno "$_ErrTitle" "$msg" "Exit & Open Log" "Ignore & Continue" && { more $DBG; die; }
else else
yesno "$_ErrTitle" "$msg" "Exit" "Ignore & Continue" && die msgbox "$_ErrTitle" "\nThe command exited abnormally: $1\n\nWith the no error message.\n"
fi fi
if [[ -e $DBG && $TERM == 'linux' ]]; then
more $DBG
fi
die 1
return 0 return 0
} }
@ -206,13 +232,6 @@ debug()
set -x set -x
exec 3>| $DBG exec 3>| $DBG
BASH_XTRACEFD=3 BASH_XTRACEFD=3
if [[ $DISPLAY && $TERM != 'linux' ]]; then
if hash 'termite' >/dev/null 2>&1; then
termite -e "tail -f $DBG" &
else
xterm -e "tail -f $DBG" &
fi
fi
export DEBUG=true export DEBUG=true
} }