176 lines
4.4 KiB
Plaintext
Executable File
176 lines
4.4 KiB
Plaintext
Executable File
# interpreter for shell commands
|
|
set shell sh
|
|
|
|
# set '-eu' options for shell commands
|
|
# These options are used to have safer shell commands. Option '-e' is used to
|
|
# exit on error and option '-u' is used to give error for unset variables.
|
|
# Option '-f' disables pathname expansion which can be useful when $f, $fs, and
|
|
# $fx variables contain names with '*' or '?' characters. However, this option
|
|
# is used selectively within individual commands as it can be limiting at
|
|
# times.
|
|
set shellopts '-eu'
|
|
|
|
# set number true
|
|
set relativenumber true
|
|
|
|
# set internal field separator (IFS) to "\n" for shell commands
|
|
# This is useful to automatically split file names in $fs and $fx properly
|
|
# since default file separator used in these variables (i.e. 'filesep' option)
|
|
# is newline. You need to consider the values of these options and create your
|
|
# commands accordingly.
|
|
set ifs "\n"
|
|
|
|
# leave some space at the top and the bottom of the screen
|
|
set scrolloff 10
|
|
|
|
# Use the `dim` attribute instead of underline for the cursor in the preview pane
|
|
set cursorpreviewfmt "\033[7;2m"
|
|
|
|
# use enter for shell commands
|
|
map <enter> shell
|
|
|
|
# show the result of execution of previous commands
|
|
map ` !true
|
|
|
|
# execute current file (must be executable)
|
|
map x $$f
|
|
map X !$f
|
|
|
|
# dedicated keys for file opener actions
|
|
map o &mimeopen $f
|
|
map O $mimeopen --ask $f
|
|
|
|
# define a custom 'open' command
|
|
# This command is called when current file is not a directory. You may want to
|
|
# use either file extensions and/or mime types here. Below uses an editor for
|
|
# text files and a file opener for the rest.
|
|
cmd open &{{
|
|
case $(file --mime-type -Lb $f) in
|
|
text/*) lf -remote "send $id \$$EDITOR \$fx";;
|
|
*) for f in $fx; do $OPENER $f > /dev/null 2> /dev/null & done;;
|
|
esac
|
|
}}
|
|
|
|
# mkdir command. See wiki if you want it to select created dir
|
|
map a :push %mkdir<space>
|
|
|
|
# define a custom 'rename' command without prompt for overwrite
|
|
# cmd rename %[ -e $1 ] && printf "file exists" || mv $f $1
|
|
# map r push :rename<space>
|
|
|
|
# make sure trash folder exists
|
|
# %mkdir -p ~/.trash
|
|
|
|
# move current file or selected files to trash folder
|
|
# (also see 'man mv' for backup/overwrite options)
|
|
cmd trash %set -f; mv $fx ~/.trash
|
|
|
|
# define a custom 'delete' command
|
|
# cmd delete ${{
|
|
# set -f
|
|
# printf "$fx\n"
|
|
# printf "delete?[y/n]"
|
|
# read ans
|
|
# [ "$ans" = "y" ] && rm -rf $fx
|
|
# }}
|
|
|
|
# use '<delete>' key for either 'trash' or 'delete' command
|
|
# map <delete> trash
|
|
# map <delete> delete
|
|
|
|
# extract the current file with the right command
|
|
# (xkcd link: https://xkcd.com/1168/)
|
|
cmd extract ${{
|
|
set -f
|
|
case $f in
|
|
*.tar.bz|*.tar.bz2|*.tbz|*.tbz2) tar xjvf $f;;
|
|
*.tar.gz|*.tgz) tar xzvf $f;;
|
|
*.tar.xz|*.txz) tar xJvf $f;;
|
|
*.zip) unzip $f;;
|
|
*.rar) unrar x $f;;
|
|
*.7z) 7z x $f;;
|
|
esac
|
|
}}
|
|
|
|
# compress current file or selected files with tar and gunzip
|
|
cmd tar ${{
|
|
set -f
|
|
mkdir $1
|
|
cp -r $fx $1
|
|
tar czf $1.tar.gz $1
|
|
rm -rf $1
|
|
}}
|
|
|
|
# compress current file or selected files with zip
|
|
cmd zip ${{
|
|
set -f
|
|
mkdir $1
|
|
cp -r $fx $1
|
|
zip -r $1.zip $1
|
|
rm -rf $1
|
|
}}
|
|
|
|
cmd trash ${{
|
|
files=$(printf "$fx" | tr '\n' ';')
|
|
while [ "$files" ]; do
|
|
file=${files%%;*}
|
|
|
|
mv "$(basename "$file")" ~/.trash
|
|
if [ "$files" = "$file" ]; then
|
|
files=''
|
|
else
|
|
files="${files#*;}"
|
|
fi
|
|
done
|
|
}}
|
|
|
|
cmd vim ${{
|
|
nvim $f
|
|
}}
|
|
|
|
cmd Sxiv ${{
|
|
nohup sxiv $f > /dev/null 2> /dev/null < /dev/null & disown
|
|
}}
|
|
|
|
cmd clipf ${{
|
|
# printf "$f" | xclip -selection clipboard
|
|
# xclip -selection clipboard -t "$(file -b --mime-type $f)" -i $f
|
|
# echo -n '$f' | xclip -sel clip -t text/uri-list -i
|
|
case "$(file -b --mime-type $f)" in
|
|
image/png|image/jpeg|image/gif)
|
|
xclip -selection clipboard -t image/png -i $f
|
|
;;
|
|
video/mp4)
|
|
# !! doesnt work. no clue how todo uri-list. ICCCM section 2.6.2 is confusing
|
|
# echo -n '$f' | xclip -selection clipboard -t x-special/gnome-copied-files -i
|
|
xclip -selection clipboard -t text/uri-list -i $f
|
|
;;
|
|
*)
|
|
xclip -selection clipboard -t "$(file -b --mime-type $f)" -i $f
|
|
;;
|
|
esac
|
|
}}
|
|
|
|
cmd clip-path ${{
|
|
if [ -z $WAYLAND_DISPLAY ]; then
|
|
printf "$f" | xclip -selection clipboard
|
|
else
|
|
printf "$f" | wl-copy
|
|
fi
|
|
}}
|
|
|
|
cmd filebrowser ${{
|
|
nohup pcmanfm $f > /dev/null 2> /dev/null < /dev/null & disown
|
|
}}
|
|
|
|
map DD trash
|
|
map DP delete
|
|
map V vim
|
|
map S Sxiv
|
|
map C clipf
|
|
map <c-c> clip-path
|
|
map P filebrowser
|
|
|
|
|
|
set icons true
|