changeset 1200:f58cb9bf1260

updated for version 7.1b
author vimboss
date Thu, 10 May 2007 17:26:28 +0000
parents 3acf7c922a04
children 4d2585cf5950
files runtime/doc/cmdline.txt runtime/doc/pi_tar.txt runtime/indent/eruby.vim runtime/indent/make.vim runtime/syntax/gpg.vim src/globals.h src/os_vms_conf.h
diffstat 7 files changed, 119 insertions(+), 156 deletions(-) [+]
line wrap: on
line diff
--- a/runtime/doc/cmdline.txt
+++ b/runtime/doc/cmdline.txt
@@ -1,4 +1,4 @@
-*cmdline.txt*   For Vim version 7.1a.  Last change: 2006 Jul 18
+*cmdline.txt*   For Vim version 7.1b.  Last change: 2006 Jul 18
 
 
 		  VIM REFERENCE MANUAL    by Bram Moolenaar
--- a/runtime/doc/pi_tar.txt
+++ b/runtime/doc/pi_tar.txt
@@ -1,4 +1,4 @@
-*pi_tar.txt*	For Vim version 7.1a.  Last change: 2006 Sep 29
+*pi_tar.txt*	For Vim version 7.1b.  Last change: 2006 Sep 29
 
        	       	       +====================+
        	       	       | Tar File Interface |
--- a/runtime/indent/eruby.vim
+++ b/runtime/indent/eruby.vim
@@ -12,13 +12,27 @@ endif
 
 runtime! indent/ruby.vim
 unlet! b:did_indent
+set indentexpr=
 
-runtime! indent/html.vim
+if exists("b:eruby_subtype")
+  exe "runtime! indent/".b:eruby_subtype.".vim"
+else
+  runtime! indent/html.vim
+endif
 unlet! b:did_indent
 
+if &l:indentexpr == ''
+  if &l:cindent
+    let &l:indentexpr = 'cindent(v:lnum)'
+  else
+    let &l:indentexpr = 'indent(prevnonblank(v:lnum-1))'
+  endif
+endif
+let b:eruby_subtype_indentexpr = &l:indentexpr
+
 let b:did_indent = 1
 
-setlocal indentexpr=GetErubyIndent(v:lnum)
+setlocal indentexpr=GetErubyIndent()
 setlocal indentkeys=o,O,*<Return>,<>>,{,},0),0],o,O,!^F,=end,=else,=elsif,=rescue,=ensure,=when
 
 " Only define the function once.
@@ -26,19 +40,19 @@ if exists("*GetErubyIndent")
   finish
 endif
 
-function! GetErubyIndent(lnum)
+function! GetErubyIndent()
   let vcol = col('.')
-  call cursor(a:lnum,1)
+  call cursor(v:lnum,1)
   let inruby = searchpair('<%','','%>')
-  call cursor(a:lnum,vcol)
-  if inruby && getline(a:lnum) !~ '^<%'
+  call cursor(v:lnum,vcol)
+  if inruby && getline(v:lnum) !~ '^<%'
     let ind = GetRubyIndent()
   else
-    let ind = HtmlIndentGet(a:lnum)
+    exe "let ind = ".b:eruby_subtype_indentexpr
   endif
-  let lnum = prevnonblank(a:lnum-1)
+  let lnum = prevnonblank(v:lnum-1)
   let line = getline(lnum)
-  let cline = getline(a:lnum)
+  let cline = getline(v:lnum)
   if cline =~# '<%\s*\%(end\|else\|\%(ensure\|rescue\|elsif\|when\).\{-\}\)\s*\%(-\=%>\|$\)'
     let ind = ind - &sw
   endif
--- a/runtime/indent/make.vim
+++ b/runtime/indent/make.vim
@@ -1,7 +1,7 @@
 " Vim indent file
-" Language:	    Makefile
-" Maintainer:	    Nikolai Weibull <now@bitwi.se>
-" Latest Revision:  2006-04-26
+" Language:         Makefile
+" Maintainer:       Nikolai Weibull <now@bitwi.se>
+" Latest Revision:  2007-05-07
 
 if exists("b:did_indent")
   finish
@@ -9,159 +9,108 @@ endif
 let b:did_indent = 1
 
 setlocal indentexpr=GetMakeIndent()
-setlocal indentkeys=!^F,o,O
+setlocal indentkeys=!^F,o,O,<:>,=else,=endif
 setlocal nosmartindent
 
 if exists("*GetMakeIndent")
   finish
 endif
 
