let g:python_pep8_indent_multiline_string = 0
endif
-let s:maxoff = 50
let s:block_rules = {
\ '^\s*elif\>': ['if', 'elif'],
\ '^\s*except\>': ['try', 'except'],
let s:block_rules_multiple = {
\ '^\s*else\>': ['if', 'elif', 'for', 'try', 'except'],
\ }
-let s:paren_pairs = ['()', '{}', '[]']
+" Pairs to look for when searching for opening parenthesis.
+" The value is the maximum offset in lines.
+let s:paren_pairs = {'()': 10, '[]': 100, '{}': 1000}
if &filetype ==# 'pyrex' || &filetype ==# 'cython'
let b:control_statement = '\v^\s*(class|def|if|while|with|for|except|cdef|cpdef)>'
else
return ret
endif
- let stopline = max([0, line('.') - s:maxoff])
-
" Return if cursor is in a comment.
exe 'if' s:skip_search '| return [0, 0] | endif'
- let positions = []
- for p in s:paren_pairs
- call add(positions, searchpairpos(
- \ '\V'.p[0], '', '\V'.p[1], 'bnW', s:skip_special_chars, stopline))
+ let nearest = [0, 0]
+ for [p, maxoff] in items(s:paren_pairs)
+ let stopline = max([0, line('.') - maxoff, nearest[0]])
+ let next = searchpairpos(
+ \ '\V'.p[0], '', '\V'.p[1], 'bnW', s:skip_special_chars, stopline)
+ if next[0] && (next[0] > nearest[0] || (next[0] == nearest[0] && next[1] > nearest[1]))
+ let nearest = next
+ endif
endfor
-
- " Remove empty matches and return the type with the closest match
- call filter(positions, 'v:val[0]')
- call sort(positions, 's:pair_sort')
-
- return get(positions, -1, [0, 0])
+ return nearest
endfunction
" Find the start of a multi-line statement