annotate runtime/indent/sh.vim @ 0:76efa0be13f1

Initial revision
author atsuki
date Sat, 10 Nov 2007 15:07:22 +0900
parents
children c16898406ff2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
1 " Vim indent file
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
2 " Language: Shell Script
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
3 " Maintainer: Nikolai Weibull <now@bitwi.se>
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
4 " Latest Revision: 2006-04-19
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
5
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
6 if exists("b:did_indent")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
7 finish
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
8 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
9 let b:did_indent = 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
10
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
11 setlocal indentexpr=GetShIndent()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
12 setlocal indentkeys+==then,=do,=else,=elif,=esac,=fi,=fin,=fil,=done
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
13 setlocal indentkeys-=:,0#
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
14
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
15 if exists("*GetShIndent")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
16 finish
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
17 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
18
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
19 let s:cpo_save = &cpo
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
20 set cpo&vim
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
21
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
22 function GetShIndent()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
23 let lnum = prevnonblank(v:lnum - 1)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
24 if lnum == 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
25 return 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
26 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
27
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
28 " Add a 'shiftwidth' after if, while, else, case, until, for, function()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
29 " Skip if the line also contains the closure for the above
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
30 let ind = indent(lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
31 let line = getline(lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
32 if line =~ '^\s*\(if\|then\|do\|else\|elif\|case\|while\|until\|for\)\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
33 \ || line =~ '^\s*\<\k\+\>\s*()\s*{'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
34 \ || line =~ '^\s*{'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
35 if line !~ '\(esac\|fi\|done\)\>\s*$' && line !~ '}\s*$'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
36 let ind = ind + &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
37 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
38 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
39
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
40 " Subtract a 'shiftwidth' on a then, do, else, esac, fi, done
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
41 " Retain the indentation level if line matches fin (for find)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
42 let line = getline(v:lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
43 if (line =~ '^\s*\(then\|do\|else\|elif\|esac\|fi\|done\)\>' || line =~ '^\s*}')
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
44 \ && line !~ '^\s*fi[ln]\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
45 let ind = ind - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
46 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
47
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
48 return ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
49 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
50
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
51 let &cpo = s:cpo_save
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
52 unlet s:cpo_save