bin: update elevation mechanisms

This commit is contained in:
xeruf 2021-10-04 10:46:40 +02:00
parent f6bed70b5f
commit 7c6706074b
5 changed files with 9 additions and 7 deletions

View File

@ -189,9 +189,10 @@ alias startMinecraftServer='curl https://ipinfo.io/ip | xclip -sel clip && cd ~/
alias u='topgrade' alias u='topgrade'
alias j='jrnl' alias j='jrnl'
jn() { jrnl -to today "$@" | bat --style=plain --pager="less +G" } jn() { jrnl -to today "$@" | less +G }
compdef jn=jrnl compdef jn=jrnl
alias jnc='jn -contains' alias jnc='jn -contains'
alias jne='jrnl --edit'
npm-reinstall() { npm-reinstall() {
rm -rf $TMPDIR/react-* rm -rf $TMPDIR/react-*

View File

@ -8,7 +8,7 @@ for last; do true; done
last=${last:-.} last=${last:-.}
# Elevate permissions if the file exists but is not accessible # Elevate permissions if the file exists but is not accessible
test -x "$(dirname $last)" || elevate=sudo test -x "$(dirname $last)" && { test -r "$last" || ! test -e "$last"; } || elevate=sudo
tput setaf 4 && $elevate file -E "$last" | ( grep -v --color=never 'directory$' || true ) tput setaf 4 && $elevate file -E "$last" | ( grep -v --color=never 'directory$' || true )
case "$($elevate file --dereference --mime "$last")" in case "$($elevate file --dereference --mime "$last")" in

View File

@ -17,7 +17,7 @@ conf_tmp="${conf_cache}.tmp"
mkdir -p "$conf_cache_dir" mkdir -p "$conf_cache_dir"
touch "$conf_cache" touch "$conf_cache"
sel=$(listconf | fzf -1 -0 --tiebreak=end,length --preview '$(test -r "{}" || echo "sudo") bat --color=always --style=numbers --line-range :200 {}' --query="$1" --history "$conf_cache_dir/searches") sel=$(listconf | fzf -1 -0 --tiebreak=end,length --preview '$(test -r {} || echo "sudo") bat --color=always --style=numbers --line-range :200 {}' --query="$1" --history "$conf_cache_dir/searches")
case "$sel" in case "$sel" in
"") exit 1;; "") exit 1;;
/etc/sudoers) sudo visudo;; /etc/sudoers) sudo visudo;;

View File

@ -11,7 +11,7 @@ case $1 in
(vlc) unbuffer vlc --full-help "${@:2}" | $paginate;; (vlc) unbuffer vlc --full-help "${@:2}" | $paginate;;
(gh|chordpro) $@ --help | $paginate;; (gh|chordpro) $@ --help | $paginate;;
(caddy) $1 help ${@:2} | $paginate;; (caddy) $1 help ${@:2} | $paginate;;
(*) man "$@" || { info "$1" -w | grep -v "manpages" && pinfo "$@"; } || ( "$@" --help || "$@" -help ) 2>&1 | $paginate;; (*) man "$@" || { info "$1" -w | grep -v "manpages" && pinfo "$@"; } || ( "$@" --help || "$@" -help ) 2>&1 | $paginate || which "$@";;
esac esac
docs="/usr/share/doc/$1" docs="/usr/share/doc/$1"
if test -d "$docs"; then if test -d "$docs"; then

View File

@ -2,15 +2,16 @@
# Remove recursively safely # Remove recursively safely
for f in "$@" for f in "$@"
do do
test -w "$f" && elevate="" || elevate=sudo
if test -d "$f"; then if test -d "$f"; then
if test -e "$f/.git" || test -e "$f/packed-refs" if test -e "$f/.git" || test -e "$f/packed-refs"
then echo -n "Force delete git project $f?" then echo -n "Force delete git project $f?"
read answer read answer
test "$answer" = "y" && rm -rf "$f" test "$answer" = "y" && $elevate rm -rf "$f"
else find "$f" -maxdepth 1 -type d -empty -printf "Removing empty %p\n" -delete else find "$f" -maxdepth 1 -type d -empty -printf "Removing empty %p\n" -delete
test -e "$f" && echo -n "$f " >&2 && rm -rI "$f" test -e "$f" && echo -n "$f " >&2 && $elevate rm -rI "$f"
fi fi
else rm -i "$f" else $elevate rm -i "$f"
fi fi
shift shift
done done