1
0
Fork 0
mirror of synced 2025-01-04 12:32:55 -05:00

Merge pull request #179 from dragonxlwang/patch-1

enable search with visual selection with highlight
This commit is contained in:
Amir Salihefendic 2016-05-14 17:11:59 +01:00
commit cc0e8a9907

View file

@ -199,8 +199,8 @@ set wrap "Wrap lines
"""""""""""""""""""""""""""""" """"""""""""""""""""""""""""""
" Visual mode pressing * or # searches for the current selection " Visual mode pressing * or # searches for the current selection
" Super useful! From an idea by Michael Naumann " Super useful! From an idea by Michael Naumann
vnoremap <silent> * :call VisualSelection('f', '')<CR> vnoremap <silent> * :<C-u>call VisualSelection('', '')<CR>/<C-R>=@/<CR><CR>
vnoremap <silent> # :call VisualSelection('b', '')<CR> vnoremap <silent> # :<C-u>call VisualSelection('', '')<CR>?<C-R>=@/<CR><CR>
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" """""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
@ -379,14 +379,10 @@ function! VisualSelection(direction, extra_filter) range
let l:pattern = escape(@", '\\/.*$^~[]') let l:pattern = escape(@", '\\/.*$^~[]')
let l:pattern = substitute(l:pattern, "\n$", "", "") let l:pattern = substitute(l:pattern, "\n$", "", "")
if a:direction == 'b' if a:direction == 'gv'
execute "normal ?" . l:pattern . "^M"
elseif a:direction == 'gv'
call CmdLine("Ag \"" . l:pattern . "\" " ) call CmdLine("Ag \"" . l:pattern . "\" " )
elseif a:direction == 'replace' elseif a:direction == 'replace'
call CmdLine("%s" . '/'. l:pattern . '/') call CmdLine("%s" . '/'. l:pattern . '/')
elseif a:direction == 'f'
execute "normal /" . l:pattern . "^M"
endif endif
let @/ = l:pattern let @/ = l:pattern