OXIESEC PANEL
- Current Dir:
/
/
usr
/
share
/
vim
/
vim80
/
indent
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/09/2024 07:13:33 AM
rwxr-xr-x
📄
README.txt
1.6 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
aap.vim
265 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
ada.vim
10.97 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
ant.vim
290 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
automake.vim
243 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
awk.vim
7.59 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
bib.vim
346 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
bst.vim
1.89 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
bzl.vim
2.43 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
c.vim
325 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
cdl.vim
4.15 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
ch.vim
470 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
chaiscript.vim
1.11 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
changelog.vim
264 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
clojure.vim
10.2 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
cmake.vim
2.62 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
cobol.vim
8.11 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
config.vim
2.13 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
context.vim
752 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
cpp.vim
329 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
cs.vim
327 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
css.vim
1.75 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
cucumber.vim
2.62 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
cuda.vim
305 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
d.vim
510 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
dictconf.vim
337 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
dictdconf.vim
338 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
docbk.vim
336 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
dtd.vim
11.59 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
dtrace.vim
451 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
dylan.vim
2.64 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
eiffel.vim
3.24 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
erlang.vim
45.29 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
eruby.vim
2.74 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
eterm.vim
668 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
falcon.vim
13.72 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
fortran.vim
7.27 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
framescript.vim
816 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
gitconfig.vim
841 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
gitolite.vim
1.25 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
go.vim
1.63 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
haml.vim
2.16 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
hamster.vim
1.39 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
hog.vim
1.85 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
html.vim
31.94 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
htmldjango.vim
273 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
idlang.vim
1.58 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
ishd.vim
1.83 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
j.vim
1.77 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
java.vim
4.19 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
javascript.vim
15 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
json.vim
4.32 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
jsp.vim
462 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
ld.vim
1.75 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
less.vim
243 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
lifelines.vim
637 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
liquid.vim
1.85 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
lisp.vim
353 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
logtalk.vim
1.7 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
lua.vim
1.88 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
mail.vim
308 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
make.vim
3.41 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
matlab.vim
1.92 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
mf.vim
156 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
mma.vim
2.18 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
mp.vim
11.06 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
nsis.vim
3.18 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
objc.vim
1.61 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
ocaml.vim
8.94 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
occam.vim
4.53 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
pascal.vim
5.52 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
perl.vim
5.76 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
perl6.vim
3.46 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
php.vim
21.91 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
postscr.vim
1.61 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
pov.vim
2.6 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
prolog.vim
1.46 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
pyrex.vim
326 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
python.vim
5.61 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
r.vim
13.58 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
readline.vim
711 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
rhelp.vim
2.77 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
rmd.vim
1.17 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
rnoweb.vim
1.06 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
rpl.vim
1.82 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
rrst.vim
1.17 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
rst.vim
1.37 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
ruby.vim
22.43 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
rust.vim
6.35 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
sas.vim
5.01 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
sass.vim
950 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
scala.vim
18.97 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
scheme.vim
241 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
scss.vim
191 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
sdl.vim
2.73 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
sh.vim
5.58 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
sml.vim
6.33 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
sql.vim
1.18 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
sqlanywhere.vim
12.86 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
systemd.vim
205 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
systemverilog.vim
8.38 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
tcl.vim
1.59 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
tcsh.vim
1.24 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
teraterm.vim
1.33 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
tex.vim
13.2 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
tf.vim
1.51 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
tilde.vim
1012 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
treetop.vim
707 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
vb.vim
2.04 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
verilog.vim
7.97 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
vhdl.vim
14.32 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
vim.vim
2.92 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
vroom.vim
379 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
xf86conf.vim
709 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
xhtml.vim
269 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
xinetd.vim
1.2 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
xml.vim
2.78 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
xsd.vim
253 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
xslt.vim
297 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
yacc.vim
781 bytes
04/18/2023 09:20:34 AM
rw-r--r--
📄
yaml.vim
5.34 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
zimbu.vim
3.84 KB
04/18/2023 09:20:34 AM
rw-r--r--
📄
zsh.vim
411 bytes
04/18/2023 09:20:34 AM
rw-r--r--
Editing: sqlanywhere.vim
Close
" Vim indent file " Language: SQL " Maintainer: David Fishburn <dfishburn dot vim at gmail dot com> " Last Change: 2017 Jun 13 " Version: 3.0 " Download: http://vim.sourceforge.net/script.php?script_id=495 " Notes: " Indenting keywords are based on Oracle and Sybase Adaptive Server " Anywhere (ASA). Test indenting was done with ASA stored procedures and " fuctions and Oracle packages which contain stored procedures and " functions. " This has not been tested against Microsoft SQL Server or " Sybase Adaptive Server Enterprise (ASE) which use the Transact-SQL " syntax. That syntax does not have end tags for IF's, which makes " indenting more difficult. " " Known Issues: " The Oracle MERGE statement does not have an end tag associated with " it, this can leave the indent hanging to the right one too many. " " History: " 3.0 (Dec 2012) " Added cpo check " " 2.0 " Added the FOR keyword to SQLBlockStart to handle (Alec Tica): " for i in 1..100 loop " |<-- I expect to have indentation here " end loop; " " Only load this indent file when no other was loaded. if exists("b:did_indent") finish endif let b:did_indent = 1 let b:current_indent = "sqlanywhere" setlocal indentkeys-=0{ setlocal indentkeys-=0} setlocal indentkeys-=: setlocal indentkeys-=0# setlocal indentkeys-=e " This indicates formatting should take place when one of these " expressions is used. These expressions would normally be something " you would type at the BEGINNING of a line " SQL is generally case insensitive, so this files assumes that " These keywords are something that would trigger an indent LEFT, not " an indent right, since the SQLBlockStart is used for those keywords setlocal indentkeys+==~end,=~else,=~elseif,=~elsif,0=~when,0=) " GetSQLIndent is executed whenever one of the expressions " in the indentkeys is typed setlocal indentexpr=GetSQLIndent() " Only define the functions once. if exists("*GetSQLIndent") finish endif let s:keepcpo= &cpo set cpo&vim " List of all the statements that start a new block. " These are typically words that start a line. " IS is excluded, since it is difficult to determine when the " ending block is (especially for procedures/functions). let s:SQLBlockStart = '^\s*\%('. \ 'if\|else\|elseif\|elsif\|'. \ 'while\|loop\|do\|for\|'. \ 'begin\|'. \ 'case\|when\|merge\|exception'. \ '\)\>' let s:SQLBlockEnd = '^\s*\(end\)\>' " The indent level is also based on unmatched paranethesis " If a line has an extra "(" increase the indent " If a line has an extra ")" decrease the indent function! s:CountUnbalancedParan( line, paran_to_check ) let l = a:line let lp = substitute(l, '[^(]', '', 'g') let l = a:line let rp = substitute(l, '[^)]', '', 'g') if a:paran_to_check =~ ')' " echom 'CountUnbalancedParan ) returning: ' . " \ (strlen(rp) - strlen(lp)) return (strlen(rp) - strlen(lp)) elseif a:paran_to_check =~ '(' " echom 'CountUnbalancedParan ( returning: ' . " \ (strlen(lp) - strlen(rp)) return (strlen(lp) - strlen(rp)) else " echom 'CountUnbalancedParan unknown paran to check: ' . " \ a:paran_to_check return 0 endif endfunction " Unindent commands based on previous indent level function! s:CheckToIgnoreRightParan( prev_lnum, num_levels ) let lnum = a:prev_lnum let line = getline(lnum) let ends = 0 let num_right_paran = a:num_levels let ignore_paran = 0 let vircol = 1 while num_right_paran > 0 silent! exec 'norm! '.lnum."G\<bar>".vircol."\<bar>" let right_paran = search( ')', 'W' ) if right_paran != lnum " This should not happen since there should be at least " num_right_paran matches for this line break endif let vircol = virtcol(".") " if getline(".") =~ '^)' let matching_paran = searchpair('(', '', ')', 'bW', \ 's:IsColComment(line("."), col("."))') if matching_paran < 1 " No match found " echom 'CTIRP - no match found, ignoring' break endif if matching_paran == lnum " This was not an unmatched parantenses, start the search again " again after this column " echom 'CTIRP - same line match, ignoring' continue endif " echom 'CTIRP - match: ' . line(".") . ' ' . getline(".") if getline(matching_paran) =~? '\(if\|while\)\>' " echom 'CTIRP - if/while ignored: ' . line(".") . ' ' . getline(".") let ignore_paran = ignore_paran + 1 endif " One match found, decrease and check for further matches let num_right_paran = num_right_paran - 1 endwhile " Fallback - just move back one " return a:prev_indent - shiftwidth() return ignore_paran endfunction " Based on the keyword provided, loop through previous non empty " non comment lines to find the statement that initated the keyword. " Return its indent level " CASE .. " WHEN ... " Should return indent level of CASE " EXCEPTION .. " WHEN ... " something; " WHEN ... " Should return indent level of exception. function! s:GetStmtStarterIndent( keyword, curr_lnum ) let lnum = a:curr_lnum " Default - reduce indent by 1 let ind = indent(a:curr_lnum) - shiftwidth() if a:keyword =~? 'end' exec 'normal! ^' let stmts = '^\s*\%('. \ '\<begin\>\|' . \ '\%(\%(\<end\s\+\)\@<!\<loop\>\)\|' . \ '\%(\%(\<end\s\+\)\@<!\<case\>\)\|' . \ '\%(\%(\<end\s\+\)\@<!\<for\>\)\|' . \ '\%(\%(\<end\s\+\)\@<!\<if\>\)'. \ '\)' let matching_lnum = searchpair(stmts, '', '\<end\>\zs', 'bW', \ 's:IsColComment(line("."), col(".")) == 1') exec 'normal! $' if matching_lnum > 0 && matching_lnum < a:curr_lnum let ind = indent(matching_lnum) endif elseif a:keyword =~? 'when' exec 'normal! ^' let matching_lnum = searchpair( \ '\%(\<end\s\+\)\@<!\<case\>\|\<exception\>\|\<merge\>', \ '', \ '\%(\%(\<when\s\+others\>\)\|\%(\<end\s\+case\>\)\)', \ 'bW', \ 's:IsColComment(line("."), col(".")) == 1') exec 'normal! $' if matching_lnum > 0 && matching_lnum < a:curr_lnum let ind = indent(matching_lnum) else let ind = indent(a:curr_lnum) endif endif return ind endfunction " Check if the line is a comment function! s:IsLineComment(lnum) let rc = synIDattr( \ synID(a:lnum, \ match(getline(a:lnum), '\S')+1, 0) \ , "name") \ =~? "comment" return rc endfunction " Check if the column is a comment function! s:IsColComment(lnum, cnum) let rc = synIDattr(synID(a:lnum, a:cnum, 0), "name") \ =~? "comment" return rc endfunction " Instead of returning a column position, return " an appropriate value as a factor of shiftwidth. function! s:ModuloIndent(ind) let ind = a:ind if ind > 0 let modulo = ind % shiftwidth() if modulo > 0 let ind = ind - modulo endif endif return ind endfunction " Find correct indent of a new line based upon the previous line function! GetSQLIndent() let lnum = v:lnum let ind = indent(lnum) " If the current line is a comment, leave the indent as is " Comment out this additional check since it affects the " indenting of =, and will not reindent comments as it should " if s:IsLineComment(lnum) == 1 " return ind " endif " Get previous non-blank line let prevlnum = prevnonblank(lnum - 1) if prevlnum <= 0 return ind endif if s:IsLineComment(prevlnum) == 1 if getline(v:lnum) =~ '^\s*\*' let ind = s:ModuloIndent(indent(prevlnum)) return ind + 1 endif " If the previous line is a comment, then return -1 " to tell Vim to use the formatoptions setting to determine " the indent to use " But only if the next line is blank. This would be true if " the user is typing, but it would not be true if the user " is reindenting the file if getline(v:lnum) =~ '^\s*$' return -1 endif endif " echom 'PREVIOUS INDENT: ' . indent(prevlnum) . ' LINE: ' . getline(prevlnum) " This is the line you just hit return on, it is not the current line " which is new and empty " Based on this line, we can determine how much to indent the new " line " Get default indent (from prev. line) let ind = indent(prevlnum) let prevline = getline(prevlnum) " Now check what's on the previous line to determine if the indent " should be changed, for example IF, BEGIN, should increase the indent " where END IF, END, should decrease the indent. if prevline =~? s:SQLBlockStart " Move indent in let ind = ind + shiftwidth() " echom 'prevl - SQLBlockStart - indent ' . ind . ' line: ' . prevline elseif prevline =~ '[()]' if prevline =~ '(' let num_unmatched_left = s:CountUnbalancedParan( prevline, '(' ) else let num_unmatched_left = 0 endif if prevline =~ ')' let num_unmatched_right = s:CountUnbalancedParan( prevline, ')' ) else let num_unmatched_right = 0 " let num_unmatched_right = s:CountUnbalancedParan( prevline, ')' ) endif if num_unmatched_left > 0 " There is a open left paranethesis " increase indent let ind = ind + ( shiftwidth() * num_unmatched_left ) elseif num_unmatched_right > 0 " if it is an unbalanced paranethesis only unindent if " it was part of a command (ie create table(..) ) " instead of part of an if (ie if (....) then) which should " maintain the indent level let ignore = s:CheckToIgnoreRightParan( prevlnum, num_unmatched_right ) " echom 'prevl - ) unbalanced - CTIRP - ignore: ' . ignore if prevline =~ '^\s*)' let ignore = ignore + 1 " echom 'prevl - begins ) unbalanced ignore: ' . ignore endif if (num_unmatched_right - ignore) > 0 let ind = ind - ( shiftwidth() * (num_unmatched_right - ignore) ) endif endif endif " echom 'CURRENT INDENT: ' . ind . ' LINE: ' . getline(v:lnum) " This is a new blank line since we just typed a carriage return " Check current line; search for simplistic matching start-of-block let line = getline(v:lnum) if line =~? '^\s*els' " Any line when you type else will automatically back up one " ident level (ie else, elseif, elsif) let ind = ind - shiftwidth() " echom 'curr - else - indent ' . ind elseif line =~? '^\s*end\>' let ind = s:GetStmtStarterIndent('end', v:lnum) " General case for end " let ind = ind - shiftwidth() " echom 'curr - end - indent ' . ind elseif line =~? '^\s*when\>' let ind = s:GetStmtStarterIndent('when', v:lnum) " If the WHEN clause is used with a MERGE or EXCEPTION " clause, do not change the indent level, since these " statements do not have a corresponding END statement. " if stmt_starter =~? 'case' " let ind = ind - shiftwidth() " endif " elseif line =~ '^\s*)\s*;\?\s*$' " elseif line =~ '^\s*)' elseif line =~ '^\s*)' let num_unmatched_right = s:CountUnbalancedParan( line, ')' ) let ignore = s:CheckToIgnoreRightParan( v:lnum, num_unmatched_right ) " If the line ends in a ), then reduce the indent " This catches items like: " CREATE TABLE T1( " c1 int, " c2 int " ); " But we do not want to unindent a line like: " IF ( c1 = 1 " AND c2 = 3 ) THEN " let num_unmatched_right = s:CountUnbalancedParan( line, ')' ) " if num_unmatched_right > 0 " elseif strpart( line, strlen(line)-1, 1 ) =~ ')' " let ind = ind - shiftwidth() if line =~ '^\s*)' " let ignore = ignore + 1 " echom 'curr - begins ) unbalanced ignore: ' . ignore endif if (num_unmatched_right - ignore) > 0 let ind = ind - ( shiftwidth() * (num_unmatched_right - ignore) ) endif " endif endif " echom 'final - indent ' . ind return s:ModuloIndent(ind) endfunction " Restore: let &cpo= s:keepcpo unlet s:keepcpo " vim: ts=4 fdm=marker sw=4