Fix issue when indexing empty strings, large cleanup.

This commit is contained in:
natemaia 2020-05-19 23:10:14 -07:00
parent 45f3b08020
commit d6c2a29c14

438
installer
View File

@ -6,28 +6,39 @@
# AIF, Calamares, and the Arch Wiki.. Credit where credit is due # AIF, Calamares, and the Arch Wiki.. Credit where credit is due
# shellcheck disable=SC2086,SC2046,SC2254,SC2164 # shellcheck disable=SC2086,SC2046,SC2254,SC2164
VER=2.1.53 VER=2.1.54
# default values { # default values {
: "${DIST=ArchLabs}" # distro name if not set : "${DIST=ArchLabs}" # distro name if not set
: "${MNT=/mnt}" # installation root mountpoint if not set : "${MNT=/mnt}" # installation root mountpoint if not set
ANS=/tmp/ans # dialog answer output file SYS=Unknown # boot type, to be determined: UEFI/BIOS
FONT=ter-i16n # font used for the linux console FONT=ter-i16n # font used for the linux console
HOOKS=shutdown # additional mkinitcpio HOOKS HOOKS=shutdown # additional mkinitcpio HOOKS
SEL=0 # currently selected menu item SEL=0 # currently selected main menu item
PACSTRAP=1 # use a fresh pacstrap or copy the iso filesystem BTRFS=0 # is btrfs used, 1 = btrfs alone, 2 = btrfs + subvolume(s)
SYS=Unknown # bios type, to be determined: UEFI/BIOS PACSTRAP=1 # use pacstrap or copy the iso filesystem
EXMNTS='' # extra partitions that were mounted, used to verify mountpoint and show user
USERCMD='' # optional command(s) entered by the user to run in the chroot
ANS=/tmp/ans # dialog answer output file
BG=/tmp/bgout # output from background process BG=/tmp/bgout # output from background process
ERR=/tmp/errlog # stderr log used internally by errshow() ERR=/tmp/errlog # stderr log used internally by errshow()
DBG=/tmp/debuglog # debug log file when passed -d DBG=/tmp/debuglog # debug log file when passed -d
RUN=/run/archiso/bootmnt/arch/boot # path for live system /boot RUN=/run/archiso/bootmnt/arch/boot # path for live system /boot
BTRFS=0 # is btrfs used, 1 = btrfs alone, 2 = btrfs + subvolume(s)
EXMNTS="" # extra partitions that were mounted, used to verify mountpoint and show user
USER_CMD="" # optional command(s) entered by the user to run in the chroot
VM="$(systemd-detect-virt)" # system running in a virtual machine
export DIALOGOPTS="--cr-wrap" # dialog environment variable to hold default options, see `man dialog` VIRT="$(systemd-detect-virt)"
MEM="$(awk '/MemTotal/ {print int($2 / 1024) "M"}' /proc/meminfo)"
LOCALES="$(awk '/\.UTF-8/ {gsub(/# .*|#/, ""); if ($1) {print $1 " - "}}' /etc/locale.gen)"
CMAPS="$(find /usr/share/kbd/keymaps -name '*.map.gz' | awk '{gsub(/\.map\.gz|.*\//, ""); print $1 " - "}' | sort)"
[[ $LINES ]] || LINES=$(tput lines)
[[ $COLUMNS ]] || COLUMNS=$(tput cols)
export DIALOGOPTS="--cr-wrap"
# }
# package arrays {
# package arrays built later from user selections # package arrays built later from user selections
typeset -a SES_PKGS USER_PKGS typeset -a SES_PKGS USER_PKGS
@ -161,12 +172,50 @@ typeset -a ISO_PKGS=(
"wvdial" "wvdial"
) # } ) # }
SYS_MEM="$(awk '/MemTotal/ {print int($2 / 1024) "M"}' /proc/meminfo)" # packages installed for each wm/de, most are depends of the skel packages {
LOCALES="$(awk '/\.UTF-8/ {gsub(/# .*|#/, ""); if ($1) {print $1 " - "}}' /etc/locale.gen)" declare -A WM_EXT=(
CMAPS="$(find /usr/share/kbd/keymaps -name '*.map.gz' | awk '{gsub(/\.map\.gz|.*\//, ""); print $1 " - "}' | sort)" [awesome]='archlabs-skel-awesome'
[bspwm]='archlabs-skel-bspwm'
[cinnamon]='gnome-terminal'
[deepin]='deepin-extra'
[dwm]='nitrogen polkit-gnome gnome-keyring dunst lxappearance'
[fluxbox]='archlabs-skel-fluxbox'
[gnome]='gnome-tweaks'
[i3-gaps]='archlabs-skel-i3-gaps'
[jwm]=''
[lxqt]='breeze breeze-icons picom libpulse network-manager-applet'
[openbox]='archlabs-skel-openbox'
[plasma]='kde-applications-meta powerdevil'
[xfce4]='archlabs-skel-xfce4 xfce4-goodies'
) # }
[[ $LINES ]] || LINES=$(tput lines) # packages installed for each login option {
[[ $COLUMNS ]] || COLUMNS=$(tput cols) declare -A LOGIN_PKGS=(
[gdm]='gdm'
[lightdm]='lightdm lightdm-gtk-greeter lightdm-gtk-greeter-settings accountsservice'
[sddm]='sddm'
[xinit]='xorg-xinit'
) # }
# extras installed for user selected packages {
# if a package requires additional packages that aren't already dependencies
# they can be added here e.g. [package]="extra"
declare -A PKG_EXT=(
[bluez]='bluez-libs bluez-utils bluez-tools bluez-plugins bluez-hid2hci'
[cairo-dock]='cairo-dock-plug-ins'
[kdenlive]='qt5ct qt5-styleplugins'
[mpd]='mpc'
[mupdf]='mupdf-tools'
[noto-fonts]='noto-fonts-emoji'
[pcmanfm]='tumbler'
[qbittorrent]='qt5ct qt5-styleplugins'
[qt5ct]='qt5-styleplugins'
[qutebrowser]='qt5ct qt5-styleplugins'
[thunar]='tumbler thunar-volman'
[transmission-qt]='qt5ct qt5-styleplugins'
[vlc]='qt5ct qt5-styleplugins'
[zathura]='zathura-pdf-poppler'
) # }
# } # }
@ -202,23 +251,6 @@ declare -A WM_SESSIONS=(
[xfce4]='startxfce4' [xfce4]='startxfce4'
) # } ) # }
# Packages installed for each wm/de, most are depends of the skel packages {
declare -A WM_EXT=(
[awesome]='archlabs-skel-awesome'
[bspwm]='archlabs-skel-bspwm'
[cinnamon]='gnome-terminal'
[deepin]='deepin-extra'
[dwm]='nitrogen polkit-gnome gnome-keyring dunst lxappearance'
[fluxbox]='archlabs-skel-fluxbox'
[gnome]='gnome-tweaks'
[i3-gaps]='archlabs-skel-i3-gaps'
[jwm]=''
[lxqt]='breeze breeze-icons picom libpulse network-manager-applet'
[openbox]='archlabs-skel-openbox'
[plasma]='kde-applications-meta powerdevil'
[xfce4]='archlabs-skel-xfce4 xfce4-goodies'
) # }
# files offered for editing after install is complete { # files offered for editing after install is complete {
declare -A EDIT_FILES=( declare -A EDIT_FILES=(
[login]='' # login is populated once we know the username and shell [login]='' # login is populated once we know the username and shell
@ -264,105 +296,77 @@ declare -A FS_OPTS=(
[btrfs]='autodefrag compress=zlib compress=lzo compress=no compress-force=zlib compress-force=lzo discard noacl noatime nodatasum nospace_cache recovery skip_balance space_cache ssd ssd_spread' [btrfs]='autodefrag compress=zlib compress=lzo compress=no compress-force=zlib compress-force=lzo discard noacl noatime nodatasum nospace_cache recovery skip_balance space_cache ssd ssd_spread'
) # } ) # }
# packages installed for each login option {
declare -A LOGIN_PKGS=(
[gdm]='gdm'
[lightdm]='lightdm lightdm-gtk-greeter lightdm-gtk-greeter-settings accountsservice'
[sddm]='sddm'
[xinit]='xorg-xinit'
) # }
# extras installed for user selected packages {
# if a package requires additional packages that aren't already dependencies
# they can be added here e.g. [package]="extra"
declare -A PKG_EXT=(
[bluez]='bluez-libs bluez-utils bluez-tools bluez-plugins bluez-hid2hci'
[cairo-dock]='cairo-dock-plug-ins'
[kdenlive]='qt5ct qt5-styleplugins'
[mpd]='mpc'
[mupdf]='mupdf-tools'
[noto-fonts]='noto-fonts-emoji'
[pcmanfm]='tumbler'
[qbittorrent]='qt5ct qt5-styleplugins'
[qt5ct]='qt5-styleplugins'
[qutebrowser]='qt5ct qt5-styleplugins'
[thunar]='tumbler thunar-volman'
[transmission-qt]='qt5ct qt5-styleplugins'
[vlc]='qt5ct qt5-styleplugins'
[zathura]='zathura-pdf-poppler'
) # }
# mirrorlist country codes to names table { # mirrorlist country codes to names table {
typeset -A COUNTRIES=( typeset -A COUNTRIES=(
[AU]="Australia" [AU]='Australia'
[AT]="Austria" [AT]='Austria'
[BD]="Bangladesh" [BD]='Bangladesh'
[BY]="Belarus" [BY]='Belarus'
[BE]="Belgium" [BE]='Belgium'
[BA]="Bosnia and Herzegovina" [BA]='Bosnia and Herzegovina'
[BR]="Brazil" [BR]='Brazil'
[BG]="Bulgaria" [BG]='Bulgaria'
[CA]="Canada" [CA]='Canada'
[CL]="Chile" [CL]='Chile'
[CN]="China" [CN]='China'
[CO]="Colombia" [CO]='Colombia'
[HR]="Croatia" [HR]='Croatia'
[CZ]="Czechia" [CZ]='Czechia'
[DK]="Denmark" [DK]='Denmark'
[EC]="Ecuador" [EC]='Ecuador'
[FI]="Finland" [FI]='Finland'
[FR]="France" [FR]='France'
[GE]="Georgia" [GE]='Georgia'
[DE]="Germany" [DE]='Germany'
[GR]="Greece" [GR]='Greece'
[HK]="Hong Kong" [HK]='Hong Kong'
[HU]="Hungary" [HU]='Hungary'
[IS]="Iceland" [IS]='Iceland'
[IN]="India" [IN]='India'
[ID]="Indonesia" [ID]='Indonesia'
[IR]="Iran" [IR]='Iran'
[IE]="Ireland" [IE]='Ireland'
[IL]="Israel" [IL]='Israel'
[IT]="Italy" [IT]='Italy'
[JP]="Japan" [JP]='Japan'
[KZ]="Kazakhstan" [KZ]='Kazakhstan'
[KE]="Kenya" [KE]='Kenya'
[LV]="Latvia" [LV]='Latvia'
[LT]="Lithuania" [LT]='Lithuania'
[LU]="Luxembourg" [LU]='Luxembourg'
[NL]="Netherlands" [NL]='Netherlands'
[NC]="New Caledonia" [NC]='New Caledonia'
[NZ]="New Zealand" [NZ]='New Zealand'
[MK]="North Macedonia" [MK]='North Macedonia'
[NO]="Norway" [NO]='Norway'
[PY]="Paraguay" [PY]='Paraguay'
[PH]="Philippines" [PH]='Philippines'
[PL]="Poland" [PL]='Poland'
[PT]="Portugal" [PT]='Portugal'
[RO]="Romania" [RO]='Romania'
[RU]="Russia" [RU]='Russia'
[RS]="Serbia" [RS]='Serbia'
[SG]="Singapore" [SG]='Singapore'
[SK]="Slovakia" [SK]='Slovakia'
[SI]="Slovenia" [SI]='Slovenia'
[ZA]="South Africa" [ZA]='South Africa'
[KR]="South Korea" [KR]='South Korea'
[ES]="Spain" [ES]='Spain'
[SE]="Sweden" [SE]='Sweden'
[CH]="Switzerland" [CH]='Switzerland'
[TW]="Taiwan" [TW]='Taiwan'
[TH]="Thailand" [TH]='Thailand'
[TR]="Turkey" [TR]='Turkey'
[UA]="Ukraine" [UA]='Ukraine'
[GB]="United Kingdom" [GB]='United Kingdom'
[US]="United States" [US]='United States'
[VN]="Vietnam" [VN]='Vietnam'
) # } ) # }
# dialog text variables { # dialog text variables {
# Basics (somewhat in order) # Basics (somewhat in order)
_keymap="\nSelect which keymap to use from the list below.\n\nThis will determine the installed system keymap, NOT locale which is chosen later.\n\nSystem default: us" _keymap="\nSelect which keymap to use from the list below.\n\nThis will determine the installed system keymap once entering a graphical environment.\n\ndefault: us"
_vconsole="\nSelect the console keymap, the console is the tty shell you reach before starting a graphical environment (Xorg).\n\nIts keymap is separate from the one used by the graphical environments, though many do use the same such as 'us' English.\n\nSystem default: us" _vconsole="\nSelect the console keymap, the console is the tty shell you reach before starting a graphical environment (Xorg).\n\nIts keymap is separate from the one used by the graphical environments, though many do use the same such as 'us' English.\n\ndefault: us"
_prep="\nThis is the installer main menu, once a step is complete you will return here.\n\nOn successful completion of a step the cursor will advance to the next step.\nOn failure the cursor will be placed on the step required to advance (when possible).\n\nSteps beginning with an asterisk (*) are required.\n\nOnce all required steps are complete, selecting the last step will finalize the install." _prep="\nThis is the installer main menu, once a step is complete you will return here.\n\nOn successful completion of a step the cursor will advance to the next step.\nOn failure the cursor will be placed on the step required to advance (when possible).\n\nSteps beginning with an asterisk (*) are required.\n\nOnce all required steps are complete, selecting the last step will finalize the install."
_device="\nSelect a device to use from the list below.\n\nDevices (/dev) are the available drives on the system. /sda, /sdb, /sdc ..." _device="\nSelect a device to use from the list below.\n\nDevices (/dev) are the available drives on the system. /sda, /sdb, /sdc ..."
_mount="\nUse [Space] to toggle mount options from below, press [Enter] when done to confirm selection.\n\nNot selecting any and confirming will run an automatic mount." _mount="\nUse [Space] to toggle mount options from below, press [Enter] when done to confirm selection.\n\nNot selecting any and confirming will run an automatic mount."
@ -509,7 +513,7 @@ select_show()
Hostname: ${NEWHOST:-none} Hostname: ${NEWHOST:-none}
Timezone: ${ZONE:-none}/${SUBZ:-none} Timezone: ${ZONE:-none}/${SUBZ:-none}
Chroot cmd: ${USER_CMD:-none} Chroot cmd: ${USERCMD:-none}
------------ USER CONFIGURATION --------------- ------------ USER CONFIGURATION ---------------
@ -538,9 +542,16 @@ select_login()
"sddm" "Simple desktop display manager (plasma and lxqt default)" || return 1 "sddm" "Simple desktop display manager (plasma and lxqt default)" || return 1
case $LOGIN_TYPE in case $LOGIN_TYPE in
gdm|sddm) gdm)
EDIT_FILES[login]="none" EDIT_FILES[login]="none"
;; ;;
sddm)
if [[ $INSTALL_WMS =~ (plasma|lxqt) ]]; then
EDIT_FILES[login]="/etc/sddm.conf.d/theme.conf"
else
EDIT_FILES[login]="none"
fi
;;
lightdm) lightdm)
LIGHTDM_GREETER='gtk-greeter' LIGHTDM_GREETER='gtk-greeter'
EDIT_FILES[login]="/etc/lightdm/lightdm.conf /etc/lightdm/lightdm-gtk-greeter.conf" EDIT_FILES[login]="/etc/lightdm/lightdm.conf /etc/lightdm/lightdm-gtk-greeter.conf"
@ -689,6 +700,7 @@ select_keymap()
echo "$KEYMAP" > /tmp/xkeys echo "$KEYMAP" > /tmp/xkeys
else else
KEYMAP="$(< /tmp/xkeys)" KEYMAP="$(< /tmp/xkeys)"
: "${KEYMAP='us'}"
fi fi
if [[ ! -f /tmp/ckeys ]]; then if [[ ! -f /tmp/ckeys ]]; then
@ -700,6 +712,7 @@ select_keymap()
echo "$CMAP" > /tmp/ckeys echo "$CMAP" > /tmp/ckeys
else else
CMAP="$(< /tmp/ckeys)" CMAP="$(< /tmp/ckeys)"
: "${CMAP='us'}"
fi fi
if [[ $TERM == 'linux' ]]; then if [[ $TERM == 'linux' ]]; then
@ -713,7 +726,58 @@ select_keymap()
select_usercmd() select_usercmd()
{ {
dlg USER_CMD input "Command" "$_usercmd" "$USER_CMD" nolimit dlg USERCMD input "Command" "$_usercmd" "$USERCMD" nolimit
}
select_mirrors()
{
codes=''
MIRROR_URL=''
typeset -ga MIRROR_COUNTRY
while :; do
dlg codes check "Mirror Countries" "\nSelect which countries to use mirrors from.\n\nNot choosing any will result in an automatic selection." \
AU Australia "$(ofn AU "$codes")" AT Austria "$(ofn AT "$codes")" \
BA "Bosnia Herzegovina" "$(ofn BA "$codes")" BY Belarus "$(ofn BY "$codes")" \
BE Belgium "$(ofn BE "$codes")" BR Brazil "$(ofn BR "$codes")" \
BG Bulgaria "$(ofn BG "$codes")" CA Canada "$(ofn CA "$codes")" \
CL Chile "$(ofn CL "$codes")" CN China "$(ofn CN "$codes")" \
CO Colombia "$(ofn CO "$codes")" CZ "Czech Republic" "$(ofn CZ "$codes")" \
DK Denmark "$(ofn DK "$codes")" EE Estonia "$(ofn EE "$codes")" \
FI Finland "$(ofn FI "$codes")" FR France "$(ofn FR "$codes")" \
DE Germany "$(ofn DE "$codes")" GB "United Kingdom" "$(ofn GB "$codes")" \
GR Greece "$(ofn GR "$codes")" HU Hungary "$(ofn HU "$codes")" \
IN India "$(ofn IN "$codes")" IE Ireland "$(ofn IE "$codes")" \
IL Israel "$(ofn IL "$codes")" IT Italy "$(ofn IT "$codes")" \
JP Japan "$(ofn JP "$codes")" KZ Kazakhstan "$(ofn KZ "$codes")" \
KR Korea "$(ofn KR "$codes")" LT Lithuania "$(ofn LT "$codes")" \
LV Latvia "$(ofn LV "$codes")" LU Luxembourg "$(ofn LU "$codes")" \
MK Macedonia "$(ofn MK "$codes")" NL Netherlands "$(ofn NL "$codes")" \
NC "New Caledonia" "$(ofn NC "$codes")" NZ "New Zealand" "$(ofn NZ "$codes")" \
NO Norway "$(ofn NO "$codes")" PL Poland "$(ofn PL "$codes")" \
PT Portugal "$(ofn PT "$codes")" RO Romania "$(ofn RO "$codes")" \
RU Russia "$(ofn RU "$codes")" RS Serbia "$(ofn RS "$codes")" \
SG Singapore "$(ofn SG "$codes")" SK Slovakia "$(ofn SK "$codes")" \
ZA "South Africa" "$(ofn ZA "$codes")" ES Spain "$(ofn ES "$codes")" \
LK "Sri Lanka" "$(ofn LK "$codes")" SE Sweden "$(ofn SE "$codes")" \
CH Switzerland "$(ofn CH "$codes")" TW Taiwan "$(ofn TW "$codes")" \
TR Turkey "$(ofn TR "$codes")" UA Ukraine "$(ofn UA "$codes")" \
US "United States" "$(ofn US "$codes")" UZ Uzbekistan "$(ofn UZ "$codes")" \
VN Vietnam "$(ofn VN "$codes")" || return 1
yesno "Mirror Countries" "\nConfirm the following countries: $(for i in $codes; do printf "%s, " "${COUNTRIES[$i]}"; done)" && break
done
for i in $codes; do
if [[ $MIRROR_URL ]]; then
MIRROR_URL+="&country=$i"
else
MIRROR_URL="https://www.archlinux.org/mirrorlist/?country=$i"
fi
MIRROR_COUNTRY+=("--country" "${COUNTRIES[$i]}")
done
MIRROR_URL+='&use_mirror_status=on'
return 0
} }
select_bootldr() select_bootldr()
@ -763,7 +827,7 @@ select_sessions()
for i in $INSTALL_WMS; do for i in $INSTALL_WMS; do
LOGIN_CHOICES+="$i - " LOGIN_CHOICES+="$i - "
if [[ $i =~ (plasma|deepin) ]]; then if [[ $i =~ (plasma|deepin) ]]; then
local pretxt="\nThere are some extra packages available for $i that you may want installed:" local pretxt="\nThere are some extra packages available for $i that can be installed:"
local txt="These are larger package groups containing applications that are a part of $i" local txt="These are larger package groups containing applications that are a part of $i"
txt+=" but are not included in the $i package group." txt+=" but are not included in the $i package group."
yesno "${i^} Extra" "$pretxt ${WM_EXT[$i]}\n\n$txt\n\nWould you like to install them?\n" || continue yesno "${i^} Extra" "$pretxt ${WM_EXT[$i]}\n\n$txt\n\nWould you like to install them?\n" || continue
@ -907,57 +971,6 @@ select_packages()
return 0 return 0
} }
select_mirror_country()
{
codes=''
MIRROR_URL=''
typeset -ga MIRROR_COUNTRY
while :; do
dlg codes check "Mirror Countries" "\nSelect which countries to use mirrors from.\n\nNot choosing any will result in an automatic selection." \
AU Australia "$(ofn AU "$codes")" AT Austria "$(ofn AT "$codes")" \
BA "Bosnia Herzegovina" "$(ofn BA "$codes")" BY Belarus "$(ofn BY "$codes")" \
BE Belgium "$(ofn BE "$codes")" BR Brazil "$(ofn BR "$codes")" \
BG Bulgaria "$(ofn BG "$codes")" CA Canada "$(ofn CA "$codes")" \
CL Chile "$(ofn CL "$codes")" CN China "$(ofn CN "$codes")" \
CO Colombia "$(ofn CO "$codes")" CZ "Czech Republic" "$(ofn CZ "$codes")" \
DK Denmark "$(ofn DK "$codes")" EE Estonia "$(ofn EE "$codes")" \
FI Finland "$(ofn FI "$codes")" FR France "$(ofn FR "$codes")" \
DE Germany "$(ofn DE "$codes")" GB "United Kingdom" "$(ofn GB "$codes")" \
GR Greece "$(ofn GR "$codes")" HU Hungary "$(ofn HU "$codes")" \
IN India "$(ofn IN "$codes")" IE Ireland "$(ofn IE "$codes")" \
IL Israel "$(ofn IL "$codes")" IT Italy "$(ofn IT "$codes")" \
JP Japan "$(ofn JP "$codes")" KZ Kazakhstan "$(ofn KZ "$codes")" \
KR Korea "$(ofn KR "$codes")" LT Lithuania "$(ofn LT "$codes")" \
LV Latvia "$(ofn LV "$codes")" LU Luxembourg "$(ofn LU "$codes")" \
MK Macedonia "$(ofn MK "$codes")" NL Netherlands "$(ofn NL "$codes")" \
NC "New Caledonia" "$(ofn NC "$codes")" NZ "New Zealand" "$(ofn NZ "$codes")" \
NO Norway "$(ofn NO "$codes")" PL Poland "$(ofn PL "$codes")" \
PT Portugal "$(ofn PT "$codes")" RO Romania "$(ofn RO "$codes")" \
RU Russia "$(ofn RU "$codes")" RS Serbia "$(ofn RS "$codes")" \
SG Singapore "$(ofn SG "$codes")" SK Slovakia "$(ofn SK "$codes")" \
ZA "South Africa" "$(ofn ZA "$codes")" ES Spain "$(ofn ES "$codes")" \
LK "Sri Lanka" "$(ofn LK "$codes")" SE Sweden "$(ofn SE "$codes")" \
CH Switzerland "$(ofn CH "$codes")" TW Taiwan "$(ofn TW "$codes")" \
TR Turkey "$(ofn TR "$codes")" UA Ukraine "$(ofn UA "$codes")" \
US "United States" "$(ofn US "$codes")" UZ Uzbekistan "$(ofn UZ "$codes")" \
VN Vietnam "$(ofn VN "$codes")" || return 1
yesno "Mirror Countries" "\nConfirm the following countries: $(for i in $codes; do printf "%s, " "${COUNTRIES[$i]}"; done)" && break
done
for i in $codes; do
if [[ $MIRROR_URL ]]; then
MIRROR_URL+="&country=$i"
else
MIRROR_URL="https://www.archlinux.org/mirrorlist/?country=$i"
fi
MIRROR_COUNTRY+=("--country" "${COUNTRIES[$i]}")
done
MIRROR_URL+='&use_mirror_status=on'
return 0
}
############################################################################### ###############################################################################
# device management menus # device management menus
# acts as an in-between function to avoid cluttering the main menu # acts as an in-between function to avoid cluttering the main menu
@ -977,21 +990,21 @@ dev_menu()
'part' 'Modify the partition layout of a device' \ 'part' 'Modify the partition layout of a device' \
'luks' 'Setup LUKS encryption on a partition or LVM' \ 'luks' 'Setup LUKS encryption on a partition or LVM' \
'lvm' 'Setup logical volume management on partition(s)' \ 'lvm' 'Setup logical volume management on partition(s)' \
'back' "$back" || return 0 'back' "$back"
if [[ $choice == 'back' ]]; then if [[ -z $WARN && $choice != 'view' ]]; then
return 0
elif [[ -z $WARN && $choice != 'view' ]]; then
msg "Data Warning" "$_warn" msg "Data Warning" "$_warn"
WARN=true WARN=true
fi fi
case "$choice" in case "$choice" in
'view') part_show ;; 'view') part_show ;;
'part') part_menu && [[ "$AUTO_ROOT" ]] && return 0 ;; 'part') part_menu && [[ "$AUTO_ROOT" ]] && return 0 ;;
'luks') luks_menu ;; 'luks') luks_menu || return 1 ;;
'lvm') lvm_menu ;; 'lvm') lvm_menu || return 1 ;;
*) break;
esac esac
done done
return 0
} }
############################################################################### ###############################################################################
@ -1115,7 +1128,6 @@ part_auto()
part_find() part_find()
{ {
local regexp="$1" err='' local regexp="$1" err=''
local s dev size isize model
PARTS="$(part_pretty "" "$regexp")" PARTS="$(part_pretty "" "$regexp")"
PART_COUNT=$(wc -l <<< "$PARTS") PART_COUNT=$(wc -l <<< "$PARTS")
@ -1207,13 +1219,12 @@ part_pretty()
s=${size%%__*} s=${size%%__*}
size_t="${s: -1:1}" size_t="${s: -1:1}"
isize=${s:0:-1} isize=${s:0:-1}
isize=${isize%.*}
if [[ $dev = /dev/nvme* ]]; then if [[ $dev = /dev/nvme* ]]; then
model=$(lsblk -lno MODEL "${dev%p[1-9]}" | awk '{gsub(/ |\t/, "_"); print}') model=$(lsblk -lno MODEL "${dev%p[1-9]}" | awk '{gsub(/ |\t/, "_"); print}')
else else
model=$(lsblk -lno MODEL "${dev%[1-9]}" | awk '{gsub(/ |\t/, "_"); print}') model=$(lsblk -lno MODEL "${dev%[1-9]}" | awk '{gsub(/ |\t/, "_"); print}')
fi fi
[[ $size_t == 'K' || ($size_t == 'M' && $isize -lt 80) ]] || printf "%s\n" "$dev ${size}__$model" [[ $size_t == 'K' || ($size_t == 'M' && ${isize%.*} -lt 80) ]] || printf "%s\n" "$dev ${size}__$model"
done < <(lsblk -lno TYPE,PATH,SIZE,FSTYPE,LABEL $part | done < <(lsblk -lno TYPE,PATH,SIZE,FSTYPE,LABEL $part |
awk "/$regexp/"' && !'"/${IGNORE_DEV:-NONEXX}/"' { awk "/$regexp/"' && !'"/${IGNORE_DEV:-NONEXX}/"' {
if ($4 == "") { if ($4 == "") {
@ -1381,11 +1392,11 @@ select_boot()
if (( PART_COUNT )); then if (( PART_COUNT )); then
while read -r dev size; do # walk partition list and skip ones that are too small/big for boot while read -r dev size; do # walk partition list and skip ones that are too small/big for boot
[[ $dev && $size ]] || continue
s=${size%%__*} s=${size%%__*}
size_t="${s: -1:1}" size_t="${s: -1:1}"
isize=${s:0:-1} isize=${s:0:-1}
isize=${isize%.*} if ! [[ $size_t == 'T' || ($size_t == 'G' && ${isize%.*} -gt 2) ]]; then
if ! [[ $size_t == 'T' || ($size_t == 'G' && $isize -gt 2) ]]; then
pts+="$dev $size " pts+="$dev $size "
(( ptcount++ )) (( ptcount++ ))
fi fi
@ -1472,11 +1483,11 @@ select_root()
return 0 # we're done here return 0 # we're done here
else # walk partition list and skip ones that are < 8G else # walk partition list and skip ones that are < 8G
while read -r dev size; do while read -r dev size; do
[[ $dev && $size ]] || continue
s=${size%%__*} s=${size%%__*}
size_t="${s: -1:1}" size_t="${s: -1:1}"
isize=${s:0:-1} isize=${s:0:-1}
isize=${isize%.*} if ! [[ $size_t == 'M' || ($size_t == 'G' && ${isize%.*} -lt 8) ]]; then
if ! [[ $size_t == 'M' || ($size_t == 'G' && $isize -lt 8) ]]; then
pts+="$dev $size " pts+="$dev $size "
(( ptcount++ )) (( ptcount++ ))
fi fi
@ -1514,11 +1525,11 @@ select_swap()
if (( PART_COUNT )) ; then if (( PART_COUNT )) ; then
while read -r dev size; do # walk partition list and skip ones that are > 64G while read -r dev size; do # walk partition list and skip ones that are > 64G
[[ $dev && $size ]] || continue
s=${size%%__*} s=${size%%__*}
size_t="${s: -1:1}" size_t="${s: -1:1}"
isize=${s:0:-1} isize=${s:0:-1}
isize=${isize%.*} if ! [[ $size_t == 'T' || ($size_t == 'G' && ${isize%.*} -gt 64) ]]; then
if ! [[ $size_t == 'T' || ($size_t == 'G' && $isize -gt 64) ]]; then
pts+="$dev $size " pts+="$dev $size "
fi fi
done <<< "$PARTS" done <<< "$PARTS"
@ -1539,7 +1550,7 @@ select_swap()
msg "Swap Size Error" \ msg "Swap Size Error" \
"\nSwap size must be 1(M|G) or greater, and can only contain whole numbers\n\nSize entered: $SWAP_S\n" 2 "\nSwap size must be 1(M|G) or greater, and can only contain whole numbers\n\nSize entered: $SWAP_S\n" 2
fi fi
if ! dlg SWAP_S input "Swap Setup" "$_swapsize" "$SYS_MEM"; then if ! dlg SWAP_S input "Swap Setup" "$_swapsize" "$MEM"; then
SWAP='' SWAP=''
SWAP_S='' SWAP_S=''
return 1 return 1
@ -1563,6 +1574,7 @@ select_extra()
# walk partition list and skip ones that are < 1G # walk partition list and skip ones that are < 1G
if (( PART_COUNT )); then if (( PART_COUNT )); then
while read -r dev size; do while read -r dev size; do
[[ $dev && $size ]] || continue
s=${size%%__*} s=${size%%__*}
[[ ${s: -1:1} == 'M' ]] && part_countdec "$dev" [[ ${s: -1:1} == 'M' ]] && part_countdec "$dev"
done <<< "$PARTS" done <<< "$PARTS"
@ -1698,9 +1710,9 @@ install_main()
chrun "chown -Rf $NEWUSER:users /home/$NEWUSER" chrun "chown -Rf $NEWUSER:users /home/$NEWUSER"
if [[ "$USER_CMD" ]]; then if [[ "$USERCMD" ]]; then
chrun "$USER_CMD" 2> "$ERR" 2>&1 chrun "$USERCMD" 2> "$ERR" 2>&1
errshow 0 "chrun '$USER_CMD'" errshow 0 "chrun '$USERCMD'"
fi fi
while :; do while :; do
@ -1759,9 +1771,9 @@ install_base()
errshow 1 "cp -vf '$RUN/x86_64/vmlinuz' '$MNT/boot/vmlinuz-linux'" errshow 1 "cp -vf '$RUN/x86_64/vmlinuz' '$MNT/boot/vmlinuz-linux'"
# remove/disable customizations done to airootfs during building # remove/disable customizations done to airootfs during building
chrun "systemctl disable pacman-init.service choose-mirror.service" > /dev/null 2>&1 chrun "systemctl disable pacman-init.service" > /dev/null 2>&1
rm -f "$MNT/etc/systemd/scripts/choose-mirror" rm -f "$MNT/etc/systemd/system/pacman-init.service"
rm -f "$MNT/etc/systemd/system/"{choose-mirror.service,etc-pacman.d-gnupg.mount,pacman-init.service} rm -f "$MNT/etc/systemd/system/etc-pacman.d-gnupg.mount"
sed -i 's/#\(Storage=\)volatile/\1auto/' "$MNT/etc/systemd/journald.conf" sed -i 's/#\(Storage=\)volatile/\1auto/' "$MNT/etc/systemd/journald.conf"
sed -i 's/\(HandleLidSwitch=\)ignore/#\1suspend/' "$MNT/etc/systemd/logind.conf" sed -i 's/\(HandleLidSwitch=\)ignore/#\1suspend/' "$MNT/etc/systemd/logind.conf"
sed -i 's/\(HandleSuspendKey=\)ignore/#\1suspend/' "$MNT/etc/systemd/logind.conf" sed -i 's/\(HandleSuspendKey=\)ignore/#\1suspend/' "$MNT/etc/systemd/logind.conf"
@ -1830,6 +1842,7 @@ install_user()
rm -f "$MNT/root/.zlogin" # remove welcome message rm -f "$MNT/root/.zlogin" # remove welcome message
echo "Setting root user password and shell"
chrun "chpasswd <<< 'root:$ROOT_PASS'" 2> "$ERR" 2>&1 chrun "chpasswd <<< 'root:$ROOT_PASS'" 2> "$ERR" 2>&1
errshow 1 "chrun 'chpasswd <<< \"root:$ROOT_PASS\"'" errshow 1 "chrun 'chpasswd <<< \"root:$ROOT_PASS\"'"
if [[ $NEWSHELL != 'zsh' ]]; then # root uses zsh by default if [[ $NEWSHELL != 'zsh' ]]; then # root uses zsh by default
@ -1839,7 +1852,7 @@ install_user()
[[ $NEWSHELL == 'mksh' ]] && cp -fv "$MNT/etc/skel/.mkshrc" "$MNT/root/.mkshrc" [[ $NEWSHELL == 'mksh' ]] && cp -fv "$MNT/etc/skel/.mkshrc" "$MNT/root/.mkshrc"
fi fi
echo "Creating new user $NEWUSER and setting password" echo "Creating user $NEWUSER and setting password"
# check if there's an existing user home for new user (separate /home) # check if there's an existing user home for new user (separate /home)
[[ -d "$MNT/home/$NEWUSER" ]] && i=1 [[ -d "$MNT/home/$NEWUSER" ]] && i=1
@ -1851,8 +1864,8 @@ install_user()
[[ $INSTALL_WMS == *dwm* ]] && install_suckless "/home/$NEWUSER" chroot [[ $INSTALL_WMS == *dwm* ]] && install_suckless "/home/$NEWUSER" chroot
# upgrade existing home with new skeleton configs # upgrade existing home with new skeleton configs, making backups when needed
[[ $i == 1 ]] && cp -aT "$MNT/etc/skel/" "$MNT/home/$NEWUSER" (( i )) && cp -rfaT -b --suffix='.bak' "$MNT/etc/skel/" "$MNT/home/$NEWUSER"
install_cleanup "$NEWUSER" install_cleanup "$NEWUSER"
@ -2053,7 +2066,7 @@ install_packages()
errshow 1 "chrun 'pacman -S efibootmgr --needed --noconfirm'" errshow 1 "chrun 'pacman -S efibootmgr --needed --noconfirm'"
fi fi
if [[ $VM == 'oracle' ]]; then if [[ $VIRT == 'oracle' ]]; then
chrun "pacman -S ${KERNEL}-headers virtualbox-guest-utils virtualbox-guest-dkms --needed --noconfirm" chrun "pacman -S ${KERNEL}-headers virtualbox-guest-utils virtualbox-guest-dkms --needed --noconfirm"
fi fi
@ -2090,7 +2103,7 @@ install_tearfree()
{ {
local xpath="$1" local xpath="$1"
if [[ $VM != 'none' ]]; then if [[ $VIRT != 'none' ]]; then
[[ -e "$xpath/40-touchpad.conf" ]] && rm -fv "$xpath/40-touchpad.conf" [[ -e "$xpath/40-touchpad.conf" ]] && rm -fv "$xpath/40-touchpad.conf"
elif [[ $TEARFREE ]]; then elif [[ $TEARFREE ]]; then
if lspci | grep ' VGA ' | grep -q 'Intel'; then if lspci | grep ' VGA ' | grep -q 'Intel'; then
@ -2234,7 +2247,7 @@ install_background()
[[ ! -d /etc/NetworkManager/system-connections ]] && net='netctl' [[ ! -d /etc/NetworkManager/system-connections ]] && net='netctl'
[[ $LUKS ]] && luks='cryptsetup' [[ $LUKS ]] && luks='cryptsetup'
select_mirror_country || AUTO_MIRROR=true select_mirrors || AUTO_MIRROR=true
if hash rsync > /dev/null 2>&1; then # ask whether to pacstrap or copy if rsync is installed if hash rsync > /dev/null 2>&1; then # ask whether to pacstrap or copy if rsync is installed
yesno 'Background Install' "$_bginstall" 'Pacstrap' 'Copy ISO' || PACSTRAP=0 yesno 'Background Install' "$_bginstall" 'Pacstrap' 'Copy ISO' || PACSTRAP=0
@ -3334,7 +3347,7 @@ chk_connect()
{ {
if [[ ! -f /tmp/new ]]; then if [[ ! -f /tmp/new ]]; then
msg "Network Connect" "\nVerifying network connection\n" 0 msg "Network Connect" "\nVerifying network connection\n" 0
if [[ $VM != 'none' ]] && hash nm-online > /dev/null 2>&1; then if [[ $VIRT != 'none' ]] && hash nm-online > /dev/null 2>&1; then
nm-online > /dev/null 2>&1 nm-online > /dev/null 2>&1
else else
ping -qc1 'archlinux.org' > /dev/null 2>&1 ping -qc1 'archlinux.org' > /dev/null 2>&1
@ -3398,7 +3411,7 @@ system_devices()
system_identify() system_identify()
{ {
if [[ $VM != 'none' ]]; then if [[ $VIRT != 'none' ]]; then
UCODE='' UCODE=''
elif grep -q 'AuthenticAMD' /proc/cpuinfo; then elif grep -q 'AuthenticAMD' /proc/cpuinfo; then
UCODE="amd-ucode" UCODE="amd-ucode"
@ -3491,11 +3504,12 @@ fi
if [[ $TERM == 'linux' ]]; then if [[ $TERM == 'linux' ]]; then
if [[ -f /tmp/font ]]; then if [[ -f /tmp/font ]]; then
FONT="$(< /tmp/font)" FONT="$(< /tmp/font)"
: "${FONT=ter-i16n}"
setfont "$FONT" setfont "$FONT"
else else
fontsize=16 fontsize=16
while [[ $TERM == 'linux' && ! -f /tmp/font ]]; do while [[ $TERM == 'linux' && ! -f /tmp/font ]]; do
dlg fontsize menu "Font Size" "\nSelect a font size from the list below.\n\nDefault: 16" \ dlg fontsize menu "Font Size" "\nSelect a font size from the list below.\n\ndefault: 16" \
12 "setfont ter-i12n" 14 "setfont ter-i14n" 16 "setfont ter-i16n" 18 "setfont ter-i18n" \ 12 "setfont ter-i12n" 14 "setfont ter-i14n" 16 "setfont ter-i16n" 18 "setfont ter-i18n" \
20 "setfont ter-i20n" 22 "setfont ter-i22n" 24 "setfont ter-i24n" 28 "setfont ter-i28n" \ 20 "setfont ter-i20n" 22 "setfont ter-i22n" 24 "setfont ter-i24n" 28 "setfont ter-i28n" \
32 "setfont ter-i32n" || break 32 "setfont ter-i32n" || break
@ -3508,7 +3522,7 @@ if [[ $TERM == 'linux' ]]; then
fi fi
if [[ ! -f /tmp/weld ]]; then if [[ ! -f /tmp/weld ]]; then
msg "Welcome to the $DIST Installer" "\nThis will help you get $DIST installed and setup on your system.\n\nIf you are unsure about an option, the default or most common\nwill be mentioned or the first selected entry will be the default.\n\n\nMenu Navigation:\n\n - Select items with the arrow keys or the option number.\n - Use [Space] to toggle check boxes and [Enter] to accept.\n - Switch between fields using [Tab] or the arrow keys.\n - Use [Page Up] and [Page Down] to jump whole pages\n - Press the highlighted key of an option to select it.\n" msg "Welcome to the $DIST Installer" "\nThis will help you get $DIST installed and setup on your system.\n\nIf you are unsure about an option, the default or most common option\nwill be described, if it is not the first selected entry will be the default.\n\n\nMenu Navigation:\n\n - Select items with the arrow keys or the highlighted key.\n - Repeatedly pressing the highlighted key for an option will cycle through options beginning with that key.\n - Use [Space] to toggle check boxes and [Enter] to accept selection.\n - Use [Escape] or select the cancel/exit button to exit a menu or dialog.\n - Switch between fields using [Tab] or the arrow keys.\n - Use [Page Up] and [Page Down] to jump whole pages.\n"
touch /tmp/weld touch /tmp/weld
fi fi