mirror of
https://github.com/Mastermindzh/dotfiles.git
synced 2024-11-21 14:23:32 +01:00
switch to sddm
This commit is contained in:
parent
ea861dbbfa
commit
3768caaa76
@ -7,6 +7,7 @@ root = true
|
||||
[*]
|
||||
end_of_line = lf
|
||||
insert_final_newline = true
|
||||
indent_size = 2
|
||||
|
||||
# Matches multiple files with brace expansion notation
|
||||
[*.{sh,py,yml}]
|
||||
|
2
dependencies/pacman.txt
vendored
2
dependencies/pacman.txt
vendored
@ -24,7 +24,6 @@ networkmanager
|
||||
eog
|
||||
python
|
||||
python-pip
|
||||
gdm
|
||||
neofetch
|
||||
git
|
||||
scrot
|
||||
@ -87,3 +86,4 @@ blueman
|
||||
pulseaudio-bluetooth
|
||||
bluez
|
||||
bluez-libs
|
||||
sddm
|
||||
|
251
install.sh
251
install.sh
@ -6,52 +6,52 @@
|
||||
|
||||
# Ask a question and return true or false based on the users input
|
||||
ask() {
|
||||
# from https://djm.me/ask
|
||||
local prompt default reply
|
||||
# from https://djm.me/ask
|
||||
local prompt default reply
|
||||
|
||||
while true; do
|
||||
while true; do
|
||||
|
||||
if [ "${2:-}" = "Y" ]; then
|
||||
prompt="Y/n"
|
||||
default=Y
|
||||
elif [ "${2:-}" = "N" ]; then
|
||||
prompt="y/N"
|
||||
default=N
|
||||
else
|
||||
prompt="y/n"
|
||||
default=
|
||||
fi
|
||||
echo -n "$1 [$prompt] "
|
||||
read -r reply </dev/tty
|
||||
if [ "${2:-}" = "Y" ]; then
|
||||
prompt="Y/n"
|
||||
default=Y
|
||||
elif [ "${2:-}" = "N" ]; then
|
||||
prompt="y/N"
|
||||
default=N
|
||||
else
|
||||
prompt="y/n"
|
||||
default=
|
||||
fi
|
||||
echo -n "$1 [$prompt] "
|
||||
read -r reply </dev/tty
|
||||
|
||||
if [ -z "$reply" ]; then
|
||||
reply=$default
|
||||
fi
|
||||
if [ -z "$reply" ]; then
|
||||
reply=$default
|
||||
fi
|
||||
|
||||
case "$reply" in
|
||||
[Yy]*) return 0 ;;
|
||||
[Nn]*) return 1 ;;
|
||||
esac
|
||||
case "$reply" in
|
||||
[Yy]*) return 0 ;;
|
||||
[Nn]*) return 1 ;;
|
||||
esac
|
||||
|
||||
done
|
||||
done
|
||||
}
|
||||
|
||||
# delete target, create dirs if they don't exist yet and finally symlink the dir
|
||||
function linkDir {
|
||||
rm -rf "$2";
|
||||
mkdir -p "${2%/*}"
|
||||
ln -sf "$1" "$2"
|
||||
rm -rf "$2"
|
||||
mkdir -p "${2%/*}"
|
||||
ln -sf "$1" "$2"
|
||||
}
|
||||
|
||||
# replace line endings with a space (for use in package managers)
|
||||
function fileToList {
|
||||
echo $(cat "$1" | sed ':a;N;$!ba;s/\n/ /g')
|
||||
echo $(cat "$1" | sed ':a;N;$!ba;s/\n/ /g')
|
||||
}
|
||||
|
||||
# create and copy files to directory
|
||||
function copyToDir {
|
||||
echo "$2" | sed 's%/[^/]*$%/%' | xargs mkdir -p
|
||||
cp "$1" "$2"
|
||||
echo "$2" | sed 's%/[^/]*$%/%' | xargs mkdir -p
|
||||
cp "$1" "$2"
|
||||
}
|
||||
|
||||
# =======================================
|
||||
@ -60,124 +60,122 @@ function copyToDir {
|
||||
|
||||
# moves all fonts into the fonts directories (overwriting existing files)
|
||||
function install_fonts {
|
||||
mkdir -p ~/.fonts
|
||||
mkdir -p ~/.local/share/fonts
|
||||
cp -rf ./fonts/* ~/.fonts
|
||||
cp -rf ./fonts/* ~/.local/share/fonts
|
||||
mkdir -p ~/.fonts
|
||||
mkdir -p ~/.local/share/fonts
|
||||
cp -rf ./fonts/* ~/.fonts
|
||||
cp -rf ./fonts/* ~/.local/share/fonts
|
||||
}
|
||||
|
||||
# install trizen, a aur helper
|
||||
function install_trizen {
|
||||
git clone https://aur.archlinux.org/trizen.git
|
||||
pushd trizen || return
|
||||
makepkg -si
|
||||
popd || return
|
||||
sudo rm -dRf trizen/
|
||||
git clone https://aur.archlinux.org/trizen.git
|
||||
pushd trizen || return
|
||||
makepkg -si
|
||||
popd || return
|
||||
sudo rm -dRf trizen/
|
||||
}
|
||||
|
||||
# install other configs
|
||||
function install_config {
|
||||
|
||||
# link directories
|
||||
linkDir "$PWD"/wallpapers/images ~/Pictures/wallpapers
|
||||
linkDir "$PWD"/i3 ~/.config/i3
|
||||
linkDir "$PWD"/config/notify-osd/notify-osd ~/.notify-osd
|
||||
linkDir "$PWD"/config/terminal/xfce4-term ~/.config/xfce4/terminal
|
||||
linkDir "$PWD"/config/gtk-3.0/settings.ini ~/.config/gtk-3.0/.config
|
||||
linkDir "$PWD"/config/ranger ~/.config/
|
||||
# link directories
|
||||
linkDir "$PWD"/wallpapers/images ~/Pictures/wallpapers
|
||||
linkDir "$PWD"/i3 ~/.config/i3
|
||||
linkDir "$PWD"/config/notify-osd/notify-osd ~/.notify-osd
|
||||
linkDir "$PWD"/config/terminal/xfce4-term ~/.config/xfce4/terminal
|
||||
linkDir "$PWD"/config/gtk-3.0/settings.ini ~/.config/gtk-3.0/.config
|
||||
linkDir "$PWD"/config/ranger ~/.config/
|
||||
|
||||
# link user files
|
||||
ln -sf "$PWD"/bash/.bashrc ~/.bashrc
|
||||
# link user files
|
||||
ln -sf "$PWD"/bash/.bashrc ~/.bashrc
|
||||
ln -sf "$PWD"/bash/.dotnet-install.sh ~/.dotnet-install.sh
|
||||
ln -sf "$PWD"/bash/.alias.sh ~/.alias
|
||||
ln -sf "$PWD"/config/nano/.nanorc ~/.nanorc
|
||||
ln -sf "$PWD"/bash/.powerline-shell.json ~/.powerline-shell.json
|
||||
ln -sf "$PWD"/config/gtk-3.0/settings.ini ~/.gtkrc-2.0.mine
|
||||
ln -sf "$PWD"/config/mimeapps.list ~/.config/mimeapps.list
|
||||
ln -sf "$PWD"/bash/.alias.sh ~/.alias
|
||||
ln -sf "$PWD"/config/nano/.nanorc ~/.nanorc
|
||||
ln -sf "$PWD"/bash/.powerline-shell.json ~/.powerline-shell.json
|
||||
ln -sf "$PWD"/config/gtk-3.0/settings.ini ~/.gtkrc-2.0.mine
|
||||
ln -sf "$PWD"/config/mimeapps.list ~/.config/mimeapps.list
|
||||
|
||||
mkdir -p ~/.config/rofi
|
||||
ln -sf "$PWD"/config/rofi/rofi.rasi ~/.config/rofi/config.rasi
|
||||
ln -sf "$PWD"/config/rofi/mytheme.rasi ~/.config/rofi/mytheme.rasi
|
||||
ln -sf "$PWD"/config/rofi/rofi.rasi ~/.config/rofi/config.rasi
|
||||
ln -sf "$PWD"/config/rofi/mytheme.rasi ~/.config/rofi/mytheme.rasi
|
||||
|
||||
ln -sf "$PWD"/config/.gitconfig ~/.gitconfig
|
||||
ln -sf "$PWD"/config/.npmrc ~/.npmrc
|
||||
ln -sf "$PWD"/config/user-dirs.dirs ~/.config/user-dirs.dirs
|
||||
mkdir -p ~/.pulse
|
||||
ln -sf "$PWD"/config/pulse/daemon.conf ~/.pulse/daemon.conf
|
||||
ln -sf "$PWD"/config/.gitconfig ~/.gitconfig
|
||||
ln -sf "$PWD"/config/.npmrc ~/.npmrc
|
||||
ln -sf "$PWD"/config/user-dirs.dirs ~/.config/user-dirs.dirs
|
||||
mkdir -p ~/.pulse
|
||||
ln -sf "$PWD"/config/pulse/daemon.conf ~/.pulse/daemon.conf
|
||||
ln -sf "$PWD"/config/picom.conf ~/.config/picom.conf
|
||||
|
||||
# link system files / directories
|
||||
sudo ln -sf "$PWD"/config/package-managers/pacman.conf /etc/pacman.conf
|
||||
sudo ln -sf "$PWD"/config/package-managers/makepkg.conf /etc/makepkg.conf
|
||||
sudo ln -sf "$PWD"/config/ntp.conf /etc/ntp.conf
|
||||
sudo ln -sf "$PWD"/bash/Completion /etc/bash_completion.d
|
||||
# link system files / directories
|
||||
sudo ln -sf "$PWD"/config/package-managers/pacman.conf /etc/pacman.conf
|
||||
sudo ln -sf "$PWD"/config/package-managers/makepkg.conf /etc/makepkg.conf
|
||||
sudo ln -sf "$PWD"/config/ntp.conf /etc/ntp.conf
|
||||
sudo ln -sf "$PWD"/bash/Completion /etc/bash_completion.d
|
||||
|
||||
# create empty .custom alias file
|
||||
echo "" > ~/.custom
|
||||
echo "" > ~/.variables
|
||||
# create empty .custom alias file
|
||||
echo "" >~/.custom
|
||||
echo "" >~/.variables
|
||||
|
||||
# system fixes
|
||||
echo fs.inotify.max_user_watches=524288 | sudo tee /etc/sysctl.d/40-max-user-watches.conf && sudo sysctl --system
|
||||
mkdir -p ~/Pictures/Screenshots
|
||||
# system fixes
|
||||
echo fs.inotify.max_user_watches=524288 | sudo tee /etc/sysctl.d/40-max-user-watches.conf && sudo sysctl --system
|
||||
mkdir -p ~/Pictures/Screenshots
|
||||
}
|
||||
|
||||
# Installs the dependencies on Arch Linux
|
||||
function install_dependencies {
|
||||
fileToList dependencies/pacman.txt | xargs sudo pacman --noconfirm -S
|
||||
fileToList dependencies/pacman.txt | xargs sudo pacman --noconfirm -S
|
||||
|
||||
install_trizen
|
||||
fileToList dependencies/aur.txt | xargs trizen --force -S --noconfirm
|
||||
install_trizen
|
||||
fileToList dependencies/aur.txt | xargs trizen --force -S --noconfirm
|
||||
|
||||
fileToList dependencies/pip.txt | xargs sudo pip install
|
||||
fileToList dependencies/pip.txt | xargs sudo pip install
|
||||
|
||||
fileToList dependencies/npm.txt | xargs sudo npm install -g
|
||||
fileToList dependencies/npm.txt | xargs sudo npm install -g
|
||||
}
|
||||
|
||||
|
||||
# =======================================
|
||||
# User output functions
|
||||
# =======================================
|
||||
|
||||
# Run the intro bit
|
||||
function intro {
|
||||
echo "___ ___ _ _ _ _ _ "
|
||||
echo "| \/ | | | (_) | | | | ( )"
|
||||
echo "| . . | __ _ ___| |_ ___ _ __ _ __ ___ _ _ __ __| |___| |__ |/ "
|
||||
echo "| |\/| |/ _\` / __| __/ _ \ '__| '_ \` _ \| | '_ \ / _' |_ / '_ \ "
|
||||
echo "| | | | (_| \__ \ || __/ | | | | | | | | | | | (_| |/ /| | | | "
|
||||
echo "\_| |_/\__,_|___/\__\___|_| |_| |_| |_|_|_| |_|\__,_/___|_| |_| "
|
||||
echo " "
|
||||
echo " "
|
||||
echo " __ _ _ "
|
||||
echo " / _(_) ___ (_) "
|
||||
echo " ___ ___ _ __ | |_ _ __ _ ( _ ) _ __ _ ___ ___ "
|
||||
echo " / __/ _ \| '_ \| _| |/ _\` | / _ \/\ | '__| |/ __/ _ \ "
|
||||
echo "| (_| (_) | | | | | | | (_| | | (_> < | | | | (_| __/ "
|
||||
echo " \___\___/|_| |_|_| |_|\__, | \___/\/ |_| |_|\___\___| "
|
||||
echo " __/ | "
|
||||
echo " |___/ "
|
||||
echo ""
|
||||
echo "___ ___ _ _ _ _ _ "
|
||||
echo "| \/ | | | (_) | | | | ( )"
|
||||
echo "| . . | __ _ ___| |_ ___ _ __ _ __ ___ _ _ __ __| |___| |__ |/ "
|
||||
echo "| |\/| |/ _\` / __| __/ _ \ '__| '_ \` _ \| | '_ \ / _' |_ / '_ \ "
|
||||
echo "| | | | (_| \__ \ || __/ | | | | | | | | | | | (_| |/ /| | | | "
|
||||
echo "\_| |_/\__,_|___/\__\___|_| |_| |_| |_|_|_| |_|\__,_/___|_| |_| "
|
||||
echo " "
|
||||
echo " "
|
||||
echo " __ _ _ "
|
||||
echo " / _(_) ___ (_) "
|
||||
echo " ___ ___ _ __ | |_ _ __ _ ( _ ) _ __ _ ___ ___ "
|
||||
echo " / __/ _ \| '_ \| _| |/ _\` | / _ \/\ | '__| |/ __/ _ \ "
|
||||
echo "| (_| (_) | | | | | | | (_| | | (_> < | | | | (_| __/ "
|
||||
echo " \___\___/|_| |_|_| |_|\__, | \___/\/ |_| |_|\___\___| "
|
||||
echo " __/ | "
|
||||
echo " |___/ "
|
||||
echo ""
|
||||
}
|
||||
|
||||
function computer {
|
||||
echo " /\ "
|
||||
echo " / \ "
|
||||
echo " /_ %%==O=% _____________ "
|
||||
echo " % - -% | '\\\\\\\\\\"
|
||||
echo " _____c% > __ | ' ____|_ "
|
||||
echo " (_|. . % \` % .' | + '||:::::: "
|
||||
echo " ||. ___)%%%%_.' | '||_____| "
|
||||
echo " ||.( \ ~ / ,)' \'_______|_____| "
|
||||
echo " || /| \'/ |\ ___/____|___\___ "
|
||||
echo " _,,,;!___*_____\_| _ ' <<<:| "
|
||||
echo " / /| |_________'___o_o| "
|
||||
echo " /_____/ / "
|
||||
echo " |:____|/ \"Boy, I LOVE this stuff\". "
|
||||
echo ""
|
||||
echo ""
|
||||
echo " /\ "
|
||||
echo " / \ "
|
||||
echo " /_ %%==O=% _____________ "
|
||||
echo " % - -% | '\\\\\\\\\\"
|
||||
echo " _____c% > __ | ' ____|_ "
|
||||
echo " (_|. . % \` % .' | + '||:::::: "
|
||||
echo " ||. ___)%%%%_.' | '||_____| "
|
||||
echo " ||.( \ ~ / ,)' \'_______|_____| "
|
||||
echo " || /| \'/ |\ ___/____|___\___ "
|
||||
echo " _,,,;!___*_____\_| _ ' <<<:| "
|
||||
echo " / /| |_________'___o_o| "
|
||||
echo " /_____/ / "
|
||||
echo " |:____|/ \"Boy, I LOVE this stuff\". "
|
||||
echo ""
|
||||
echo ""
|
||||
}
|
||||
|
||||
|
||||
# =======================================
|
||||
# Main loop
|
||||
# =======================================
|
||||
@ -188,24 +186,25 @@ intro
|
||||
|
||||
ask "Do you want to continue installing my config and rice?" Y &&
|
||||
|
||||
# Ask for dependency installation
|
||||
if ask "Do you want to install the applications listen in ./dependencies? (might prompt for password)" Y; then
|
||||
# Ask for dependency installation
|
||||
if ask "Do you want to install the applications listen in ./dependencies? (might prompt for password)" Y; then
|
||||
install_dependencies
|
||||
fi
|
||||
fi
|
||||
|
||||
# Ask for config installation
|
||||
if ask "Do you want to install the config files?" Y; then
|
||||
install_config
|
||||
install_config
|
||||
fi
|
||||
|
||||
# Ask for font installation
|
||||
if ask "Do you want to install the fonts?" Y; then
|
||||
install_fonts
|
||||
install_fonts
|
||||
fi
|
||||
|
||||
# ask to enable gdm
|
||||
if ask "Do you want to enable GDM?" Y; then
|
||||
sudo systemctl enable gdm.service
|
||||
# ask to enable the display manager
|
||||
if ask "Do you want to enable sddm?" Y; then
|
||||
sudo systemctl set-default graphical.target
|
||||
sudo systemctl enable sddm.service
|
||||
fi
|
||||
|
||||
clear
|
||||
@ -215,16 +214,16 @@ prompt=$(echo $'\n> ' "Please select a specific computer to install or q to fini
|
||||
|
||||
PS3="$prompt: "
|
||||
select opt in "$PWD/computers"/*; do
|
||||
if (( REPLY == "q" )) ; then
|
||||
break
|
||||
if ((REPLY == "q")); then
|
||||
break
|
||||
|
||||
elif (( REPLY > 0 )) ; then
|
||||
bash "$opt/install.sh"
|
||||
break
|
||||
else
|
||||
echo "Invalid option. Try another one."
|
||||
fi
|
||||
elif ((REPLY > 0)); then
|
||||
bash "$opt/install.sh"
|
||||
break
|
||||
else
|
||||
echo "Invalid option. Try another one."
|
||||
fi
|
||||
done
|
||||
clear
|
||||
|
||||
echo "Enjoy using my rice! Do not forget to select i3 in GDM :)"
|
||||
echo "Enjoy using my rice! Do not forget to select i3 in sddm :)"
|
||||
|
Loading…
Reference in New Issue
Block a user