summaryrefslogtreecommitdiffstats
path: root/runtime/indent/tcl.vim
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2005-06-29 22:40:58 +0000
committerBram Moolenaar <Bram@vim.org>2005-06-29 22:40:58 +0000
commit42eeac3552c5a5ea10f24373f76b93633b6c8604 (patch)
tree902f3158470a3e9c53850708cf982c85c6338796 /runtime/indent/tcl.vim
parent24bbcfe8fe62ea43b1cea86243be4fdc8794140b (diff)
updated for version 7.0097v7.0097
Diffstat (limited to 'runtime/indent/tcl.vim')
-rw-r--r--runtime/indent/tcl.vim129
1 files changed, 38 insertions, 91 deletions
diff --git a/runtime/indent/tcl.vim b/runtime/indent/tcl.vim
index 326575e8f8..83e7719cb7 100644
--- a/runtime/indent/tcl.vim
+++ b/runtime/indent/tcl.vim
@@ -1,27 +1,21 @@
" Vim indent file
-" Language: Tcl
-" Maintainer: Nikolai Weibull <source@pcppopper.org>
-" URL: http://www.pcppopper.org/vim/indent/pcp/tcl/
-" Latest Revision: 2004-05-21
-" arch-tag: 64fab1fa-d670-40ab-a191-55678f20ceb0
+" Language: Tcl
+" Maintainer: Nikolai Weibull <nikolai+work.vim@bitwi.se>
+" Latest Revision: 2005-06-29
-" only load this indent file when no other was loaded.
if exists("b:did_indent")
finish
endif
-
let b:did_indent = 1
setlocal indentexpr=GetTclIndent()
-setlocal indentkeys-=:,0#
-setlocal indentkeys+=0]
+setlocal indentkeys=0{,0},!^F,o,O,0]
-" only define the function once.
if exists("*GetTclIndent")
finish
endif
-function s:PrevNonBlankNonComment(lnum)
+function s:prevnonblanknoncomment(lnum)
let lnum = prevnonblank(a:lnum)
while lnum > 0
let line = getline(lnum)
@@ -33,91 +27,44 @@ function s:PrevNonBlankNonComment(lnum)
return lnum
endfunction
-function! GetTclIndent()
- let lnum = s:PrevNonBlankNonComment(v:lnum - 1)
-
- if lnum == 0
- return 0
- endif
-
- let line = getline(lnum)
- let ind = indent(lnum)
-
- " TODO: Possible improvement, check that 'begin' and 'end' aren't inside a
- " comment or string. This will mess it up. As I am pressed for time and
- " stuff like this is unlikely to happen I won't deal with it in this
- " version.
- let open = 0
- let begin = match(line, '{', 0)
- while begin > -1
- let end = match(line, '}', begin + 1)
- if end < 0
- let open = open + 1
- else
- let tmp = match(line, '{', begin + 1)
- if tmp != -1 && tmp < end
- let open = open + 1
+function s:count_braces(lnum, count_open)
+ let n_open = 0
+ let n_close = 0
+ let line = getline(a:lnum)
+ let pattern = '\\\@<![{}]'
+ let i = match(line, pattern)
+ while i != -1
+ if synIDattr(synID(a:lnum, i + 1, 1), 'name') !~ 'tcl\%(Comment\|String\)'
+ if line[i] == '{'
+ let n_open += 1
+ elseif line[i] == '}'
+ if n_open > 0
+ let n_open -= 1
+ else
+ let n_close += 1
+ endif
endif
endif
- let begin = match(line, '{', begin + 1)
- endwhile
-
- let begin = match(line, '[', 0)
- while begin > -1
- let end = match(line, ']', begin + 1)
- if end < 0
- let open = open + 1
- else
- let tmp = match(line, '{', begin + 1)
- if tmp != -1 && tmp < end
- let open = open + 1
- endif
- endif
- let begin = match(line, '{', begin + 1)
- endwhile
-
- let close = 0
- let prev = 0
- let end = matchend(line, '^\s*}.*}', prev)
- while end > -1
- let begin = match(line, '{', prev + 1)
- if begin < 0 || begin > prev
- let close = close + 1
- endif
- let prev = end
- let end = match(line, '}', prev + 1)
+ let i = match(line, pattern, i + 1)
endwhile
+ return a:count_open ? n_open : n_close
+endfunction
- let prev = 0
- let end = match(line, ']', prev)
- while end > -1
- let begin = match(line, '[', prev + 1)
- if begin < 0 || begin > prev
- let close = close + 1
- endif
- let prev = end
- let end = match(line, ']', prev + 1)
- endwhile
-
- let ind = ind + (open - close) * &sw
-
- let line = getline(v:lnum)
+function GetTclIndent()
+ let pnum = s:prevnonblanknoncomment(v:lnum - 1)
+ if pnum == 0
+ return 0
+ endif
- let close = 0
- let prev = 0
- let end = match(line, '}', prev)
- while end > -1
- let begin = match(line, '{', prev + 1)
- if begin < 0 || begin > prev
- let close = close + 1
- endif
- let prev = end
- let end = match(line, '}', prev + 1)
- endwhile
+ let ind = indent(pnum) + s:count_braces(pnum, 1) * &sw
+ if getline(pnum) =~ '\\$'
+ let ind += &sw
+ endif
- let ind = ind - close * &sw
+ let pnum = s:prevnonblanknoncomment(pnum - 1)
+ if pnum > 0 && getline(pnum) =~ '\\$'
+ let ind -= &sw
+ endif
- return ind >= 0 ? ind : 0
+ return ind - s:count_braces(v:lnum, 0) * &sw
endfunction
-
-" vim: set sts=2 sw=2: