On-demand loading for imaps of <Plug> mappings
This commit is contained in:
parent
06ced6b640
commit
aca17edd1c
1 changed files with 7 additions and 3 deletions
10
plug.vim
10
plug.vim
|
@ -115,9 +115,12 @@ function! plug#end()
|
|||
let commands = type(plug.on) == 1 ? [plug.on] : plug.on
|
||||
for cmd in commands
|
||||
if cmd =~ '^<Plug>.\+'
|
||||
if empty(mapcheck(cmd))
|
||||
execute printf(
|
||||
\ "noremap <silent> %s :call <SID>lod_map(%s, %s)<CR>", cmd, string(cmd), string(plug))
|
||||
if empty(mapcheck(cmd)) && empty(mapcheck(cmd, 'i'))
|
||||
for [mode, prefix] in [['i', "<C-O>"], ['', '']]
|
||||
execute printf(
|
||||
\ "%snoremap <silent> %s %s:call <SID>lod_map(%s, %s)<CR>",
|
||||
\ mode, cmd, prefix, string(cmd), string(plug))
|
||||
endfor
|
||||
endif
|
||||
elseif !exists(':'.cmd)
|
||||
execute printf(
|
||||
|
@ -166,6 +169,7 @@ endfunction
|
|||
|
||||
function! s:lod_map(map, plug)
|
||||
execute 'unmap '.a:map
|
||||
execute 'iunmap '.a:map
|
||||
call s:lod(a:plug)
|
||||
let extra = ''
|
||||
while 1
|
||||
|
|
Loading…
Reference in a new issue