updated for version 7.0120
This commit is contained in:
		| @ -1,4 +1,4 @@ | |||||||
| *autocmd.txt*   For Vim version 7.0aa.  Last change: 2005 Jul 21 | *autocmd.txt*   For Vim version 7.0aa.  Last change: 2005 Jul 30 | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  VIM REFERENCE MANUAL    by Bram Moolenaar | 		  VIM REFERENCE MANUAL    by Bram Moolenaar | ||||||
| @ -487,7 +487,7 @@ VimLeave			Before exiting Vim, just after writing the | |||||||
| 				VimLeavePre. | 				VimLeavePre. | ||||||
| 				To detect an abnormal exit use |v:dying|. | 				To detect an abnormal exit use |v:dying|. | ||||||
| 							*EncodingChanged* | 							*EncodingChanged* | ||||||
| EncodingChanged			Fires off when the 'encoding' option is | EncodingChanged			Fires off after the 'encoding' option has been | ||||||
| 				changed.  Useful to set up fonts, for example. | 				changed.  Useful to set up fonts, for example. | ||||||
| 							*InsertEnter* | 							*InsertEnter* | ||||||
| InsertEnter			When starting Insert mode.  Also for Replace | InsertEnter			When starting Insert mode.  Also for Replace | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| *change.txt*    For Vim version 7.0aa.  Last change: 2005 Jun 25 | *change.txt*    For Vim version 7.0aa.  Last change: 2005 Jul 30 | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  VIM REFERENCE MANUAL    by Bram Moolenaar | 		  VIM REFERENCE MANUAL    by Bram Moolenaar | ||||||
| @ -682,8 +682,8 @@ For the definition of a pattern, see |pattern|. | |||||||
|  |  | ||||||
| 					*sub-replace-special* *:s\=* | 					*sub-replace-special* *:s\=* | ||||||
| When the {string} starts with "\=" it is evaluated as an expression, see | When the {string} starts with "\=" it is evaluated as an expression, see | ||||||
| |sub-replace-expression|.  Otherwise these characters in {string} have a | |sub-replace-expression|.  You can use that for any special characters. | ||||||
| special meaning: | Otherwise these characters in {string} have a special meaning: | ||||||
| 								*:s%* | 								*:s%* | ||||||
| When {string} is equal to "%" and '/' is included with the 'cpotions' option, | When {string} is equal to "%" and '/' is included with the 'cpotions' option, | ||||||
| then the {string} of the previous substitute command is used. |cpo-/| | then the {string} of the previous substitute command is used. |cpo-/| | ||||||
| @ -771,9 +771,12 @@ Be careful: The separation character must not appear in the expression! | |||||||
| Consider using a character like "@" or ":".  There is no problem if the result | Consider using a character like "@" or ":".  There is no problem if the result | ||||||
| of the expression contains the separation character. | of the expression contains the separation character. | ||||||
|  |  | ||||||
| Example: > | Examples: > | ||||||
| 	:s@\n@\="\r" . expand("$HOME") . "\r"@ | 	:s@\n@\="\r" . expand("$HOME") . "\r"@ | ||||||
| This replaces an end-of-line with a new line containing the value of $HOME. | This replaces an end-of-line with a new line containing the value of $HOME. > | ||||||
|  |  | ||||||
|  | 	s/E/\="\<Char-0x20ac>"/g | ||||||
|  | This replaces 'E' characters with an euro sign. Read more in |<Char->|. | ||||||
|  |  | ||||||
|  |  | ||||||
| 4.3 Search and replace					*search-replace* | 4.3 Search and replace					*search-replace* | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| *eval.txt*      For Vim version 7.0aa.  Last change: 2005 Jul 29 | *eval.txt*      For Vim version 7.0aa.  Last change: 2005 Jul 30 | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  VIM REFERENCE MANUAL    by Bram Moolenaar | 		  VIM REFERENCE MANUAL    by Bram Moolenaar | ||||||
| @ -3341,14 +3341,14 @@ nr2char({expr})						*nr2char()* | |||||||
| printf({fmt}, {expr1} ...)				*printf()* | printf({fmt}, {expr1} ...)				*printf()* | ||||||
| 		Return a String with {fmt}, where "%" items are replaced by | 		Return a String with {fmt}, where "%" items are replaced by | ||||||
| 		the formatted form of their respective arguments.  Example: > | 		the formatted form of their respective arguments.  Example: > | ||||||
| 			:echo printf("%4d: E%d %.30s", lnum, err, text) | 			printf("%4d: E%d %.30s", lnum, errno, msg) | ||||||
| <		May result in: | <		May result in: | ||||||
| 			  99: E42 asdfasdfasdfasdfasdfasdfasdfas ~ | 			"  99: E42 asdfasdfasdfasdfasdfasdfasdfas" ~ | ||||||
|  |  | ||||||
| 		Often used items are: | 		Often used items are: | ||||||
| 		  %s   	string | 		  %s   	string | ||||||
| 		  %6s	string right-aligned in 6 characters | 		  %6s	string right-aligned in 6 characters | ||||||
| 		  %c    character | 		  %c    single byte | ||||||
| 		  %d    decimal number | 		  %d    decimal number | ||||||
| 		  %5d   decimal number padded with spaces to 5 characters | 		  %5d   decimal number padded with spaces to 5 characters | ||||||
| 		  %x    hex number | 		  %x    hex number | ||||||
| @ -3362,12 +3362,13 @@ printf({fmt}, {expr1} ...)				*printf()* | |||||||
| 		the result. | 		the result. | ||||||
|  |  | ||||||
| 		The "%" starts a conversion specification.  The following | 		The "%" starts a conversion specification.  The following | ||||||
| 		arguments appear in sequence.  Overview: | 		arguments appear in sequence: | ||||||
|  |  | ||||||
| 			%  flags  min-field-width  .precision  type | 			%  [flags]  [field-width]  [.precision]  type | ||||||
|  |  | ||||||
|  | 	        flags | ||||||
|  | 			Zero or more of the following flags: | ||||||
|  |  | ||||||
| 	        -   Zero or more of the following flags: |  | ||||||
|                  |  | ||||||
| 		    #	      The value should be converted to an "alternate | 		    #	      The value should be converted to an "alternate | ||||||
| 			      form".  For c, d, and s conversions, this option | 			      form".  For c, d, and s conversions, this option | ||||||
| 			      has no effect.  For o conversions, the precision | 			      has no effect.  For o conversions, the precision | ||||||
| @ -3378,85 +3379,91 @@ printf({fmt}, {expr1} ...)				*printf()* | |||||||
| 			      For x and X conversions, a non-zero result has | 			      For x and X conversions, a non-zero result has | ||||||
| 			      the string "0x" (or "0X" for X conversions) | 			      the string "0x" (or "0X" for X conversions) | ||||||
| 			      prepended to it. | 			      prepended to it. | ||||||
|                  |  | ||||||
| 		    0 (zero)  Zero padding.  For all conversions the converted | 		    0 (zero)  Zero padding.  For all conversions the converted | ||||||
| 			      value is padded on the left with zeros rather | 			      value is padded on the left with zeros rather | ||||||
| 			      than blanks.  If a precision is given with a | 			      than blanks.  If a precision is given with a | ||||||
| 			      numeric conversion (d, o, x, and X), the 0 flag | 			      numeric conversion (d, o, x, and X), the 0 flag | ||||||
| 			      is ignored. | 			      is ignored. | ||||||
|                  |  | ||||||
| 		    -	      A negative field width flag; the converted value | 		    -	      A negative field width flag; the converted value | ||||||
| 			      is to be left adjusted on the field boundary. | 			      is to be left adjusted on the field boundary. | ||||||
| 			      The converted value is padded on the right with | 			      The converted value is padded on the right with | ||||||
| 			      blanks, rather than on the left with blanks or | 			      blanks, rather than on the left with blanks or | ||||||
| 			      zeros.  A - overrides a 0 if both are given. | 			      zeros.  A - overrides a 0 if both are given. | ||||||
|                  |  | ||||||
| 		    ' ' (space)  A blank should be left before a positive | 		    ' ' (space)  A blank should be left before a positive | ||||||
| 			      number produced by a signed conversion (d). | 			      number produced by a signed conversion (d). | ||||||
|                  |  | ||||||
| 		    +	      A sign must always be placed before a number | 		    +	      A sign must always be placed before a number | ||||||
| 			      produced by a signed conversion.  A + overrides | 			      produced by a signed conversion.  A + overrides | ||||||
| 			      a space if both are used. | 			      a space if both are used. | ||||||
|                  |  | ||||||
| 		-   An optional decimal digit string specifying a minimum | 		field-width | ||||||
| 		    field width.  If the converted value has fewer characters | 			An optional decimal digit string specifying a minimum | ||||||
| 		    than the field width, it will be padded with spaces on the | 			field width.  If the converted value has fewer | ||||||
| 		    left (or right, if the left-adjustment flag has been | 			characters than the field width, it will be padded | ||||||
| 		    given) to fill out the field width. | 			with spaces on the left (or right, if the | ||||||
|                  | 			left-adjustment flag has been given) to fill out the | ||||||
| 		-   An optional precision, in the form of a period '.' | 			field width. | ||||||
| 		    followed by an optional digit string.  If the digit string |  | ||||||
| 		    is omitted, the precision is taken as zero.  This gives | 		.precision | ||||||
| 		    the minimum number of digits to appear for d, o, x, and X | 			An optional precision, in the form of a period '.' | ||||||
| 		    conversions, or the maximum number of characters to be | 			followed by an optional digit string.  If the digit | ||||||
| 		    printed from a string for s conversions. | 			string is omitted, the precision is taken as zero. | ||||||
|                  | 			This gives the minimum number of digits to appear for | ||||||
| 		-   A character that specifies the type of conversion to be | 			d, o, x, and X conversions, or the maximum number of | ||||||
| 		    applied, see below. | 			characters to be printed from a string for s | ||||||
|                  | 			conversions. | ||||||
|  |  | ||||||
|  | 		type | ||||||
|  | 			A character that specifies the type of conversion to | ||||||
|  | 			be applied, see below. | ||||||
|  |  | ||||||
| 		A field width or precision, or both, may be indicated by an | 		A field width or precision, or both, may be indicated by an | ||||||
| 		asterisk '*' instead of a digit string.  In this case, a | 		asterisk '*' instead of a digit string.  In this case, a | ||||||
| 		Number argument supplies the field width or precision.  A | 		Number argument supplies the field width or precision.  A | ||||||
| 		negative field width is treated as a left adjustment flag | 		negative field width is treated as a left adjustment flag | ||||||
| 		followed by a positive field width; a negative precision is | 		followed by a positive field width; a negative precision is | ||||||
| 		treated as though it were missing.  Example: > | 		treated as though it were missing.  Example: > | ||||||
| 			:echo printf("%d: %.*s", nr, columns, line) | 			:echo printf("%d: %.*s", nr, width, line) | ||||||
| <		This limits the length of the text used from "line" to | <		This limits the length of the text used from "line" to | ||||||
| 		"columns" bytes. | 		"width" bytes. | ||||||
|  |  | ||||||
| 	        The conversion specifiers and their meanings are: | 	        The conversion specifiers and their meanings are: | ||||||
|                  |  | ||||||
| 		doxX    The Number argument is converted to signed decimal | 		doxX    The Number argument is converted to signed decimal | ||||||
| 			(d), unsigned octal (o), or unsigned hexadecimal (x | 			(d), unsigned octal (o), or unsigned hexadecimal (x | ||||||
| 			and X) notation.  The letters "abcdef" are used for | 			and X) notation.  The letters "abcdef" are used for | ||||||
| 			x conversions; the letters "ABCDEF" are used for X | 			x conversions; the letters "ABCDEF" are used for X | ||||||
| 			conversions.  The precision, if any, gives the minimum | 			conversions. | ||||||
| 			number of digits that must appear; if the converted | 			The precision, if any, gives the minimum number of | ||||||
| 			value requires fewer digits, it is padded on the left | 			digits that must appear; if the converted value | ||||||
| 			with zeros. | 			requires fewer digits, it is padded on the left with | ||||||
|                  | 			zeros. | ||||||
| 		c	The Number argument is converted to a byte, and | 			In no case does a non-existent or small field width | ||||||
| 			the resulting character is written. | 			cause truncation of a numeric field; if the result of | ||||||
|                  | 			a conversion is wider than the field width, the field | ||||||
| 		s	The String argument is used.  If a precision is | 			is expanded to contain the conversion result. | ||||||
| 			specified, no more bytes than the number specified are |  | ||||||
| 			written. | 		c	The Number argument is converted to a byte, and the | ||||||
|                  | 			resulting character is written. | ||||||
|  |  | ||||||
|  | 		s	The text of the String argument is used.  If a | ||||||
|  | 			precision is specified, no more bytes than the number | ||||||
|  | 			specified are used. | ||||||
|  |  | ||||||
| 		%	A '%' is written.  No argument is converted.  The | 		%	A '%' is written.  No argument is converted.  The | ||||||
| 			complete conversion specification is "%%". | 			complete conversion specification is "%%". | ||||||
|                  |  | ||||||
| 		Each argument can be Number or String and is converted |  | ||||||
| 		automatically to fit the conversion specifier. |  | ||||||
|  |  | ||||||
| 		In no case does a non-existent or small field width cause | 		Each argument can be Number or String and is converted | ||||||
| 		truncation of a numeric field; if the result of a conversion | 		automatically to fit the conversion specifier.  Any other | ||||||
| 		is wider than the field width, the field is expanded to | 		argument type results in an error message. | ||||||
| 		contain the conversion result. |  | ||||||
|  |  | ||||||
| 							*E766* *767* | 							*E766* *767* | ||||||
| 		The number of {exprN} arguments must exactly match the number | 		The number of {exprN} arguments must exactly match the number | ||||||
| 		of "%" items.  If there are not sufficient or too many | 		of "%" items.  If there are not sufficient or too many | ||||||
| 		arguments an error is given. | 		arguments an error is given.  Up to 18 arguments can be used. | ||||||
|  |  | ||||||
|  |  | ||||||
| prevnonblank({lnum})					*prevnonblank()* | prevnonblank({lnum})					*prevnonblank()* | ||||||
| @ -4242,7 +4249,7 @@ taglist({expr})							*taglist()* | |||||||
| 		information about these fields.  For C code the fields | 		information about these fields.  For C code the fields | ||||||
| 		"struct", "class" and "enum" may appear, they give the name of | 		"struct", "class" and "enum" may appear, they give the name of | ||||||
| 		the entity the tag is contained in. | 		the entity the tag is contained in. | ||||||
|   |  | ||||||
| 		The ex-command 'cmd' can be either an ex search pattern, a | 		The ex-command 'cmd' can be either an ex search pattern, a | ||||||
| 		line number or a line number followed by a byte number. | 		line number or a line number followed by a byte number. | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| *options.txt*	For Vim version 7.0aa.  Last change: 2005 Jul 29 | *options.txt*	For Vim version 7.0aa.  Last change: 2005 Jul 30 | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  VIM REFERENCE MANUAL	  by Bram Moolenaar | 		  VIM REFERENCE MANUAL	  by Bram Moolenaar | ||||||
| @ -1584,46 +1584,54 @@ A jump table for the options with a short description can be found at |Q_op|. | |||||||
| 'completefunc' 'cfu'	string	(default: empty) | 'completefunc' 'cfu'	string	(default: empty) | ||||||
| 			local to buffer | 			local to buffer | ||||||
| 			{not in Vi} | 			{not in Vi} | ||||||
| 	This option specifies a completion function to be used for CTRL-X | 			{not available when compiled without the +eval | ||||||
| 	CTRL-U.  The function will be invoked with four arguments: | 			or +insert_expand feature} | ||||||
| 	   a:line	the text of the current line | 	This option specifies a function to be used for CTRL-X CTRL-U | ||||||
| 	   a:base	the text with which matches should match | 	completion. |i_CTRL-X_CTRL-U| | ||||||
| 	   a:col        column in a:line where the cursor is, first column is |  | ||||||
| 	   		zero | 	The function will be invoked with three arguments: | ||||||
| 	   a:findstart  either 1 or 0 | 	   a:findstart  either 1 or 0 | ||||||
|  | 	   a:col        column in the cursor line where the completion ends, | ||||||
|  | 			first column is zero | ||||||
|  | 	   a:base	the text with which matches should match | ||||||
|  |  | ||||||
| 	When the a:findstart argument is 1, the function must return the | 	When the a:findstart argument is 1, the function must return the | ||||||
| 	column of where the completion starts.  It must be a number between | 	column of where the completion starts.  It must be a number between | ||||||
| 	zero and "a:col".  This involves looking at the characters in a:line | 	zero and "a:col".  This involves looking at the characters in the | ||||||
| 	before column a:col and include those characters that could be part of | 	cursor line before column a:col and include those characters that | ||||||
| 	the completed item. | 	could be part of the completed item.  The text between this column and | ||||||
| 	When the a:findstart argument is 0 the function must return a string | 	a:col will be replaced with the matches.  Return -1 if no completion | ||||||
| 	with the matching words, separated by newlines.  When there are no | 	can be done. | ||||||
| 	matches return an empty string. |  | ||||||
|  | 	When the a:findstart argument is 0 the function must return a List | ||||||
|  | 	with the matching words.  These matches should include the "a:base" | ||||||
|  | 	text.  When there are no matches return an empty List. | ||||||
|  |  | ||||||
|  | 	The function must not move the cursor! | ||||||
|  |  | ||||||
| 	An example that completes the names of the months: > | 	An example that completes the names of the months: > | ||||||
| 		fun! CompleteMonths(line, base, col, findstart) | 		fun! CompleteMonths(findstart, col, base) | ||||||
| 		  if a:findstart | 		  if a:findstart | ||||||
| 		    " locate start column of word | 		    " locate the start of the word | ||||||
|  | 		    let line = getline('.') | ||||||
| 		    let start = a:col | 		    let start = a:col | ||||||
| 		    while start > 0 && a:line[start - 1] =~ '\a' | 		    while start > 0 && line[start - 1] =~ '\a' | ||||||
| 		      let start = start - 1 | 		      let start -= 1 | ||||||
| 		    endwhile | 		    endwhile | ||||||
| 		    return start | 		    return start | ||||||
| 		  else | 		  else | ||||||
| 		    " find months matching with "a:base" | 		    " find months matching with "a:base" | ||||||
| 		    let res = "Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec" | 		    let res = [] | ||||||
| 		    if a:base != '' | 		    for m in split("Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec") | ||||||
| 		      let res = substitute(res, '\c\<\(\(' . a:base . '.\{-}\>\)\|.\{-}\>\)', '\2', 'g') | 		      if m =~ '^' . a:base | ||||||
| 		    endif | 			call add(res, m) | ||||||
| 		    let res = substitute(res, ' \+', "\n", 'g') | 		      endif | ||||||
|  | 		    endfor | ||||||
| 		    return res | 		    return res | ||||||
| 		  endif | 		  endif | ||||||
| 		endfun | 		endfun | ||||||
| 		set completefunc=CompleteMonths | 		set completefunc=CompleteMonths | ||||||
| <	Note that a substitute() function is used to reduce the list of | < | ||||||
| 	possible values and remove the ones that don't match the base.  The |  | ||||||
| 	part before the "\|" matches the base, the part after it is used |  | ||||||
| 	when there is no match.  The "\2" in the replacement is empty if the |  | ||||||
| 	part before the "\|" does not match. |  | ||||||
|  |  | ||||||
| 				*'confirm'* *'cf'* *'noconfirm'* *'nocf'* | 				*'confirm'* *'cf'* *'noconfirm'* *'nocf'* | ||||||
| 'confirm' 'cf'		boolean (default off) | 'confirm' 'cf'		boolean (default off) | ||||||
|  | |||||||
| @ -5162,7 +5162,6 @@ hebrew	hebrew.txt	/*hebrew* | |||||||
| hebrew.txt	hebrew.txt	/*hebrew.txt* | hebrew.txt	hebrew.txt	/*hebrew.txt* | ||||||
| help	various.txt	/*help* | help	various.txt	/*help* | ||||||
| help-context	help.txt	/*help-context* | help-context	help.txt	/*help-context* | ||||||
| help-tags	tags	1 |  | ||||||
| help-translated	various.txt	/*help-translated* | help-translated	various.txt	/*help-translated* | ||||||
| help-xterm-window	various.txt	/*help-xterm-window* | help-xterm-window	various.txt	/*help-xterm-window* | ||||||
| help.txt	help.txt	/*help.txt* | help.txt	help.txt	/*help.txt* | ||||||
| @ -6752,7 +6751,6 @@ usr_44.txt	usr_44.txt	/*usr_44.txt* | |||||||
| usr_45.txt	usr_45.txt	/*usr_45.txt* | usr_45.txt	usr_45.txt	/*usr_45.txt* | ||||||
| usr_90.txt	usr_90.txt	/*usr_90.txt* | usr_90.txt	usr_90.txt	/*usr_90.txt* | ||||||
| usr_toc.txt	usr_toc.txt	/*usr_toc.txt* | usr_toc.txt	usr_toc.txt	/*usr_toc.txt* | ||||||
| utf-16	options.txt	/*utf-16* |  | ||||||
| utf-8	mbyte.txt	/*utf-8* | utf-8	mbyte.txt	/*utf-8* | ||||||
| utf-8-char-arg	mbyte.txt	/*utf-8-char-arg* | utf-8-char-arg	mbyte.txt	/*utf-8-char-arg* | ||||||
| utf-8-in-xwindows	mbyte.txt	/*utf-8-in-xwindows* | utf-8-in-xwindows	mbyte.txt	/*utf-8-in-xwindows* | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ | |||||||
| " You can also use this as a start for your own set of menus. | " You can also use this as a start for your own set of menus. | ||||||
| " | " | ||||||
| " Maintainer:	Bram Moolenaar <Bram@vim.org> | " Maintainer:	Bram Moolenaar <Bram@vim.org> | ||||||
| " Last Change:	2005 Jul 22 | " Last Change:	2005 Jul 30 | ||||||
|  |  | ||||||
| " Note that ":an" (short for ":anoremenu") is often used to make a menu work | " Note that ":an" (short for ":anoremenu") is often used to make a menu work | ||||||
| " in all modes and avoid side effects from mappings defined by the user. | " in all modes and avoid side effects from mappings defined by the user. | ||||||
| @ -424,22 +424,30 @@ if has("spell") | |||||||
|   an 40.335.260 &Tools.&Spelling.Set\ language\ to\ "en_us"	:set spl=en_us spell<CR> |   an 40.335.260 &Tools.&Spelling.Set\ language\ to\ "en_us"	:set spl=en_us spell<CR> | ||||||
|   an <silent> 40.335.270 &Tools.&Spelling.&Find\ More\ Languages	:call <SID>SpellLang()<CR> |   an <silent> 40.335.270 &Tools.&Spelling.&Find\ More\ Languages	:call <SID>SpellLang()<CR> | ||||||
|  |  | ||||||
|  |   let s:undo_spellang = ['aun &Tools.&Spelling.&Find\ More\ Languages'] | ||||||
|   func! s:SpellLang() |   func! s:SpellLang() | ||||||
|     silent! aun &Tools.&Spelling.&Find\ More\ Languages |     for cmd in s:undo_spellang | ||||||
|  |       exe "silent! " . cmd | ||||||
|  |     endfor | ||||||
|  |     let s:undo_spellang = [] | ||||||
|  |  | ||||||
|     if &enc == "iso-8859-15" |     if &enc == "iso-8859-15" | ||||||
|       let enc = "latin1" |       let enc = "latin1" | ||||||
|     else |     else | ||||||
|       let enc = &enc |       let enc = &enc | ||||||
|     endif |     endif | ||||||
|  |  | ||||||
|     let found = 0 |     let found = 0 | ||||||
|     let s = globpath(&rtp, "spell/*." . enc . ".spl") |     let s = globpath(&rtp, "spell/*." . enc . ".spl") | ||||||
|     if s != "" |     if s != "" | ||||||
|       let n = 300 |       let n = 300 | ||||||
|       for f in split(s, "\n") |       for f in split(s, "\n") | ||||||
| 	let nm = substitute(f, '.*spell[/\\]\(..\)\.[^/\\]*\.spl', '\1', "") | 	let nm = substitute(f, '.*spell[/\\]\(..\)\.[^/\\]*\.spl', '\1', "") | ||||||
| 	if nm != "en" | 	if nm != "en" && nm !~ '/' | ||||||
| 	  exe 'an 40.335.' . n . ' &Tools.&Spelling.Set\ language\ to\ "' . nm . '" :set spl=' . nm . ' spell<CR>' |  | ||||||
| 	  let found += 1 | 	  let found += 1 | ||||||
|  | 	  let menuname = '&Tools.&Spelling.Set\ language\ to\ "' . nm . '"' | ||||||
|  | 	  exe 'an 40.335.' . n . ' ' . menuname . ' :set spl=' . nm . ' spell<CR>' | ||||||
|  | 	  let s:undo_spellang += ['aun ' . menuname] | ||||||
| 	endif | 	endif | ||||||
| 	let n += 10 | 	let n += 10 | ||||||
|       endfor |       endfor | ||||||
| @ -451,6 +459,10 @@ if has("spell") | |||||||
|     else |     else | ||||||
|       echomsg "Found " . found . " more spell files" |       echomsg "Found " . found . " more spell files" | ||||||
|     endif |     endif | ||||||
|  |     " Need to redo this when 'encoding' is changed. | ||||||
|  |     augroup spellmenu | ||||||
|  |     au! EncodingChanged * call <SID>SpellLang() | ||||||
|  |     augroup END | ||||||
|   endfun |   endfun | ||||||
|  |  | ||||||
| endif | endif | ||||||
|  | |||||||
							
								
								
									
										141
									
								
								src/edit.c
									
									
									
									
									
								
							
							
						
						
									
										141
									
								
								src/edit.c
									
									
									
									
									
								
							| @ -2550,85 +2550,56 @@ ins_compl_next_buf(buf, flag) | |||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef FEAT_COMPL_FUNC | #ifdef FEAT_COMPL_FUNC | ||||||
| static char_u *call_completefunc __ARGS((char_u *line, char_u *base, int col, int preproc)); | static int expand_by_function __ARGS((int col, char_u *base, char_u ***matches)); | ||||||
| static int expand_by_function __ARGS((linenr_T lnum, int col, char_u *base, char_u ***matches)); |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Execute user defined complete function 'completefunc'. |  * Execute user defined complete function 'completefunc', and get matches in | ||||||
|  * Return NULL if some error occurs. |  * "matches". | ||||||
|  */ |  * Return value is number of matches. | ||||||
|     static char_u * |  | ||||||
| call_completefunc(line, base, col, preproc) |  | ||||||
|     char_u	*line; |  | ||||||
|     char_u	*base; |  | ||||||
|     int		col; |  | ||||||
|     int		preproc; |  | ||||||
| { |  | ||||||
|     char_u	colbuf[30]; |  | ||||||
|     char_u	*args[4]; |  | ||||||
|  |  | ||||||
|     /* Return NULL when 'completefunc' isn't set. */ |  | ||||||
|     if (*curbuf->b_p_cfu == NUL) |  | ||||||
| 	return NULL; |  | ||||||
|  |  | ||||||
|     sprintf((char *)colbuf, "%d", col + (base ? (int)STRLEN(base) : 0)); |  | ||||||
|     args[0] = line; |  | ||||||
|     args[1] = base; |  | ||||||
|     args[2] = colbuf; |  | ||||||
|     args[3] = (char_u *)(preproc ? "1" : "0"); |  | ||||||
|     return (char_u *)call_func_retstr(curbuf->b_p_cfu, 4, args, FALSE); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Execute user defined complete function 'completefunc', and get candidates |  | ||||||
|  * are separeted with "\n".  Return value is number of candidates and array |  | ||||||
|  * of candidates as "matches". |  | ||||||
|  */ |  */ | ||||||
|     static int |     static int | ||||||
| expand_by_function(lnum, col, base, matches) | expand_by_function(col, base, matches) | ||||||
|     linenr_T	lnum; |  | ||||||
|     int		col; |     int		col; | ||||||
|     char_u	*base; |     char_u	*base; | ||||||
|     char_u	***matches; |     char_u	***matches; | ||||||
| { | { | ||||||
|     char_u	*matchstr = NULL; |     list_T      *matchlist; | ||||||
|     char_u	*line_copy = vim_strsave(ml_get(lnum)); |     char_u	colbuf[30]; | ||||||
|  |     char_u	*args[3]; | ||||||
|  |     listitem_T	*li; | ||||||
|  |     garray_T    ga; | ||||||
|  |     char_u	*p; | ||||||
|  |  | ||||||
|     /* Execute 'completefunc' and get the result */ |     if (*curbuf->b_p_cfu == NUL) | ||||||
|     matchstr = call_completefunc(line_copy, base, col, 0); | 	return 0; | ||||||
|     vim_free(line_copy); |  | ||||||
|  |  | ||||||
|     /* Parse returned string */ |     /* Call 'completefunc' to obtain the list of matches. */ | ||||||
|     if (matchstr != NULL) |     args[0] = (char_u *)"0"; | ||||||
|  |     sprintf((char *)colbuf, "%d", col + (int)STRLEN(base)); | ||||||
|  |     args[1] = colbuf; | ||||||
|  |     args[2] = base; | ||||||
|  |  | ||||||
|  |     matchlist = call_func_retlist(curbuf->b_p_cfu, 3, args, FALSE); | ||||||
|  |     if (matchlist == NULL) | ||||||
|  | 	return 0; | ||||||
|  |  | ||||||
|  |     /* Go through the List with matches and put them in an array. */ | ||||||
|  |     ga_init2(&ga, (int)sizeof(char_u *), 8); | ||||||
|  |     for (li = matchlist->lv_first; li != NULL; li = li->li_next) | ||||||
|     { |     { | ||||||
| 	garray_T    ga; | 	p = get_tv_string_chk(&li->li_tv); | ||||||
| 	char_u	    *p, *pnext; | 	if (p != NULL && *p != NUL) | ||||||
|  |  | ||||||
| 	ga_init2(&ga, (int)sizeof(char*), 8); |  | ||||||
| 	for (p = matchstr; *p != NUL; p = pnext) |  | ||||||
| 	{ | 	{ | ||||||
| 	    int len; | 	    if (ga_grow(&ga, 1) == FAIL) | ||||||
|  | 		break; | ||||||
| 	    pnext = vim_strchr(p, '\n'); | 	    ((char_u **)ga.ga_data)[ga.ga_len] = vim_strsave(p); | ||||||
| 	    if (pnext == NULL) | 	    ++ga.ga_len; | ||||||
| 		pnext = p + STRLEN(p); |  | ||||||
| 	    len = pnext - p; |  | ||||||
| 	    if (len > 0) |  | ||||||
| 	    { |  | ||||||
| 		if (ga_grow(&ga, 1) == FAIL) |  | ||||||
| 		    break; |  | ||||||
| 		((char_u **)ga.ga_data)[ga.ga_len] = vim_strnsave(p, len); |  | ||||||
| 		++ga.ga_len; |  | ||||||
| 	    } |  | ||||||
| 	    if (*pnext != NUL) |  | ||||||
| 		++pnext; |  | ||||||
| 	} | 	} | ||||||
| 	vim_free(matchstr); |  | ||||||
| 	if (ga.ga_len > 0) |  | ||||||
| 	    *matches = (char_u**)ga.ga_data; |  | ||||||
| 	return ga.ga_len; |  | ||||||
|     } |     } | ||||||
|     return 0; |  | ||||||
|  |     list_unref(matchlist); | ||||||
|  |     *matches = (char_u **)ga.ga_data; | ||||||
|  |     return ga.ga_len; | ||||||
| } | } | ||||||
| #endif /* FEAT_COMPL_FUNC */ | #endif /* FEAT_COMPL_FUNC */ | ||||||
|  |  | ||||||
| @ -2868,8 +2839,8 @@ ins_compl_get_exp(ini, dir) | |||||||
|  |  | ||||||
| #ifdef FEAT_COMPL_FUNC | #ifdef FEAT_COMPL_FUNC | ||||||
| 	case CTRL_X_FUNCTION: | 	case CTRL_X_FUNCTION: | ||||||
| 	    num_matches = expand_by_function(first_match_pos.lnum, | 	    num_matches = expand_by_function(first_match_pos.col, | ||||||
| 				 first_match_pos.col, compl_pattern, &matches); | 						     compl_pattern, &matches); | ||||||
| 	    if (num_matches > 0) | 	    if (num_matches > 0) | ||||||
| 		ins_compl_add_matches(num_matches, matches, dir); | 		ins_compl_add_matches(num_matches, matches, dir); | ||||||
| 	    break; | 	    break; | ||||||
| @ -3477,31 +3448,33 @@ ins_complete(c) | |||||||
| 	else if (ctrl_x_mode == CTRL_X_FUNCTION) | 	else if (ctrl_x_mode == CTRL_X_FUNCTION) | ||||||
| 	{ | 	{ | ||||||
| 	    /* | 	    /* | ||||||
| 	     * Call user defined function 'completefunc' with line content, | 	     * Call user defined function 'completefunc' with "a:findstart" is | ||||||
| 	     * cursor column number and preproc is 1.  Obtain length of text | 	     * 1 to obtain the length of text to use for completion. | ||||||
| 	     * to use for completion. |  | ||||||
| 	     */ | 	     */ | ||||||
| 	    char_u  *lenstr; | 	    char_u	colbuf[30]; | ||||||
| 	    int	    keeplen = 0; | 	    char_u	*args[3]; | ||||||
| 	    char_u  *line_copy = vim_strsave(line); | 	    int		col; | ||||||
|  |  | ||||||
| 	    /* Call 'completefunc' and get pattern length as a string */ | 	    /* Call 'completefunc' and get pattern length as a string */ | ||||||
| 	    lenstr = call_completefunc(line_copy, NULL, curs_col, 1); | 	    if (*curbuf->b_p_cfu == NUL) | ||||||
| 	    vim_free(line_copy); |  | ||||||
| 	    if (lenstr == NULL) |  | ||||||
| 		return FAIL; | 		return FAIL; | ||||||
| 	    keeplen = atoi((char *)lenstr); |  | ||||||
| 	    vim_free(lenstr); | 	    args[0] = (char_u *)"1"; | ||||||
| 	    if (keeplen < 0) | 	    sprintf((char *)colbuf, "%d", (int)curs_col); | ||||||
|  | 	    args[1] = colbuf; | ||||||
|  | 	    args[2] = NULL; | ||||||
|  |  | ||||||
|  | 	    col = call_func_retnr(curbuf->b_p_cfu, 3, args, FALSE); | ||||||
|  | 	    if (col < 0) | ||||||
| 		return FAIL; | 		return FAIL; | ||||||
| 	    if ((colnr_T)keeplen > curs_col) | 	    compl_col = col; | ||||||
| 		keeplen = curs_col; | 	    if ((colnr_T)compl_col > curs_col) | ||||||
|  | 		compl_col = curs_col; | ||||||
|  |  | ||||||
| 	    /* Setup variables for completion.  Need to obtain "line" again, | 	    /* Setup variables for completion.  Need to obtain "line" again, | ||||||
| 	     * it may have become invalid. */ | 	     * it may have become invalid. */ | ||||||
| 	    line = ml_get(curwin->w_cursor.lnum); | 	    line = ml_get(curwin->w_cursor.lnum); | ||||||
| 	    compl_col = keeplen; | 	    compl_length = curs_col - compl_col; | ||||||
| 	    compl_length = curs_col - keeplen; |  | ||||||
| 	    compl_pattern = vim_strnsave(line + compl_col, compl_length); | 	    compl_pattern = vim_strnsave(line + compl_col, compl_length); | ||||||
| 	    if (compl_pattern == NULL) | 	    if (compl_pattern == NULL) | ||||||
| 		return FAIL; | 		return FAIL; | ||||||
| @ -3510,7 +3483,7 @@ ins_complete(c) | |||||||
| 	else if (ctrl_x_mode == CTRL_X_OCCULT) | 	else if (ctrl_x_mode == CTRL_X_OCCULT) | ||||||
| 	{ | 	{ | ||||||
| 	    /* TODO: let language-specific function handle locating the text | 	    /* TODO: let language-specific function handle locating the text | ||||||
| 	     * to be completed or use 'coupler' option. */ | 	     * to be completed. */ | ||||||
| 	    while (--startcol >= 0 && vim_isIDc(line[startcol])) | 	    while (--startcol >= 0 && vim_isIDc(line[startcol])) | ||||||
| 		; | 		; | ||||||
| 	    compl_col += ++startcol; | 	    compl_col += ++startcol; | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ list_T *eval_spell_expr __ARGS((char_u *badword, char_u *expr)); | |||||||
| int get_spellword __ARGS((list_T *list, char_u **pp)); | int get_spellword __ARGS((list_T *list, char_u **pp)); | ||||||
| typval_T *eval_expr __ARGS((char_u *arg, char_u **nextcmd)); | typval_T *eval_expr __ARGS((char_u *arg, char_u **nextcmd)); | ||||||
| void *call_func_retstr __ARGS((char_u *func, int argc, char_u **argv, int safe)); | void *call_func_retstr __ARGS((char_u *func, int argc, char_u **argv, int safe)); | ||||||
|  | long call_func_retnr __ARGS((char_u *func, int argc, char_u **argv, int safe)); | ||||||
| void *call_func_retlist __ARGS((char_u *func, int argc, char_u **argv, int safe)); | void *call_func_retlist __ARGS((char_u *func, int argc, char_u **argv, int safe)); | ||||||
| void *save_funccal __ARGS((void)); | void *save_funccal __ARGS((void)); | ||||||
| void restore_funccal __ARGS((void *vfc)); | void restore_funccal __ARGS((void *vfc)); | ||||||
|  | |||||||
| @ -36,5 +36,5 @@ | |||||||
| #define VIM_VERSION_NODOT	"vim70aa" | #define VIM_VERSION_NODOT	"vim70aa" | ||||||
| #define VIM_VERSION_SHORT	"7.0aa" | #define VIM_VERSION_SHORT	"7.0aa" | ||||||
| #define VIM_VERSION_MEDIUM	"7.0aa ALPHA" | #define VIM_VERSION_MEDIUM	"7.0aa ALPHA" | ||||||
| #define VIM_VERSION_LONG	"VIM - Vi IMproved 7.0aa ALPHA (2005 Jul 29)" | #define VIM_VERSION_LONG	"VIM - Vi IMproved 7.0aa ALPHA (2005 Jul 30)" | ||||||
| #define VIM_VERSION_LONG_DATE	"VIM - Vi IMproved 7.0aa ALPHA (2005 Jul 29, compiled " | #define VIM_VERSION_LONG_DATE	"VIM - Vi IMproved 7.0aa ALPHA (2005 Jul 30, compiled " | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user