Fixes #3, breaks '.'.
This commit is contained in:
parent
7f548cbb18
commit
0c30ba85f0
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user