summaryrefslogtreecommitdiffstats
path: root/indent/awk.vim
diff options
context:
space:
mode:
Diffstat (limited to 'indent/awk.vim')
-rw-r--r--indent/awk.vim236
1 files changed, 0 insertions, 236 deletions
diff --git a/indent/awk.vim b/indent/awk.vim
deleted file mode 100644
index 8637dd53..00000000
--- a/indent/awk.vim
+++ /dev/null
@@ -1,236 +0,0 @@
-if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'vim') == -1
-
-" vim: set sw=3 sts=3:
-
-" Awk indent script. It can handle multi-line statements and expressions.
-" It works up to the point where the distinction between correct/incorrect
-" and personal taste gets fuzzy. Drop me an e-mail for bug reports and
-" reasonable style suggestions.
-"
-" Bugs:
-" =====
-" - Some syntax errors may cause erratic indentation.
-" - Same for very unusual but syntacticly correct use of { }
-" - In some cases it's confused by the use of ( and { in strings constants
-" - This version likes the closing brace of a multiline pattern-action be on
-" character position 1 before the following pattern-action combination is
-" formatted
-
-" Author:
-" =======
-" Erik Janssen, ejanssen@itmatters.nl
-"
-" History:
-" ========
-" 26-04-2002 Got initial version working reasonably well
-" 29-04-2002 Fixed problems in function headers and max line width
-" Added support for two-line if's without curly braces
-" Fixed hang: 2011 Aug 31
-
-" Only load this indent file when no other was loaded.
-if exists("b:did_indent")
- finish
-endif
-
-let b:did_indent = 1
-
-setlocal indentexpr=GetAwkIndent()
-" Mmm, copied from the tcl indent program. Is this okay?
-setlocal indentkeys-=:,0#
-
-" Only define the function once.
-if exists("*GetAwkIndent")
- finish
-endif
-
-" This function contains a lot of exit points. It checks for simple cases
-" first to get out of the function as soon as possible, thereby reducing the
-" number of possibilities later on in the difficult parts
-
-function! GetAwkIndent()
-
- " Find previous line and get it's indentation
- let prev_lineno = s:Get_prev_line( v:lnum )
- if prev_lineno == 0
- return 0
- endif
- let prev_data = getline( prev_lineno )
- let ind = indent( prev_lineno )
-
- " Increase indent if the previous line contains an opening brace. Search
- " for this brace the hard way to prevent errors if the previous line is a
- " 'pattern { action }' (simple check match on /{/ increases the indent then)
-
- if s:Get_brace_balance( prev_data, '{', '}' ) > 0
- return ind + shiftwidth()
- endif
-
- let brace_balance = s:Get_brace_balance( prev_data, '(', ')' )
-
- " If prev line has positive brace_balance and starts with a word (keyword
- " or function name), align the current line on the first '(' of the prev
- " line
-
- if brace_balance > 0 && s:Starts_with_word( prev_data )
- return s:Safe_indent( ind, s:First_word_len(prev_data), getline(v:lnum))
- endif
-
- " If this line starts with an open brace bail out now before the line
- " continuation checks.
-
- if getline( v:lnum ) =~ '^\s*{'
- return ind
- endif
-
- " If prev line seems to be part of multiline statement:
- " 1. Prev line is first line of a multiline statement
- " -> attempt to indent on first ' ' or '(' of prev line, just like we
- " indented the positive brace balance case above
- " 2. Prev line is not first line of a multiline statement
- " -> copy indent of prev line
-
- let continue_mode = s:Seems_continuing( prev_data )
- if continue_mode > 0
- if s:Seems_continuing( getline(s:Get_prev_line( prev_lineno )) )
- " Case 2
- return ind
- else
- " Case 1
- if continue_mode == 1
- " Need continuation due to comma, backslash, etc
- return s:Safe_indent( ind, s:First_word_len(prev_data), getline(v:lnum))
- else
- " if/for/while without '{'
- return ind + shiftwidth()
- endif
- endif
- endif
-
- " If the previous line doesn't need continuation on the current line we are
- " on the start of a new statement. We have to make sure we align with the
- " previous statement instead of just the previous line. This is a bit
- " complicated because the previous statement might be multi-line.
- "
- " The start of a multiline statement can be found by:
- "
- " 1 If the previous line contains closing braces and has negative brace
- " balance, search backwards until cumulative brace balance becomes zero,
- " take indent of that line
- " 2 If the line before the previous needs continuation search backward
- " until that's not the case anymore. Take indent of one line down.
-
- " Case 1
- if prev_data =~ ')' && brace_balance < 0
- while brace_balance != 0 && prev_lineno > 0
- let prev_lineno = s:Get_prev_line( prev_lineno )
- let prev_data = getline( prev_lineno )
- let brace_balance=brace_balance+s:Get_brace_balance(prev_data,'(',')' )
- endwhile
- let ind = indent( prev_lineno )
- else
- " Case 2
- if s:Seems_continuing( getline( prev_lineno - 1 ) )
- let prev_lineno = prev_lineno - 2
- let prev_data = getline( prev_lineno )
- while prev_lineno > 0 && (s:Seems_continuing( prev_data ) > 0)
- let prev_lineno = s:Get_prev_line( prev_lineno )
- let prev_data = getline( prev_lineno )
- endwhile
- let ind = indent( prev_lineno + 1 )
- endif
- endif
-
- " Decrease indent if this line contains a '}'.
- if getline(v:lnum) =~ '^\s*}'
- let ind = ind - shiftwidth()
- endif
-
- return ind
-endfunction
-
-" Find the open and close braces in this line and return how many more open-
-" than close braces there are. It's also used to determine cumulative balance
-" across multiple lines.
-
-function! s:Get_brace_balance( line, b_open, b_close )
- let line2 = substitute( a:line, a:b_open, "", "g" )
- let openb = strlen( a:line ) - strlen( line2 )
- let line3 = substitute( line2, a:b_close, "", "g" )
- let closeb = strlen( line2 ) - strlen( line3 )
- return openb - closeb
-endfunction
-
-" Find out whether the line starts with a word (i.e. keyword or function
-" call). Might need enhancements here.
-
-function! s:Starts_with_word( line )
- if a:line =~ '^\s*[a-zA-Z_0-9]\+\s*('
- return 1
- endif
- return 0
-endfunction
-
-" Find the length of the first word in a line. This is used to be able to
-" align a line relative to the 'print ' or 'if (' on the previous line in case
-" such a statement spans multiple lines.
-" Precondition: only to be used on lines where 'Starts_with_word' returns 1.
-
-function! s:First_word_len( line )
- let white_end = matchend( a:line, '^\s*' )
- if match( a:line, '^\s*func' ) != -1
- let word_end = matchend( a:line, '[a-z]\+\s\+[a-zA-Z_0-9]\+[ (]*' )
- else
- let word_end = matchend( a:line, '[a-zA-Z_0-9]\+[ (]*' )
- endif
- return word_end - white_end
-endfunction
-
-" Determine if 'line' completes a statement or is continued on the next line.
-" This one is far from complete and accepts illegal code. Not important for
-" indenting, however.
-
-function! s:Seems_continuing( line )
- " Unfinished lines
- if a:line =~ '\(--\|++\)\s*$'
- return 0
- endif
- if a:line =~ '[\\,\|\&\+\-\*\%\^]\s*$'
- return 1
- endif
- " if/for/while (cond) eol
- if a:line =~ '^\s*\(if\|while\|for\)\s*(.*)\s*$' || a:line =~ '^\s*else\s*'
- return 2
- endif
- return 0
-endfunction
-
-" Get previous relevant line. Search back until a line is that is no
-" comment or blank and return the line number
-
-function! s:Get_prev_line( lineno )
- let lnum = a:lineno - 1
- let data = getline( lnum )
- while lnum > 0 && (data =~ '^\s*#' || data =~ '^\s*$')
- let lnum = lnum - 1
- let data = getline( lnum )
- endwhile
- return lnum
-endfunction
-
-" This function checks whether an indented line exceeds a maximum linewidth
-" (hardcoded 80). If so and it is possible to stay within 80 positions (or
-" limit num of characters beyond linewidth) by decreasing the indent (keeping
-" it > base_indent), do so.
-
-function! s:Safe_indent( base, wordlen, this_line )
- let line_base = matchend( a:this_line, '^\s*' )
- let line_len = strlen( a:this_line ) - line_base
- let indent = a:base
- if (indent + a:wordlen + line_len) > 80
- " Simple implementation good enough for the time being
- let indent = indent + 3
- endif
- return indent + a:wordlen
-endfunction
-
-endif