133 lines
5.4 KiB
VimL
133 lines
5.4 KiB
VimL
" Vim filetype plugin file
|
|
" Language: python
|
|
" Maintainer: Tom Picton <tom@tompicton.co.uk>
|
|
" Previous Maintainer: James Sully <sullyj3@gmail.com>
|
|
" Previous Maintainer: Johannes Zellner <johannes@zellner.org>
|
|
" Last Change: Sun, 15 April 2018
|
|
" https://github.com/tpict/vim-ftplugin-python
|
|
|
|
if exists("b:did_ftplugin") | finish | endif
|
|
let b:did_ftplugin = 1
|
|
let s:keepcpo= &cpo
|
|
set cpo&vim
|
|
|
|
setlocal cinkeys-=0#
|
|
setlocal indentkeys-=0#
|
|
setlocal include=^\\s*\\(from\\\|import\\)
|
|
|
|
" For imports with leading .., append / and replace additional .s with ../
|
|
let b:grandparent_match = '^\(.\.\)\(\.*\)'
|
|
let b:grandparent_sub = '\=submatch(1)."/".repeat("../",strlen(submatch(2)))'
|
|
|
|
" For imports with a single leading ., replace it with ./
|
|
let b:parent_match = '^\.\(\.\)\@!'
|
|
let b:parent_sub = './'
|
|
|
|
" Replace any . sandwiched between word characters with /
|
|
let b:child_match = '\(\w\)\.\(\w\)'
|
|
let b:child_sub = '\1/\2'
|
|
|
|
setlocal includeexpr=substitute(substitute(substitute(
|
|
\v:fname,
|
|
\b:grandparent_match,b:grandparent_sub,''),
|
|
\b:parent_match,b:parent_sub,''),
|
|
\b:child_match,b:child_sub,'g')
|
|
|
|
setlocal suffixesadd=.py
|
|
setlocal comments=b:#,fb:-
|
|
setlocal commentstring=#\ %s
|
|
|
|
setlocal omnifunc=pythoncomplete#Complete
|
|
if has('python3')
|
|
setlocal omnifunc=python3complete#Complete
|
|
endif
|
|
|
|
set wildignore+=*.pyc
|
|
|
|
let b:next_toplevel='\v%$\|^(class\|def\|async def)>'
|
|
let b:prev_toplevel='\v^(class\|def\|async def)>'
|
|
let b:next_endtoplevel='\v%$\|\S.*\n+(def\|class)'
|
|
let b:prev_endtoplevel='\v\S.*\n+(def\|class)'
|
|
let b:next='\v%$\|^\s*(class\|def\|async def)>'
|
|
let b:prev='\v^\s*(class\|def\|async def)>'
|
|
let b:next_end='\v\S\n*(%$\|^(\s*\n*)*(class\|def\|async def)\|^\S)'
|
|
let b:prev_end='\v\S\n*(^(\s*\n*)*(class\|def\|async def)\|^\S)'
|
|
|
|
execute "nnoremap <silent> <buffer> ]] :call <SID>Python_jump('n', '". b:next_toplevel."', 'W', v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> [[ :call <SID>Python_jump('n', '". b:prev_toplevel."', 'Wb', v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> ][ :call <SID>Python_jump('n', '". b:next_endtoplevel."', 'W', 0, v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> [] :call <SID>Python_jump('n', '". b:prev_endtoplevel."', 'Wb', 0, v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> ]m :call <SID>Python_jump('n', '". b:next."', 'W', v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> [m :call <SID>Python_jump('n', '". b:prev."', 'Wb', v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> ]M :call <SID>Python_jump('n', '". b:next_end."', 'W', 0, v:count1)<cr>"
|
|
execute "nnoremap <silent> <buffer> [M :call <SID>Python_jump('n', '". b:prev_end."', 'Wb', 0, v:count1)<cr>"
|
|
|
|
execute "onoremap <silent> <buffer> ]] :call <SID>Python_jump('o', '". b:next_toplevel."', 'W', v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> [[ :call <SID>Python_jump('o', '". b:prev_toplevel."', 'Wb', v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> ][ :call <SID>Python_jump('o', '". b:next_endtoplevel."', 'W', 0, v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> [] :call <SID>Python_jump('o', '". b:prev_endtoplevel."', 'Wb', 0, v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> ]m :call <SID>Python_jump('o', '". b:next."', 'W', v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> [m :call <SID>Python_jump('o', '". b:prev."', 'Wb', v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> ]M :call <SID>Python_jump('o', '". b:next_end."', 'W', 0, v:count1)<cr>"
|
|
execute "onoremap <silent> <buffer> [M :call <SID>Python_jump('o', '". b:prev_end."', 'Wb', 0, v:count1)<cr>"
|
|
|
|
execute "xnoremap <silent> <buffer> ]] :call <SID>Python_jump('x', '". b:next_toplevel."', 'W', v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> [[ :call <SID>Python_jump('x', '". b:prev_toplevel."', 'Wb', v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> ][ :call <SID>Python_jump('x', '". b:next_endtoplevel."', 'W', 0, v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> [] :call <SID>Python_jump('x', '". b:prev_endtoplevel."', 'Wb', 0, v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> ]m :call <SID>Python_jump('x', '". b:next."', 'W', v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> [m :call <SID>Python_jump('x', '". b:prev."', 'Wb', v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> ]M :call <SID>Python_jump('x', '". b:next_end."', 'W', 0, v:count1)<cr>"
|
|
execute "xnoremap <silent> <buffer> [M :call <SID>Python_jump('x', '". b:prev_end."', 'Wb', 0, v:count1)<cr>"
|
|
|
|
if !exists('*<SID>Python_jump')
|
|
fun! <SID>Python_jump(mode, motion, flags, count, ...) range
|
|
let l:startofline = (a:0 >= 1) ? a:1 : 1
|
|
|
|
if a:mode == 'x'
|
|
normal! gv
|
|
endif
|
|
|
|
if l:startofline == 1
|
|
normal! 0
|
|
endif
|
|
|
|
let cnt = a:count
|
|
mark '
|
|
while cnt > 0
|
|
call search(a:motion, a:flags)
|
|
let cnt = cnt - 1
|
|
endwhile
|
|
|
|
if l:startofline == 1
|
|
normal! ^
|
|
endif
|
|
endfun
|
|
endif
|
|
|
|
if has("browsefilter") && !exists("b:browsefilter")
|
|
let b:browsefilter = "Python Files (*.py)\t*.py\n" .
|
|
\ "All Files (*.*)\t*.*\n"
|
|
endif
|
|
|
|
if !exists("g:python_recommended_style") || g:python_recommended_style != 0
|
|
" As suggested by PEP8.
|
|
setlocal expandtab shiftwidth=4 softtabstop=4 tabstop=8
|
|
endif
|
|
|
|
" First time: try finding "pydoc".
|
|
if !exists('g:pydoc_executable')
|
|
if executable('pydoc')
|
|
let g:pydoc_executable = 1
|
|
else
|
|
let g:pydoc_executable = 0
|
|
endif
|
|
endif
|
|
" If "pydoc" was found use it for keywordprg.
|
|
if g:pydoc_executable
|
|
setlocal keywordprg=pydoc
|
|
endif
|
|
|
|
let &cpo = s:keepcpo
|
|
unlet s:keepcpo
|