support back insert for any situation
This commit is contained in:
parent
eea7b44270
commit
106578d69e
@ -88,26 +88,30 @@ function! AutoPairsInsert(key)
|
|||||||
|
|
||||||
" The key is difference open-pair, then it means only for ) ] } by default
|
" The key is difference open-pair, then it means only for ) ] } by default
|
||||||
if !has_key(g:AutoPairs, a:key)
|
if !has_key(g:AutoPairs, a:key)
|
||||||
" Skip the character if next character is space
|
let b:autopairs_saved_pair = [a:key, getpos('.')]
|
||||||
if current_char == ' ' && next_char == a:key
|
|
||||||
return "\<Right>\<Right>"
|
|
||||||
end
|
|
||||||
|
|
||||||
" Skip the character if closed pair is next character
|
|
||||||
if current_char == ''
|
|
||||||
let next_lineno = line('.')+1
|
|
||||||
let next_line = getline(nextnonblank(next_lineno))
|
|
||||||
let next_char = matchstr(next_line, '\s*\zs.')
|
|
||||||
if next_char == a:key
|
|
||||||
return "\<ESC>e^a"
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
" Skip the character if current character is the same as input
|
" Skip the character if current character is the same as input
|
||||||
if current_char == a:key
|
if current_char == a:key
|
||||||
return "\<Right>"
|
return "\<Right>"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if !g:AutoPairsFlyMode
|
||||||
|
" Skip the character if next character is space
|
||||||
|
if current_char == ' ' && next_char == a:key
|
||||||
|
return "\<Right>\<Right>"
|
||||||
|
end
|
||||||
|
|
||||||
|
" Skip the character if closed pair is next character
|
||||||
|
if current_char == ''
|
||||||
|
let next_lineno = line('.')+1
|
||||||
|
let next_line = getline(nextnonblank(next_lineno))
|
||||||
|
let next_char = matchstr(next_line, '\s*\zs.')
|
||||||
|
if next_char == a:key
|
||||||
|
return "\<ESC>e^a"
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
" Fly Mode, and the key is closed-pairs, search closed-pair and jump
|
" Fly Mode, and the key is closed-pairs, search closed-pair and jump
|
||||||
if g:AutoPairsFlyMode && has_key(g:AutoPairsClosedPairs, a:key)
|
if g:AutoPairsFlyMode && has_key(g:AutoPairsClosedPairs, a:key)
|
||||||
if search(a:key, 'W')
|
if search(a:key, 'W')
|
||||||
@ -213,7 +217,8 @@ endfunction
|
|||||||
|
|
||||||
function! AutoPairsMap(key)
|
function! AutoPairsMap(key)
|
||||||
let escaped_key = substitute(a:key, "'", "''", 'g')
|
let escaped_key = substitute(a:key, "'", "''", 'g')
|
||||||
execute 'inoremap <buffer> <silent> <expr>'.a:key." AutoPairsInsert('".escaped_key."')"
|
" use expr will cause search() doesn't work
|
||||||
|
execute 'inoremap <buffer> <silent> '.a:key." <C-R>=AutoPairsInsert('".escaped_key."')<CR>"
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! AutoPairsToggle()
|
function! AutoPairsToggle()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user