xbps: custom xtools (xi and xr)
This commit is contained in:
parent
7e36003590
commit
b35ca70be4
3 changed files with 85 additions and 0 deletions
|
@ -1,5 +1,7 @@
|
||||||
# xbps
|
# xbps
|
||||||
alias xup="xi -Su"
|
alias xup="xi -Su"
|
||||||
|
# uses custom /usr/bin/xr
|
||||||
|
alias xcln="xr -Oo"
|
||||||
|
|
||||||
# listing files
|
# listing files
|
||||||
eza_params=(
|
eza_params=(
|
||||||
|
|
57
private_dot_local/bin/executable_xi
Normal file
57
private_dot_local/bin/executable_xi
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# xi PKGS... - like xbps-install -S, but take cwd repo and sudo/su into account
|
||||||
|
|
||||||
|
if [ -n "$XBPS_HOSTDIR" ]; then
|
||||||
|
XBPS_BINPKGS="$XBPS_HOSTDIR/binpkgs"
|
||||||
|
else
|
||||||
|
XBPS_DISTDIR="$(xdistdir 2>/dev/null)" || XBPS_DISTDIR=.
|
||||||
|
XBPS_BINPKGS="$XBPS_DISTDIR/hostdir/binpkgs"
|
||||||
|
fi
|
||||||
|
|
||||||
|
set -- \
|
||||||
|
--repository="$XBPS_BINPKGS" \
|
||||||
|
--repository="$XBPS_BINPKGS/nonfree" \
|
||||||
|
--repository="$XBPS_BINPKGS/multilib" \
|
||||||
|
--repository="$XBPS_BINPKGS/multilib/nonfree" \
|
||||||
|
--repository="$XBPS_BINPKGS/debug" \
|
||||||
|
"$@"
|
||||||
|
|
||||||
|
if BRANCH=$(git symbolic-ref -q --short HEAD 2>/dev/null) && [ -n "$BRANCH" ]; then
|
||||||
|
set -- \
|
||||||
|
--repository="$XBPS_BINPKGS/$BRANCH" \
|
||||||
|
--repository="$XBPS_BINPKGS/$BRANCH/nonfree" \
|
||||||
|
--repository="$XBPS_BINPKGS/$BRANCH/multilib" \
|
||||||
|
--repository="$XBPS_BINPKGS/$BRANCH/multilib/nonfree" \
|
||||||
|
--repository="$XBPS_BINPKGS/$BRANCH/debug" \
|
||||||
|
"$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
which_sudo() {
|
||||||
|
if [ "$(id -u)" = "0" ]; then
|
||||||
|
return
|
||||||
|
elif command -v doas >/dev/null && [ -f /etc/doas.conf ]; then
|
||||||
|
echo doas
|
||||||
|
elif command -v sudo >/dev/null && sudo -l | grep -q -e ' ALL$' -e xbps-install; then
|
||||||
|
echo sudo
|
||||||
|
else
|
||||||
|
echo su
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
do_install() {
|
||||||
|
if [ "$SUDO" = su ]; then
|
||||||
|
su root -c 'xbps-install "$@"' -- sh "$@"
|
||||||
|
else
|
||||||
|
$SUDO xbps-install "$@"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
SUDO=$(which_sudo)
|
||||||
|
do_install -S "$@"
|
||||||
|
status=$?
|
||||||
|
if [ $status -eq 16 ]; then
|
||||||
|
do_install -u xbps &&
|
||||||
|
do_install -S "$@"
|
||||||
|
else
|
||||||
|
exit $status
|
||||||
|
fi
|
26
private_dot_local/bin/executable_xr
Normal file
26
private_dot_local/bin/executable_xr
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# xr PKGS... - like xbps-remove -R, but take sudo/su into account
|
||||||
|
|
||||||
|
which_sudo() {
|
||||||
|
if [ "$(id -u)" = "0" ]; then
|
||||||
|
return
|
||||||
|
elif command -v doas >/dev/null && [ -f /etc/doas.conf ]; then
|
||||||
|
echo doas
|
||||||
|
elif command -v sudo >/dev/null && sudo -l | grep -q -e ' ALL$' -e xbps-install; then
|
||||||
|
echo sudo
|
||||||
|
else
|
||||||
|
echo su
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
do_remove() {
|
||||||
|
if [ "$SUDO" = su ]; then
|
||||||
|
su root -c 'xbps-remove "$@"' -- sh "$@"
|
||||||
|
else
|
||||||
|
$SUDO xbps-remove "$@"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
SUDO=$(which_sudo)
|
||||||
|
do_remove -R "$@"
|
||||||
|
exit $?
|
Loading…
Add table
Reference in a new issue