summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvimboss <devnull@localhost>2007-08-02 21:00:50 +0000
committervimboss <devnull@localhost>2007-08-02 21:00:50 +0000
commit697137599aba404c85800d0ddb8573d448be0eb4 (patch)
treed66f7de7ab38491bb49fa995ff6858f0cd174a95
parent512d5683dcff5f9510700231dfb7f0d8fb13d257 (diff)
downloadvim-697137599aba404c85800d0ddb8573d448be0eb4.tar.gz
updated for version 7.1-048v7.1.048v7-1-048
-rw-r--r--runtime/plugin/matchparen.vim24
-rw-r--r--src/version.c2
2 files changed, 20 insertions, 6 deletions
diff --git a/runtime/plugin/matchparen.vim b/runtime/plugin/matchparen.vim
index 8bf0d9ca..d709c982 100644
--- a/runtime/plugin/matchparen.vim
+++ b/runtime/plugin/matchparen.vim
@@ -1,6 +1,6 @@
" Vim plugin for showing matching parens
" Maintainer: Bram Moolenaar <Bram@vim.org>
-" Last Change: 2006 Oct 12
+" Last Change: 2007 Jul 30
" Exit quickly when:
" - this plugin was already loaded (or disabled)
@@ -62,25 +62,37 @@ function! s:Highlight_Matching_Pair()
" Figure out the arguments for searchpairpos().
" Restrict the search to visible lines with "stopline".
" And avoid searching very far (e.g., for closed folds and long lines)
+ " The "viewable" variables give a range in which we can scroll while keeping
+ " the cursor at the same position
+ " adjustedScrolloff accounts for very large numbers of scrolloff
+ let adjustedScrolloff = min([&scrolloff, (line('w$') - line('w0')) / 2])
+ let bottom_viewable = min([line('$'), c_lnum + &lines - adjustedScrolloff - 2])
+ let top_viewable = max([1, c_lnum-&lines+adjustedScrolloff + 2])
+ " one of these stoplines will be adjusted below, but the current values are
+ " minimal boundaries within the current window
+ let stoplinebottom = line('w$')
+ let stoplinetop = line('w0')
if i % 2 == 0
let s_flags = 'nW'
let c2 = plist[i + 1]
if has("byte_offset") && has("syntax_items") && &smc > 0
let stopbyte = min([line2byte("$"), line2byte(".") + col(".") + &smc * 2])
- let stopline = min([line('w$'), byte2line(stopbyte)])
+ let stopline = min([bottom_viewable, byte2line(stopbyte)])
else
- let stopline = min([line('w$'), c_lnum + 100])
+ let stopline = min([bottom_viewable, c_lnum + 100])
endif
+ let stoplinebottom = stopline
else
let s_flags = 'nbW'
let c2 = c
let c = plist[i - 1]
if has("byte_offset") && has("syntax_items") && &smc > 0
let stopbyte = max([1, line2byte(".") + col(".") - &smc * 2])
- let stopline = max([line('w0'), byte2line(stopbyte)])
+ let stopline = max([top_viewable, byte2line(stopbyte)])
else
- let stopline = max([line('w0'), c_lnum - 100])
+ let stopline = max([top_viewable, c_lnum - 100])
endif
+ let stoplinetop = stopline
endif
if c == '['
let c = '\['
@@ -106,7 +118,7 @@ function! s:Highlight_Matching_Pair()
endif
" If a match is found setup match highlighting.
- if m_lnum > 0 && m_lnum >= line('w0') && m_lnum <= line('w$')
+ if m_lnum > 0 && m_lnum >= stoplinetop && m_lnum <= stoplinebottom
exe '3match MatchParen /\(\%' . c_lnum . 'l\%' . (c_col - before) .
\ 'c\)\|\(\%' . m_lnum . 'l\%' . m_col . 'c\)/'
let w:paren_hl_on = 1
diff --git a/src/version.c b/src/version.c
index e89d1206..31841b3d 100644
--- a/src/version.c
+++ b/src/version.c
@@ -667,6 +667,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 48,
+/**/
47,
/**/
46,