+let s:comment_rx = '^\s*#'
 let s:rule_rx = '^[^ \t#:][^#:]*:\{1,2}\%([^=:]\|$\)'
+let s:continued_rule_rx = '^[^#:]*:\{1,2}\%([^=:]\|$\)'
 let s:continuation_rx = '\\$'
-let s:assignment_rx = '^\s*\h\w*\s*+\==\s*\zs.*\\$'
+let s:assignment_rx = '^\s*\h\w*\s*[+?]\==\s*\zs.*\\$'
+let s:folded_assignment_rx = '^\s*\h\w*\s*[+?]\=='
+" TODO: This needs to be a lot more restrictive in what it matches.
+let s:just_inserted_rule_rx = '^\s*[^#:]\+:\{1,2}$'
+let s:conditional_directive_rx = '^ *\%(ifn\=\%(eq\|def\)\|else\)\>'
+let s:end_conditional_directive_rx = '^\s*\%(else\|endif\)\>'
 
-" TODO: Deal with comments, string, and all kinds of other crap, e.g., defines.
-" TODO: Unwrap the whole logic of this function into something that requires a
-" lot less 'return's.
+function s:remove_continuation(line)
+  return substitute(a:line, s:continuation_rx, "", "")
+endfunction
+
 function GetMakeIndent()
-  let lnum = v:lnum - 1
-  if lnum == 0
+  " TODO: Should this perhaps be v:lnum -1?
+"  let prev_lnum = prevnonblank(v:lnum - 1)
+  let prev_lnum = v:lnum - 1
+  if prev_lnum == 0
     return 0
   endif
+  let prev_line = getline(prev_lnum)
 
-  " Figure out if the previous line is part of a rule or not.  If it is, then
-  " we more or less just indent by a 'tabstop', the previous' lines indent, or
-  " remove all indent if the current line is itself a rule.  Also, if the line
-  " in question is part of a continuation-line set constituting the rule line
-  " itself, we indent by either a 'shiftwidth', if the line is the first in the
-  " continuation, or use the indent of the previous line, if not.
-  while lnum > 0
-    let line = getline(lnum)
-    if line[0] != "\t"
-      " We found a non-shell-command line, i.e., one that doesn't have a
-      " leading tab.
-      if line =~ s:rule_rx
-	" The line looks like a rule line, so we must therefore either be inside a
-	" rule or we are a continuation line to that rule line.
-	if line =~ s:continuation_rx
-	  " Ah, the rule line was continued, so look up the last continuation
-	  " line that's above the current line.
-	  while line =~ s:continuation_rx && lnum < v:lnum
-	    let lnum += 1
-	    let line = getline(lnum)
-	  endwhile
-	  let lnum -= 1
-	  let line = getline(lnum)
-	endif
+  let prev_prev_lnum = prev_lnum - 1
+  let prev_prev_line = prev_prev_lnum != 0 ? getline(prev_prev_lnum) : ""
 
-	" If the line that we've found is right above the current line, deal
-	" with it specifically.
-	if lnum == v:lnum - 1
-	  " If it was continued, indent the current line by a shiftwidth, as it
-	  " is the first to follow it.  Otherwise, depending on if the current
-	  " line is a rule line, i.e, a rule line following another rule line,
-	  " then indent to the left margin.  Otherwise, the current line is the
-	  " first shell-command line in the rule, so indent by a 'tabstop'
-	  if line =~ s:continuation_rx
-	    return &sw
-	  else
-	    return getline(v:lnum) =~ s:rule_rx ? 0 : &ts
-	  endif
-	else
-	  " If the previous line was a continuation line, then unless it was
-	  " itself a part of a continuation line, add a 'shiftwidth''s worth of
-	  " indent.  Otherwise, just use the indent of the previous line.
-	  " Otherwise, if the previous line wasn't a continuation line, check
-	  " if the one above it was.  If it was then indent to whatever level
-	  " the 'owning' line had.  Otherwise, indent to the previous line's
-	  " level.
-	  let lnum = v:lnum - 1
-	  let line = getline(lnum)
-	  if line =~ s:continuation_rx
-	    let pnum = v:lnum - 2
-	    let pine = getline(pnum)
-	    if pine =~ s:continuation_rx
-	      return indent(lnum)
-	    else
-	      return indent(lnum) + &sw
-	    endif
-	  else
-	    let lnum = v:lnum - 2
-	    let line = getline(lnum)
-	    if line =~ s:continuation_rx
-	      while lnum > 0
-		if line !~ s:continuation_rx
-		  let lnum += 1
-		  let line = getline(lnum)
-		  break
-		endif
-		let lnum -= 1
-		let line = getline(lnum)
-	      endwhile
-	      " We've found the owning line.  Indent to it's level.
-	      return indent(lnum)
-	    else
-	      return indent(v:lnum - 1)
-	    endif
-	  endif
-	endif
+  " TODO: Deal with comments.  In comments, continuations aren't interesting.
+  if prev_line =~ s:continuation_rx
+    if prev_prev_line =~ s:continuation_rx
+      return indent(prev_lnum)
+    elseif prev_line =~ s:rule_rx
+      return &sw
+    elseif prev_line =~ s:assignment_rx
+      call cursor(prev_lnum, 1)
+      if search(s:assignment_rx, 'W') != 0
+        return virtcol('.') - 1
+      else
+        " TODO: ?
+        return &sw
       endif
