Plugin highlighting word under cursor and all of its occurrences.
- Helps predict how vim word movements (
w,e,b) will behave - Plays well with
*and# - Instant access to information where the variable under cursor is used
- Works out of the box!
The most importantly it solves all the problems other similar plugins have with knowing what exactly is a word and when cursor is on the word.
Plugin determines what is a word based on what is a keyword in current file type. For example foo#bar in .vim file will be a single word (because vimscript allows to put # as part of variable name), but in .rb file foo#bar will be considered as two words (because # starts comment).
via Plug, Neobundle or Vundle:
Plug 'dominikduda/vim_current_word'
NeoBundle 'dominikduda/vim_current_word'
Plugin 'dominikduda/vim_current_word'
via Pathogen:
git clone https://github.com/dominikduda/vim_current_word.git ~/.vim/bundle/vim_current_word
via Vim 8 packages:
git clone https://github.com/dominikduda/vim_current_word.git ~/.vim/pack/plugins/start/vim_current_word
By default vim_current_word will underline twins of word under cursor and use your Search highlight group to color word under cursor. If you want to change this behavior see the styling section.
Plugin defines :VimCurrentWordToggle command which enables/disables plugin on the fly.
" Twins of word under cursor:
let g:vim_current_word#highlight_twins = 1
" The word under cursor:
let g:vim_current_word#highlight_current_word = 1Setting this option to more than 0 will enable delayed highlighting. The value of this variable is a delay in milliseconds.
let g:vim_current_word#highlight_delay = 0Disabling this option will make the word highlight persist over window switches and even over focusing different application window.
let g:vim_current_word#highlight_only_in_focused_window = 1To avoid specific filetypes, add this variable to your vimrc:
let g:vim_current_word#excluded_filetypes = ['ruby']If you only want to disable the plugin in some buffers, see the next configuration item.
To prevent the plugin from running in one or more buffers add following to your vimrc:
autocmd BufAdd NERD_tree_*,your_buffer_name.rb,*.js :let b:vim_current_word_disabled_in_this_buffer = 1The example above disables the plugin in:
- Every buffer which name start with
NERD_tree_ - Every buffer which name equals
your_buffer_name.rb - Every buffer which name ends with
.js
let g:vim_current_word#enabled = 1Change highlight style of twins of word under cursor:
hi CurrentWordTwins guifg=#XXXXXX guibg=#XXXXXX gui=underline,bold,italic ctermfg=XXX ctermbg=XXX cterm=underline,bold,italic
" └┴┴┴┴┤ └┴┴┴┴┤ └┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┤ └┴┤ └┴┤ └┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┤
" gui-vim font color hex code│ │ gui-vim special styles│ │ │ console-vim special styles│
" ───────────────────────────┘ │ ──────────────────────┘ │ │ ──────────────────────────┘
" gui-vim background color hex code│ console-vim font term color code│ │
" ─────────────────────────────────┘ ────────────────────────────────┘ │
" console-vim background term color code│
" ──────────────────────────────────────┘Change highlight style of the word under cursor:
hi CurrentWord guifg=#XXXXXX guibg=#XXXXXX gui=underline,bold,italic ctermfg=XXX ctermbg=XXX cterm=underline,bold,italic
" └┴┴┴┴┴──┐ └┴┴┴┴┤ └┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┤ └┴┤ └┴┤ └┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┴┤
" gui-vim font color hex code│ │ gui-vim special styles│ │ │ console-vim special styles│
" ───────────────────────────┘ │ ──────────────────────┘ │ │ ──────────────────────────┘
" gui-vim background color hex code│ console-vim font term color code│ │
" ─────────────────────────────────┘ ────────────────────────────────┘ │
" console-vim background term color code│
" ──────────────────────────────────────┘To achieve the style from the first gif (in terminal vim):
hi CurrentWord ctermbg=53
hi CurrentWordTwins ctermbg=237Rather important notes:
- If you do not want any special styles just ommit them (or use
gui=NONE cterm=NONE) - Here you can find color codes for console-vim
You have to set custom higlights below colorscheme in your .vimrc.
Change word under cursor twins or word under cursor match id. You should touch this only if you encounter some match id already taken error - theoretically may occur when some other plugin will override required id.
let g:vim_current_word#twins_match_id = 502
let g:vim_current_word#current_word_match_id = 502
Thanks to Bartosz Mąka for creating the gifs and testing.
Thanks to Dávid Csákvári for information about a script which was the inspiration for this plugin.
Plugin by Dominik Duda


