Fixes #3, breaks '.'.

This commit is contained in:
Miao Jiang 2016-03-28 03:06:51 +08:00
parent 7f548cbb18
commit 0c30ba85f0

View File

@ -69,6 +69,18 @@ if !exists('g:AutoPairsSmartQuotes')
let g:AutoPairsSmartQuotes = 1 let g:AutoPairsSmartQuotes = 1
endif endif
" 7.4.849 support <C-G>U to avoid breaking '.'
" Issue talk: https://github.com/jiangmiao/auto-pairs/issues/3
" Vim note: https://github.com/vim/vim/releases/tag/v7.4.849
if v:version >= 704 && has("patch849")
let s:Go = "\<C-G>U"
else
let s:Go = ""
endif
let s:Left = s:Go."\<LEFT>"
let s:Right = s:Go."\<RIGHT>"
" Will auto generated {']' => '[', ..., '}' => '{'}in initialize. " Will auto generated {']' => '[', ..., '}' => '{'}in initialize.
let g:AutoPairsClosedPairs = {} let g:AutoPairsClosedPairs = {}
@ -105,13 +117,13 @@ function! AutoPairsInsert(key)
" 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 "\<C-G>U\<Right>" return s:Right
end end
if !g:AutoPairsFlyMode if !g:AutoPairsFlyMode
" Skip the character if next character is space " Skip the character if next character is space
if current_char == ' ' && next_char == a:key if current_char == ' ' && next_char == a:key
return "\<C-G>U\<Right>\<C-G>U\<Right>" return s:Right.s:Right
end end
" Skip the character if closed pair is next character " Skip the character if closed pair is next character
@ -132,7 +144,7 @@ function! AutoPairsInsert(key)
" 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(b:AutoPairsClosedPairs, a:key) if g:AutoPairsFlyMode && has_key(b:AutoPairsClosedPairs, a:key)
if search(a:key, 'W') if search(a:key, 'W')
return "\<C-G>U\<Right>" return s:Right
endif endif
endif endif
@ -144,7 +156,7 @@ function! AutoPairsInsert(key)
let close = b:AutoPairs[open] let close = b:AutoPairs[open]
if current_char == close && open == close if current_char == close && open == close
return "\<C-G>U\<Right>" return s:Right
end end
" Ignore auto close ' if follows a word " Ignore auto close ' if follows a word
@ -159,7 +171,7 @@ function! AutoPairsInsert(key)
let pprev_char = line[col('.')-3] let pprev_char = line[col('.')-3]
if pprev_char == open && prev_char == open if pprev_char == open && prev_char == open
" Double pair found " Double pair found
return repeat(a:key, 4) . repeat("\<C-G>U\<LEFT>", 3) return repeat(a:key, 4) . repeat(s:Left, 3)
end end
end end
@ -194,7 +206,7 @@ function! AutoPairsInsert(key)
endif endif
endif endif
return open.close."\<C-G>U\<Left>" return open.close.s:Left
endfunction endfunction
function! AutoPairsDelete() function! AutoPairsDelete()
@ -318,10 +330,10 @@ function! AutoPairsFastWrap()
else else
call search(s:FormatChunk(followed_open_pair, followed_close_pair), 'We') call search(s:FormatChunk(followed_open_pair, followed_close_pair), 'We')
end end
return "\<C-G>U\<RIGHT>".inputed_close_pair."\<C-G>U\<LEFT>" return s:Right.inputed_close_pair.s:Left
else else
normal he normal he
return "\<C-G>U\<RIGHT>".current_char."\<C-G>U\<LEFT>" return s:Right.current_char.s:Left
end end
endfunction endfunction
@ -388,7 +400,7 @@ function! AutoPairsSpace()
let cmd = '' let cmd = ''
let cur_char =line[col('.')-1] let cur_char =line[col('.')-1]
if has_key(g:AutoPairsParens, prev_char) && g:AutoPairsParens[prev_char] == cur_char if has_key(g:AutoPairsParens, prev_char) && g:AutoPairsParens[prev_char] == cur_char
let cmd = "\<SPACE>\<C-G>U\<LEFT>" let cmd = "\<SPACE>".s:Left
endif endif
return "\<SPACE>".cmd return "\<SPACE>".cmd
endfunction endfunction