-
-      " The line wasn't a rule line, so the current line is part of a series
-      " of tab-indented lines that don't belong to any rule.
-      break
+    else
+      " TODO: OK, this might be a continued shell command, so perhaps indent
+      " properly here?  Leave this out for now, but in the next release this
+      " should be using indent/sh.vim somehow.
+      "if prev_line =~ '^\t' " s:rule_command_rx
+      "  if prev_line =~ '^\s\+[@-]\%(if\)\>'
+      "    return indent(prev_lnum) + 2
+      "  endif
+      "endif
+      return indent(prev_lnum) + &sw
     endif
-    let lnum -= 1
-  endwhile
-
-  " If the line before the one we are currently indenting ended with a
-  " continuation, then try to figure out what 'owns' that line and indent
-  " appropriately.
-  let lnum = v:lnum - 1
-  let line = getline(lnum)
-  if line =~ s:continuation_rx
-    let indent = indent(lnum)
-    if line =~ s:assignment_rx
-      " The previous line is a continuation line that begins a variable-
-      " assignment expression, so set the indent to just beyond the whitespace
-      " following the assignment operator ('=').
-      call cursor(lnum, 1)
-      if search(s:assignment_rx, 'W') != 0
-	let indent = virtcol('.') - 1
-      endif
-    endif
-
-    " The previous line didn't constitute an assignment, so just indent to
-    " whatever level it had.
-    return indent
-  endif
-
-  " If the line above the line above the current line ended was continued,
-  " then the line above the current line was part of a continued line.  Find
-  " the 'owning' line and indent to its level.
-  let lnum = v:lnum - 2
-  let line = getline(lnum)
-  if line =~ s:continuation_rx
-    while lnum > 0
-      if line !~ s:continuation_rx
-	let lnum += 1
-	let line = getline(lnum)
-	break
-      endif
+  elseif prev_prev_line =~ s:continuation_rx
+    let folded_line = s:remove_continuation(prev_prev_line) . ' ' . s:remove_continuation(prev_line)
+    let lnum = prev_prev_lnum - 1
+    let line = getline(lnum)
+    while line =~ s:continuation_rx
+      let folded_line = s:remove_continuation(line) . ' ' . folded_line
       let lnum -= 1
       let line = getline(lnum)
     endwhile
-    " We've found the owning line.  Indent to it's level.
-    return indent(lnum)
-  endif
-
-  " If nothing else caught on, then check if this line is a rule line.  If it
-  " is, indent it to the left margin.  Otherwise, simply use the indent of the
-  " previous line.
-  let line = getline(v:lnum)
-  if line =~ s:rule_rx
-    return 0
+    let folded_lnum = lnum + 1
+    if folded_line =~ s:rule_rx
+      if getline(v:lnum) =~ s:rule_rx
+        return 0
+      else
+        return &ts
+      endif
+    else
+"    elseif folded_line =~ s:folded_assignment_rx
+      if getline(v:lnum) =~ s:rule_rx
+        return 0
+      else
+        return indent(folded_lnum)
+      endif
+"    else
+"      " TODO: ?
+"      return indent(prev_lnum)
+    endif
+  elseif prev_line =~ s:rule_rx
+    if getline(v:lnum) =~ s:rule_rx
+      return 0
+    else
+      return &ts
+    endif
+  elseif prev_line =~ s:conditional_directive_rx
+    return &sw
   else
