structural changes
This commit is contained in:
parent
111026d6f2
commit
647601a743
1 changed files with 91 additions and 134 deletions
211
install.sh
211
install.sh
|
@ -5,7 +5,7 @@ command_exists() {
|
|||
command -v "$@" >/dev/null 2>&1
|
||||
}
|
||||
|
||||
getImports() {
|
||||
source-script() {
|
||||
local url="$1"
|
||||
local import="$(mktemp)"
|
||||
if command_exists curl; then
|
||||
|
@ -22,39 +22,41 @@ getImports() {
|
|||
rm "$import"
|
||||
echo "imported $url"
|
||||
}
|
||||
|
||||
__pre_stow__() {
|
||||
echo_note "__pre_stow__"
|
||||
pen blue "Getting things ready.."
|
||||
sleep 2
|
||||
conf="$HOME/.config"
|
||||
bak_dir="$HOME/.bak"
|
||||
dirs=(
|
||||
"btop"
|
||||
"gBar"
|
||||
"yazi"
|
||||
"fastfetch"
|
||||
"foot"
|
||||
"hypr"
|
||||
"tmux"
|
||||
"kitty"
|
||||
"neovide"
|
||||
"rofi"
|
||||
"tofi"
|
||||
"waybar"
|
||||
"wlogout"
|
||||
"wob"
|
||||
"yazi"
|
||||
"zellij"
|
||||
)
|
||||
|
||||
pen yellow "Trying to clean the environment.."
|
||||
|
||||
if [ ! -d "$bak_dir" ]; then
|
||||
repen yellow "backup dir created at $bak_dir" &&
|
||||
pen grey "backup dir created at $bak_dir" &&
|
||||
silentexec mkdir "$bak_dir"
|
||||
else
|
||||
pen bold yellow "Backup dir already present, clearing now" &&
|
||||
pen bold grey "Backup dir already present, clearing now" &&
|
||||
rm -rf "${bak_dir:?}/*"
|
||||
fi
|
||||
|
||||
for _dirs in "${dirs[@]}"; do
|
||||
if [ -d "$conf/$_dirs" ]; then
|
||||
repen moved $_dirs
|
||||
pen grey "moved $_dirs"
|
||||
mv -f "$conf/$_dirs" "$bak_dir"
|
||||
fi
|
||||
done
|
||||
|
@ -62,19 +64,21 @@ __pre_stow__() {
|
|||
h_files=(
|
||||
".zshrc"
|
||||
".zshenv"
|
||||
".bashrc"
|
||||
".bash_alias"
|
||||
".wezterm.lua"
|
||||
)
|
||||
|
||||
for _f in "${h_files[@]}"; do
|
||||
if [ -f "$HOME/$_f" ]; then
|
||||
repen moved $_f
|
||||
pen "moved $_f"
|
||||
mv -f "$HOME/$_f" "$bak_dir" && echo_info "Moved $_f to $bak_dir"
|
||||
fi
|
||||
done
|
||||
|
||||
for _d in ".zsh .tmux .fzf"; do
|
||||
if [ -d "$HOME/$_d" ]; then
|
||||
repen moved $_d
|
||||
pen "moved $_d"
|
||||
mv -f "$HOME/$_d" "$bak_dir" && echo_info "Moved $_d to $bak_dir"
|
||||
fi
|
||||
done
|
||||
|
@ -112,32 +116,21 @@ askThings() {
|
|||
|
||||
__optional__=false
|
||||
|
||||
if confirm askOptional "Do you also want to install optional packages?" </dev/tty; then
|
||||
if confirm "Do you also want to install optional packages?" </dev/tty; then
|
||||
__optional__=true
|
||||
fi
|
||||
# read -r askOptional </dev/tty
|
||||
|
||||
if [ ! -d "$HOME/.config/nvim" ]; then
|
||||
choose askNvim "Do you also want to install a neovim config?" default mini astro none </dev/tty
|
||||
# read -r askNvim </dev/tty
|
||||
if ! command_exists nvim; then
|
||||
if confirm "Do you also want to install neovim" </dev/tty; then
|
||||
neovim=true
|
||||
else
|
||||
neovim=false
|
||||
fi
|
||||
fi
|
||||
|
||||
}
|
||||
|
||||
initNvim() {
|
||||
echo_info "Do you want to init the neovim configuratin (installs plugins and lsps headlessly) (Y/n)"
|
||||
read -r initNeovim </dev/tty
|
||||
|
||||
case "$initNeovim" in
|
||||
[nN])
|
||||
return 0
|
||||
;;
|
||||
*)
|
||||
nvim --headless +q
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
ask_Neovide() {
|
||||
echo_info "Do you also want to install a neovide config? [y/N]"
|
||||
read -r askNeovide </dev/tty
|
||||
|
@ -151,13 +144,13 @@ ask_Neovide() {
|
|||
}
|
||||
|
||||
instPika() {
|
||||
if ! command_exists "$1"; then
|
||||
# if ! command_exists "$1"; then
|
||||
if command_exists curl; then
|
||||
curl -fsSL "https://git.k4li.de/scripts/installs/raw/branch/main/${1}.sh" | bash
|
||||
else
|
||||
echo_warning "curl was not found, could not install $1!"
|
||||
fi
|
||||
fi
|
||||
# fi
|
||||
}
|
||||
|
||||
cloneDots() {
|
||||
|
@ -165,12 +158,15 @@ cloneDots() {
|
|||
cloneName="${2:-$1}"
|
||||
|
||||
if command_exists git; then
|
||||
[ -d ./dotfiles ] &&
|
||||
[ ! -d "./dotfiles/${choise}" ] &&
|
||||
git clone --depth=1 "https://git.k4li.de/dotfiles/${choise}.git" "./dotfiles/.config/${cloneName}"
|
||||
|
||||
if [ -d ./dotfiles ] && [ ! -d "./dotfiles/${choise}" ]; then
|
||||
pen red bold "Depending on your internet speed, this might take a while.."
|
||||
spin yellow bold "Cloning dotfiles $cloneName"
|
||||
run git clone --depth=1 "https://git.k4li.de/dotfiles/${choise}.git" "./dotfiles/.config/${cloneName}" && check "Cloned dotfiles" || throw "Failed cloning dotfiles!"
|
||||
else
|
||||
echo_error "Git was not found"
|
||||
throw "$choise is already cloned.."
|
||||
fi
|
||||
else
|
||||
throw "Git was not found"
|
||||
fi
|
||||
}
|
||||
|
||||
|
@ -182,25 +178,6 @@ __validate__() {
|
|||
[[ -n "$bar" ]] && cloneDots "$bar"
|
||||
[[ -n "$terminal" ]] && cloneDots "$terminal"
|
||||
|
||||
case "$askNvim" in
|
||||
default)
|
||||
neovim="true"
|
||||
cloneDots "nvim"
|
||||
;;
|
||||
mini)
|
||||
neovim="true"
|
||||
cloneDots "nvim-mini" "nvim"
|
||||
;;
|
||||
astro)
|
||||
neovim="true"
|
||||
cloneDots "nvim-astro" "nvim"
|
||||
;;
|
||||
none)
|
||||
neovim="false"
|
||||
return 0
|
||||
;;
|
||||
esac
|
||||
|
||||
else
|
||||
echo_error "Something went terribly wrong"
|
||||
exit 1
|
||||
|
@ -250,10 +227,7 @@ __dep__() {
|
|||
neovim)
|
||||
if $neovim; then
|
||||
instPika neovim
|
||||
|
||||
initNvim
|
||||
ask_Neovide
|
||||
if $neovide; then
|
||||
if confirm "Do you also want to install a neovide config?"; then
|
||||
instPika neovide
|
||||
fi
|
||||
fi
|
||||
|
@ -262,18 +236,12 @@ __dep__() {
|
|||
if ! command_exists "$hyprdots_dependency"; then
|
||||
# echo_note "--- installing $hyprdots_dependency ---"
|
||||
spin bold yellow "Installing $hyprdots_dependency.."
|
||||
if run --err err pkg-install "$hyprdots_dependency"; then
|
||||
check green bold "$hyprdots_dependency was installed"
|
||||
run --err err pkg-install "$hyprdots_dependency" && check "$hyprdots_dependency installed" || throw "$hyprdots_dependency could not get installed" && echo_error "${err:-}"
|
||||
else
|
||||
throw "$hyprdots_dependency could not get installed"
|
||||
echo_error "${err:-}"
|
||||
fi
|
||||
else
|
||||
repen bold green "$hyprdots_dependency - already installed"
|
||||
check bold green "$hyprdots_dependency - $(pen yellow bold already installed)"
|
||||
fi
|
||||
;;
|
||||
esac
|
||||
|
||||
done
|
||||
}
|
||||
|
||||
|
@ -281,7 +249,11 @@ __monitors__() {
|
|||
if [ ! -e "$HOME/.monitors.conf" ]; then
|
||||
res="$(hyprctl monitors | grep -oP '\d+x\d+@\d+\.\d+' | head -n 1)"
|
||||
touch "$HOME/.monitors.conf"
|
||||
if [[ -n $res ]]; then
|
||||
echo "monitor = eDP-1, ${res}, 0x0, 1" >>"$HOME/.monitors.conf"
|
||||
else
|
||||
echo "monitor = preferred,, 0x0, 1" >>"$HOME/.monitors.conf"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
|
@ -292,64 +264,44 @@ pkg_optional() {
|
|||
"trash-cli"
|
||||
)
|
||||
|
||||
case "$_ops" in
|
||||
Y | y | yes)
|
||||
for _o_ in "${_ops[@]}"; do
|
||||
if command_exists "$_o_"; then
|
||||
echo_note "$_o_ - is already installed"
|
||||
else
|
||||
echo_info "Installing $_o_"
|
||||
pkg-install "$_o_"
|
||||
for pkg in "${_opts[@]}"; do
|
||||
spin "Installing $pkg"
|
||||
if ! command_exists $pkg; then
|
||||
run pkg-install $pkg && check "$pkg installed" || throw "Error installing $pkg"
|
||||
fi
|
||||
done
|
||||
;;
|
||||
*)
|
||||
echo default
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
__stow__() {
|
||||
local err
|
||||
spin grey "Linking dotfiles.."
|
||||
|
||||
if run --err err stow --verbose --target="$HOME" --defer=.gitmodules --restow */; then
|
||||
check "Linked dotfiles!"
|
||||
else
|
||||
throw "Could not use stow to link dofiles.."
|
||||
run --err err stow --verbose --target="$HOME" --defer=.gitmodules --restow */ && check "Linked dotfiles!" ||
|
||||
throw "Could not use stow to link dofiles.." &&
|
||||
echo_error "${err:-}"
|
||||
fi
|
||||
}
|
||||
|
||||
c_fonts() {
|
||||
local err
|
||||
local dirFonts="$HOME/.local/share/fonts/"
|
||||
if [[ ! -d "$dirFonts" ]]; then
|
||||
if choose "Seems like you may miss some fonts.. Do you want to clone them now to <$HOME/.local/share/fonts/>" </dev/tty; then
|
||||
# echo_info "Seems like you may miss some fonts.. Do you want to clone them now to <$HOME/.local/share/fonts/> ? [y|n]" && read -r ask_fonts
|
||||
|
||||
# case "$ask_fonts" in
|
||||
# [Yy])
|
||||
if choose "Seems like you may miss some fonts.. Do you want to clone them now into $(pen blue bold $HOME/.local/share/fonts)" </dev/tty; then
|
||||
if ! command_exists git; then
|
||||
spin "Installing fonts.."
|
||||
if run pkg-install git; then
|
||||
return 0
|
||||
fi
|
||||
spin "Installing dependencies.."
|
||||
run pkg-install git && check "Installed git!" || throw "Couldn't install git!" && return 69
|
||||
|
||||
if run --err err git clone --depth=1 https://git.k4li.de/pika/fonts.git "$dirFonts"; then
|
||||
check "Cloned fonts correctly!"
|
||||
else
|
||||
throw "Error cloning fonts!"
|
||||
echo_error "${err:-}"
|
||||
fi
|
||||
else
|
||||
git clone --depth=1 https://git.k4li.de/pika/fonts.git "$dirFonts"
|
||||
fi
|
||||
|
||||
spin "Cloning fonts now.. This might take a while.."
|
||||
|
||||
run --err err git clone --depth=1 https://git.k4li.de/pika/fonts.git "$dirFonts" && check "Cloned fonts correctly!" || throw "Error cloning fonts!" && echo_error "${err:-}"
|
||||
# ;;
|
||||
# [Nn])
|
||||
else
|
||||
pen bold red "You might have some font issues, but that's your business now!"
|
||||
return 0
|
||||
return
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
@ -357,34 +309,18 @@ c_fonts() {
|
|||
c_wallpapers() {
|
||||
local dirWallpaper="$HOME/.wallpapers"
|
||||
if [[ ! -d "$dirWallpaper" ]]; then
|
||||
if confirm "Seems like you may miss some wallpapers.. Do you want to clone them now to <$HOME/.wallpapers/> ?" </dev/tty; then
|
||||
if confirm "Seems like you may miss some wallpapers.. Do you want to clone them now to $(pen blue bold $HOME/.wallpapers)?" </dev/tty; then
|
||||
|
||||
# case "$ask_wall" in
|
||||
# [Yy])
|
||||
spin blue "Preparing wallpaper clone.."
|
||||
if ! command_exists git; then
|
||||
if run pkg-install git; then
|
||||
return 0
|
||||
spin "Installing dependencies.."
|
||||
run pkg-install git && check "Installed git!" || throw "Couldn't install git!" && return 69
|
||||
fi
|
||||
else
|
||||
if run --err err git clone --depth=1 https://git.k4li.de/pika/wallpaper.git "$dirWallpaper"; then
|
||||
check bold blue "Wallpapers loaded correctly!"
|
||||
else
|
||||
throw "Error downloading wallpapers!"
|
||||
echo_error "${err:-}"
|
||||
fi
|
||||
fi
|
||||
# ;;
|
||||
# [Nn])
|
||||
spin blue bold "Cloning wallpaper repo.. This might take a while.."
|
||||
run --err err git clone --depth=1 https://git.k4li.de/pika/wallpaper.git "$dirWallpaper" && check bold blue "Wallpapers loaded correctly!" || throw "Error downloading wallpapers!" && echo_error "${err:-}"
|
||||
else
|
||||
pen bold red "All right, be sure to checkout the $HOME/.config/hypr/.scripts/random_swww.sh to change the wallpaper dir"
|
||||
return 0
|
||||
fi
|
||||
# ;;
|
||||
# *)
|
||||
# c_wallpapers
|
||||
# ;;
|
||||
# esac
|
||||
fi
|
||||
}
|
||||
|
||||
|
@ -394,19 +330,31 @@ mkdirs() {
|
|||
pen grey "mkdir $HOME/.config"
|
||||
silentexec mkdir $HOME/.config
|
||||
fi
|
||||
|
||||
if [[ ! -f $HOME/.local/share/icons/ ]]; then
|
||||
pen grey "mkdir -p $HOME/.local/share/icons/"
|
||||
silentexec mkdir -p $HOME/.local/share/icons/
|
||||
fi
|
||||
if [[ ! -f $HOME/.local/share/fonts/ ]]; then
|
||||
c_fonts || pen grey "mkdir -p $HOME/.local/share/fonts/" && silentexec mkdir -p $HOME/.local/share/fonts/
|
||||
fi
|
||||
|
||||
c_fonts
|
||||
c_wallpapers
|
||||
}
|
||||
|
||||
setup-env() {
|
||||
local beddu=https://git.k4li.de/scripts/beddu/raw/branch/main/dist/beddu.sh
|
||||
local pika=https://git.k4li.de/scripts/imports/raw/branch/main/distros.sh
|
||||
|
||||
if ! command_exists pkg-install && ! command_exists checkAndInstall; then
|
||||
source-script $pika
|
||||
fi
|
||||
|
||||
if ! command_exists pen && ! command_exists spin; then
|
||||
source-script $beddu
|
||||
fi
|
||||
}
|
||||
|
||||
main() {
|
||||
mkdirs
|
||||
local err
|
||||
|
||||
# check_root
|
||||
# get_packager
|
||||
|
@ -414,9 +362,18 @@ main() {
|
|||
__validate__
|
||||
__dep__
|
||||
|
||||
mkdirs
|
||||
|
||||
if ! command_exists stow; then
|
||||
if confirm "We couldn't find stow on the machine, do you want us to install it?"; then
|
||||
pkg-install stow
|
||||
line
|
||||
spin grey "Installing stow now.."
|
||||
if run --err err pkg-install stow; then
|
||||
check "Stow was installed correctly!"
|
||||
else
|
||||
check "Error while installing stow!"
|
||||
echo_error "${err:-}"
|
||||
fi
|
||||
else
|
||||
pen red bold "You cannot proceed without installing stow! Please install manually"
|
||||
exit 1
|
||||
|
@ -439,6 +396,6 @@ main() {
|
|||
pen blue bold "found resolution ${res}"
|
||||
}
|
||||
|
||||
if getImports "https://git.k4li.de/scripts/imports/raw/branch/main/distros.sh" && getImports "https://git.k4li.de/scripts/beddu/raw/branch/main/dist/beddu.sh"; then
|
||||
if setup-env; then
|
||||
main
|
||||
fi
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue