1
0
mirror of https://github.com/gryf/python.vim.git synced 2025-12-17 11:30:22 +01:00

4 Commits
1.4 ... 1.8

Author SHA1 Message Date
Mikael Berthe
97ed3fccdb Version 1.8
Applied a patch from Jon Franklin: IM-Python menu improvements.
Updated copyright and email address.
-
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: 2006-08-18 07:30
" (C) Copyright 2001 Mikael Berthe <mikael.berthe@efrei.fr> " (C) Copyright 2001-2005 Mikael Berthe <bmikael@lists.lilotux.net>
" Version: 1.4 " Version: 1.8
" 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"
@@ -279,49 +279,137 @@ function! PythonNextLine(direction)
execute "normal ".ln."G" execute "normal ".ln."G"
endfunction endfunction
" update the IM-Python menu, that holds Classes and Functions
function! UpdateMenu() function! UpdateMenu()
" delete menu if it already exists, then rebuild it.
" this is necessary in case you've got multiple buffers open
" a future enhancement to this would be to make the menu aware of
" all buffers currently open, and group classes and functions by buffer
if exists("g:menuran")
aunmenu IM-Python
else
let g:menuran=1
endif
let restore_fe = &foldenable
set nofoldenable
" preserve disposition of window and cursor
let cline=line('.') let cline=line('.')
call MakeClassStructure () let ccol=col('.') - 1
call MakeFuncStructure () norm H
execute "normal ".cline."Gzz" let hline=line('.')
" create the menu
call MenuBuilder()
" restore disposition of window and cursor
exe "norm ".hline."Gzt"
let dnscroll=cline-hline
exe "norm ".dnscroll."j".ccol."l"
let &foldenable = restore_fe
endfunction endfunction
" make a menu that holds all of the classes function! MenuBuilder()
function! MakeClassStructure () norm gg0
norm mpgg0 let currentclass = -1
while line(".") <= line("$") let classlist = []
if match ( getline("."), '^\s*class\s\+' ) != -1 let parentclass = ""
norm ^w"nyw while line(".") < line("$")
let name=@n " search for a class or function
exe 'menu IM-Python.classes.'.name.' '.line(".").'gg' if match ( getline("."), '^\s*class\s\+[a-zA-Z].*:\|^\s*def\s\+[a-zA-Z].*:' ) != -1
endif norm ^
if line(".") == line("$") let linenum = line('.')
return let indentcol = col('.')
endif norm "nye
let classordef=@n
norm w"nywge
let objname=@n
let parentclass = FindParentClass(classlist, indentcol)
if classordef == "class"
call AddClass(objname, linenum, parentclass)
else " this is a function
call AddFunction(objname, linenum, parentclass)
endif
call RebuildClassList(classlist, [objname, indentcol], classordef)
endif " line matched
norm j norm j
endwhile endwhile
norm 'p
endfunction endfunction
" make a menu that holds all of the function definitions " classlist contains the list of nested classes we are in.
function! MakeFuncStructure () " in most cases it will be empty or contain a single class
norm mpgg0 " but where a class is nested within another, it will contain 2 or more
while line(".") <= line("$") " this function adds or removes classes from the list based on indentation
if match ( getline("."), '^\s*def\s\+' ) != -1 function! RebuildClassList(classlist, newclass, classordef)
norm ^w"nyw let i = len(a:classlist) - 1
let name=@n while i > -1
exe 'menu IM-Python.functions.'.name.' '.line(".").'gg' if a:newclass[1] <= a:classlist[i][1]
call remove(a:classlist, i)
endif endif
if line(".") == line("$") let i = i - 1
return
endif
norm j
endwhile endwhile
norm 'p if a:classordef == "class"
call add(a:classlist, a:newclass)
endif
endfunction endfunction
" we found a class or function, determine its parent class based on
" indentation and what's contained in classlist
function! FindParentClass(classlist, indentcol)
let i = 0
let parentclass = ""
while i < len(a:classlist)
if a:indentcol <= a:classlist[i][1]
break
else
if len(parentclass) == 0
let parentclass = a:classlist[i][0]
else
let parentclass = parentclass.'\.'.a:classlist[i][0]
endif
endif
let i = i + 1
endwhile
return parentclass
endfunction
" add a class to the menu
function! AddClass(classname, lineno, parentclass)
if len(a:parentclass) > 0
let classstring = a:parentclass.'\.'.a:classname
else
let classstring = a:classname
endif
exe 'menu IM-Python.classes.'.classstring.' :call <SID>JumpToAndUnfold('.a:lineno.')<CR>'
endfunction
" add a function to the menu, grouped by member class
function! AddFunction(functionname, lineno, parentclass)
if len(a:parentclass) > 0
let funcstring = a:parentclass.'.'.a:functionname
else
let funcstring = a:functionname
endif
exe 'menu IM-Python.functions.'.funcstring.' :call <SID>JumpToAndUnfold('.a:lineno.')<CR>'
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: