updated for version 7.0041
This commit is contained in:
		| @ -1,4 +1,4 @@ | |||||||
| *eval.txt*      For Vim version 7.0aa.  Last change: 2005 Jan 16 | *eval.txt*      For Vim version 7.0aa.  Last change: 2005 Jan 17 | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  VIM REFERENCE MANUAL    by Bram Moolenaar | 		  VIM REFERENCE MANUAL    by Bram Moolenaar | ||||||
| @ -35,7 +35,7 @@ done, the features in this document are not available.  See |+eval| and | |||||||
| 1. Variables						*variables* | 1. Variables						*variables* | ||||||
|  |  | ||||||
| 1.1 Variable types ~ | 1.1 Variable types ~ | ||||||
|  | 							*E712* | ||||||
| There are four types of variables: | There are four types of variables: | ||||||
|  |  | ||||||
| Number		A 32 bit signed number. | Number		A 32 bit signed number. | ||||||
| @ -80,7 +80,7 @@ Note that in the command > | |||||||
| "foo" is converted to 0, which means FALSE.  To test for a non-empty string, | "foo" is converted to 0, which means FALSE.  To test for a non-empty string, | ||||||
| use strlen(): > | use strlen(): > | ||||||
| 	:if strlen("foo") | 	:if strlen("foo") | ||||||
|  | <						*E728* *E729* *E730* *E731* | ||||||
| List and Funcref types are not automatically converted. | List and Funcref types are not automatically converted. | ||||||
|  |  | ||||||
| 								*E706* | 								*E706* | ||||||
| @ -93,23 +93,32 @@ equivalent though.  Consider this sequence of commands: > | |||||||
|  |  | ||||||
|  |  | ||||||
| 1.2 Function references ~ | 1.2 Function references ~ | ||||||
| 						*Funcref* *E695* *E703* | 					*Funcref* *E695* *E703* *E718* | ||||||
| A Funcref variable is obtained with the |function()| function.  It can be used | A Funcref variable is obtained with the |function()| function.  It can be used | ||||||
| in an expression to invoke the function it refers to by using it in the place | in an expression in the place of a function name, before the parenthesis | ||||||
| of a function name, before the parenthesis around the arguments.  Example: > | around the arguments, to invoke the function it refers to.  Example: > | ||||||
|  |  | ||||||
| 	:let Fn = function("MyFunc") | 	:let Fn = function("MyFunc") | ||||||
| 	:echo Fn() | 	:echo Fn() | ||||||
| < | <							*E704* *E705* *E707* | ||||||
| 							*E704* *E705* *E707* |  | ||||||
| A Funcref variable must start with a capital, "s:", "w:" or "b:".  You cannot | A Funcref variable must start with a capital, "s:", "w:" or "b:".  You cannot | ||||||
| have both a Funcref variable and a function with the same name. | have both a Funcref variable and a function with the same name. | ||||||
|  |  | ||||||
| Note that a Funcref cannot be used with the |:call| command, because its | A special case is defining a function and directly assigning its Funcref to a | ||||||
| argument is not an expression. | Dictionary entry.  Example: > | ||||||
|  | 	:function dict.init() dict | ||||||
|  | 	:   let self.val = 0 | ||||||
|  | 	:endfunction | ||||||
|  |  | ||||||
|  | The key of the Dictionary can start with a lower case letter.  The actual | ||||||
|  | function name is not used here.  Also see |numbered-function|. | ||||||
|  |  | ||||||
|  | A Funcref can also be used with the |:call| command: > | ||||||
|  | 	:call Fn() | ||||||
|  | 	:call dict.init() | ||||||
|  |  | ||||||
| The name of the referenced function can be obtained with |string()|. > | The name of the referenced function can be obtained with |string()|. > | ||||||
| 	:echo "The function is " . string(Myfunc) | 	:let func = string(Myfunc) | ||||||
|  |  | ||||||
| You can use |call()| to invoke a Funcref and use a list variable for the | You can use |call()| to invoke a Funcref and use a list variable for the | ||||||
| arguments: > | arguments: > | ||||||
| @ -117,7 +126,7 @@ arguments: > | |||||||
|  |  | ||||||
|  |  | ||||||
| 1.3 Lists ~ | 1.3 Lists ~ | ||||||
| 							*List* *E686* *E712* | 							*List* *E686* | ||||||
| A List is an ordered sequence of items.  An item can be of any type.  Items | A List is an ordered sequence of items.  An item can be of any type.  Items | ||||||
| can be accessed by their index number.  Items can be added and removed at any | can be accessed by their index number.  Items can be added and removed at any | ||||||
| position in the sequence. | position in the sequence. | ||||||
| @ -194,32 +203,32 @@ change "bb": > | |||||||
| 	:let bb = aa | 	:let bb = aa | ||||||
| 	:call add(aa, 4) | 	:call add(aa, 4) | ||||||
| 	:echo bb | 	:echo bb | ||||||
| 	[1, 2, 3, 4] | <	[1, 2, 3, 4] | ||||||
|  |  | ||||||
| Making a copy of a list is done with the |copy()| function.  Using [:] also | Making a copy of a list is done with the |copy()| function.  Using [:] also | ||||||
| works, as explained above.  This creates a shallow copy of the list: Changing | works, as explained above.  This creates a shallow copy of the list: Changing | ||||||
| a list item in the list will also change the item in the copied list: > | a list item in the list will also change the item in the copied list: > | ||||||
| 	:let aa = [[1, 'a'], 2, 3] | 	:let aa = [[1, 'a'], 2, 3] | ||||||
| 	:let bb = copy(aa) | 	:let bb = copy(aa) | ||||||
| 	:let aa = aa + [4] | 	:call add(aa, 4) | ||||||
| 	:let aa[0][1] = 'aaa' | 	:let aa[0][1] = 'aaa' | ||||||
| 	:echo aa | 	:echo aa | ||||||
| 	[[1, aaa], 2, 3, 4] | <	[[1, aaa], 2, 3, 4] > | ||||||
| 	:echo bb | 	:echo bb | ||||||
| 	[[1, aaa], 2, 3] | <	[[1, aaa], 2, 3] | ||||||
|  |  | ||||||
| To make a completely independent list use |deepcopy()|.  This also makes a | To make a completely independent list use |deepcopy()|.  This also makes a | ||||||
| copy of the values in the list, recursively. | copy of the values in the list, recursively.  Up to a hundred levels deep. | ||||||
|  |  | ||||||
| The operator "is" can be used to check if two variables refer to the same | The operator "is" can be used to check if two variables refer to the same | ||||||
| list.  "isnot" does the opposite.  In contrast "==" compares if two lists have | List.  "isnot" does the opposite.  In contrast "==" compares if two lists have | ||||||
| the same value. > | the same value. > | ||||||
| 	:let alist = [1, 2, 3] | 	:let alist = [1, 2, 3] | ||||||
| 	:let blist = [1, 2, 3] | 	:let blist = [1, 2, 3] | ||||||
| 	:echo alist is blist | 	:echo alist is blist | ||||||
| 	0 | <	0 > | ||||||
| 	:echo alist == blist | 	:echo alist == blist | ||||||
| 	1 | <	1 | ||||||
|  |  | ||||||
|  |  | ||||||
| List unpack ~ | List unpack ~ | ||||||
| @ -249,7 +258,7 @@ To change a specific item of a list use |:let| this way: > | |||||||
| 	:let listlist[0][3] = item | 	:let listlist[0][3] = item | ||||||
|  |  | ||||||
| To change part of a list you can specify the first and last item to be | To change part of a list you can specify the first and last item to be | ||||||
| modified.  The value must match the range of replaced items: > | modified.  The value must at least have the number of items in the range: > | ||||||
| 	:let list[3:5] = [3, 4, 5] | 	:let list[3:5] = [3, 4, 5] | ||||||
|  |  | ||||||
| Adding and removing items from a list is done with functions.  Here are a few | Adding and removing items from a list is done with functions.  Here are a few | ||||||
| @ -257,15 +266,15 @@ examples: > | |||||||
| 	:call insert(list, 'a')		" prepend item 'a' | 	:call insert(list, 'a')		" prepend item 'a' | ||||||
| 	:call insert(list, 'a', 3)	" insert item 'a' before list[3] | 	:call insert(list, 'a', 3)	" insert item 'a' before list[3] | ||||||
| 	:call add(list, "new")		" append String item | 	:call add(list, "new")		" append String item | ||||||
| 	:call add(list, [1, 2])		" append List as one new item | 	:call add(list, [1, 2])		" append a List as one new item | ||||||
| 	:call extend(list, [1, 2])	" extend the list with two more items | 	:call extend(list, [1, 2])	" extend the list with two more items | ||||||
| 	:let i = remove(list, 3)	" remove item 3 | 	:let i = remove(list, 3)	" remove item 3 | ||||||
| 	:unlet list[3]			" idem | 	:unlet list[3]			" idem | ||||||
| 	:let l = remove(list, 3, -1)	" remove items 3 to last item | 	:let l = remove(list, 3, -1)	" remove items 3 to last item | ||||||
| 	:unlet list[3 : ]		" idem | 	:unlet list[3 : ]		" idem | ||||||
| 	:call filter(list, 'v:val =~ "x"')  " remove items with an 'x' | 	:call filter(list, 'v:val !~ "x"')  " remove items with an 'x' | ||||||
|  |  | ||||||
| Changing the oder of items in a list: > | Changing the order of items in a list: > | ||||||
| 	:call sort(list)		" sort a list alphabetically | 	:call sort(list)		" sort a list alphabetically | ||||||
| 	:call reverse(list)		" reverse the order of items | 	:call reverse(list)		" reverse the order of items | ||||||
|  |  | ||||||
| @ -274,24 +283,24 @@ For loop ~ | |||||||
|  |  | ||||||
| The |:for| loop executes commands for each item in a list.  A variable is set | The |:for| loop executes commands for each item in a list.  A variable is set | ||||||
| to each item in the list in sequence.  Example: > | to each item in the list in sequence.  Example: > | ||||||
| 	:for i in mylist | 	:for item in mylist | ||||||
| 	:   call Doit(i) | 	:   call Doit(item) | ||||||
| 	:endfor | 	:endfor | ||||||
|  |  | ||||||
| This works like: > | This works like: > | ||||||
| 	:let index = 0 | 	:let index = 0 | ||||||
| 	:while index < len(mylist) | 	:while index < len(mylist) | ||||||
| 	:   let i = mylist[index] | 	:   let item = mylist[index] | ||||||
| 	:   :call Doit(i) | 	:   :call Doit(item) | ||||||
| 	:   let index = index + 1 | 	:   let index = index + 1 | ||||||
| 	:endwhile | 	:endwhile | ||||||
|  |  | ||||||
| Note that all items in the list should be of the same type, otherwise this | Note that all items in the list should be of the same type, otherwise this | ||||||
| results in an error |E706|.  To avoid this |:unlet| the variable at the end of | results in error |E706|.  To avoid this |:unlet| the variable at the end of | ||||||
| the loop. | the loop. | ||||||
|  |  | ||||||
| If all you want to do is modify each item in the list then the |map()| | If all you want to do is modify each item in the list then the |map()| | ||||||
| function might be a simpler method than a for loop. | function will be a simpler method than a for loop. | ||||||
|  |  | ||||||
| Just like the |:let| command, |:for| also accepts a list of variables.  This | Just like the |:let| command, |:for| also accepts a list of variables.  This | ||||||
| requires the argument to be a list of lists. > | requires the argument to be a list of lists. > | ||||||
| @ -302,7 +311,7 @@ requires the argument to be a list of lists. > | |||||||
| This works like a |:let| command is done for each list item.  Again, the types | This works like a |:let| command is done for each list item.  Again, the types | ||||||
| must remain the same to avoid an error. | must remain the same to avoid an error. | ||||||
|  |  | ||||||
| It is also possible to put remaining items in a list: > | It is also possible to put remaining items in a List variable: > | ||||||
| 	:for [i, j; rest] in listlist | 	:for [i, j; rest] in listlist | ||||||
| 	:   call Doit(i, j) | 	:   call Doit(i, j) | ||||||
| 	:   if !empty(rest) | 	:   if !empty(rest) | ||||||
| @ -312,7 +321,7 @@ It is also possible to put remaining items in a list: > | |||||||
|  |  | ||||||
|  |  | ||||||
| List functions ~ | List functions ~ | ||||||
|  | 						*E714* | ||||||
| Functions that are useful with a List: > | Functions that are useful with a List: > | ||||||
| 	:let r = call(funcname, list)	" call a function with an argument list | 	:let r = call(funcname, list)	" call a function with an argument list | ||||||
| 	:if empty(list)			" check if list is empty | 	:if empty(list)			" check if list is empty | ||||||
| @ -330,24 +339,26 @@ Functions that are useful with a List: > | |||||||
|  |  | ||||||
|  |  | ||||||
| 1.4 Dictionaries ~ | 1.4 Dictionaries ~ | ||||||
| 							*Dictionaries* | 						*Dictionaries* *Dictionary* | ||||||
| A Dictionary is an associative array: Each entry has a key and a value.  The | A Dictionary is an associative array: Each entry has a key and a value.  The | ||||||
| entry can be located with the key.  The entries are stored without ordering. | entry can be located with the key.  The entries are stored without a specific | ||||||
|  | ordering. | ||||||
|  |  | ||||||
|  |  | ||||||
| Dictionary creation ~ | Dictionary creation ~ | ||||||
|  | 						*E720* *E721* *E722* *E723* | ||||||
| A Dictionary is created with a comma separated list of entries in curly | A Dictionary is created with a comma separated list of entries in curly | ||||||
| braces.  Each entry has a key and a value, separated by a colon.  Examples: > | braces.  Each entry has a key and a value, separated by a colon.  Each key can | ||||||
|  | only appear once.  Examples: > | ||||||
| 	:let mydict = {1: 'one', 2: 'two', 3: 'three'} | 	:let mydict = {1: 'one', 2: 'two', 3: 'three'} | ||||||
| 	:let emptydict = {} | 	:let emptydict = {} | ||||||
|  | <							*E713* *E716* *E717* | ||||||
| A key is always a String.  You can use a Number, it will be converted to a | A key is always a String.  You can use a Number, it will be converted to a | ||||||
| String automatically.  Thus the String '4' and the number 4 will find the same | String automatically.  Thus the String '4' and the number 4 will find the same | ||||||
| entry.  Note that the String '04' and the Number 04 are different, since 04 | entry.  Note that the String '04' and the Number 04 are different, since the | ||||||
| will be converted to the String '4'. | Number will be converted to the String '4'. | ||||||
|  |  | ||||||
| A value can be any expression.  Using a Dictionary for an entry creates a | A value can be any expression.  Using a Dictionary for a value creates a | ||||||
| nested Dictionary: > | nested Dictionary: > | ||||||
| 	:let nestdict = {1: {11: 'a', 12: 'b'}, 2: {21: 'c'}} | 	:let nestdict = {1: {11: 'a', 12: 'b'}, 2: {21: 'c'}} | ||||||
|  |  | ||||||
| @ -360,7 +371,7 @@ The normal way to access an entry is by putting the key in square brackets: > | |||||||
| 	:let val = mydict["one"] | 	:let val = mydict["one"] | ||||||
| 	:let mydict["four"] = 4 | 	:let mydict["four"] = 4 | ||||||
|  |  | ||||||
| You can add new entries to an existing Dictionary this way. | You can add new entries to an existing Dictionary this way, unlike Lists. | ||||||
|  |  | ||||||
| For keys that consist entirely of letters, digits and underscore the following | For keys that consist entirely of letters, digits and underscore the following | ||||||
| form can be used |expr-entry|: > | form can be used |expr-entry|: > | ||||||
| @ -369,7 +380,7 @@ form can be used |expr-entry|: > | |||||||
|  |  | ||||||
| Since an entry can be any type, also a List and a Dictionary, the indexing and | Since an entry can be any type, also a List and a Dictionary, the indexing and | ||||||
| key lookup can be repeated: > | key lookup can be repeated: > | ||||||
| 	:let dict.key[idx].key = 0 | 	:echo dict.key[idx].key | ||||||
|  |  | ||||||
|  |  | ||||||
| Dictionary to List conversion ~ | Dictionary to List conversion ~ | ||||||
| @ -391,7 +402,7 @@ To loop over the values use the |values()| function:  > | |||||||
| 	:endfor | 	:endfor | ||||||
|  |  | ||||||
| If you want both the key and the value use the |items()| function.  It returns | If you want both the key and the value use the |items()| function.  It returns | ||||||
| a List of Lists with two items: the key and the value: > | a List in which each item is a  List with two items, the key and the value: > | ||||||
| 	:for entry in items(mydict) | 	:for entry in items(mydict) | ||||||
| 	:   echo entry[0] . ': ' . entry[1] | 	:   echo entry[0] . ': ' . entry[1] | ||||||
| 	:endfor | 	:endfor | ||||||
| @ -425,39 +436,52 @@ Three ways to remove the entry with key "aaa" from dict: > | |||||||
| 	:unlet dict['aaa'] | 	:unlet dict['aaa'] | ||||||
|  |  | ||||||
| Merging a Dictionary with another is done with |extend()|: > | Merging a Dictionary with another is done with |extend()|: > | ||||||
| 	:call extend(adict, bdict)	" extend adict with entries from bdict | 	:call extend(adict, bdict) | ||||||
|  | This extends adict with all entries from bdict.  Duplicate keys cause entries | ||||||
|  | in adict to be overwritten.  An optional third argument can change this. | ||||||
|  |  | ||||||
| Weeding out entries from a Dictionary can be done with |filter()|: > | Weeding out entries from a Dictionary can be done with |filter()|: > | ||||||
| 	:call filter(dict 'v:val =~ "x"')  " remove entries with value 'x' | 	:call filter(dict 'v:val =~ "x"')  | ||||||
|  | This removes all entries from "dict" with a value not matching 'x'. | ||||||
|  |  | ||||||
|  |  | ||||||
| Dictionary function ~ | Dictionary function ~ | ||||||
| 						*Dictionary-function* *self* | 					*Dictionary-function* *self* *E725* | ||||||
| When a function is defined with the "dict" attribute it can be used in a | When a function is defined with the "dict" attribute it can be used in a | ||||||
| special way with a dictionary.  Example: > | special way with a dictionary.  Example: > | ||||||
| 	:function Mylen() dict | 	:function Mylen() dict | ||||||
| 	:   return len(self) - 4 | 	:   return len(self.data) | ||||||
| 	:endfunction | 	:endfunction | ||||||
| 	:let dict.len = function(Mylen) | 	:let mydict = {'data': [0, 1, 2, 3], 'len': function("Mylen")} | ||||||
| 	:let l = dict.len() | 	:echo mydict.len() | ||||||
|  |  | ||||||
| This is like a method in object oriented programming.  The entry in the | This is like a method in object oriented programming.  The entry in the | ||||||
| Dictionary is a |Funcref|.  The local variable "self" refers to the dictionary | Dictionary is a |Funcref|.  The local variable "self" refers to the dictionary | ||||||
| the function was invoked from. | the function was invoked from. | ||||||
|  |  | ||||||
|  | It is also possible to add a function without the "dict" attribute as a | ||||||
|  | Funcref to a Dictionary, but the "self" variable is not available then. | ||||||
|  |  | ||||||
|  | 						*numbered-function* | ||||||
| To avoid the extra name for the function it can be defined and directly | To avoid the extra name for the function it can be defined and directly | ||||||
| assigned to a Dictionary in this way: > | assigned to a Dictionary in this way: > | ||||||
| 	:function dict.len() dict | 	:let mydict = {'data': [0, 1, 2, 3]} | ||||||
| 	:   return len(self) - 4 | 	:function mydict.len() dict | ||||||
|  | 	:   return len(self.data) | ||||||
| 	:endfunction | 	:endfunction | ||||||
|  | 	:echo mydict.len() | ||||||
|  |  | ||||||
| It is also possible to add a Funcref to a Dictionary without the "dict" | The function will then get a number and the value of dict.len is a |Funcref| | ||||||
| attribute, but the "self" variable is not available then. | that references this function.  The function can only be used through a | ||||||
|  | |Funcref|.  It will automatically be deleted when there is no |Funcref| | ||||||
|  | remaining that refers to it. | ||||||
|  |  | ||||||
|  | It is not necessary to use the "dict" attribute for a numbered function. | ||||||
|  |  | ||||||
|  |  | ||||||
| Functions for Dictionaries ~ | Functions for Dictionaries ~ | ||||||
|  | 							*E715* | ||||||
| Functions that are useful with a Dictionary: > | Functions that can be used with a Dictionary: > | ||||||
| 	:if has_key(dict, 'foo')	" TRUE if dict has entry with key "foo" | 	:if has_key(dict, 'foo')	" TRUE if dict has entry with key "foo" | ||||||
| 	:if empty(dict)			" TRUE if dict is empty | 	:if empty(dict)			" TRUE if dict is empty | ||||||
| 	:let l = len(dict)		" number of items in dict | 	:let l = len(dict)		" number of items in dict | ||||||
| @ -656,6 +680,11 @@ A List can only be compared with a List and only "equal", "not equal" and "is" | |||||||
| can be used.  This compares the values of the list, recursively.  Ignoring | can be used.  This compares the values of the list, recursively.  Ignoring | ||||||
| case means case is ignored when comparing item values. | case means case is ignored when comparing item values. | ||||||
|  |  | ||||||
|  | 							*E735* *E736* | ||||||
|  | A Dictionary can only be compared with a Dictionary and only "equal", "not | ||||||
|  | equal" and "is" can be used.  This compares the key/values of the Dictionary, | ||||||
|  | recursively.  Ignoring case means case is ignored when comparing item values. | ||||||
|  |  | ||||||
| 							*E693* *E694* | 							*E693* *E694* | ||||||
| A Funcref can only be compared with a Funcref and only "equal" and "not equal" | A Funcref can only be compared with a Funcref and only "equal" and "not equal" | ||||||
| can be used.  Case is never ignored. | can be used.  Case is never ignored. | ||||||
| @ -1856,6 +1885,10 @@ deepcopy({expr})					*deepcopy()* *E698* | |||||||
| 		copy, and vise versa.  When an item is a List, a copy for it | 		copy, and vise versa.  When an item is a List, a copy for it | ||||||
| 		is made, recursively.  Thus changing an item in the copy does | 		is made, recursively.  Thus changing an item in the copy does | ||||||
| 		not change the contents of the original List. | 		not change the contents of the original List. | ||||||
|  | 								*E724* | ||||||
|  | 		Nesting is possible up to 100 levels.  When there is an item | ||||||
|  | 		that refers back to a higher level making a deep copy will | ||||||
|  | 		fail. | ||||||
| 		Also see |copy()|. | 		Also see |copy()|. | ||||||
|  |  | ||||||
| delete({fname})							*delete()* | delete({fname})							*delete()* | ||||||
| @ -3052,6 +3085,7 @@ prevnonblank({lnum})					*prevnonblank()* | |||||||
| 		above it, zero is returned. | 		above it, zero is returned. | ||||||
| 		Also see |nextnonblank()|. | 		Also see |nextnonblank()|. | ||||||
|  |  | ||||||
|  | 							*E726* *E727* | ||||||
| range({expr} [, {max} [, {stride}]])				*range()* | range({expr} [, {max} [, {stride}]])				*range()* | ||||||
| 		Returns a List with Numbers: | 		Returns a List with Numbers: | ||||||
| 		- If only {expr} is specified: [0, 1, ..., {expr} - 1] | 		- If only {expr} is specified: [0, 1, ..., {expr} - 1] | ||||||
| @ -4013,11 +4047,24 @@ instead of "s:" when the mapping is expanded outside of the script. | |||||||
| :fu[nction]		List all functions and their arguments. | :fu[nction]		List all functions and their arguments. | ||||||
|  |  | ||||||
| :fu[nction] {name}	List function {name}. | :fu[nction] {name}	List function {name}. | ||||||
| 							*E124* *E125* | 			{name} can also be a Dictionary entry that is a | ||||||
|  | 			Funcref: > | ||||||
|  | 				:function dict.init | ||||||
|  | <							*E124* *E125* | ||||||
| :fu[nction][!] {name}([arguments]) [range] [abort] [dict] | :fu[nction][!] {name}([arguments]) [range] [abort] [dict] | ||||||
| 			Define a new function by the name {name}.  The name | 			Define a new function by the name {name}.  The name | ||||||
| 			must be made of alphanumeric characters and '_', and | 			must be made of alphanumeric characters and '_', and | ||||||
| 			must start with a capital or "s:" (see above). | 			must start with a capital or "s:" (see above). | ||||||
|  |  | ||||||
|  | 			{name} can also be a Dictionary entry that is a | ||||||
|  | 			Funcref: > | ||||||
|  | 				:function dict.init(arg) | ||||||
|  | <			"dict" must be an existing dictionary.  The entry | ||||||
|  | 			"init" is added if it didn't exist yet.  Otherwise [!] | ||||||
|  | 			is required to overwrite an existing function.  The | ||||||
|  | 			result is a |Funcref| to a numbered function.  The | ||||||
|  | 			function can only be used with a |Funcref| and will be | ||||||
|  | 			deleted if there are no more references to it. | ||||||
| 						*function-argument* *a:var* | 						*function-argument* *a:var* | ||||||
| 			An argument can be defined by giving its name.  In the | 			An argument can be defined by giving its name.  In the | ||||||
| 			function this can then be used as "a:name" ("a:" for | 			function this can then be used as "a:name" ("a:" for | ||||||
| @ -4049,10 +4096,12 @@ instead of "s:" when the mapping is expanded outside of the script. | |||||||
| 			is excluded, ":{range}call" will call the function for | 			is excluded, ":{range}call" will call the function for | ||||||
| 			each line in the range, with the cursor on the start | 			each line in the range, with the cursor on the start | ||||||
| 			of each line.  See |function-range-example|. | 			of each line.  See |function-range-example|. | ||||||
|  |  | ||||||
| 			When the [abort] argument is added, the function will | 			When the [abort] argument is added, the function will | ||||||
| 			abort as soon as an error is detected. | 			abort as soon as an error is detected. | ||||||
| 			The last used search pattern and the redo command "." | 			The last used search pattern and the redo command "." | ||||||
| 			will not be changed by the function. | 			will not be changed by the function. | ||||||
|  |  | ||||||
| 			When the [dict] argument is added, the function must | 			When the [dict] argument is added, the function must | ||||||
| 			be invoked through an entry in a Dictionary.  The | 			be invoked through an entry in a Dictionary.  The | ||||||
| 			local variable "self" will then be set to the | 			local variable "self" will then be set to the | ||||||
| @ -4064,7 +4113,12 @@ instead of "s:" when the mapping is expanded outside of the script. | |||||||
|  |  | ||||||
| 					*:delf* *:delfunction* *E130* *E131* | 					*:delf* *:delfunction* *E130* *E131* | ||||||
| :delf[unction] {name}	Delete function {name}. | :delf[unction] {name}	Delete function {name}. | ||||||
|  | 			{name} can also be a Dictionary entry that is a | ||||||
|  | 			Funcref: > | ||||||
|  | 				:delfunc dict.init | ||||||
|  | <			This will remove the "init" entry from "dict".  The | ||||||
|  | 			function is deleted if there are no more references to | ||||||
|  | 			it. | ||||||
| 							*:retu* *:return* *E133* | 							*:retu* *:return* *E133* | ||||||
| :retu[rn] [expr]	Return from a function.  When "[expr]" is given, it is | :retu[rn] [expr]	Return from a function.  When "[expr]" is given, it is | ||||||
| 			evaluated and returned as the result of the function. | 			evaluated and returned as the result of the function. | ||||||
| @ -4238,7 +4292,8 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| 			the index can be repeated. | 			the index can be repeated. | ||||||
| 			This cannot be used to add an item to a list. | 			This cannot be used to add an item to a list. | ||||||
|  |  | ||||||
| :let {var-name}[{idx1}:{idx2}] = {expr1}	*E708* *E709* *E710* *E711* | 							*E711* *E719* | ||||||
|  | :let {var-name}[{idx1}:{idx2}] = {expr1}		*E708* *E709* *E710* | ||||||
| 			Set a sequence of items in a List to the result of the | 			Set a sequence of items in a List to the result of the | ||||||
| 			expression {expr1}, which must be a list with the | 			expression {expr1}, which must be a list with the | ||||||
| 			correct number of items. | 			correct number of items. | ||||||
| @ -4247,9 +4302,20 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| 			When the selected range of items is partly past the | 			When the selected range of items is partly past the | ||||||
| 			end of the list, items will be added. | 			end of the list, items will be added. | ||||||
|  |  | ||||||
|  | :let {var} += {expr1}	Like ":let {var} = {var} + {expr1}". | ||||||
|  | :let {var} -= {expr1}	Like ":let {var} = {var} - {expr1}". | ||||||
|  | :let {var} .= {expr1}	Like ":let {var} = {var} . {expr1}". | ||||||
|  | 			These fail if {var} was not set yet and when the type | ||||||
|  | 			of {var} and {expr1} don't fit the operator. | ||||||
|  |  | ||||||
|  |  | ||||||
| :let ${env-name} = {expr1}			*:let-environment* *:let-$* | :let ${env-name} = {expr1}			*:let-environment* *:let-$* | ||||||
| 			Set environment variable {env-name} to the result of | 			Set environment variable {env-name} to the result of | ||||||
| 			the expression {expr1}.  The type is always String. | 			the expression {expr1}.  The type is always String. | ||||||
|  | :let ${env-name} .= {expr1} | ||||||
|  | 			Append {expr1} to the environment variable {env-name}. | ||||||
|  | 			If the environment variable didn't exist yet this | ||||||
|  | 			works like "=". | ||||||
|  |  | ||||||
| :let @{reg-name} = {expr1}			*:let-register* *:let-@* | :let @{reg-name} = {expr1}			*:let-register* *:let-@* | ||||||
| 			Write the result of the expression {expr1} in register | 			Write the result of the expression {expr1} in register | ||||||
| @ -4265,6 +4331,10 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| <			This is different from searching for an empty string, | <			This is different from searching for an empty string, | ||||||
| 			that would match everywhere. | 			that would match everywhere. | ||||||
|  |  | ||||||
|  | :let @{reg-name} .= {expr1} | ||||||
|  | 			Append {expr1} to register {reg-name}.  If the | ||||||
|  | 			register was empty it's like setting it to {expr1}. | ||||||
|  |  | ||||||
| :let &{option-name} = {expr1}			*:let-option* *:let-star* | :let &{option-name} = {expr1}			*:let-option* *:let-star* | ||||||
| 			Set option {option-name} to the result of the | 			Set option {option-name} to the result of the | ||||||
| 			expression {expr1}.  A String or Number value is | 			expression {expr1}.  A String or Number value is | ||||||
| @ -4275,11 +4345,26 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| 			Example: > | 			Example: > | ||||||
| 				:let &path = &path . ',/usr/local/include' | 				:let &path = &path . ',/usr/local/include' | ||||||
|  |  | ||||||
|  | :let &{option-name} .= {expr1} | ||||||
|  | 			For a string option: Append {expr1} to the value. | ||||||
|  | 			Does not insert a comma like |:set+=|. | ||||||
|  |  | ||||||
|  | :let &{option-name} += {expr1} | ||||||
|  | :let &{option-name} -= {expr1} | ||||||
|  | 			For a number or boolean option: Add or subtract | ||||||
|  | 			{expr1}. | ||||||
|  |  | ||||||
| :let &l:{option-name} = {expr1} | :let &l:{option-name} = {expr1} | ||||||
|  | :let &l:{option-name} .= {expr1} | ||||||
|  | :let &l:{option-name} += {expr1} | ||||||
|  | :let &l:{option-name} -= {expr1} | ||||||
| 			Like above, but only set the local value of an option | 			Like above, but only set the local value of an option | ||||||
| 			(if there is one).  Works like |:setlocal|. | 			(if there is one).  Works like |:setlocal|. | ||||||
|  |  | ||||||
| :let &g:{option-name} = {expr1} | :let &g:{option-name} = {expr1} | ||||||
|  | :let &g:{option-name} .= {expr1} | ||||||
|  | :let &g:{option-name} += {expr1} | ||||||
|  | :let &g:{option-name} -= {expr1} | ||||||
| 			Like above, but only set the global value of an option | 			Like above, but only set the global value of an option | ||||||
| 			(if there is one).  Works like |:setglobal|. | 			(if there is one).  Works like |:setglobal|. | ||||||
|  |  | ||||||
| @ -4293,17 +4378,36 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| 			command as mentioned above. | 			command as mentioned above. | ||||||
| 			Example: > | 			Example: > | ||||||
| 				:let [s, item] = GetItem(s) | 				:let [s, item] = GetItem(s) | ||||||
|  | <			Detail: {expr1} is evaluated first, then the | ||||||
|  | 			assignments are done in sequence.  This matters if | ||||||
|  | 			{name2} depends on {name1}.  Example: > | ||||||
|  | 				:let x = [0, 1] | ||||||
|  | 				:let i = 0 | ||||||
|  | 				:let [i, x[i]] = [1, 2] | ||||||
|  | 				:echo x | ||||||
|  | <			The result is [0, 2]. | ||||||
|  |  | ||||||
|  | :let [{name1}, {name2}, ...] .= {expr1} | ||||||
|  | :let [{name1}, {name2}, ...] += {expr1} | ||||||
|  | :let [{name1}, {name2}, ...] -= {expr1} | ||||||
|  | 			Like above, but append/add/subtract the value for each | ||||||
|  | 			List item. | ||||||
|  |  | ||||||
| :let [{name}, ..., ; {lastname}] = {expr1} | :let [{name}, ..., ; {lastname}] = {expr1} | ||||||
| 			Like above, but the List may have more items than | 			Like |let-unpack| above, but the List may have more | ||||||
| 			there are names.  A list of the remaining items is | 			items than there are names.  A list of the remaining | ||||||
| 			assigned to {lastname}.  If there are no remaining | 			items is assigned to {lastname}.  If there are no | ||||||
| 			items {lastname} is set to an empty list. | 			remaining items {lastname} is set to an empty list. | ||||||
| 			Example: > | 			Example: > | ||||||
| 				:let [a, b; rest] = ["aval", "bval", 3, 4] | 				:let [a, b; rest] = ["aval", "bval", 3, 4] | ||||||
| < | < | ||||||
|  | :let [{name}, ..., ; {lastname}] .= {expr1} | ||||||
|  | :let [{name}, ..., ; {lastname}] += {expr1} | ||||||
|  | :let [{name}, ..., ; {lastname}] -= {expr1} | ||||||
|  | 			Like above, but append/add/subtract the value for each | ||||||
|  | 			List item. | ||||||
| 							*E106* | 							*E106* | ||||||
| :let {var-name}	..	List the value of variable {var-name}.  Several | :let {var-name}	..	List the value of variable {var-name}.  Multiple | ||||||
| 			variable names may be given. | 			variable names may be given. | ||||||
|  |  | ||||||
| :let			List the values of all variables.  The type of the | :let			List the values of all variables.  The type of the | ||||||
| @ -4363,7 +4467,7 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| 			is no extra ":endif". | 			is no extra ":endif". | ||||||
|  |  | ||||||
| :wh[ile] {expr1}			*:while* *:endwhile* *:wh* *:endw* | :wh[ile] {expr1}			*:while* *:endwhile* *:wh* *:endw* | ||||||
| 							*E170* *E585* *E588* | 						*E170* *E585* *E588* *E733* | ||||||
| :endw[hile]		Repeat the commands between ":while" and ":endwhile", | :endw[hile]		Repeat the commands between ":while" and ":endwhile", | ||||||
| 			as long as {expr1} evaluates to non-zero. | 			as long as {expr1} evaluates to non-zero. | ||||||
| 			When an error is detected from a command inside the | 			When an error is detected from a command inside the | ||||||
| @ -4378,7 +4482,7 @@ This would call the function "my_func_whizz(parameter)". | |||||||
| 			NOTE: The ":append" and ":insert" commands don't work | 			NOTE: The ":append" and ":insert" commands don't work | ||||||
| 			properly inside a ":while" and ":for" loop. | 			properly inside a ":while" and ":for" loop. | ||||||
|  |  | ||||||
| :for {var} in {list}					*:for* *E690* | :for {var} in {list}					*:for* *E690* *E732* | ||||||
| :endfo[r]						*:endfo* *:endfor* | :endfo[r]						*:endfo* *:endfor* | ||||||
| 			Repeat the commands between ":for" and ":endfor" for | 			Repeat the commands between ":for" and ":endfor" for | ||||||
| 			each item in {list}.  variable {var} is set to the | 			each item in {list}.  variable {var} is set to the | ||||||
|  | |||||||
| @ -1172,11 +1172,16 @@ ex_endwhile(eap) | |||||||
| 	fl =  cstack->cs_flags[cstack->cs_idx]; | 	fl =  cstack->cs_flags[cstack->cs_idx]; | ||||||
| 	if (!(fl & csf)) | 	if (!(fl & csf)) | ||||||
| 	{ | 	{ | ||||||
|  | 	    /* If we are in a ":while" or ":for" but used the wrong endloop | ||||||
|  | 	     * command, do not rewind to the next enclosing ":for"/":while". */ | ||||||
| 	    if (fl & CSF_WHILE) | 	    if (fl & CSF_WHILE) | ||||||
| 		eap->errmsg = (char_u *)_("E999: Using :endfor with :while"); | 		eap->errmsg = (char_u *)_("E732: Using :endfor with :while"); | ||||||
| 	    else if (fl & CSF_FOR) | 	    else if (fl & CSF_FOR) | ||||||
| 		eap->errmsg = (char_u *)_("E999: Using :endwhile with :for"); | 		eap->errmsg = (char_u *)_("E733: Using :endwhile with :for"); | ||||||
| 	    else if (!(fl & CSF_TRY)) | 	} | ||||||
|  | 	if (!(fl & (CSF_WHILE | CSF_FOR))) | ||||||
|  | 	{ | ||||||
|  | 	    if (!(fl & CSF_TRY)) | ||||||
| 		eap->errmsg = e_endif; | 		eap->errmsg = e_endif; | ||||||
| 	    else if (fl & CSF_FINALLY) | 	    else if (fl & CSF_FINALLY) | ||||||
| 		eap->errmsg = e_endtry; | 		eap->errmsg = e_endtry; | ||||||
|  | |||||||
| @ -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 (2004 Jan 16)" | #define VIM_VERSION_LONG	"VIM - Vi IMproved 7.0aa ALPHA (2004 Jan 17)" | ||||||
| #define VIM_VERSION_LONG_DATE	"VIM - Vi IMproved 7.0aa ALPHA (2004 Jan 16, compiled " | #define VIM_VERSION_LONG_DATE	"VIM - Vi IMproved 7.0aa ALPHA (2004 Jan 17, compiled " | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user