diff options
author | Bram Moolenaar <Bram@vim.org> | 2006-04-05 20:41:53 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2006-04-05 20:41:53 +0000 |
commit | 910f66f90c928da8b607ccfdc12fc33d9cb8d4a9 (patch) | |
tree | 152a03d1d7ea3e8d433addba4f463d8a7a68a5fd /runtime/plugin | |
parent | e2f98b95c8071f772695602cd4f714dc588eb8e7 (diff) | |
download | vim-git-910f66f90c928da8b607ccfdc12fc33d9cb8d4a9.tar.gz |
updated for version 7.0c10v7.0c10
Diffstat (limited to 'runtime/plugin')
-rw-r--r-- | runtime/plugin/matchparen.vim | 30 | ||||
-rw-r--r-- | runtime/plugin/vimballPlugin.vim | 2 |
2 files changed, 17 insertions, 15 deletions
diff --git a/runtime/plugin/matchparen.vim b/runtime/plugin/matchparen.vim index 57505179c..a3475f084 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 Mar 29 +" Last Change: 2006 Apr 04 " Exit quickly when: " - this plugin was already loaded (or disabled) @@ -16,8 +16,6 @@ augroup matchparen autocmd! CursorMoved,CursorMovedI * call s:Highlight_Matching_Pair() augroup END -let s:paren_hl_on = 0 - " Skip the rest if it was already done. if exists("*s:Highlight_Matching_Pair") finish @@ -30,9 +28,9 @@ set cpo-=C " for any matching paren. function! s:Highlight_Matching_Pair() " Remove any previous match. - if s:paren_hl_on + if exists('w:paren_hl_on') && w:paren_hl_on 3match none - let s:paren_hl_on = 0 + let w:paren_hl_on = 0 endif " Avoid that we remove the popup menu. @@ -63,21 +61,25 @@ 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 avoid searching very far (e.g., for closed folds and long lines) if i % 2 == 0 let s_flags = 'nW' let c2 = plist[i + 1] - let stopline = line('w$') - if stopline > c_lnum + 100 - let stopline = c_lnu + 100 + if has("byte_offset") && has("syntax_items") && &smc > 0 + let stopbyte = min([line2byte("$"), line2byte(".") + col(".") + &smc * 2]) + let stopline = min([line('w$'), byte2line(stopbyte)]) + else + let stopline = min([line('w$'), c_lnum + 100]) endif else let s_flags = 'nbW' let c2 = c let c = plist[i - 1] - let stopline = line('w0') - if stopline < c_lnum - 100 - let stopline = c_lnu - 100 + if has("byte_offset") && has("syntax_items") && &smc > 0 + let stopbyte = max([1, line2byte(".") + col(".") - &smc * 2]) + let stopline = max([line('w0'), byte2line(stopbyte)]) + else + let stopline = max([line('w0'), c_lnum - 100]) endif endif if c == '[' @@ -86,7 +88,7 @@ function! s:Highlight_Matching_Pair() endif " When not in a string or comment ignore matches inside them. - let s_skip ='synIDattr(synID(c_lnum, c_col - before, 0), "name") ' . + let s_skip ='synIDattr(synID(line("."), col(".") - before, 0), "name") ' . \ '=~? "string\\|comment"' execute 'if' s_skip '| let s_skip = 0 | endif' @@ -105,7 +107,7 @@ function! s:Highlight_Matching_Pair() if m_lnum > 0 && m_lnum >= line('w0') && m_lnum <= line('w$') exe '3match MatchParen /\(\%' . c_lnum . 'l\%' . (c_col - before) . \ 'c\)\|\(\%' . m_lnum . 'l\%' . m_col . 'c\)/' - let s:paren_hl_on = 1 + let w:paren_hl_on = 1 endif endfunction diff --git a/runtime/plugin/vimballPlugin.vim b/runtime/plugin/vimballPlugin.vim index cb714043a..35158893f 100644 --- a/runtime/plugin/vimballPlugin.vim +++ b/runtime/plugin/vimballPlugin.vim @@ -21,7 +21,7 @@ set cpo&vim com! -ra -na=+ -bang MkVimball call vimball#MkVimball(<line1>,<line2>,<bang>0,<f-args>) com! -na=0 UseVimball call vimball#Vimball(1) com! -na=0 VimballList call vimball#Vimball(0) -au BufReadPost *.vba echohl WarningMsg | echo "Source this file to extract it! (:so %)" | echohl None +au BufEnter *.vba echohl WarningMsg | echo "Source this file to extract it! (:so %)" | echohl None let &cpo= s:keepcpo unlet s:keepcpo |