Merge pull request #403 from blueyed/fix-rename

Fix rename
This commit is contained in:
Dave Halter
2015-05-03 15:48:37 +02:00
3 changed files with 62 additions and 22 deletions

View File

@@ -199,6 +199,10 @@ function! jedi#rename(...)
PythonJedi jedi_vim.rename() PythonJedi jedi_vim.rename()
endfunction endfunction
function! jedi#rename_visual(...)
PythonJedi jedi_vim.rename_visual()
endfunction
function! jedi#completions(findstart, base) function! jedi#completions(findstart, base)
PythonJedi jedi_vim.completions() PythonJedi jedi_vim.completions()
endfunction endfunction

View File

@@ -19,6 +19,7 @@ if g:jedi#auto_initialization
" rename " rename
if g:jedi#rename_command != '' if g:jedi#rename_command != ''
execute "nnoremap <buffer> ".g:jedi#rename_command." :call jedi#rename()<CR>" execute "nnoremap <buffer> ".g:jedi#rename_command." :call jedi#rename()<CR>"
execute "vnoremap <buffer> ".g:jedi#rename_command." :call jedi#rename_visual()<CR>"
endif endif
" documentation/pydoc " documentation/pydoc
if g:jedi#documentation_command != '' if g:jedi#documentation_command != ''

View File

@@ -431,10 +431,10 @@ def rename():
vim_command('autocmd InsertLeave <buffer> call jedi#rename(1)') vim_command('autocmd InsertLeave <buffer> call jedi#rename(1)')
vim_command('augroup END') vim_command('augroup END')
vim_command("let s:jedi_replace_orig = expand('<cword>')")
vim_command('normal! diw') vim_command('normal! diw')
vim_command(':startinsert') vim_command(':startinsert')
else: else:
window_path = vim.current.buffer.name
# reset autocommand # reset autocommand
vim_command('autocmd! jedi_rename InsertLeave') vim_command('autocmd! jedi_rename InsertLeave')
@@ -444,31 +444,64 @@ def rename():
vim_command('normal! u') # undo the space at the end vim_command('normal! u') # undo the space at the end
vim.current.window.cursor = cursor vim.current.window.cursor = cursor
if replace is None: return do_rename(replace)
echo_highlight('No rename possible, if no name is given.')
else:
temp_rename = goto(is_related_name=True, no_output=True)
# sort the whole thing reverse (positions at the end of the line
# must be first, because they move the stuff before the position).
temp_rename = sorted(temp_rename, reverse=True,
key=lambda x: (x.module_path, x.start_pos))
for r in temp_rename:
if r.in_builtin_module():
continue
if vim.current.buffer.name != r.module_path:
result = new_buffer(r.module_path)
if not result:
return
vim.current.window.cursor = r.start_pos def rename_visual():
vim_command('normal! cw%s' % replace) replace = vim.eval('input("Rename to: ")')
orig = vim.eval('getline(".")[(getpos("\'<")[2]-1):getpos("\'>")[2]]')
do_rename(replace, orig)
result = new_buffer(window_path)
def do_rename(replace, orig = None):
if replace is None:
echo_highlight('No rename possible, if no name is given.')
return
if orig is None:
orig = vim_eval('s:jedi_replace_orig')
# Save original window / tab.
saved_tab = int(vim_eval('tabpagenr()'))
saved_win = int(vim_eval('winnr()'))
temp_rename = goto(is_related_name=True, no_output=True)
# sort the whole thing reverse (positions at the end of the line
# must be first, because they move the stuff before the position).
temp_rename = sorted(temp_rename, reverse=True,
key=lambda x: (x.module_path, x.start_pos))
buffers = set()
for r in temp_rename:
if r.in_builtin_module():
continue
if vim.current.buffer.name != r.module_path:
result = new_buffer(r.module_path)
if not result: if not result:
return echo_highlight("Jedi-vim: failed to create buffer window for {}!".format(r.module_path))
vim.current.window.cursor = cursor continue
echo_highlight('Jedi did %s renames!' % len(temp_rename))
buffers.add(vim.current.buffer.name)
# Save view.
saved_view = vim_eval('winsaveview()')
# Replace original word.
vim.current.window.cursor = r.start_pos
vim_command('normal! c{:d}l{}'.format(len(orig), replace))
# Restore view.
vim_command('call winrestview(%s)' % PythonToVimStr(saved_view))
# Restore previous tab and window.
vim_command('tabnext {:d}'.format(saved_tab))
vim_command('{:d}wincmd w'.format(saved_win))
if len(buffers) > 1:
echo_highlight('Jedi did {:d} renames in {:d} buffers!'.format(
len(temp_rename), len(buffers)))
else:
echo_highlight('Jedi did {:d} renames!'.format(len(temp_rename)))
@_check_jedi_availability(show_error=True) @_check_jedi_availability(show_error=True)
@@ -567,6 +600,8 @@ def _tabnew(path, options=''):
if buf_path == path: if buf_path == path:
# tab exists, just switch to that tab # tab exists, just switch to that tab
vim_command('tabfirst | tabnext %i' % (tab_nr + 1)) vim_command('tabfirst | tabnext %i' % (tab_nr + 1))
# Goto the buffer's window.
vim_command('exec bufwinnr(%i) . " wincmd w"' % (buf_nr + 1))
break break
else: else:
continue continue