-    return indent(v:lnum - 1)
+    let line = getline(v:lnum)
+    if line =~ s:just_inserted_rule_rx
+      return 0
+    elseif line =~ s:end_conditional_directive_rx
+      return v:lnum - 1 == 0 ? 0 : indent(v:lnum - 1) - &sw
+    else
+      return v:lnum - 1 == 0 ? 0 : indent(v:lnum - 1)
+    endif
   endif
 endfunction
--- a/runtime/syntax/gpg.vim
+++ b/runtime/syntax/gpg.vim
@@ -1,7 +1,7 @@
 " Vim syntax file
 " Language:         gpg(1) configuration file
 " Maintainer:       Nikolai Weibull <now@bitwi.se>
-" Latest Revision:  2006-04-19
+" Latest Revision:  2007-05-06
 
 if exists("b:current_syntax")
   finish
@@ -54,7 +54,7 @@ syn keyword gpgOption   contained skipwh
                         \ personal-digest-preferences photo-viewer
                         \ recipient s2k-cipher-algo s2k-digest-algo s2k-mode
                         \ secret-keyring set-filename set-policy-url status-fd
-                        \ trusted-key
+                        \ trusted-key verify-options
 syn keyword gpgOption   contained skipwhite nextgroup=gpgArgError
                         \ allow-freeform-uid allow-non-selfsigned-uid
                         \ allow-secret-key-import always-trust
--- a/src/globals.h
+++ b/src/globals.h
@@ -263,7 +263,7 @@ EXTERN int trylevel INIT(= 0);
 /*
  * When "force_abort" is TRUE, always skip commands after an error message,
  * even after the outermost ":endif", ":endwhile" or ":endfor" or for a
- * function whithout the "abort" flag.  It is set to TRUE when "trylevel" is
+ * function without the "abort" flag.  It is set to TRUE when "trylevel" is
  * non-zero (and ":silent!" was not used) or an exception is being thrown at
  * the time an error is detected.  It is set to FALSE when "trylevel" gets
  * zero again and there was no error or interrupt or throw.
@@ -948,7 +948,7 @@ EXTERN typebuf_T typebuf		/* typeahead b
 #endif
 		    ;
 #ifdef FEAT_EX_EXTRA
-EXTERN int	ex_normal_busy INIT(= 0); /* recursivenes of ex_normal() */
+EXTERN int	ex_normal_busy INIT(= 0); /* recursiveness of ex_normal() */
 EXTERN int	ex_normal_lock INIT(= 0); /* forbid use of ex_normal() */
 #endif
 EXTERN int	stop_insert_mode;	/* for ":stopinsert" and 'insertmode' */
@@ -984,7 +984,7 @@ EXTERN int	term_console INIT(= FALSE); /
 #endif
 EXTERN int	termcap_active INIT(= FALSE);	/* set by starttermcap() */
 EXTERN int	cur_tmode INIT(= TMODE_COOK);	/* input terminal mode */
-EXTERN int	bangredo INIT(= FALSE);	    /* set to TRUE whith ! command */
+EXTERN int	bangredo INIT(= FALSE);	    /* set to TRUE with ! command */
 EXTERN int	searchcmdlen;		    /* length of previous search cmd */
 #ifdef FEAT_SYN_HL
 EXTERN int	reg_do_extmatch INIT(= 0);  /* Used when compiling regexp:
@@ -1304,8 +1304,8 @@ EXTERN linenr_T		spell_redraw_lnum INIT(
 #endif
 
 #ifdef ALT_X_INPUT
-/* we need to be able to go into the displatch loop while processing a command
- * recevied via alternate input. However, we don't want to process another
+/* we need to be able to go into the dispatch loop while processing a command
+ * received via alternate input. However, we don't want to process another
  * command until the first is completed.
  */
 EXTERN int	suppress_alternate_input INIT(= FALSE);
--- a/src/os_vms_conf.h
+++ b/src/os_vms_conf.h
@@ -74,7 +74,7 @@
 /* Define if struct sigcontext is present */
 #define HAVE_SIGCONTEXT
 
-/* Define if toupper/tolower only work on lower/upercase characters */
+/* Define if toupper/tolower only work on lower/uppercase characters */
 /* #define BROKEN_TOUPPER */
 
 /* Define if tgetstr() has a second argument that is (char *) */