Skip to content

neocryses/vim-alias

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 

Repository files navigation

vim-alias

This plugin lets you define command-line abbreviations by :Alias which only expand at the beginning of the command prompt.

You can pass the optional parameters

-buffer or -range

to create a buffer local alias or one that accepts a range preceding the alias.

These command line abbreviations work like the bash aliases, except that the alias is substituted in-place.

Check out why an alias is most often preferable to a <leader> mapping!

Usage

    :Alias [-range] [-buffer] <lhs> <rhs>
    :UnAlias [-buffer]  <lhs> ...
    :Aliases [-buffer] [<lhs> ...]

To define the Aliases after Vim has started up, define them in ~/.vim/after/plugin/alias.vim, or add to ~/.vimrc

if exists('s:loaded_vimafter')
  silent doautocmd VimAfter VimEnter *
else
  let s:loaded_vimafter = 1
  augroup VimAfter
    autocmd!
    autocmd VimEnter * source ~/.vim/after/vimrc.vim
  augroup END
endif

and define them in ~/.vim/after/vimrc.vim.

Examples:

    :Alias   -range   dg   <c-r>=&l:diff?"diffget":"dg"<cr>
    :Alias   -buffer  spl  setlocal\ spell<bar>setlocal\ spelllang=en
    :Alias            w!!  write\ !sudo\ tee\ >\ /dev/null\ %
    :Alias            F    find\ *<c-r>=Eatchar("\ ")<cr>
    :Alias            th   tab\ help
    :Alias            sft  setfiletype
    :Alias            g    !git
    :Alias            g!   g!
    :UnAlias          g
    :Aliases

See :help abbreviations for Eatchar(c).

Configuration

The variable g:cmdaliasCmdPrefixes lists the patterns of all commands by which an alias command may be preceded and yet expand. It defaults to

  let g:cmdaliasCmdPrefixes = [
    \ '\d*verb\%[ose]', 'debug', 'sil\%[ent]!\?', 'uns\%[ilent]', 'redir\?!\?',
    \ '.*[^|]|',
    \ 'ld!\?', '[cl]fd!\?', '[cl]f\?do!\?',
    \ '\%(\%([.$]\|\d\+\)\%([,;]\%([.$]\|\d\+\)\)*\)\?\s*' .
    \ '\%(argdo\?!\?\|bufdo\?!\?\|windo\?\|tabdo\?\)' ]

Installation

If you use vim-plug, then add the following line to your vimrc file:

Plug 'Konfekt/vim-alias'

Credits

This plugin builds and improves on cmdalias.vim 3.0 by Hari Krishna Dara by

  • allowing for aliases of commands preceded by a range (like :Alias -range dg diffget),
  • allowing for alias names ending in non-word chars (like :Alias w!! ...),
  • having a Vim documentation, and
  • more checks for proper usage, more consistent parameter parsing and a finer check for blanks or commands (such as : silent! ) preceding the alias.

About

versatile Vim command-line aliases

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Vim Script 100.0%