diff --git a/.config/lf/colors b/.config/lf/colors index 17e8c99e..eb37bfcb 100644 --- a/.config/lf/colors +++ b/.config/lf/colors @@ -1,4 +1,4 @@ -# vim:ft=dircolors + # (This is not a dircolors file but it helps to highlight colors and comments) # default values from dircolors diff --git a/.config/lf/lfrc b/.config/lf/lfrc index e6c2f702..defe814a 100644 --- a/.config/lf/lfrc +++ b/.config/lf/lfrc @@ -11,23 +11,19 @@ set previewer "~/.config/lf/preview/chafa" set cursorpreviewfmt "\033[7;90m" set promptfmt "\033[34;1m%u\033[36m@\033[34m%h \033[35m[\033[0;1m%d\033[35m]\033[32m ยป \033[33m%f\033[0m" -cmd pushedit %{{ - echo "Open: " && read files - if sh -c '[ -n "$VIM" ]'; then - lf -remote "send $id vimopen $files" - else - lf -remote "send $id \$echo $files | xargs -or nvim +wa" - fi - lf -remote "send $id reload" +# This might seem awkward, but it it needed to trigger the open for the taolf nvim plugin +cmd open ${{ + set +u + [ "$lf_user_multiopen" = "true" ] && { $OPENER $fx; return; } + $OPENER "$f" }} -cmd edit ${{ - if sh -c "[ -n \"\$VIM\" ]"; then - lf -remote "send $id vimopen $fx" - else - lf -remote "send $id \$echo \$fx | xargs -or nvim +wa" - fi - lf -remote "send $id unselect" +cmd pushedit %{{ + echo "Open: " && read files + echo + echo $files | xargs touch + lf -remote "send $id \$$OPENER $files + send $id unselect" }} cmd open-with ${{ @@ -35,16 +31,6 @@ cmd open-with ${{ rifle -c $XDG_CONFIG_HOME/lf/rifle.conf -p $method $fx }} -cmd vimopen &{{ - touch "$@" - lf -remote "$( - for f in "$@"; do printf "%b" "send $id toggle $f\n"; done - printf "%b" "send $id select $f\n" - printf "%b" "send $id open\n" - printf "%b" "send $id unselect\n" - )" -}} - cmd mkdir &mkdir -p "$(echo $* | tr ' ' '\ ')" cmd trash &{{ @@ -54,7 +40,7 @@ cmd trash &{{ lf -remote "send load" }} -cmd lazygit %{{ +cmd lazygit ${{ dir=$(dirname "$(realpath "${f:-_}")"}) if ! git --noglob-pathspecs -C $dir status >/dev/null 2>&1; then echo "Initialize git repo in '${dir}' [Y/n]:" && read yn && @@ -186,18 +172,13 @@ cmd extract ${{ cmd set_previewer %{{ if [ "${1}" = "sixel" ]; then - lf -remote "send $id set sixel" - lf -remote "send $id set previewer ~/.config/lf/preview/sixel" - lf -remote "send $id reload" + lf -remote "send $id :set sixel; set previewer ~/.config/lf/preview/sixel; reload" echo 'Previewer set to sixel' elif [ "${1}" = "ueberzug" ]; then - lf -remote "send $id set cleaner ~/.config/lf/preview/clean" - lf -remote "send $id set previewer ~/.config/lf/preview/ueberzug" - lf -remote "send $id reload" + lf -remote "send $id :set cleaner ~/.config/lf/preview/clean; set previewer ~/.config/lf/preview/ueberzug; reload" echo 'Previewer set to ueberzug' else - lf -remote "send $id set previewer ~/.config/lf/preview/chafa" - lf -remote "send $id reload" + lf -remote "send $id :set previewer ~/.config/lf/preview/chafa; reload" echo 'Previewer set to chafa' fi }} @@ -222,6 +203,7 @@ map <c-e> extract map P link # map S share map <c-g> lazygit +map <a-g> $gdu map <c-v> pushedit map <c-n> push :mkdir<space> map N push :&touch<space> @@ -242,8 +224,9 @@ map n &echo $f | xclip -r -selection c map <esc> quit map g/ cd "/" map W new_lf_term -map e edit +map e :set user_multiopen "true" ; open; set user_multiopen "false" map E $sudo -e $f +map R $lf -remote "send $id :select \"$(readlink $f)\"" # Load bookmark shortcuts source "~/.config/lf/shortcutrc" diff --git a/.config/lf/rifle.conf b/.config/lf/rifle.conf index 0427d498..1f1dec42 100644 --- a/.config/lf/rifle.conf +++ b/.config/lf/rifle.conf @@ -1,202 +1,114 @@ # vim: ft=cfg -# -# This is the configuration file of "rifle", ranger's file executor/opener. -# Each line consists of conditions and a command. For each line the conditions -# are checked and if they are met, the respective command is run. -# -# Syntax: -# <condition1> , <condition2> , ... = command -# -# The command can contain these environment variables: -# $1-$9 | The n-th selected file -# $@ | All selected files -# -# If you use the special command "ask", rifle will ask you what program to run. -# -# Prefixing a condition with "!" will negate its result. -# These conditions are currently supported: -# match <regexp> | The regexp matches $1 -# ext <regexp> | The regexp matches the extension of $1 -# mime <regexp> | The regexp matches the mime type of $1 -# name <regexp> | The regexp matches the basename of $1 -# path <regexp> | The regexp matches the absolute path of $1 -# has <program> | The program is installed (i.e. located in $PATH) -# env <variable> | The environment variable "variable" is non-empty -# file | $1 is a file -# directory | $1 is a directory -# number <n> | change the number of this command to n -# terminal | stdin, stderr and stdout are connected to a terminal -# X | $DISPLAY is not empty (i.e. Xorg runs) -# -# There are also pseudo-conditions which have a "side effect": -# flag <flags> | Change how the program is run. See below. -# label <label> | Assign a label or name to the command so it can -# | be started with :open_with <label> in ranger -# | or `rifle -p <label>` in the standalone executable. -# else | Always true. -# -# Flags are single characters which slightly transform the command: -# f | Fork the program, make it run in the background. -# | New command = setsid $command >& /dev/null & -# r | Execute the command with root permissions -# | New command = sudo $command -# t | Run the program in a new terminal. If $TERMCMD is not defined, -# | rifle will attempt to extract it from $TERM. -# | New command = $TERMCMD -e $command -# Note: The "New command" serves only as an illustration, the exact -# implementation may differ. -# Note: When using rifle in ranger, there is an additional flag "c" for -# only running the current file even if you have marked multiple files. + +#------------------------------------------- +# Environment checks +#------------------------------------------- +# env NVIM, env lf_shell = $HOME/.local/libexec/vimlf-open "$@" #------------------------------------------- # Websites #------------------------------------------- -# Rarely installed browsers get higher priority; It is assumed that if you -# install a rare browser, you probably use it. Firefox/konqueror/w3m on the -# other hand are often only installed as fallback browsers. -ext x?html?, has qutebrowser, X, flag f = qutebrowser -- "$@" -ext x?html?, has chromium-browser, X, flag f = chromium-browser -- "$@" -ext x?html?, has chromium, X, flag f = chromium -- "$@" -ext x?html?, has firefox, X, flag f = firefox -- "$@" -ext x?html?, has elinks, terminal = elinks "$@" -ext x?html?, has links2, terminal = links2 "$@" -ext x?html?, has links, terminal = links "$@" -ext x?html?, has lynx, terminal = lynx -- "$@" -ext x?html?, has w3m, terminal = w3m "$@" +ext x?html?, has brave, X, flag f = brave -- "$@" +ext x?html?, has firefox, X, flag f = firefox -- "$@" +ext x?html?, has chromium, X, flag f = chromium -- "$@" +ext x?html?, has lynx, terminal = lynx -- "$@" +ext x?html?, has w3m, terminal = w3m "$@" -#-------------------------------------------- -# Code #------------------------------------------- -# ext py = python -- "$1" -# ext pl = perl -- "$1" -# ext rb = ruby -- "$1" -# ext js = node -- "$1" -# ext sh = sh -- "$1" -# ext php = php -- "$1" -# ext lisp = emacs -- "$1" +# Misc +#------------------------------------------- +# HACK: This '-- --' fixes nvim's argument parsing when given empty files and executed with --embed +label editor, mime ^text|x-empty$, env EMBEDDED = ${VISUAL:-$EDITOR} -- -- "$@" +label editor, mime ^text|x-empty$ = ${VISUAL:-$EDITOR} -- "$@" +label pager, mime ^text|x-empty$ = $PAGER -- "$@" +label editor, ext xml|json|csv|tex|py|pl|rb|rs|js|sh|php|dart = ${VISUAL:-$EDITOR} -- "$@" +label pager, ext xml|json|csv|tex|py|pl|rb|rs|js|sh|php|dart = $PAGER -- "$@" -ext cue , terminal, flag t = delay .3; vim -- "$@" -ext cue , terminal = file "$@"|less -ext cue, terminal, flag f = iconv -f cp1251 "$1" >"$1.___"; mv -f "$1.___" "$1" #-------------------------------------------- # Audio without X #------------------------------------------- -mime ^audio|ogg$, terminal, has mpv ,flag t = mpv -- "$@" +mime ^audio|ogg$, terminal, has mpv = mpv -- "$@" + #-------------------------------------------- # Video/Audio with a GUI #------------------------------------------- -mime ^video, has mpv, X, flag f = mpv --save-position-on-quit -- "$@" -ext ts, has mpv, X, flag f = mpv --save-position-on-quit -- "$@" -mime ^video, has mpv, X, flag f = vlc -- "$@" +mime ^video, has mpv, X, flag f = mpv -- "$@" +mime ^video|^audio, has vlc, X, flag f = vlc -- "$@" #-------------------------------------------- # Video without X: #------------------------------------------- mime ^video, terminal, !X, has mpv = mpv -- "$@" -#torrent -ext torrent, has transmission-gtk, X, flag f = transmission-gtk -p -- "$@" -mime torrent, has transmission-gtk, X, flag f = transmission-gtk -p -- "$@" -ext torrent, has transmission-cli, terminal = transmission-cli -- "$@" -mime torrent, has transmission-cli, terminal = transmission-cli -- "$@" - #------------------------------------------- # Documents #------------------------------------------- -ext pdf, has llpp, X, flag f = llpp "$@" -ext pdf|djvu|epub, has zathura, X, flag f = zathura -- "$@" -ext pdf, has firefox, X, flag f = firefox -- "$@" -ext pdf, has xournalpp, X, flag f = xournalpp -- "$@" -ext pdf, has mupdf, X, flag f = mupdf "$@" -ext pdf, has mupdf-x11, X, flag f = mupdf-x11 "$@" -ext pdf, has apvlv, X, flag f = apvlv -- "$@" -ext pdf, has xpdf, X, flag f = xpdf -- "$@" -ext pdf|djvu, has evince, X, flag f = evince -- "$@" -ext pdf|djvu, has atril, X, flag f = atril -- "$@" -ext pdf, has okular, X, flag f = okular -- "$@" -ext pdf, has epdfview, X, flag f = epdfview -- "$@" -ext pdf, has qpdfview, X, flag f = qpdfview "$@" -ext pdf, has open, X, flag f = open "$@" - -ext docx?, has catdoc, terminal = catdoc -- "$@" | "$PAGER" -ext sxc|xlsx?|xlt|xlw|gnm|gnumeric, has gnumeric, X, flag f = gnumeric -- "$@" -ext sxc|xlsx?|xlt|xlw|gnm|gnumeric, has kspread, X, flag f = kspread -- "$@" +ext djvu, has zathura, X, flag f = zathura -- "$@" +ext epub, has zathura, X, flag f = zathura -- "$@" +ext cb[rz], has zathura, X, flag f = zathura -- "$@" +ext pdf, has zathura, X, flag f = zathura -- "$@" ext pptx?|od[dfgpst]|docx?|sxc|xlsx?|xlt|xlw|gnm|gnumeric, has libreoffice, X, flag f = libreoffice "$@" -ext pptx?|od[dfgpst]|docx?|sxc|xlsx?|xlt|xlw|gnm|gnumeric, has soffice, X, flag f = soffice "$@" -ext pptx?|od[dfgpst]|docx?|sxc|xlsx?|xlt|xlw|gnm|gnumeric, has ooffice, X, flag f = ooffice "$@" - -ext djvu, has djview, X, flag f = djview -- "$@" -ext epub|mobi, X, flag f = ebook-viewer -- "$@" +ext docx?, has catdoc, terminal = catdoc -- "$@" | $PAGER +ext sc, has sc, = sc -- "$@" #------------------------------------------- -# Image Viewing: +# Images #------------------------------------------- -mime ^image/svg, has inkscape, X, flag f = inkscape -- "$@" -mime ^image/svg, has display, X, flag f = display -- "$@" -mime ^image, has sxiv, X, flag f = sxiv -- "$@" -mime ^image, has nsxiv, X, flag f = nsxiv -- "$@" -mime ^image, has gimp, X, flag f = gimp -- "$@" -ext xcf, X, flag f = gimp -- "$@" +mime ^image/svg, has inkscape, X, flag f = inkscape -- "$@" +mime ^image/svg, has display, X, flag f = display -- "$@" +mime ^image, has nsxiv, X, flag f = nsxiv -- "$@" +mime ^image, has sxiv, X, flag f = sxiv -- "$@" +mime ^image, has gimp, X, flag f = gimp -- "$@" +mime ^image, has krita, X, flag f = krita -- "$@" +ext xcf, has gimp, X, flag f = gimp -- "$@" +ext kra, has krita, X, flag f = krita -- "$@" #------------------------------------------- # Archives #------------------------------------------- -# avoid password prompt by providing empty password -ext 7z, has 7z = 7z -p l "$@" | "$PAGER" -ext ace|ar|arc|bz2?|cab|cpio|cpt|deb|dgc|dmg|gz, has atool = atool --list --each -- "$@" | "$PAGER" -ext iso|jar|msi|pkg|rar|shar|tar|tgz|xar|xpi|xz|zip, has atool = atool --list --each -- "$@" | "$PAGER" +ext 7z, has 7z = 7z -p l "$@" | $PAGER +ext ace|ar|arc|bz2?|cab|cpio|cpt|deb|dgc|dmg|gz, has atool = atool --list --each -- "$@" | $PAGER +ext iso|jar|msi|pkg|rar|shar|tar|tgz|xar|xpi|xz|zip, has atool = atool --list --each -- "$@" | $PAGER ext 7z|ace|ar|arc|bz2?|cab|cpio|cpt|deb|dgc|dmg|gz, has atool = atool --extract --each -- "$@" ext iso|jar|msi|pkg|rar|shar|tar|tgz|xar|xpi|xz|zip, has atool = atool --extract --each -- "$@" + # Listing and extracting archives without atool: -ext tar|gz|bz2|xz, has tar = tar vvtf "$1" | "$PAGER" -ext tar|gz|bz2|xz, has tar = for file in "$@"; do tar vvxf "$file"; done -ext bz2, has bzip2 = for file in "$@"; do bzip2 -dk "$file"; done -ext zip, has unzip = unzip -l "$1" | less -ext zip, has unzip = for file in "$@"; do unzip -d "${file%.*}" "$file"; done -ext ace, has unace = unace l "$1" | less -ext ace, has unace = for file in "$@"; do unace e "$file"; done -ext rar, has unrar = unrar l "$1" | less -ext rar, has unrar = for file in "$@"; do unrar x "$file"; done +ext tar|gz|bz2|xz, has tar = tar vvtf "$1" | $PAGER +ext tar|gz|bz2|xz, has tar = for file in "$@"; do tar vvxf "$file"; done +ext bz2, has bzip2 = for file in "$@"; do bzip2 -dk "$file"; done +ext zip, has unzip = unzip -l "$1" | less +ext zip, has unzip = for file in "$@"; do unzip -d "${file%.*}" "$file"; done +ext ace, has unace = unace l "$1" | less +ext ace, has unace = for file in "$@"; do unace e "$file"; done +ext rar, has unrar = unrar l "$1" | less +ext rar, has unrar = for file in "$@"; do unrar x "$file"; done #------------------------------------------- -# Misc +# Fonts #------------------------------------------- -# Define the "editor" for text files as first action -mime ^inode/x-empty$, label editor = "$EDITOR" -- "$@" -mime ^inode/x-empty$, label pager = "$EDITOR" -- "$@" -mime ^text, label editor = "$EDITOR" -- "$@" -mime ^text, label pager = "$PAGER" -- "$@" -!mime ^text, label editor, ext xml|json|csv|tex|py|pl|rb|js|sh|php|rs = "$EDITOR" -- "$@" -!mime ^text, label pager, ext xml|json|csv|tex|py|pl|rb|js|sh|php|rs = "$PAGER" -- "$@" -ext 1 = man "$1" -ext s[wmf]c, has zsnes, X = zsnes "$1" -ext s[wmf]c, has snes9x-gtk,X = snes9x-gtk "$1" -ext nes, has fceux, X = fceux "$1" -ext exe = wine "$1" -name ^[mM]akefile$ = make +mime ^font, has fontforge, X, flag f = fontforge "$@" #------------------------------------------- # Flag t fallback terminals #------------------------------------------- -# Rarely installed terminal emulators get higher priority; It is assumed that -# if you install a rare terminal emulator, you probably use it. -# gnome-terminal/konsole/xterm on the other hand are often installed as part of -# a desktop environment or as fallback terminal emulators. -mime ^ranger/x-terminal-emulator, has kitty = kitty -- "$@" -mime ^ranger/x-terminal-emulator, has st = st -e "$@" -mime ^ranger/x-terminal-emulator, has urxvt = urxvt -e "$@" +mime ^ranger/x-terminal-emulator, has st = st -e "$@" mime ^ranger/x-terminal-emulator, has xterm = xterm -e "$@" -#------------------------------------------- -# Misc -#------------------------------------------- -# This depends on my setbg script! -label wallpaper, number 11, mime ^image, X = setbg "$1" -# Define the editor for non-text files + pager as last action - !mime ^text, !ext xml|json|csv|tex|py|pl|rb|js|sh|php = ask -label editor, !mime ^text, !ext xml|json|csv|tex|py|pl|rb|js|sh|php = ${VISUAL:-$EDITOR} -- "$@" -label pager, !mime ^text, !ext xml|json|csv|tex|py|pl|rb|js|sh|php = "$PAGER" -- "$@" +#------------------------------------------- +# Fallback +#------------------------------------------- +else = ask +label open, has xdg-open = xdg-open "$@" +label open, has open = open -- "$@" -# The very last action, so that it's never triggered accidentally, is to execute a program: +###################################################################### +# The actions below are left so low down in this file on purpose, so # +# they are never triggered accidentally. # +###################################################################### + +# Execute a file as program/script. mime application/x-executable = "$1" + +# Move the file to trash using trash-cli. +label trash, has trash-put = trash-put -- "$@" diff --git a/.config/zsh/configs/widgets b/.config/zsh/configs/widgets index 8555998c..77c4887d 100644 --- a/.config/zsh/configs/widgets +++ b/.config/zsh/configs/widgets @@ -15,14 +15,9 @@ function write_title_wd() { echo -ne "\033]0;$(print -P "%n@%m [%3~]")\007"; } function reset_beam() { echo -ne '\e[5 q'; } function lfwrap () { + export EMBEDDED=true LF_DIRFILE="/tmp/lfdir.$(uuidgen)" - if [ "${LF_PREVIEW_TYPE:-sixel}" = "sixel" ]; then - lf-sixel -last-dir-path="$LF_DIRFILE" - elif [ "${LF_PREVIEW_TYPE}" = "ueberzug" ]; then - lf-ueberzug -last-dir-path="$LF_DIRFILE" - else - lf -last-dir-path="$LF_DIRFILE" - fi + lfX -last-dir-path="$LF_DIRFILE" dir="$(cat "$LF_DIRFILE")" rm "$LF_DIRFILE" if [ -d "$dir" ]; then diff --git a/.local/bin/lf-sixel b/.local/bin/lf-sixel deleted file mode 100755 index 346a6aff..00000000 --- a/.local/bin/lf-sixel +++ /dev/null @@ -1,11 +0,0 @@ -#!/bin/sh -set -e - -if [ -n "$SSH_CLIENT" ] || [ -n "$SSH_TTY" ]; then - # shellcheck disable=2068 - command lf $@ -else - [ ! -d "$HOME/.cache/lf" ] && mkdir --parents "$HOME/.cache/lf" - # shellcheck disable=2016,2068 - command lf -command 'set_previewer sixel' $@ 3>&- -fi diff --git a/.local/bin/lf-ueberzug b/.local/bin/lfX similarity index 62% rename from .local/bin/lf-ueberzug rename to .local/bin/lfX index e449b30a..19048235 100755 --- a/.local/bin/lf-ueberzug +++ b/.local/bin/lfX @@ -7,14 +7,15 @@ clean() { } if [ -n "$SSH_CLIENT" ] || [ -n "$SSH_TTY" ]; then - command lf "$@" + # shellcheck disable=2068 + command lf $@ else - [ ! -d "$XDG_CACHE_HOME/lf" ] && mkdir --parents "$XDG_CACHE_HOME/lf" + [ ! -d "$HOME/.cache/lf" ] && mkdir --parents "$HOME/.cache/lf" export FIFO_UEBERZUG="$XDG_CACHE_HOME/lf/ueberzug-$$" mkfifo "$FIFO_UEBERZUG" ueberzug layer -s -p json <"$FIFO_UEBERZUG" & exec 3>"$FIFO_UEBERZUG" trap clean EXIT - # shellcheck disable=2016 - command lf -command 'set_previewer ueberzug' "$@" 3>&- + # shellcheck disable=2016,2068 + command lf $@ 3>&- fi diff --git a/.local/bin/opener b/.local/bin/opener index f026df66..509cb5ea 100755 --- a/.local/bin/opener +++ b/.local/bin/opener @@ -1,11 +1,6 @@ #!/bin/sh -set -f -if [ "$2" ]; then - for f in "$@"; do - # shellcheck disable=2086 - rifle -c "$XDG_CONFIG_HOME/lf/rifle.conf" -p 0 $f - done -else - rifle -c "$XDG_CONFIG_HOME/lf/rifle.conf" -p 0 "$1" -fi +[ -n "$SCRATCHPAD" ] && set -- -ft "$@" +set -- -p0 -c "$XDG_CONFIG_HOME/lf/rifle.conf" "$@" + +rifle "$@"