1
0
mirror of https://github.com/gryf/python.vim.git synced 2025-12-18 03:50:28 +01:00

3 Commits
1.4 ... 1.7

Author SHA1 Message Date
Mikael Berthe
7a5bb2412f Version 1.7: Use <Down> instead of 'j', so it should work when j is mapped. -
Mikael Berthe
dc9722e464 Version 1.6: Works better with folding... Many thanks to Guy L. Oliver! -
Mikael Berthe
414dc1c5c0 Version 1.5
Same as 1.4, I just fixed a typo in the comments and my e-mail address...
-

View File

@@ -1,12 +1,12 @@
" -*- vim -*- " -*- vim -*-
" FILE: python.vim " FILE: python.vim
" LAST MODIFICATION: 2001/09/05 " LAST MODIFICATION: 2003/07/25 19:00
" (C) Copyright 2001 Mikael Berthe <mikael.berthe@efrei.fr> " (C) Copyright 2001-2003 Mikael Berthe <mikael.b@netcourrier.com>
" Version: 1.4 " Version: 1.7
" USAGE: " USAGE:
" "
" Juste source this script when editing Python files. " Just source this script when editing Python files.
" Example: au FileType python source ~me/.vim/scripts/python.vim " Example: au FileType python source ~me/.vim/scripts/python.vim
" You can set the global variable "g:py_select_leading_comments" to 0 " You can set the global variable "g:py_select_leading_comments" to 0
" if you don't want to select comments preceding a declaration (these " if you don't want to select comments preceding a declaration (these
@@ -20,7 +20,7 @@
" shift commands... " shift commands...
" "
" REQUIREMENTS: " REQUIREMENTS:
" vim (>= 600) " vim (>= 6)
" "
" Shortcuts: " Shortcuts:
" [[ -- Jump to beginning of block " [[ -- Jump to beginning of block
@@ -191,7 +191,7 @@ function! PythonCommentSelection() range
if strlen(getline(cl)) if strlen(getline(cl))
execute "normal ".ind."|i".commentString execute "normal ".ind."|i".commentString
endif endif
execute "normal j" execute "normal \<Down>"
let cl = cl + 1 let cl = cl + 1
endwhile endwhile
endfunction endfunction
@@ -247,7 +247,7 @@ function! PythonSelectObject(obj)
execute "normal V".cl."G" execute "normal V".cl."G"
else else
" Select the whole block " Select the whole block
normal j execute "normal \<Down>"
let cl = line('.') let cl = line('.')
execute ":".beg execute ":".beg
execute "normal V".PythonBoB(cl, 1, 0)."G" execute "normal V".PythonBoB(cl, 1, 0)."G"
@@ -280,22 +280,26 @@ function! PythonNextLine(direction)
endfunction endfunction
" update the IM-Python menu, that holds Classes and Functions " Update the IM-Python menu, that holds Classes and Functions
function! UpdateMenu() function! UpdateMenu()
let restore_fe = &foldenable
set nofoldenable
let cline=line('.') let cline=line('.')
call MakeClassStructure () call MakeClassStructure ()
call MakeFuncStructure () call MakeFuncStructure ()
execute "normal ".cline."Gzz" execute "normal ".cline."Gzz"
let &foldenable = restore_fe
endfunction endfunction
" make a menu that holds all of the classes " Make a menu that holds all of the classes
function! MakeClassStructure () function! MakeClassStructure ()
norm mpgg0 norm mpgg0
while line(".") <= line("$") while line(".") <= line("$")
if match ( getline("."), '^\s*class\s\+' ) != -1 if match ( getline("."), '^\s*class\s\+' ) != -1
norm ^w"nyw norm ^w"nyw
let name=@n let name=@n
exe 'menu IM-Python.classes.'.name.' '.line(".").'gg' "exe 'menu IM-Python.classes.'.name.' '.line(".").'gg15zo'
exe 'menu IM-Python.classes.'.name.' :call <SID>JumpToAndUnfold('.line(".").')<CR>'
endif endif
if line(".") == line("$") if line(".") == line("$")
return return
@@ -305,14 +309,15 @@ function! MakeClassStructure ()
norm 'p norm 'p
endfunction endfunction
" make a menu that holds all of the function definitions " Make a menu that holds all of the function definitions
function! MakeFuncStructure () function! MakeFuncStructure ()
norm mpgg0 norm mpgg0
while line(".") <= line("$") while line(".") <= line("$")
if match ( getline("."), '^\s*def\s\+' ) != -1 if match ( getline("."), '^\s*def\s\+' ) != -1
norm ^w"nyw norm ^w"nyw
let name=@n let name=@n
exe 'menu IM-Python.functions.'.name.' '.line(".").'gg' "exe 'menu IM-Python.functions.'.name.' '.line(".").'gg15zo'
exe 'menu IM-Python.functions.'.name.' :call <SID>JumpToAndUnfold('.line(".").')<CR>'
endif endif
if line(".") == line("$") if line(".") == line("$")
return return
@@ -322,6 +327,26 @@ function! MakeFuncStructure ()
norm 'p norm 'p
endfunction endfunction
function! s:JumpToAndUnfold(line)
" Go to the right line
execute 'normal '.a:line.'gg'
" Check to see if we are in a fold
let lvl = foldlevel(a:line)
if lvl != 0
" and if so, then expand the fold out, other wise, ignore this part.
execute 'normal 15zo'
endif
endfunction
"" This one will work only on vim 6.2 because of the try/catch expressions.
" function! s:JumpToAndUnfoldWithExceptions(line)
" try
" execute 'normal '.a:line.'gg15zo'
" catch /^Vim\((\a\+)\)\=:E490:/
" " Do nothing, just consume the error
" endtry
"endfunction
" vim:set et sts=2 sw=2: " vim:set et sts=2 sw=2: