annotate runtime/indent/sqlanywhere.vim @ 48:67300faee616 v7-3-618

v7-3-618
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 01 Aug 2012 18:08:28 +0900
parents e170173ecb68
children
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: SQL
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
3 " Maintainer: David Fishburn <fishburn at ianywhere dot com>
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
4 " Last Change: Mon Apr 02 2007 9:13:47 AM
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
5 " Version: 1.5
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
6 " Download: http://vim.sourceforge.net/script.php?script_id=495
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
7
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
8 " Notes:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
9 " Indenting keywords are based on Oracle and Sybase Adaptive Server
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
10 " Anywhere (ASA). Test indenting was done with ASA stored procedures and
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
11 " fuctions and Oracle packages which contain stored procedures and
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
12 " functions.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
13 " This has not been tested against Microsoft SQL Server or
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
14 " Sybase Adaptive Server Enterprise (ASE) which use the Transact-SQL
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
15 " syntax. That syntax does not have end tags for IF's, which makes
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
16 " indenting more difficult.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
17 "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
18 " Known Issues:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
19 " The Oracle MERGE statement does not have an end tag associated with
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
20 " it, this can leave the indent hanging to the right one too many.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
21
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
22 " Only load this indent file when no other was loaded.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
23 if exists("b:did_indent")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
24 finish
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
25 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
26 let b:did_indent = 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
27 let b:current_indent = "sqlanywhere"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
28
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
29 setlocal indentkeys-=0{
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
30 setlocal indentkeys-=0}
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
31 setlocal indentkeys-=:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
32 setlocal indentkeys-=0#
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
33 setlocal indentkeys-=e
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
34
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
35 " This indicates formatting should take place when one of these
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
36 " expressions is used. These expressions would normally be something
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
37 " you would type at the BEGINNING of a line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
38 " SQL is generally case insensitive, so this files assumes that
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
39 " These keywords are something that would trigger an indent LEFT, not
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
40 " an indent right, since the SQLBlockStart is used for those keywords
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
41 setlocal indentkeys+==~end,=~else,=~elseif,=~elsif,0=~when,0=)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
42
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
43 " GetSQLIndent is executed whenever one of the expressions
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
44 " in the indentkeys is typed
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
45 setlocal indentexpr=GetSQLIndent()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
46
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
47 " Only define the functions once.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
48 if exists("*GetSQLIndent")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
49 finish
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
50 endif
48
67300faee616 v7-3-618
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
51 let s:keepcpo= &cpo
67300faee616 v7-3-618
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
52 set cpo&vim
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
53
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
54 " List of all the statements that start a new block.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
55 " These are typically words that start a line.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
56 " IS is excluded, since it is difficult to determine when the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
57 " ending block is (especially for procedures/functions).
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
58 let s:SQLBlockStart = '^\s*\%('.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
59 \ 'if\|else\|elseif\|elsif\|'.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
60 \ 'while\|loop\|do\|'.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
61 \ 'begin\|'.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
62 \ 'case\|when\|merge\|exception'.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
63 \ '\)\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
64 let s:SQLBlockEnd = '^\s*\(end\)\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
65
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
66 " The indent level is also based on unmatched paranethesis
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
67 " If a line has an extra "(" increase the indent
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
68 " If a line has an extra ")" decrease the indent
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
69 function s:CountUnbalancedParan( line, paran_to_check )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
70 let l = a:line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
71 let lp = substitute(l, '[^(]', '', 'g')
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
72 let l = a:line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
73 let rp = substitute(l, '[^)]', '', 'g')
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
74
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
75 if a:paran_to_check =~ ')'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
76 " echom 'CountUnbalancedParan ) returning: ' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
77 " \ (strlen(rp) - strlen(lp))
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
78 return (strlen(rp) - strlen(lp))
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
79 elseif a:paran_to_check =~ '('
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
80 " echom 'CountUnbalancedParan ( returning: ' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
81 " \ (strlen(lp) - strlen(rp))
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
82 return (strlen(lp) - strlen(rp))
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
83 else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
84 " echom 'CountUnbalancedParan unknown paran to check: ' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
85 " \ a:paran_to_check
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
86 return 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
87 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
88 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
89
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
90 " Unindent commands based on previous indent level
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
91 function s:CheckToIgnoreRightParan( prev_lnum, num_levels )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
92 let lnum = a:prev_lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
93 let line = getline(lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
94 let ends = 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
95 let num_right_paran = a:num_levels
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
96 let ignore_paran = 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
97 let vircol = 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
98
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
99 while num_right_paran > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
100 silent! exec 'norm! '.lnum."G\<bar>".vircol."\<bar>"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
101 let right_paran = search( ')', 'W' )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
102 if right_paran != lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
103 " This should not happen since there should be at least
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
104 " num_right_paran matches for this line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
105 break
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
106 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
107 let vircol = virtcol(".")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
108
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
109 " if getline(".") =~ '^)'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
110 let matching_paran = searchpair('(', '', ')', 'bW',
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
111 \ 's:IsColComment(line("."), col("."))')
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
112
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
113 if matching_paran < 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
114 " No match found
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
115 " echom 'CTIRP - no match found, ignoring'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
116 break
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
117 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
118
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
119 if matching_paran == lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
120 " This was not an unmatched parantenses, start the search again
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
121 " again after this column
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
122 " echom 'CTIRP - same line match, ignoring'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
123 continue
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
124 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
125
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
126 " echom 'CTIRP - match: ' . line(".") . ' ' . getline(".")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
127
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
128 if getline(matching_paran) =~? '\(if\|while\)\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
129 " echom 'CTIRP - if/while ignored: ' . line(".") . ' ' . getline(".")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
130 let ignore_paran = ignore_paran + 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
131 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
132
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
133 " One match found, decrease and check for further matches
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
134 let num_right_paran = num_right_paran - 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
135
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
136 endwhile
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
137
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
138 " Fallback - just move back one
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
139 " return a:prev_indent - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
140 return ignore_paran
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
141 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
142
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
143 " Based on the keyword provided, loop through previous non empty
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
144 " non comment lines to find the statement that initated the keyword.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
145 " Return its indent level
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
146 " CASE ..
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
147 " WHEN ...
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
148 " Should return indent level of CASE
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
149 " EXCEPTION ..
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
150 " WHEN ...
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
151 " something;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
152 " WHEN ...
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
153 " Should return indent level of exception.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
154 function s:GetStmtStarterIndent( keyword, curr_lnum )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
155 let lnum = a:curr_lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
156
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
157 " Default - reduce indent by 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
158 let ind = indent(a:curr_lnum) - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
159
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
160 if a:keyword =~? 'end'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
161 exec 'normal! ^'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
162 let stmts = '^\s*\%('.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
163 \ '\<begin\>\|' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
164 \ '\%(\%(\<end\s\+\)\@<!\<loop\>\)\|' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
165 \ '\%(\%(\<end\s\+\)\@<!\<case\>\)\|' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
166 \ '\%(\%(\<end\s\+\)\@<!\<for\>\)\|' .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
167 \ '\%(\%(\<end\s\+\)\@<!\<if\>\)'.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
168 \ '\)'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
169 let matching_lnum = searchpair(stmts, '', '\<end\>\zs', 'bW',
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
170 \ 's:IsColComment(line("."), col(".")) == 1')
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
171 exec 'normal! $'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
172 if matching_lnum > 0 && matching_lnum < a:curr_lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
173 let ind = indent(matching_lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
174 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
175 elseif a:keyword =~? 'when'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
176 exec 'normal! ^'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
177 let matching_lnum = searchpair(
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
178 \ '\%(\<end\s\+\)\@<!\<case\>\|\<exception\>\|\<merge\>',
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
179 \ '',
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
180 \ '\%(\%(\<when\s\+others\>\)\|\%(\<end\s\+case\>\)\)',
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
181 \ 'bW',
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
182 \ 's:IsColComment(line("."), col(".")) == 1')
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
183 exec 'normal! $'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
184 if matching_lnum > 0 && matching_lnum < a:curr_lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
185 let ind = indent(matching_lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
186 else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
187 let ind = indent(a:curr_lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
188 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
189 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
190
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
191 return ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
192 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
193
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
194
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
195 " Check if the line is a comment
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
196 function s:IsLineComment(lnum)
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
197 let rc = synIDattr(
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
198 \ synID(a:lnum,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
199 \ match(getline(a:lnum), '\S')+1, 0)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
200 \ , "name")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
201 \ =~? "comment"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
202
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
203 return rc
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
204 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
205
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
206
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
207 " Check if the column is a comment
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
208 function s:IsColComment(lnum, cnum)
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
209 let rc = synIDattr(synID(a:lnum, a:cnum, 0), "name")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
210 \ =~? "comment"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
211
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
212 return rc
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
213 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
214
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
215
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
216 " Instead of returning a column position, return
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
217 " an appropriate value as a factor of shiftwidth.
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
218 function s:ModuloIndent(ind)
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
219 let ind = a:ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
220
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
221 if ind > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
222 let modulo = ind % &shiftwidth
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
223
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
224 if modulo > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
225 let ind = ind - modulo
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
226 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
227 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
228
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
229 return ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
230 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
231
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
232
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
233 " Find correct indent of a new line based upon the previous line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
234 function GetSQLIndent()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
235 let lnum = v:lnum
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
236 let ind = indent(lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
237
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
238 " If the current line is a comment, leave the indent as is
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
239 " Comment out this additional check since it affects the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
240 " indenting of =, and will not reindent comments as it should
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
241 " if s:IsLineComment(lnum) == 1
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
242 " return ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
243 " endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
244
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
245 " while 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
246 " Get previous non-blank line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
247 let prevlnum = prevnonblank(lnum - 1)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
248 if prevlnum <= 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
249 return ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
250 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
251
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
252 if s:IsLineComment(prevlnum) == 1
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
253 if getline(v:lnum) =~ '^\s*\*'
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
254 let ind = s:ModuloIndent(indent(prevlnum))
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
255 return ind + 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
256 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
257 " If the previous line is a comment, then return -1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
258 " to tell Vim to use the formatoptions setting to determine
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
259 " the indent to use
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
260 " But only if the next line is blank. This would be true if
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
261 " the user is typing, but it would not be true if the user
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
262 " is reindenting the file
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
263 if getline(v:lnum) =~ '^\s*$'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
264 return -1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
265 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
266 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
267
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
268 " let prevline = getline(prevlnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
269 " if prevline !~ '^\s*$'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
270 " " echom 'previous non blank - break: ' . prevline
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
271 " break
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
272 " endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
273 " endwhile
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
274
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
275 " echom 'PREVIOUS INDENT: ' . indent(prevlnum) . ' LINE: ' . getline(prevlnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
276
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
277 " This is the line you just hit return on, it is not the current line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
278 " which is new and empty
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
279 " Based on this line, we can determine how much to indent the new
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
280 " line
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
281
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
282 " Get default indent (from prev. line)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
283 let ind = indent(prevlnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
284 let prevline = getline(prevlnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
285
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
286 " Now check what's on the previous line to determine if the indent
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
287 " should be changed, for example IF, BEGIN, should increase the indent
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
288 " where END IF, END, should decrease the indent.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
289 if prevline =~? s:SQLBlockStart
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
290 " Move indent in
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
291 let ind = ind + &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
292 " echom 'prevl - SQLBlockStart - indent ' . ind . ' line: ' . prevline
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
293 elseif prevline =~ '[()]'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
294 if prevline =~ '('
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
295 let num_unmatched_left = s:CountUnbalancedParan( prevline, '(' )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
296 else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
297 let num_unmatched_left = 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
298 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
299 if prevline =~ ')'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
300 let num_unmatched_right = s:CountUnbalancedParan( prevline, ')' )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
301 else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
302 let num_unmatched_right = 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
303 " let num_unmatched_right = s:CountUnbalancedParan( prevline, ')' )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
304 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
305 if num_unmatched_left > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
306 " There is a open left paranethesis
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
307 " increase indent
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
308 let ind = ind + ( &sw * num_unmatched_left )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
309 elseif num_unmatched_right > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
310 " if it is an unbalanced paranethesis only unindent if
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
311 " it was part of a command (ie create table(..) )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
312 " instead of part of an if (ie if (....) then) which should
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
313 " maintain the indent level
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
314 let ignore = s:CheckToIgnoreRightParan( prevlnum, num_unmatched_right )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
315 " echom 'prevl - ) unbalanced - CTIRP - ignore: ' . ignore
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
316
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
317 if prevline =~ '^\s*)'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
318 let ignore = ignore + 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
319 " echom 'prevl - begins ) unbalanced ignore: ' . ignore
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
320 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
321
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
322 if (num_unmatched_right - ignore) > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
323 let ind = ind - ( &sw * (num_unmatched_right - ignore) )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
324 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
325
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
326 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
327 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
328
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
329
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
330 " echom 'CURRENT INDENT: ' . ind . ' LINE: ' . getline(v:lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
331
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
332 " This is a new blank line since we just typed a carriage return
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
333 " Check current line; search for simplistic matching start-of-block
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
334 let line = getline(v:lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
335
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
336 if line =~? '^\s*els'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
337 " Any line when you type else will automatically back up one
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
338 " ident level (ie else, elseif, elsif)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
339 let ind = ind - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
340 " echom 'curr - else - indent ' . ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
341 elseif line =~? '^\s*end\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
342 let ind = s:GetStmtStarterIndent('end', v:lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
343 " General case for end
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
344 " let ind = ind - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
345 " echom 'curr - end - indent ' . ind
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
346 elseif line =~? '^\s*when\>'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
347 let ind = s:GetStmtStarterIndent('when', v:lnum)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
348 " If the WHEN clause is used with a MERGE or EXCEPTION
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
349 " clause, do not change the indent level, since these
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
350 " statements do not have a corresponding END statement.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
351 " if stmt_starter =~? 'case'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
352 " let ind = ind - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
353 " endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
354 " elseif line =~ '^\s*)\s*;\?\s*$'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
355 " elseif line =~ '^\s*)'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
356 elseif line =~ '^\s*)'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
357 let num_unmatched_right = s:CountUnbalancedParan( line, ')' )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
358 let ignore = s:CheckToIgnoreRightParan( v:lnum, num_unmatched_right )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
359 " If the line ends in a ), then reduce the indent
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
360 " This catches items like:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
361 " CREATE TABLE T1(
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
362 " c1 int,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
363 " c2 int
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
364 " );
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
365 " But we do not want to unindent a line like:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
366 " IF ( c1 = 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
367 " AND c2 = 3 ) THEN
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
368 " let num_unmatched_right = s:CountUnbalancedParan( line, ')' )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
369 " if num_unmatched_right > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
370 " elseif strpart( line, strlen(line)-1, 1 ) =~ ')'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
371 " let ind = ind - &sw
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
372 if line =~ '^\s*)'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
373 " let ignore = ignore + 1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
374 " echom 'curr - begins ) unbalanced ignore: ' . ignore
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
375 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
376
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
377 if (num_unmatched_right - ignore) > 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
378 let ind = ind - ( &sw * (num_unmatched_right - ignore) )
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
379 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
380 " endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
381 endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
382
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
383 " echom 'final - indent ' . ind
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
384 return s:ModuloIndent(ind)
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
385 endfunction
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
386
48
67300faee616 v7-3-618
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
387 let &cpo = s:keepcpo
67300faee616 v7-3-618
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
388 unlet s:keepcpo
67300faee616 v7-3-618
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
389
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
390 " vim:sw=4: