Update partition list handling

This commit is contained in:
natemaia 2019-01-20 15:40:59 -08:00
parent 14069e46a6
commit d93b0f529c

View File

@ -904,6 +904,16 @@ format_as()
errshow "${FS_CMDS[$2]} $1" && FORMATTED+=" $part" errshow "${FS_CMDS[$2]} $1" && FORMATTED+=" $part"
} }
decr_pcount()
{
for i in $(printf "%s" "$@"); do
if (( COUNT > 0 )); then
PARTS="$(sed "/${i//\//\\/}/d" <<< "$PARTS")"
(( COUNT-- ))
fi
done
}
enable_swap() enable_swap()
{ {
if [[ $1 == "$MNT/swapfile" && $SWAP_SIZE ]]; then if [[ $1 == "$MNT/swapfile" && $SWAP_SIZE ]]; then
@ -939,16 +949,15 @@ select_device()
[[ $1 == 'boot' ]] && msg="$_DevSelTitle for bootloader\n" || umount_dir $MNT [[ $1 == 'boot' ]] && msg="$_DevSelTitle for bootloader\n" || umount_dir $MNT
if [[ $DEV_COUNT -eq 1 && $SYS_DEVS ]]; then if [[ $DEV_COUNT -eq 1 && $SYS_DEVS ]]; then
# auto select without mention (it's annoying)
DEVICE="$(awk '{print $1}' <<< "$SYS_DEVS")" DEVICE="$(awk '{print $1}' <<< "$SYS_DEVS")"
elif (( DEV_COUNT > 1 )); then elif (( DEV_COUNT > 1 )); then
tput civis tput civis
DEVICE="$(menubox "$_DevSelTitle " "${msg}$_DevSelBody" $SYS_DEVS)" || return 1 DEVICE="$(menubox "$_DevSelTitle " "${msg}$_DevSelBody" $SYS_DEVS)"
[[ $DEVICE ]] || return 1
elif [[ $DEV_COUNT -lt 1 && $1 != 'boot' ]]; then elif [[ $DEV_COUNT -lt 1 && $1 != 'boot' ]]; then
msgbox "$_ErrTitle" "\nNo available devices to use.\n$_Exit"; die 1 msgbox "$_ErrTitle" "\nNo available devices to use.\n$_Exit"; die 1
fi fi
# 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
@ -958,10 +967,10 @@ confirm_mount()
{ {
local part="$1" mount="$2" local part="$1" mount="$2"
[[ $mount == "$MNT" ]] && local m="/ (root)" || local m="${mount#$MNT}" [[ $mount == "$MNT" ]] && local m="/ (root)" || local m="${mount#$MNT}"
if [[ $(mount) == *"$mount"* ]]; then if [[ $(mount) == *"$mount"* ]]; then
infobox "$_MntTitle" "$_MntSucc\nPartition: $part\nMountpoint: $m\n" 1 infobox "$_MntTitle" "$_MntSucc\nPartition: $part\nMountpoint: $m\n" 1
PARTS="$(sed "s~${part} [0-9]*[G-M]~~; s~${part} [0-9]*\.[0-9]*[G-M]~~" <<< "$PARTS")" decr_pcount $part
(( COUNT > 0 )) && (( COUNT-- ))
else else
infobox "$_MntTitle" "$_MntFail\n$msg\n" 1 infobox "$_MntTitle" "$_MntFail\n$msg\n" 1
return 1 return 1
@ -1053,8 +1062,7 @@ auto_partition()
sleep 0.5 sleep 0.5
AUTO_ROOT_PART="$(lsblk -lno NAME,TYPE $device | awk 'NR == 3 {print "/dev/"$1}')" AUTO_ROOT_PART="$(lsblk -lno NAME,TYPE $device | awk 'NR == 3 {print "/dev/"$1}')"
mkfs.ext4 -q $AUTO_ROOT_PART >/dev/null 2>&1 mkfs.ext4 -q $AUTO_ROOT_PART >/dev/null 2>&1
tput civis tput civis; sleep 0.5
sleep 0.5
msgbox "$_PrepParts" "\nAuto partitioning complete.\n\n$(lsblk -o NAME,MODEL,SIZE,TYPE,FSTYPE $device)\n" msgbox "$_PrepParts" "\nAuto partitioning complete.\n\n$(lsblk -o NAME,MODEL,SIZE,TYPE,FSTYPE $device)\n"
} }
@ -1082,7 +1090,7 @@ find_partitions()
local str="$1" err='' local str="$1" err=''
# string of partitions as /TYPE/PART SIZE # string of partitions as /TYPE/PART SIZE
if [[ $IGNORE_DEV != "" ]]; then if [[ $IGNORE_DEV ]]; then
PARTS="$(lsblk -lno TYPE,NAME,SIZE | PARTS="$(lsblk -lno TYPE,NAME,SIZE |
awk "/$str/"' && !'"/$IGNORE_DEV/"' { awk "/$str/"' && !'"/$IGNORE_DEV/"' {
sub(/^part/, "/dev/"); sub(/^part/, "/dev/");
@ -1139,12 +1147,18 @@ mount_menu()
lvm_detect lvm_detect
umount_dir $MNT umount_dir $MNT
find_partitions 'part|lvm|crypt' || { SEL=2; return 1; } find_partitions 'part|lvm|crypt' || { SEL=2; return 1; }
[[ $LUKS_PART ]] && decr_pcount $LUKS_PART
[[ $LVM_PARTS ]] && decr_pcount $LVM_PARTS
select_root_partition || return 1 select_root_partition || return 1
if [[ $SYS == "UEFI" ]]; then if [[ $SYS == "UEFI" ]]; then
select_efi_partition || { BOOT_PART=""; return 1; } select_efi_partition || { BOOT_PART=""; return 1; }
elif (( COUNT > 0 )); then elif (( COUNT > 0 )); then
select_boot_partition || { BOOT_PART=""; return 1; } select_boot_partition || { BOOT_PART=""; return 1; }
fi fi
setup_boot || return 1 setup_boot || return 1
select_swap || return 1 select_swap || return 1
select_extra_partitions || return 1 select_extra_partitions || return 1
@ -1174,9 +1188,8 @@ select_swap()
enable_swap "$MNT/swapfile" enable_swap "$MNT/swapfile"
SWAP_PART="/swapfile" SWAP_PART="/swapfile"
else else
enable_swap "$SWAP_PART" enable_swap $SWAP_PART
PARTS="$(sed "s~${SWAP_PART} [0-9]*[G-M]~~; s~${SWAP_PART} [0-9]*\.[0-9]*[G-M]~~" <<< "$PARTS")" decr_pcount $SWAP_PART
(( COUNT > 0 )) && (( COUNT-- ))
SWAP_SIZE="$(lsblk -lno SIZE $SWAP_PART)" SWAP_SIZE="$(lsblk -lno SIZE $SWAP_PART)"
fi fi
return 0 return 0
@ -1328,9 +1341,10 @@ select_root_partition()
{ {
tput civis tput civis
if (( COUNT == 1 )); then if (( COUNT == 1 )); then
ROOT_PART="$(awk 'NF > 0 {print $1}' <<< "$PARTS")" ROOT_PART="$(awk 'NR==1 {print $1}' <<< "$PARTS")"
elif ! ROOT_PART="$(menubox "$_PrepMount" "$_SelRootBody" $PARTS)"; then else
return 1 ROOT_PART="$(menubox "$_PrepMount" "$_SelRootBody" $PARTS)"
[[ $ROOT_PART ]] || return 1
fi fi
select_filesystem "$ROOT_PART" || { ROOT_PART=""; return 1; } select_filesystem "$ROOT_PART" || { ROOT_PART=""; return 1; }
@ -1492,8 +1506,9 @@ create_user()
fi fi
fi fi
printf "Creating user $NEWUSER with: useradd -m -u 1000 -g users -G $groups -s $MYSHELL $NEWUSER\n"
local groups='audio,autologin,floppy,log,network,rfkill,scanner,storage,optical,power,wheel' local groups='audio,autologin,floppy,log,network,rfkill,scanner,storage,optical,power,wheel'
printf "Creating user $NEWUSER with: useradd -m -u 1000 -g users -G $groups -s $MYSHELL $NEWUSER\n"
chrun "groupadd -r autologin" 2>$ERR chrun "groupadd -r autologin" 2>$ERR
errshow 1 "groupadd -r autologin" errshow 1 "groupadd -r autologin"
chrun "useradd -m -u 1000 -g users -G $groups -s $MYSHELL $NEWUSER" 2>$ERR chrun "useradd -m -u 1000 -g users -G $groups -s $MYSHELL $NEWUSER" 2>$ERR