Input is now complelty handled in the SnippetManager
This commit is contained in:
parent
493c628346
commit
86a400df80
@ -62,7 +62,7 @@ inoremap <S-Tab> <C-R>=PyVimSnips_JumpBackwards()<cr>
|
|||||||
snoremap <S-Tab> <Esc>:call PyVimSnips_JumpBackwards()<cr>
|
snoremap <S-Tab> <Esc>:call PyVimSnips_JumpBackwards()<cr>
|
||||||
|
|
||||||
" Do not remap this.
|
" Do not remap this.
|
||||||
snoremap <BS> <Esc>:py PySnipSnippets.backspace()<cr>
|
snoremap <BS> <Esc>:py PySnipSnippets.backspace_while_selected()<cr>
|
||||||
|
|
||||||
au CursorMovedI * py PySnipSnippets.cursor_moved()
|
au CursorMovedI * py PySnipSnippets.cursor_moved()
|
||||||
au InsertEnter * py PySnipSnippets.entered_insert_mode()
|
au InsertEnter * py PySnipSnippets.entered_insert_mode()
|
||||||
|
@ -304,18 +304,7 @@ class SnippetManager(object):
|
|||||||
if self._vstate.moved.col <= 0 and self._vstate.moved.line == 1:
|
if self._vstate.moved.col <= 0 and self._vstate.moved.line == 1:
|
||||||
self._chars_entered('\n')
|
self._chars_entered('\n')
|
||||||
elif self._vstate.moved.col < 0: # Some deleting was going on
|
elif self._vstate.moved.col < 0: # Some deleting was going on
|
||||||
sline = self._csnippet.abs_start.line
|
self._backspace(-self._vstate.moved.col)
|
||||||
dlines = self._csnippet.end.line - self._csnippet.start.line
|
|
||||||
|
|
||||||
self._csnippet.backspace(-self._vstate.moved.col)
|
|
||||||
# Replace
|
|
||||||
self._vb.replace_lines(sline, sline + dlines,
|
|
||||||
self._csnippet._current_text)
|
|
||||||
|
|
||||||
ct_end = self._ctab.abs_end
|
|
||||||
vim.current.window.cursor = ct_end.line +1, ct_end.col
|
|
||||||
|
|
||||||
self._vstate.update()
|
|
||||||
else:
|
else:
|
||||||
line = vim.current.line
|
line = vim.current.line
|
||||||
|
|
||||||
@ -323,7 +312,6 @@ class SnippetManager(object):
|
|||||||
self._vstate.pos.col]
|
self._vstate.pos.col]
|
||||||
self._chars_entered(chars)
|
self._chars_entered(chars)
|
||||||
|
|
||||||
|
|
||||||
self._expect_move_wo_change = False
|
self._expect_move_wo_change = False
|
||||||
|
|
||||||
def entered_insert_mode(self):
|
def entered_insert_mode(self):
|
||||||
@ -332,17 +320,24 @@ class SnippetManager(object):
|
|||||||
self.reset()
|
self.reset()
|
||||||
|
|
||||||
def _chars_entered(self, chars):
|
def _chars_entered(self, chars):
|
||||||
sline = self._csnippet.abs_start.line
|
|
||||||
dlines = self._csnippet.end.line - self._csnippet.start.line
|
|
||||||
|
|
||||||
if self._csnippet._tab_selected:
|
if self._csnippet._tab_selected:
|
||||||
self._ctab.current_text = chars
|
self._ctab.current_text = chars
|
||||||
self._csnippet._tab_selected = False
|
self._csnippet._tab_selected = False
|
||||||
else:
|
else:
|
||||||
self._ctab.current_text += chars
|
self._ctab.current_text += chars
|
||||||
|
|
||||||
|
self._update_vim_buffer()
|
||||||
|
|
||||||
|
def _backspace(self, count):
|
||||||
|
self._ctab.current_text = self._ctab.current_text[:-count]
|
||||||
|
self._update_vim_buffer()
|
||||||
|
|
||||||
|
def _update_vim_buffer(self):
|
||||||
|
sline = self._csnippet.abs_start.line
|
||||||
|
dlines = self._csnippet.end.line - self._csnippet.start.line
|
||||||
|
|
||||||
self._csnippet.update()
|
self._csnippet.update()
|
||||||
|
|
||||||
# Replace
|
# Replace
|
||||||
dlines += self._vstate.moved.line
|
dlines += self._vstate.moved.line
|
||||||
self._vb.replace_lines(sline, sline + dlines,
|
self._vb.replace_lines(sline, sline + dlines,
|
||||||
@ -352,7 +347,7 @@ class SnippetManager(object):
|
|||||||
|
|
||||||
self._vstate.update()
|
self._vstate.update()
|
||||||
|
|
||||||
def backspace(self):
|
def backspace_while_selected(self):
|
||||||
# BS was called in select mode
|
# BS was called in select mode
|
||||||
|
|
||||||
if self._csnippet and self._csnippet.tab_selected:
|
if self._csnippet and self._csnippet.tab_selected:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user