" vim: filetype=vifm : " Sample configuration file for vifm (last updated: 31 August, 2021) " You can edit this file by hand. " The " character at the beginning of a line comments out the line. " Blank lines are ignored. " The basic format for each item is shown with an example. " ------------------------------------------------------------------------------ " Command used to edit files in various contexts. The default is vim. " If you would like to use another vi clone such as Elvis or Vile " you will need to change this setting. set vicmd=vim " This makes vifm perform file operations on its own instead of relying on " standard utilities like `cp`. While using `cp` and alike is a more universal " solution, it's also much slower when processing large amounts of files and " doesn't support progress measuring. set syscalls " Trash Directory " The default is to move files that are deleted with dd or :d to " the trash directory. If you change this you will not be able to move " files by deleting them and then using p to put the file in the new location. " I recommend not changing this until you are familiar with vifm. " This probably shouldn't be an option. set trash " This is how many directories to store in the directory history. set history=100 " Automatically resolve symbolic links on l or Enter. set nofollowlinks " Natural sort of (version) numbers within text. set sortnumbers " Maximum number of changes that can be undone. set undolevels=100 " Use Vim's format of help file (has highlighting and "hyperlinks"). " If you would rather use a plain text help file set novimhelp. set vimhelp " If you would like to run an executable file when you " press Enter, l or Right Arrow, set this. set norunexec " List of color schemes to try (picks the first one supported by the terminal) colorscheme catppuccin " Format for displaying time in file list. For example: " TIME_STAMP_FORMAT=%m/%d-%H:%M " See man date or man strftime for details. set timefmt=%m/%d\ %H:%M " Show list of matches on tab completion in command-line mode set wildmenu " Display completions in a form of popup with descriptions of the matches set wildstyle=popup " Display suggestions in normal, visual and view modes for keys, marks and " registers (at most 5 files). In other view, when available. set suggestoptions=normal,visual,view,otherpane,keys,marks,registers " Ignore case in search patterns unless it contains at least one uppercase " letter set ignorecase set smartcase " Don't highlight search results automatically set nohlsearch " Use increment searching (search while typing) set incsearch " Try to leave some space from cursor to upper/lower border in lists set scrolloff=4 " Don't do too many requests to slow file systems if !has('win') set slowfs=curlftpfs endif " Set custom status line look set statusline=" Hint: %z%= %A %10u:%-7g %15s %20d " " ------------------------------------------------------------------------------ " :mark mark /full/directory/path [filename] mark r ~/repos/ mark h ~/ " ------------------------------------------------------------------------------ " :com[mand][!] command_name action " The following macros can be used in a command " %a is replaced with the user arguments. " %c the current file under the cursor. " %C the current file under the cursor in the other directory. " %f the current selected file, or files. " %F the current selected file, or files in the other directory. " %b same as %f %F. " %d the current directory name. " %D the other window directory name. " %m run the command in a menu window command! df df -h %m 2> /dev/null command! diff vim -d %f %F command! zip zip -r %c.zip %f command! run !! ./%f command! make !!make %a command! mkcd :mkdir %a | cd %a command! vgrep vim "+grep %a" command! reload :write | restart full " ------------------------------------------------------------------------------ " The file type is for the default programs to be used with " a file extension. " :filetype pattern1,pattern2 defaultprogram,program2 " :fileviewer pattern1,pattern2 consoleviewer " The other programs for the file type can be accessed with the :file command " The command macros like %f, %F, %d, %D may be used in the commands. " The %a macro is ignored. To use a % you must put %%. " For automated FUSE mounts, you must register an extension with :file[x]type " in one of following formats: " " :filetype extensions FUSE_MOUNT|some_mount_command using %SOURCE_FILE and %DESTINATION_DIR variables " %SOURCE_FILE and %DESTINATION_DIR are filled in by vifm at runtime. " A sample line might look like this: " :filetype *.zip,*.jar,*.war,*.ear FUSE_MOUNT|fuse-zip %SOURCE_FILE %DESTINATION_DIR " " :filetype extensions FUSE_MOUNT2|some_mount_command using %PARAM and %DESTINATION_DIR variables " %PARAM and %DESTINATION_DIR are filled in by vifm at runtime. " A sample line might look like this: " :filetype *.ssh FUSE_MOUNT2|sshfs %PARAM %DESTINATION_DIR " %PARAM value is filled from the first line of file (whole line). " Example first line for SshMount filetype: root@127.0.0.1:/ " " You can also add %CLEAR if you want to clear screen before running FUSE " program. " Pdf filextype {*.pdf}, zathura %c %i &, apvlv %c, xpdf %c, libreoffice %c fileviewer {*.pdf}, pdftotext -nopgbrk %c - " PostScript filextype {*.ps,*.eps,*.ps.gz}, \ {View in zathura} \ zathura %f, \ {View in gv} \ gv %c %i &, " Object filetype {*.o}, nm %f | less " Man page filetype {*.[1-8]}, man ./%c fileviewer {*.[1-8]}, man ./%c | col -b " Images filextype {*.bmp,*.jpg,*.jpeg,*.png,*.gif,*.xpm}, \ image-roll %f fileviewer {*.bmp,*.jpg,*.jpeg,*.png,*.gif,*.xpm}, \ viu -x %px -y %py -w %pw -h %ph %c " MD5 filetype *.md5 \ {Check MD5 hash sum} \ md5sum -c %f %S, " SHA1 filetype *.sha1 \ {Check SHA1 hash sum} \ sha1sum -c %f %S, " SHA256 filetype *.sha256 \ {Check SHA256 hash sum} \ sha256sum -c %f %S, " SHA512 filetype *.sha512 \ {Check SHA512 hash sum} \ sha512sum -c %f %S, " GPG signature filetype {*.asc}, \ {Check signature} \ !!gpg --verify %c, " FuseZipMount filetype {*.zip,*.jar,*.war,*.ear,*.oxt,*.apkg}, \ \ {Mount with fuse-zip} \ FUSE_MOUNT|fuse-zip %SOURCE_FILE %DESTINATION_DIR, \ {View contents} \ zip -sf %c | less, \ {Extract here} \ tar -xf %c, fileviewer *.zip,*.jar,*.war,*.ear,*.oxt zip -sf %c " ArchiveMount filetype {*.tar,*.tar.bz2,*.tbz2,*.tgz,*.tar.gz,*.tar.xz,*.txz,*.tar.zst,*.tzst}, \ \ {Mount with archivemount} \ FUSE_MOUNT|archivemount %SOURCE_FILE %DESTINATION_DIR, fileviewer *.tgz,*.tar.gz tar -tzf %c fileviewer *.tar.bz2,*.tbz2 tar -tjf %c fileviewer *.tar.xz,*.txz tar -tJf %c fileviewer *.tar.zst,*.tzst tar -t --zstd -f %c fileviewer {*.tar}, tar -tf %c " Office files filextype {*.odt,*.doc,*.docx,*.xls,*.xlsx,*.odp,*.pptx,*.ppt}, \ \ libreoffice %f & fileviewer {*.doc}, catdoc %c fileviewer {*.docx}, \ \ docx2txt.pl %f - " Directories filextype */ \ {View in thunar} \ Thunar %f &, " Syntax highlighting in preview " " Explicitly set highlight type for some extensions " " 256-color terminal " fileviewer *.[ch],*.[ch]pp highlight -O xterm256 -s dante --syntax c %c " fileviewer Makefile,Makefile.* highlight -O xterm256 -s dante --syntax make %c " " 16-color terminal " fileviewer *.c,*.h highlight -O ansi -s dante %c " " Or leave it for automatic detection " " fileviewer *[^/] pygmentize -O style=monokai -f console256 -g " Displaying pictures in terminal " " fileviewer *.jpg,*.png shellpic %c " Open all other files with default system programs (you can also remove all " :file[x]type commands above to ensure they don't interfere with system-wide " settings). By default all unknown files are opened with 'vi[x]cmd' " uncommenting one of lines below will result in ignoring 'vi[x]cmd' option " for unknown file types. " For *nix: " filetype * xdg-open " For OS X: " filetype * open " For Windows: " filetype * start, explorer %"f & " ------------------------------------------------------------------------------ " What should be saved automatically between vifm sessions. Drop "savedirs" " value if you don't want vifm to remember last visited directories for you. set vifminfo=dhistory,savedirs,chistory,state,tui,shistory, \phistory,fhistory,dirstack,registers,bookmarks,bmarks " ------------------------------------------------------------------------------ " Examples of configuring both panels " Customize view columns a bit (enable ellipsis for truncated file names) " " set viewcolumns=-{name}..,6{}. " Filter-out build and temporary files " " filter! {*.lo,*.o,*.d,*.class,*.pyc,*.pyo,.*~} " ------------------------------------------------------------------------------ " Sample mappings " Start shell in current directory nnoremap s :shell " Display sorting dialog nnoremap S :sort " Toggle visibility of preview window nnoremap w :view vnoremap w :viewgv " Open file in existing instance of gvim nnoremap o :!gvim --remote-tab-silent %f " Open file in new instance of gvim nnoremap O :!gvim %f " Open file in the background using its default program nnoremap gb :file &l " Interaction with system clipboard if has('win') " Yank current directory path to Windows clipboard with forward slashes nnoremap yp :!echo %"d:gs!\!/! %i | clip " Yank path to current file to Windows clipboard with forward slashes nnoremap yf :!echo %"c:gs!\!/! %i | clip elseif executable('xclip') " Yank current directory path into the clipboard nnoremap yd :!echo %d | xclip %i " Yank current file path into the clipboard nnoremap yf :!echo %c:p | xclip %i elseif executable('xsel') " Yank current directory path into primary and selection clipboards nnoremap yd :!echo -n %d | xsel --input --primary %i && \ echo -n %d | xsel --clipboard --input %i " Yank current file path into into primary and selection clipboards nnoremap yf :!echo -n %c:p | xsel --input --primary %i && \ echo -n %c:p | xsel --clipboard --input %i endif " Mappings for faster renaming nnoremap I cw nnoremap cc cw nnoremap A cw " Open console in current directory nnoremap ,t :!xterm & " Open editor to edit vifmrc and apply settings after returning to vifm nnoremap ,c :write | edit $MYVIFMRC | restart full " Open gvim to edit vifmrc nnoremap ,C :!gvim --remote-tab-silent $MYVIFMRC & " Toggle wrap setting on ,w key nnoremap ,w :set wrap! " Example of standard two-panel file managers mappings nnoremap :!less %f nnoremap :edit nnoremap :copy nnoremap :move nnoremap :mkdir nnoremap :delete " Midnight commander alike mappings " Open current directory in the other pane nnoremap :sync " Open directory under cursor in the other pane nnoremap :sync %c " Swap panes nnoremap x " ------------------------------------------------------------------------------ " Various customization examples " Use ag (the silver searcher) instead of grep " " set grepprg='ag --line-numbers %i %a %s' " Add additional place to look for executables " " let $PATH = $HOME.'/bin/fuse:'.$PATH " Block particular shortcut " " nnoremap " Export IPC name of current instance as environment variable and use it to " communicate with the instance later. " " It can be used in some shell script that gets run from inside vifm, for " example, like this: " vifm --server-name "$VIFM_SERVER_NAME" --remote +"cd '$PWD'" " " let $VIFM_SERVER_NAME = v:servername " ------------------------------------------------------------------------------ " Ranger devicons for ViFM " https://github.com/cirala/vifm_devicons " " Filetypes/directories set classify=' :dir:/, :exe:, :reg:, :link:,? :?:, ::../::' " Specific files set classify+=' ::.Xdefaults,,.Xresources,,.bashprofile,,.bash_profile,,.bashrc,,.dmrc,,.d_store,,.fasd,,.gitconfig,,.gitignore,,.jack-settings,,.mime.types,,.nvidia-settings-rc,,.pam_environment,,.profile,,.recently-used,,.selected_editor,,.xinitpurc,,.zprofile,,.yarnc,,.snclirc,,.tmux.conf,,.urlview,,.config,,.ini,,.user-dirs.dirs,,.mimeapps.list,,.offlineimaprc,,.msmtprc,,.Xauthority,,config::' set classify+=' ::dropbox::' set classify+=' ::favicon.*,,README,,readme::' set classify+=' ::.vim,,.vimrc,,.gvimrc,,.vifm::' set classify+=' ::gruntfile.coffee,,gruntfile.js,,gruntfile.ls::' set classify+=' ::gulpfile.coffee,,gulpfile.js,,gulpfile.ls::' set classify+=' ::ledger::' set classify+=' ::license,,copyright,,copying,,LICENSE,,COPYRIGHT,,COPYING::' set classify+=' ::node_modules::' " File extensions set classify+=' ::*.nix::' set classify+='λ ::*.ml,,*.mli::' set classify+=' ::*.styl::' set classify+=' ::*.scss::' set classify+=' ::*.py,,*.pyc,,*.pyd,,*.pyo::' set classify+=' ::*.php::' set classify+=' ::*.markdown,,*.md::' set classify+=' ::*.json::' set classify+=' ::*.js::' set classify+=' ::*.bmp,,*.gif,,*.ico,,*.jpeg,,*.jpg,,*.png,,*.svg,,*.svgz,,*.tga,,*.tiff,,*.xmb,,*.xcf,,*.xpm,,*.xspf,,*.xwd,,*.cr2,,*.dng,,*.3fr,,*.ari,,*.arw,,*.bay,,*.crw,,*.cr3,,*.cap,,*.data,,*.dcs,,*.dcr,,*.drf,,*.eip,,*.erf,,*.fff,,*.gpr,,*.iiq,,*.k25,,*.kdc,,*.mdc,,*.mef,,*.mos,,*.mrw,,*.obm,,*.orf,,*.pef,,*.ptx,,*.pxn,,*.r3d,,*.raf,,*.raw,,*.rwl,,*.rw2,,*.rwz,,*.sr2,,*.srf,,*.srw,,*.tif,,*.x3f,,*.webp,,*.avif,,*.jxl::' set classify+=' ::*.ejs,,*.htm,,*.html,,*.slim,,*.xml::' set classify+=' ::*.mustasche::' set classify+=' ::*.css,,*.less,,*.bat,,*.conf,,*.ini,,*.rc,,*.yml,,*.cfg::' set classify+=' ::*.rss::' set classify+=' ::*.coffee::' set classify+=' ::*.twig::' set classify+=' ::*.c++,,*.cpp,,*.cxx,,*.h::' set classify+=' ::*.cc,,*.c::' set classify+=' ::*.hs,,*.lhs::' set classify+=' ::*.lua::' set classify+=' ::*.jl::' set classify+=' ::*.go::' set classify+=' ::*.ts::' set classify+=' ::*.db,,*.dump,,*.sql::' set classify+=' ::*.sln,,*.suo::' set classify+=' ::*.exe::' set classify+=' ::*.diff,,*.sum,,*.md5,,*.sha512::' set classify+=' ::*.scala::' set classify+=' ::*.java,,*.jar::' set classify+=' ::*.xul::' set classify+=' ::*.clj,,*.cljc::' set classify+=' ::*.pl,,*.pm,,*.t::' set classify+=' ::*.cljs,,*.edn::' set classify+=' ::*.rb::' set classify+=' ::*.fish,,*.sh,,*.bash::' set classify+=' ::*.dart::' set classify+=' ::*.f#,,*.fs,,*.fsi,,*.fsscript,,*.fsx::' set classify+=' ::*.rlib,,*.rs::' set classify+=' ::*.d::' set classify+=' ::*.erl,,*.hrl::' set classify+=' ::*.ai::' set classify+=' ::*.psb,,*.psd::' set classify+=' ::*.jsx,,*.tsx::' set classify+=' ::*.aac,,*.anx,,*.asf,,*.au,,*.axa,,*.flac,,*.m2a,,*.m4a,,*.mid,,*.midi,,*.mp3,,*.mpc,,*.oga,,*.ogg,,*.ogx,,*.ra,,*.ram,,*.rm,,*.spx,,*.wav,,*.wma,,*.ac3::' set classify+=' ::*.avi,,*.flv,,*.mkv,,*.mov,,*.mp4,,*.mpeg,,*.mpg,,*.webm,,*.av1::' set classify+=' ::*.epub,,*.pdf,,*.fb2,,*.djvu::' set classify+=' ::*.7z,,*.apk,,*.bz2,,*.cab,,*.cpio,,*.deb,,*.gem,,*.gz,,*.gzip,,*.lh,,*.lzh,,*.lzma,,*.rar,,*.rpm,,*.tar,,*.tgz,,*.xz,,*.zip,,*.zst::' set classify+=' ::*.cbr,,*.cbz::' set classify+=' ::*.log::' set classify+=' ::*.doc,,*.docx,,*.adoc::' set classify+=' ::*.xls,,*.xlsmx::' set classify+=' ::*.pptx,,*.ppt::'