Finish cleaning up package defaults for each WM and removing defaults

This commit is contained in:
natemaia 2018-12-02 21:10:31 -08:00
parent 50faa08c2c
commit 5258991023
6 changed files with 48 additions and 45 deletions

View File

@ -10,7 +10,7 @@
# immutable globals # immutable globals
readonly VER="1.7.20" # Installer version readonly VER="1.7.24" # Installer version
readonly DIST="ArchLabs" # Linux distributor readonly DIST="ArchLabs" # Linux distributor
readonly MNT="/mnt/install" # Install mountpoint readonly MNT="/mnt/install" # Install mountpoint
readonly ERR="/tmp/errlog" # Built-in error log readonly ERR="/tmp/errlog" # Built-in error log
@ -21,6 +21,7 @@ main()
if [[ $CURRENT_MENU != "main" ]]; then if [[ $CURRENT_MENU != "main" ]]; then
if [[ $SAVED ]]; then if [[ $SAVED ]]; then
SELECTED=$((SAVED + 1)) SELECTED=$((SAVED + 1))
unset SAVED
else else
SELECTED=1 SELECTED=1
fi fi

View File

@ -22,19 +22,6 @@ declare -Agrx BOOTLDRS=(
[UEFI]="systemd-boot ${BMNTS[UEFI-systemd-boot]} grub ${BMNTS[UEFI-grub]} syslinux ${BMNTS[UEFI-syslinux]}" [UEFI]="systemd-boot ${BMNTS[UEFI-systemd-boot]} grub ${BMNTS[UEFI-grub]} syslinux ${BMNTS[UEFI-syslinux]}"
) )
declare -Agx EDIT_FILES=(
[2]="/etc/X11/xorg.conf.d/00-keyboard.conf /etc/default/keyboard /etc/vconsole.conf"
[3]="/etc/locale.conf /etc/default/locale"
[4]="/etc/hostname /etc/hosts"
[5]="/etc/sudoers"
[6]="/etc/mkinitcpio.conf"
[7]="/etc/fstab"
[8]="/etc/crypttab"
[9]="/etc/default/grub"
[10]="/etc/pacman.conf"
[11]="" # empty login files, we don't know /home/USER?/FILES?
)
prep_for_grub() prep_for_grub()
{ {
local cfg="$MNT/etc/default/grub" local cfg="$MNT/etc/default/grub"

View File

@ -37,6 +37,7 @@ declare -g PACKAGES=""
declare -g MYSHELL="" declare -g MYSHELL=""
declare -g MKINIT_HOOKS="shutdown" declare -g MKINIT_HOOKS="shutdown"
# match the wm name with the actual session name used for xinit
declare -gA WM_SESSIONS=( declare -gA WM_SESSIONS=(
[i3-gaps]='i3' [i3-gaps]='i3'
[dwm]='dwm' [dwm]='dwm'
@ -47,13 +48,26 @@ declare -gA WM_SESSIONS=(
[cinnamon]='cinnamon-session' [cinnamon]='cinnamon-session'
) )
# additional packages installed for the given window manager
declare -gA WM_EXT=( declare -gA WM_EXT=(
[dwm]="ttf-hack" [bspwm]="sxhkd libmpdclient jsoncpp archlabs-screenlock archlabs-polybar rofi"
[bspwm]="sxhkd"
[gnome]="gnome-extra" [gnome]="gnome-extra"
[i3-gaps]="i3status perl-anyevent-i3" [i3-gaps]="i3status perl-anyevent-i3 libmpdclient jsoncpp archlabs-screenlock archlabs-polybar rofi"
[xfce4]="xfce4-goodies xfce4-pulseaudio-plugin" [xfce4]="xfce4-goodies xfce4-pulseaudio-plugin"
[openbox]="archlabs-obkey obconf archlabs-kickshaw tint2 archlabs-skippy-xd conky jgmenu" [openbox]="archlabs-obkey obconf archlabs-kickshaw tint2 archlabs-oblogout jgmenu tint2 archlabs-skippy-xd conky thunar termite libmpdclient jsoncpp archlabs-screenlock archlabs-paranoid archlabs-polybar rofi"
)
declare -gA EDIT_FILES=(
[2]="/etc/X11/xorg.conf.d/00-keyboard.conf /etc/default/keyboard /etc/vconsole.conf"
[3]="/etc/locale.conf /etc/default/locale"
[4]="/etc/hostname /etc/hosts"
[5]="/etc/sudoers"
[6]="/etc/mkinitcpio.conf"
[7]="/etc/fstab"
[8]="/etc/crypttab"
[9]="/etc/default/grub"
[10]="/etc/pacman.conf"
[11]="" # empty login files, we don't know /home/USER?/FILES?
) )
# } # }
@ -171,8 +185,9 @@ user_creation()
{ {
tput cnorm tput cnorm
local values local values
if ! values="$(dialog --stdout --no-cancel --separator '~' --ok-label "Submit" --backtitle "$BT" \ if ! values="$(dialog --stdout --no-cancel --separator '~' \
--title " $_UserTitle " --insecure --mixedform "$_UserBody" 27 75 10 \ --ok-label "Submit" --backtitle "$BT" --title " $_UserTitle " \
--insecure --mixedform "$_UserBody" 27 75 10 \
"$_Username" 1 1 "" 1 $((${#_Username} + 2)) 71 0 0 \ "$_Username" 1 1 "" 1 $((${#_Username} + 2)) 71 0 0 \
"$_Password" 2 1 "" 2 $((${#_Password} + 2)) 71 0 1 \ "$_Password" 2 1 "" 2 $((${#_Password} + 2)) 71 0 1 \
"$_Password2" 3 1 "" 3 $((${#_Password2} + 2)) 71 0 1 \ "$_Password2" 3 1 "" 3 $((${#_Password2} + 2)) 71 0 1 \
@ -312,10 +327,9 @@ select_wm_or_de()
"bspwm" "A tiling window manager that represents windows as the leaves of a binary tree" off \ "bspwm" "A tiling window manager that represents windows as the leaves of a binary tree" off \
"gnome" "A desktop environment that aims to be simple and easy to use" off \ "gnome" "A desktop environment that aims to be simple and easy to use" off \
"cinnamon" "A desktop environment combining a traditional desktop layout with modern graphical effects" off \ "cinnamon" "A desktop environment combining a traditional desktop layout with modern graphical effects" off \
"xfce4" "A lightweight and modular desktop environment based on GTK+ 2 and 3" off)"; then "xfce4" "A lightweight and modular desktop environment based on GTK+ 2 and 3" off)" || [[ ! $INSTALL_WMS ]]; then
return 1 return 1
fi fi
[[ $INSTALL_WMS ]] || INSTALL_WMS='openbox'
WM_NUM=$(awk '{print NF}' <<< "$INSTALL_WMS") WM_NUM=$(awk '{print NF}' <<< "$INSTALL_WMS")
WM_PACKAGES="${INSTALL_WMS/dwm/}" # remove dwm from package list WM_PACKAGES="${INSTALL_WMS/dwm/}" # remove dwm from package list
@ -323,17 +337,10 @@ select_wm_or_de()
# packages needed for the selected WMs/DEs # packages needed for the selected WMs/DEs
for wm in $INSTALL_WMS; do for wm in $INSTALL_WMS; do
LOGIN_CHOICES="${LOGIN_CHOICES}$wm - " LOGIN_CHOICES+="$wm - "
WM_PACKAGES+=" ${WM_EXT[$wm]}" WM_PACKAGES+=" ${WM_EXT[$wm]}"
done done
if [[ $INSTALL_WMS =~ (openbox|bspwm|i3-gaps) ]]; then
WM_PACKAGES+=" libmpdclient jsoncpp archlabs-screenlock termite archlabs-oblogout"
WM_PACKAGES+=" archlabs-polybar archlabs-paranoid rofi thunar"
elif [[ $INSTALL_WMS =~ xfce4 ]]; then
WM_PACKAGES+=" archlabs-oblogout archlabs-screenlock archlabs-paranoid"
fi
# choose how to log in # choose how to log in
select_login_method || return 1 select_login_method || return 1
@ -354,11 +361,7 @@ select_wm_or_de()
fi fi
# add packages to the main package list # add packages to the main package list
if [[ $MYSHELL == *mksh ]]; then
declare -g PACKAGES="mksh $WM_PACKAGES"
else
declare -g PACKAGES="$WM_PACKAGES" declare -g PACKAGES="$WM_PACKAGES"
fi
} }
select_login_method() select_login_method()
@ -406,11 +409,17 @@ select_packages()
esac esac
select_packages select_packages
else else
# add any extra for each package
# add any extras for each package
for pkg in $PACKAGES; do for pkg in $PACKAGES; do
[[ ${PKG_EXT[$pkg]} ]] && PACKAGES+=" ${PKG_EXT[$pkg]}" [[ ${PKG_EXT[$pkg]} ]] && PACKAGES+=" ${PKG_EXT[$pkg]}"
done done
# add mksh to package list if it was chosen as the login shell
if [[ $MYSHELL == *mksh ]]; then
declare -g PACKAGES="mksh $PACKAGES"
fi
# remove duplicates and leading spaces # remove duplicates and leading spaces
PACKAGES="$(uniq <<< "${PACKAGES/^ /}")" PACKAGES="$(uniq <<< "${PACKAGES/^ /}")"
return 0 return 0

View File

@ -23,6 +23,7 @@ install()
oneshot install_base oneshot install_base
# generate /etc/fstab and touch it up if we used a swapfile # generate /etc/fstab and touch it up if we used a swapfile
echo
genfstab -U $MNT > $MNT/etc/fstab 2>$ERR genfstab -U $MNT > $MNT/etc/fstab 2>$ERR
echeck "genfstab -U $MNT > $MNT/etc/fstab" echeck "genfstab -U $MNT > $MNT/etc/fstab"
[[ -f $MNT/swapfile ]] && sed -i "s~${MNT}~~" $MNT/etc/fstab [[ -f $MNT/swapfile ]] && sed -i "s~${MNT}~~" $MNT/etc/fstab
@ -56,7 +57,7 @@ install_base()
{ {
# compressed image? # compressed image?
if [[ -e /run/archiso/sfs/airootfs/ ]]; then if [[ -e /run/archiso/sfs/airootfs/ ]]; then
printf "\nUnpacking base system --- Total: ~ 2.9G\n\n" printf "\nUnpacking base system --- Total: ~ 2.7G\n\n"
rsync -ah --info=progress2 /run/archiso/sfs/airootfs/ $MNT/ rsync -ah --info=progress2 /run/archiso/sfs/airootfs/ $MNT/
else else
# update the mirrorlist.. MUST be done before pacstrapping or it may be slow # update the mirrorlist.. MUST be done before pacstrapping or it may be slow
@ -282,7 +283,7 @@ run_mkinitcpio()
mirrorlist_sort() mirrorlist_sort()
{ {
printf "\n\n%s\n\n" "Sorting the mirrorlist" printf "\n%s\n\n" "Sorting the mirrorlist"
if hash reflector >/dev/null 2>&1; then if hash reflector >/dev/null 2>&1; then
$MIRROR_CMD --save $MNT/etc/pacman.d/mirrorlist --verbose || $MIRROR_CMD --save $MNT/etc/pacman.d/mirrorlist --verbose ||
reflector --score 100 -l 50 -f 10 --sort rate --verbose --save $MNT/etc/pacman.d/mirrorlist reflector --score 100 -l 50 -f 10 --sort rate --verbose --save $MNT/etc/pacman.d/mirrorlist
@ -336,7 +337,7 @@ package_operations()
suckless_install() suckless_install()
{ {
# install and setup dwm # install and setup dwm
printf "\n\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"

View File

@ -43,10 +43,10 @@ select_editors()
{ {
local pkgs="" local pkgs=""
pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \ pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \
"neovim" "A fork of Vim aiming to improve user experience, plugins, and GUIs." off \
"atom" "An open-source text editor developed by GitHub that is licensed under the MIT License" off \ "atom" "An open-source text editor developed by GitHub that is licensed under the MIT License" off \
"geany" "A fast and lightweight IDE" off \ "geany" "A fast and lightweight IDE" off \
"emacs" "An extensible, customizable, self-documenting real-time display editor" off \ "emacs" "An extensible, customizable, self-documenting real-time display editor" off \
"neovim" "A fork of Vim aiming to improve user experience, plugins, and GUIs." off \
"mousepad" "A simple text editor" off)" "mousepad" "A simple text editor" off)"
printf "%s" "$pkgs" printf "%s" "$pkgs"
} }
@ -57,7 +57,10 @@ select_terminals()
pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \ pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \
"termite" "A minimal VTE-based terminal emulator" off \ "termite" "A minimal VTE-based terminal emulator" off \
"rxvt-unicode" "A unicode enabled rxvt-clone terminal emulator" off \ "rxvt-unicode" "A unicode enabled rxvt-clone terminal emulator" off \
"xterm" "The standard terminal emulator for the X window system" off \
"alacritty" "A minimal VTE-based terminal emulator" off \
"terminator" "Terminal emulator that supports tabs and grids" off \ "terminator" "Terminal emulator that supports tabs and grids" off \
"sakura" "A terminal emulator based on GTK and VTE" off \
"tilix" "A tiling terminal emulator for Linux using GTK+ 3" off \ "tilix" "A tiling terminal emulator for Linux using GTK+ 3" off \
"tilda" "A Gtk based drop down terminal for Linux and Unix" off \ "tilda" "A Gtk based drop down terminal for Linux and Unix" off \
"xfce4-terminal" "A terminal emulator based in the Xfce Desktop Environment" off)" "xfce4-terminal" "A terminal emulator based in the Xfce Desktop Environment" off)"
@ -69,6 +72,7 @@ select_music_and_video()
local pkgs="" local pkgs=""
pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \ pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \
"vlc" "A free and open source cross-platform multimedia player" off \ "vlc" "A free and open source cross-platform multimedia player" off \
"mpv" "A media player based on mplayer" off \
"mpd" "A flexible, powerful, server-side application for playing music" off \ "mpd" "A flexible, powerful, server-side application for playing music" off \
"ncmpcpp" "An mpd client and almost exact clone of ncmpc with some new features" off \ "ncmpcpp" "An mpd client and almost exact clone of ncmpc with some new features" off \
"cmus" "A small, fast and powerful console music player for Unix-like operating systems" off \ "cmus" "A small, fast and powerful console music player for Unix-like operating systems" off \
@ -121,9 +125,12 @@ select_managment()
pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \ pkgs="$(checkbox "$_Packages" "$_PackageBody" 0 0 0 \
"thunar" "A modern file manager for the Xfce Desktop Environment" off \ "thunar" "A modern file manager for the Xfce Desktop Environment" off \
"pcmanfm" "A fast and lightweight file manager based in Lxde" off \ "pcmanfm" "A fast and lightweight file manager based in Lxde" off \
"gparted" "A GUI frontend for creating and manipulating partition tables" off \
"gnome-disk-utility" "Disk Management Utility" off \ "gnome-disk-utility" "Disk Management Utility" off \
"gnome-system-monitor" "View current processes and monitor system state" off \ "gnome-system-monitor" "View current processes and monitor system state" off \
"qt5ct" "GUI for managing Qt based application themes, icons, and fonts" off \ "qt5ct" "GUI for managing Qt based application themes, icons, and fonts" off \
"file-roller" "Create and modify archives" off \
"xarchiver" "A GTK+ frontend to various command line archivers" off \
"ttf-hack" "A hand groomed and optically balanced typeface based on Bitstream Vera Mono" off \ "ttf-hack" "A hand groomed and optically balanced typeface based on Bitstream Vera Mono" off \
"ttf-anonymous-pro" "A family of four fixed-width fonts designed especially with coding in mind" off \ "ttf-anonymous-pro" "A family of four fixed-width fonts designed especially with coding in mind" off \
"ttf-font-awesome" "Iconic font designed for Bootstrap" off \ "ttf-font-awesome" "Iconic font designed for Bootstrap" off \

View File

@ -159,15 +159,13 @@ system_checks()
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
export HAS_NETWORK=true
else
infobox "$_ErrTitle" "$_NoNetwork" 3 infobox "$_ErrTitle" "$_NoNetwork" 3
die 1
fi fi
fi fi
else
export HAS_NETWORK=true
fi fi
return 0 return 0
} }