wip
This commit is contained in:
parent
f27e5f774f
commit
d3b6d8010f
2 changed files with 120 additions and 7 deletions
119
hyprlock.sh
Normal file
119
hyprlock.sh
Normal file
|
@ -0,0 +1,119 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# ─< Check if the given command exists silently >─────────────────────────────────────────
|
||||||
|
command_exists() {
|
||||||
|
command -v "$@" >/dev/null 2>&1
|
||||||
|
}
|
||||||
|
|
||||||
|
# WHY:
|
||||||
|
# This import will give you the following variables:
|
||||||
|
# _sudo="sudo -E" <- only if non root user
|
||||||
|
# distro = <distro name, like 'arch', 'debian', 'fedora'..>
|
||||||
|
# arch = bool
|
||||||
|
# fedora = bool
|
||||||
|
# opensuse = bool....
|
||||||
|
# You can then use it for, `if $arch; then`
|
||||||
|
# Also this gives you the _install command, which installs a package pased on the packagemanager/distro used.
|
||||||
|
# CAUTION:
|
||||||
|
# This only wokrs for generic package names, like neovim, or vim, or tmux etc..
|
||||||
|
# not every package packagemanager has the same packagenames for their packages..
|
||||||
|
getImports() {
|
||||||
|
local url="https://git.k4li.de/scripts/imports/raw/branch/main/distros.sh"
|
||||||
|
local import="$(mktemp)"
|
||||||
|
if command_exists curl; then
|
||||||
|
curl -fsSL $url -o $import
|
||||||
|
elif command_exists wget; then
|
||||||
|
wget -o $import $url
|
||||||
|
else
|
||||||
|
echo "curl/wget is required, but missing.."
|
||||||
|
exit 69
|
||||||
|
fi
|
||||||
|
|
||||||
|
source "$import"
|
||||||
|
sleep 0.2
|
||||||
|
rm "$import"
|
||||||
|
}
|
||||||
|
|
||||||
|
getDependencies() {
|
||||||
|
echo_info "Checking build dependencies.."
|
||||||
|
|
||||||
|
# INFO:
|
||||||
|
# ╭─────────────────────────────────────────────────────────────────────────╮
|
||||||
|
# │ You can define dependencies for various linux distros here. It will │
|
||||||
|
# │ automagically be pulled via the $pkgArray[$distro] variable │
|
||||||
|
# ╰─────────────────────────────────────────────────────────────────────────╯
|
||||||
|
depsDebian=(libcairo2-dev mesa-common-dev cmake libgbm-dev libdrm-dev libopengl-dev wayland-protocols wayland-utils libsdbus-c++-dev)
|
||||||
|
# depsUbuntu=()
|
||||||
|
depsFedora=()
|
||||||
|
depsOpensuse=()
|
||||||
|
depsArch=()
|
||||||
|
depsAlpine=()
|
||||||
|
|
||||||
|
declare -A deps=(
|
||||||
|
[debian]="depsDebian"
|
||||||
|
[ubuntu]="depsUbuntu"
|
||||||
|
[fedora]="depsFedora"
|
||||||
|
[arch]="depsArch"
|
||||||
|
[alpine]="depsAlpine"
|
||||||
|
[opensuse]="depsOpensuse"
|
||||||
|
)
|
||||||
|
|
||||||
|
# INFO:
|
||||||
|
# ╭────────────────────────────────────────────────────────────────╮
|
||||||
|
# │ This variable stores the packages you provided for each distro │
|
||||||
|
# ╰────────────────────────────────────────────────────────────────╯
|
||||||
|
declare -n pkgArray="${deps[$distro]}"
|
||||||
|
|
||||||
|
case "$distro" in
|
||||||
|
debian | ubuntu | arch | fedora | alpine | opensuse) checkAndInstall "${pkgArray[@]}" ;;
|
||||||
|
*)
|
||||||
|
echo_error "Cannot install for $distro"
|
||||||
|
return 69
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
cloneAndBuild() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
main() {
|
||||||
|
case "$distro" in
|
||||||
|
arch)
|
||||||
|
_install hyprlock
|
||||||
|
;;
|
||||||
|
debian)
|
||||||
|
echo "debian"
|
||||||
|
;;
|
||||||
|
ubuntu)
|
||||||
|
echo "ubuntu"
|
||||||
|
;;
|
||||||
|
fedora)
|
||||||
|
echo "fedora"
|
||||||
|
;;
|
||||||
|
alpine)
|
||||||
|
echo "alpine"
|
||||||
|
;;
|
||||||
|
opensuse)
|
||||||
|
echo "opensuse"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "$distro is not supported by this script!"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
if getImports; then
|
||||||
|
case "$@" in
|
||||||
|
--silent | -s)
|
||||||
|
silent=true
|
||||||
|
echo_warning "Running script silently!"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
silent=false
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
getDependencies
|
||||||
|
main
|
||||||
|
fi
|
|
@ -106,10 +106,6 @@ main() {
|
||||||
debian)
|
debian)
|
||||||
cloneAndInstall
|
cloneAndInstall
|
||||||
;;
|
;;
|
||||||
*)
|
|
||||||
echo "$distro is not supported by this script!"
|
|
||||||
exit 69
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,14 +115,12 @@ if ! $arch || ! $debian; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if getImports; then
|
if getImports; then
|
||||||
|
silent=false
|
||||||
case "$@" in
|
case "$@" in
|
||||||
--silent | -s)
|
--silent | -s)
|
||||||
silent=true
|
silent=true
|
||||||
echo_warning "Running script silently!"
|
echo_warning "Running script silently!"
|
||||||
;;
|
;;
|
||||||
*)
|
|
||||||
silent=false
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
getDependencies
|
getDependencies
|
||||||
main
|
main
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue