blob: d4fbb33ea8010a4bda8f35ac8c7803b729ac25f8 [file] [log] [blame]
Bram Moolenaar488c6512005-08-11 20:09:58 +00001*version7.txt* For Vim version 7.0aa. Last change: 2005 Aug 11
Bram Moolenaar071d4272004-06-13 20:20:40 +00002
3
4 VIM REFERENCE MANUAL by Bram Moolenaar
5
6
7Welcome to Vim 7! A large number of features has been added. This file
8mentions all the new items, changes to existing features and bug fixes
Bram Moolenaarb2956cd2005-01-27 14:42:53 +00009compared to Vim 6.x. Use this command to see the version you are using: >
10 :version
Bram Moolenaar071d4272004-06-13 20:20:40 +000011
12See |vi_diff.txt| for an overview of differences between Vi and Vim 7.0.
13See |version4.txt| for differences between Vim 3.x and Vim 4.x.
14See |version5.txt| for differences between Vim 4.x and Vim 5.x.
15See |version6.txt| for differences between Vim 5.x and Vim 6.x.
16
17INCOMPATIBLE CHANGES |incompatible-7|
18
19NEW FEATURES |new-7|
20
Bram Moolenaarbac234e2005-01-17 22:21:07 +000021Vim script enhancements |new-vim-script|
Bram Moolenaar60c78922005-03-20 22:40:14 +000022Spell checking |new-spell|
Bram Moolenaar325b7a22004-07-05 15:58:32 +000023KDE support |new-KDE|
Bram Moolenaarfb670262005-06-05 22:06:27 +000024MzScheme interface |new-MzScheme|
25Printing multi-byte text |new-print-multi-byte|
Bram Moolenaar293ee4d2004-12-09 21:34:53 +000026Translated manual pages |new-manpage-trans|
Bram Moolenaar8fc061c2004-12-29 21:03:02 +000027Internal grep |new-vimgrep|
Bram Moolenaar87e25fd2005-07-27 21:13:01 +000028Scroll back in messages |new-scroll-back|
Bram Moolenaar4399ef42005-02-12 14:29:27 +000029POSIX compatibility |new-posix|
Bram Moolenaare2ac10d2005-03-07 23:26:06 +000030Debugger support |new-debug-support|
Bram Moolenaar0be6e642005-08-04 21:32:22 +000031Remote file explorer |new-netrw-explore|
Bram Moolenaar071d4272004-06-13 20:20:40 +000032Various new items |new-items-7|
33
34IMPROVEMENTS |improvements-7|
35
36COMPILE TIME CHANGES |compile-changes-7|
37
38BUG FIXES |bug-fixes-7|
39
40==============================================================================
41INCOMPATIBLE CHANGES *incompatible-7*
42
43These changes are incompatible with previous releases. Check this list if you
Bram Moolenaarb2956cd2005-01-27 14:42:53 +000044run into a problem when upgrading from Vim 6.x to 7.0.
45
46A ":write file" command no longer resets the 'modified' flag of the buffer,
47unless the '+' flag is in 'cpoptions' |cpo-+|. This was illogical, since the
48buffer is still modified compared to the original file. And when undoing
49all changes the file would actually be marked modified. It does mean that
50":quit" fails now.
Bram Moolenaar071d4272004-06-13 20:20:40 +000051
Bram Moolenaarf4b8e572004-06-24 15:53:16 +000052":helpgrep" now uses a help window to display a match.
53
Bram Moolenaar1cd871b2004-12-19 22:46:22 +000054In an argument list double quotes could be used to include spaces in a file
55name. This caused a difference between ":edit" and ":next" for escaping
56double quotes and it is incompatible with some versions of Vi.
57 Command Vim 6.x file name Vim 7.x file name ~
58 :edit foo\"888 'foo"888' 'foo"888'
59 :next foo\"888 'foo888' 'foo"888'
60 :next a\"b c\"d 'ab cd' 'a"b' and 'c"d'
61
Bram Moolenaar8c711452005-01-14 21:53:12 +000062In a |literal-string| a single quote can be doubled to get one.
63":echo 'a''b'" would result in "a b", but now that two quotes stand for one it
64results in "a'b".
65
Bram Moolenaar04a09c12005-08-01 22:02:32 +000066When overwriting a file with ":w! fname" there was no warning for when "fname"
67was being edited by another Vim. Vim now gives an error message |E768|.
68
Bram Moolenaarf4b8e572004-06-24 15:53:16 +000069
70Minor incompatibilities:
71
72For filetype detection: For many types, instead of ~/.dir/filename use
73*/.dir/filename, so that it also works for other user's files.
74
75":0verbose" now sets 'verbose' to zero instead of one.
76
77Removed the old and incomplete "VimBuddy" code.
78
79Buffers without a name report "No Name" instead of "No File". It was
80confusing for buffers with a name and 'buftype' set to "nofile".
Bram Moolenaar071d4272004-06-13 20:20:40 +000081
Bram Moolenaar7b0294c2004-10-11 10:16:09 +000082When ":file xxx" is used in a buffer without a name, the alternate file name
83isn't set. This avoids creating buffers without a name that are not useful.
84
85The "2html.vim" script now converts closed folds to HTML. This means the HTML
Bram Moolenaarf4630b62005-05-20 21:31:17 +000086looks like its displayed, with the same folds open and closed. Use "zR", or
87"let html_ignore_folding=1", if no folds should appear in the HTML. (partly by
88Carl Osterwisch)
Bram Moolenaar47136d72004-10-12 20:02:24 +000089Diff mode now is also converted as it is displayed.
Bram Moolenaar7b0294c2004-10-11 10:16:09 +000090
Bram Moolenaar293ee4d2004-12-09 21:34:53 +000091Win32: The effect of the <F10> key depended on 'winaltkeys'. Now it depends
92on whether <F10> has been mapped or not. This allows mapping <F10> without
93changing 'winaltkeys'.
94
Bram Moolenaar8c711452005-01-14 21:53:12 +000095When 'octal' is in 'nrformats' and using CTRL-A on "08" it became "018", which
96is illogical. Now it becomes "9". The leading zero(s) is(are) removed to
97avoid the number becoming octal after incrementing "009" to "010".
Bram Moolenaar1cd871b2004-12-19 22:46:22 +000098
99When 'encoding' is set to a Unicode encoding, the value for 'fileencodings'
100now includes "default" before "latin1". This means that for files with 8-bit
101encodings the default is to use the encoding specified by the environment, if
102possible. Previously latin1 would always be used, which is wrong in a
103non-latin1 environment, such as Russian.
104
Bram Moolenaard438e912005-01-31 19:21:46 +0000105Previously Vim would exit when there are two windows, both of them displaying
106a help file, and using ":quit". Now only the window is closed.
107
Bram Moolenaar4399ef42005-02-12 14:29:27 +0000108"-w {scriptout}" only works when {scriptout} doesn't start with a digit.
109Otherwise it's used to set the 'window' option.
110
Bram Moolenaar8bf59b92005-03-06 23:40:56 +0000111Previously <Home> and <xHome> could be mapped separately. This had the
112disadvantage that all mappings (with modifiers) had to be duplicated, since
113you can't be sure what the keyboard generates. Now all <xHome> are internally
114translated to <Home>, both for the keys and for mappings. Also for <xEnd>,
115<xF1>, etc.
116
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +0000117":put" now leaves the cursor on the last inserted line.
118
Bram Moolenaar7fae6362005-06-30 22:06:41 +0000119When a .gvimrc file exists then 'compatible' is off, just like when a ".vimrc"
120file exists.
121
Bram Moolenaar071d4272004-06-13 20:20:40 +0000122==============================================================================
123NEW FEATURES *new-7*
124
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000125Vim script enhancements *new-vim-script*
126-----------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +0000127
128In Vim scripts the following types have been added:
129
Bram Moolenaar31c67ef2005-01-11 21:34:41 +0000130 List ordered list of items |List|
131 Dictionary associative array of items |Dictionary|
132 Funcref reference to a function |Funcref|
Bram Moolenaar071d4272004-06-13 20:20:40 +0000133
134Many functions and commands have been added to support the new types.
135
Bram Moolenaar31c67ef2005-01-11 21:34:41 +0000136The |string()| function can be used to get a string representation of a
137variable. Works for Numbers, Strings and composites of them. Then |eval()|
138can be used to turn the string back into the variable value.
139
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000140The |:let| command can now use ":let var += expr" like using ":let var = var +
141expr". "-=" and ".=" works in a similar way.
142
Bram Moolenaar038eb0e2005-02-27 22:43:26 +0000143With the |:profile| command you can find out where your function or script
144wastes its time.
145
Bram Moolenaar843ee412004-06-30 16:16:41 +0000146
Bram Moolenaar60c78922005-03-20 22:40:14 +0000147Spell checking *new-spell*
148--------------
149
150Spell checking has been integrated in Vim. There were a few implementations
151with scripts, but they were slow and/or required an external program.
152
153The 'spell' option is used to switch spell checking on or off.
154The 'spelllang' option is used to specify the languages that are accepted.
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000155The 'spellfile' option specifies where new words are added.
Bram Moolenaar7fae6362005-06-30 22:06:41 +0000156The 'spellsuggest' option specifies the methods used for making suggestions
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000157
158The |[s| and |]s| commands can be used to move to the next or previous error.
159The |zg| and |zw| commands can be used to add good and wrong words.
160The |z?| command can be used to correct the word.
Bram Moolenaar7fae6362005-06-30 22:06:41 +0000161The |:mkspell| command is used to generate a Vim spell file from word lists.
Bram Moolenaar60c78922005-03-20 22:40:14 +0000162
163The "undercurl" highlighting attribute was added to nicely point out spelling
164mistakes in the GUI (based on patch from Marcin Dalecki).
165The "guisp" color can be used to give it a color different from foreground and
166background.
167The number of possible different highlight attributes was raised from about
168220 to over 30000. This allows for the attributes of spelling to be combined
Bram Moolenaar75c50c42005-06-04 22:06:24 +0000169with syntax highlighting attributes. This is also used for syntax
170highlighting.
Bram Moolenaar60c78922005-03-20 22:40:14 +0000171
172Much more info here: |spell|.
173
174
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000175KDE support *new-KDE*
Bram Moolenaar843ee412004-06-30 16:16:41 +0000176-----------
177
178Kvim is the KDE version of Vim. It uses the Qt toolkit. See |KVim|.
179(Thomas Capricelli, Philippe Fremy, Mickael Marchand, Mark Westcott, et al.)
180
Bram Moolenaar071d4272004-06-13 20:20:40 +0000181
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000182MzScheme interface *new-MzScheme*
183------------------
184
185The MzScheme interpreter is supported. |MzScheme|
186The |:mzscheme| command can be used to execute MzScheme commands.
187The |:mzfile| command can be used to execute an MzScheme script file.
188
Bram Moolenaar31c67ef2005-01-11 21:34:41 +0000189
Bram Moolenaar8299df92004-07-10 09:47:34 +0000190Printing multi-byte text *new-print-multi-byte*
191------------------
192
193The |:hardcopy| command now supports printing multi-byte characters.
194The 'printmbcharset' and 'printmbfont' options are used for this.
195Also see |postscript-cjk-printing|. (Mike Williams)
196
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000197
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000198Translated manual pages *new-manpage-trans*
199-----------------------
200
201The manual page of Vim and associated programs is now also available in
Bram Moolenaar4ad237d2005-03-11 22:49:40 +0000202several other languages.
203
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +0000204French - translated by David Blanchet
Bram Moolenaar4ad237d2005-03-11 22:49:40 +0000205Italian - translated by Antonio Colombo
206Russian - translated by Vassily Ragosin
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000207
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +0000208The Unix Makefile installs the Italian manual pages in .../man/it/man1/,
209.../man/it.ISO8859-1/man1/ and .../man/it.UTF-8/man1/. There appears to be no
210standard for what encoding goes in the "it" directory, the 8-bit encoded file
211is used there as a best guess.
212Other languages are installed in similar places.
Bram Moolenaar67fe1a12005-05-22 22:12:58 +0000213The translated pages are not automatically installed when Vim was configured
214with "--disable-nls", but "make install-languages install-tool-languages" will
215do it anyway.
Bram Moolenaarb5bf5b82004-12-24 14:35:23 +0000216
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000217
Bram Moolenaar8fc061c2004-12-29 21:03:02 +0000218Internal grep *new-vimgrep*
219-------------
220
221The ":vimgrep" command can be used to search for a pattern in a list of files.
222This is like the ":grep" command, but no external program is used. Besides
223better portability, handling of different file encodings and using multi-line
224patterns, this also allows grepping in compressed and remote files.
225|:vimgrep|.
226
Bram Moolenaar05159a02005-02-26 23:04:13 +0000227If you want to use the search results in a script you can use the
Bram Moolenaar2641f772005-03-25 21:58:17 +0000228|getqflist()| function.
Bram Moolenaar05159a02005-02-26 23:04:13 +0000229
Bram Moolenaar231334e2005-07-25 20:46:57 +0000230To search in files in various directories the "**" pattern can be used. It
231expands into an arbitrary depth of directories. "**" can be used in all
232places where file names are expanded, thus also with |:next| and |:args|.
233
Bram Moolenaar8fc061c2004-12-29 21:03:02 +0000234
Bram Moolenaar87e25fd2005-07-27 21:13:01 +0000235Scroll back in messages *new-scroll-back*
236-----------------------
237
238When displaying messages, at the |more-prompt| and the |hit-enter-prompt|, The
239'k', 'u' and 'b' keys can be used to scroll back to previous messages. This
240is especially useful for commands such as ":syntax", ":autocommand" and
241":highlight". This is implemented in a generic way thus it works for all
242commands and highlighting is kept. Only works when the 'more' option is set.
243Previously it only partly worked for ":clist".
244
Bram Moolenaar661b1822005-07-28 22:36:45 +0000245The |g<| command can be used to see the last page of messages after you have
246hit <Enter> at the |hit-enter-prompt|. Then you can scroll further back.
247
Bram Moolenaar87e25fd2005-07-27 21:13:01 +0000248
Bram Moolenaar4399ef42005-02-12 14:29:27 +0000249POSIX compatibility *new-posix*
250-------------------
251
252The POSIX test suite was used to verify POSIX compatibility. A number of
253problems have been fixed to make Vim more POSIX compatible. Some of them
254conflict with traditional Vi or expected behavior. The $VIM_POSIX environment
255variable can be set to get POSIX compatibility. See |posix|.
256
257Items that were fixed for both Vi and POSIX compatibilty:
258- repeating "R" with a count only overwrites text once; added the 'X' flag to
259 'cpoptions' |cpo-X|
260- a vertical movement command that moves to a non-existing line fails; added
261 the '-' flag to 'cpoptions' |cpo--|
262- when preserving a file and doing ":q!" the file can be recovered; added the
263 '&' flag to 'cpoptions' |cpo-&|
264- The 'window' option is partly implemented. It specifies how much CTRL-F and
265 CTRL-B scroll when there is one window. The "-w {number}" argument is now
266 accepted. "-w {scriptout}" only works when {scriptout} doesn't start with a
267 digit.
268- Allow "-c{command}" argument, no space between "-c" and {command}.
269- When writing a file with ":w!" don't reset 'readonly' when 'Z' is present in
270 'cpoptions'.
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000271- Allow 'l' and '#' flags for ":list", ":print" and ":number".
272- Added the '.' flag to 'cpoptions': ":cd" fails when the buffer is modified.
273- In Ex mode with an empty buffer ":read file" doesn't keep an empty line
274 above or below the new lines.
275- Remove a backslash before a NL for the ":global" command.
276- When ":append", ":insert" or ":change" is used with ":global", get the
277 inserted lines from the command. Can use backslash-NL to separate lines.
278- Can use ":global /pat/ visual" to execute Normal mode commands at each
279 matched line. Use "Q" to continue and go to the next line.
280- The |:open| command has been partially implemented. It stops Ex mode, but
281 redraws the whole screen, not just one line as open mode is supposed to do.
282- Support using a pipe to read the output from and write input to an external
283 command. Added the 'shelltemp' option and has("filterpipe").
284- In ex silent mode the ":set" command output is displayed.
285- The ":@@" and ":**" give an error message when no register was used before.
286- The search pattern "[]-`]" matches ']', '^', '_' and '`'.
287- Autoindent for ":insert" is using the line below the insert.
288- Autoindent for ":change" is using the first changed line.
289- Editing Ex command lines is not done in cooked mode, because CTRL-D and
290 CTRL-T cannot be handled then.
Bram Moolenaar45eeb132005-06-06 21:59:07 +0000291- In Ex mode, "1,3" prints three lines. "%" prints all lines.
292- In Ex mode "undo" would undo all changes since Ex mode was started.
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000293- Implemented the 'prompt' option.
Bram Moolenaar4399ef42005-02-12 14:29:27 +0000294
295
Bram Moolenaare2ac10d2005-03-07 23:26:06 +0000296Debugger support *new-debug-support*
297----------------
298
299The 'balloonexpr' option has been added. This is a generic way to implement
300balloon functionality. You can use it to show info for the word under the
301mouse pointer.
302
303
Bram Moolenaar0be6e642005-08-04 21:32:22 +0000304Remote file explorer *new-netrw-explore*
305--------------------
306
307The netrw plugin now also supports viewing a directory, when "scp://" is used.
308Deleting and renaming files is possible.
309
310To avoid duplicating a lot of code, the previous file explorer plugin has been
311integrated in the netrw plugin. This means browsing local and remote files
312works the same way.
313
314":browse edit" and ":browse split" use the netrw plugin when it's available
315and a GUI dialog is not possible.
316
317The netrw plugin is maintained by Charles Campbell.
318
319
Bram Moolenaar071d4272004-06-13 20:20:40 +0000320Various new items *new-items-7*
321-----------------
322
323Normal mode commands: ~
324
Bram Moolenaarcfbc5ee2004-07-02 15:38:35 +0000325a", a' and a` New text objects to select quoted strings. |a'|
326i", i' and i' (Taro Muraoka)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000327
Bram Moolenaar05159a02005-02-26 23:04:13 +0000328CTRL-W <Enter> In the quickfix window: opens a new window to show the
329 location of the error under the cursor.
330
Bram Moolenaarff6f0612005-07-19 22:21:12 +0000331|at| and |it| text objects select a block of text between HTML or XML tags.
332
333
Bram Moolenaar488c6512005-08-11 20:09:58 +0000334Insert mode commands: ~
335
336CTRL-\ CTRL-O Execute a Normal mode command. Like CTRL-O but
337 without moving the cursor.
338
Bram Moolenaar071d4272004-06-13 20:20:40 +0000339Options: ~
340
Bram Moolenaarcfbc5ee2004-07-02 15:38:35 +0000341'completefunc' The name of a function used for user-specified Insert
342 mode completion. CTRL-X CTRL-U can be used in Insert
343 mode to do any kind of completion. (Taro Muraoka)
344'quoteescape' Characters used to escape quotes inside a string.
345 Used for the a", a' and a` text objects. |a'|
Bram Moolenaar592e0a22004-07-03 16:05:59 +0000346'numberwidth' Minimal width of the space used for the 'number'
347 option. (Emmanuel Renieris)
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000348'mzquantum' Time in msec to schedule MzScheme threads.
Bram Moolenaar8299df92004-07-10 09:47:34 +0000349'printmbcharset' CJK character set to be used for :hardcopy
350'printmbfont' font names to be used for CJK output of :hardcopy
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000351'fsync' Whether fsync() is called after writing a file.
352 (Ciaran McCreesh)
Bram Moolenaarb5bf5b82004-12-24 14:35:23 +0000353'wildoptions' "tagfile" value enables listing the file name of
354 matching tags for CTRL-D command line completion.
355 (based on an idea from Yegappan Lakshmanan)
Bram Moolenaar86b68352004-12-27 21:59:20 +0000356'formatlistpat' pattern to recognize a numbered list for formatting.
357 (idea by Hugo Haas)
Bram Moolenaar60c78922005-03-20 22:40:14 +0000358'spell' switch spell checking on/off
359'spelllang' languages to check spelling for
Bram Moolenaar42eeac32005-06-29 22:40:58 +0000360'spellsuggest' methods for spell suggestions
Bram Moolenaar3b56eb32005-07-11 22:40:32 +0000361'synmaxcol' maximum column to look for syntax items; avoids very
362 slow redrawing when there are very long lines
Bram Moolenaar54ee7752005-05-31 22:22:17 +0000363'verbosefile' Log messages in a file.
Bram Moolenaar86b68352004-12-27 21:59:20 +0000364
Bram Moolenaar071d4272004-06-13 20:20:40 +0000365
366Ex commands: ~
367
Bram Moolenaar843ee412004-06-30 16:16:41 +0000368Win32: The ":winpos" command now also works in the console. (Vipin Aravind)
369
Bram Moolenaar8299df92004-07-10 09:47:34 +0000370|:startreplace| Start Replace mode. (Charles Campbell)
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000371
Bram Moolenaar8299df92004-07-10 09:47:34 +0000372|:0file| Removes the name of the buffer. (Charles Campbell)
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000373
Bram Moolenaar2df6dcc2004-07-12 15:53:54 +0000374|:diffoff| Switch off diff mode in the current window or in all
375 windows.
376
Bram Moolenaard4755bb2004-09-02 19:12:26 +0000377|:keepalt| Do not change the alternate file.
378
Bram Moolenaarc0197e22004-09-13 20:26:32 +0000379|:delmarks| Delete marks.
380
Bram Moolenaar7b0294c2004-10-11 10:16:09 +0000381|:sandbox| Command modifier: execute the argument in the sandbox.
382
Bram Moolenaarb5bf5b82004-12-24 14:35:23 +0000383|:exusage| Help for Ex commands (Nvi command).
384
385|:viusage| Help for Vi commands (Nvi command).
386
Bram Moolenaar86b68352004-12-27 21:59:20 +0000387|:cbuffer| Read error lines from a buffer. (partly by Yegappan
388 Lakshmanan)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000389
Bram Moolenaar67fe1a12005-05-22 22:12:58 +0000390|:sort| Sort lines in the buffer without depending on an
391 external command.
392
Bram Moolenaar87e25fd2005-07-27 21:13:01 +0000393|:caddfile| Add error messages to an existing quickfix list
394 (Yegappan Lakshmanan).
395
396|:cexpr| Read error messages from a Vim expression (Yegappan
397 Lakshmanan).
398
Bram Moolenaar67fe1a12005-05-22 22:12:58 +0000399
Bram Moolenaar071d4272004-06-13 20:20:40 +0000400New functions: ~
401
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000402|add()| append an item to a List
403|append()| append List of lines to the buffer
Bram Moolenaar87b774d2005-07-20 22:04:36 +0000404|browsedir()| dialog to select a directory
405|byteidx()| index of a character (Ilya Sher)
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000406|call()| call a function with List as arguments
Bram Moolenaar572cb562005-08-05 21:35:02 +0000407|complete_add()| add match for 'completefunc'
408|complete_check()| check for key pressed, for 'completefunc'
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000409|copy()| make a shallow copy of a List or Dictionary
410|count()| count nr of times a value is in a List or Dictionary
411|deepcopy()| make a full copy of a List or Dictionary
412|empty()| check if List or Dictionary is empty
Bram Moolenaarb982ca52005-03-28 21:02:15 +0000413|getqflist()| list of quickfix errors (Yegappan Lakshmanan)
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000414|extend()| append one List to another or add items from one
415 Dictionary to another
416|filter()| remove selected items from a List or Dictionary
Bram Moolenaar87b774d2005-07-20 22:04:36 +0000417|finddir()| find a directory in 'path'
418|findfile()| find a file in 'path' (Johannes Zellner)
419|foldtextresult()| the text displayed for a closed fold at line "lnum"
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000420|function()| make a Funcref out of a function name
421|get()| get an item from a List or Dictionary
Bram Moolenaar342337a2005-07-21 21:11:17 +0000422|getbufline()| get a list of lines from a specified buffer
Bram Moolenaar87b774d2005-07-20 22:04:36 +0000423 (Yegappan Lakshmanan)
424|getfontname()| get actual font name being used
425|getfperm()| get file permission string (Nikolai Weibull)
426|getftype()| get type of file (Nikolai Weibull)
427|getline()| with second argument: get List with buffer lines
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000428|has_key()| check whether a key appears in a Dictionary
429|insert()| insert an item somewhere in a List
430|items()| get List of Dictionary key-value pairs
431|join()| join List items into a String
432|keys()| get List of Dictionary keys
433|len()| number of items in a List or Dictionary
434|map()| change each List or Dictionary item
Bram Moolenaar2a8d1f82005-02-05 21:43:56 +0000435|matchlist()| list with match and submatches of a pattern in a string
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000436|max()| maximum value in a List or Dictionary
437|min()| minimum value in a List or Dictionary
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000438|mkdir()| create a directory
Bram Moolenaar4be06f92005-07-29 22:36:03 +0000439|printf()| format text
Bram Moolenaar2a8d1f82005-02-05 21:43:56 +0000440|readfile()| read a file into a list of lines
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000441|remove()| remove one or more items from a List or Dictionary
Bram Moolenaar87b774d2005-07-20 22:04:36 +0000442|repeat()| repeat "expr" "count" times (Christophe Poucet)
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000443|reverse()| reverse the order of a List
Bram Moolenaarb982ca52005-03-28 21:02:15 +0000444|setqflist()| create a quickfix list (Yegappan Lakshmanan)
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000445|sort()| sort a List
Bram Moolenaar42eeac32005-06-29 22:40:58 +0000446|soundfold()| get the sound-a-like equivalent of a word
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000447|split()| split a String into a List
Bram Moolenaar42eeac32005-06-29 22:40:58 +0000448|spellbadword()| get a badly spelled word
449|spellsuggest()| get suggestions for correct spelling
Bram Moolenaar87b774d2005-07-20 22:04:36 +0000450|string()| string representation of a List or Dictionary
451|system()| filters {input} through a shell command
452|taglist()| get list of matching tags (Yegappan Lakshmanan)
453|tr()| translate characters (Ron Aaron)
Bram Moolenaarbac234e2005-01-17 22:21:07 +0000454|values()| get List of Dictionary values
Bram Moolenaar2a8d1f82005-02-05 21:43:56 +0000455|writefile()| write a list of lines into a file
Bram Moolenaar8299df92004-07-10 09:47:34 +0000456
Bram Moolenaarbee0c5b2005-02-07 22:03:36 +0000457User defined functions can now be loaded automatically from the "autoload"
458directory in 'runtimepath'. See |autoload-functions|.
459
Bram Moolenaar071d4272004-06-13 20:20:40 +0000460
461New autocommand events: ~
462
Bram Moolenaar8299df92004-07-10 09:47:34 +0000463|InsertEnter| starting Insert or Replace mode
464|InsertChange| going from Insert to Replace mode or back
465|InsertLeave| leaving Insert or Replace mode
Bram Moolenaar843ee412004-06-30 16:16:41 +0000466
Bram Moolenaar8299df92004-07-10 09:47:34 +0000467|ColorScheme| after loading a color scheme
Bram Moolenaarbee0c5b2005-02-07 22:03:36 +0000468|QuickFixCmdPre| before :make, :grep et al. (Ciaran McCreesh)
469|QuickFixCmdPost| after :make, :grep et al. (Ciaran McCreesh)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000470
Bram Moolenaarcfbc5ee2004-07-02 15:38:35 +0000471
Bram Moolenaarc0197e22004-09-13 20:26:32 +0000472New items in search patterns: ~
473|/\%d| \%d123 search for character with decimal number
474|/\]| [\d123] idem, in a colletion
475|/\%o| \%o103 search for character with octal number
476|/\]| [\o1o3] idem, in a colletion
477|/\%x| \%x1a search for character with 2 pos. hex number
478|/\]| [\x1a] idem, in a colletion
479|/\%u| \%u12ab search for character with 4 pos. hex number
480|/\]| [\u12ab] idem, in a colletion
481|/\%U| \%U1234abcd search for character with 8 pos. hex number
482|/\]| [\U1234abcd] idem, in a colletion
483 (The above partly by Ciaran McCreesh)
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +0000484|/[[=| [[=a=]] an equivalence class (only for latin1 characters)
485|/[[.| [[.a.]] a collation element (only works with single char)
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000486
487Nesting |/multi| items no longer is an error when an empty match is possible.
488
489It is now possible to use \{0}, it matches the preceding atom zero times. Not
490useful, just for compatibility.
Bram Moolenaarc0197e22004-09-13 20:26:32 +0000491
492
Bram Moolenaarcfbc5ee2004-07-02 15:38:35 +0000493New Syntax/Indent/FTplugin files: ~
494
495MuPAD source syntax, indent and ftplugin. (Dave Silvia)
496
Bram Moolenaard4755bb2004-09-02 19:12:26 +0000497ABAB/4 syntax file. (Marius van Wyk)
498
499SQL-Informix syntax file. (Dean L Hill)
500
Bram Moolenaar15d0a8c2004-09-06 17:44:46 +0000501PHP compiler plugin. (Doug Kearns)
502
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000503Sive syntax file. (Nikolai Weibull)
504
Bram Moolenaar0e4d8772005-06-07 21:12:49 +0000505Pascal indent file. (Neil Carter)
506
Bram Moolenaar42eeac32005-06-29 22:40:58 +0000507Many filetype plugins and others from Nikolai Weibull.
508
Bram Moolenaarce0842a2005-07-18 21:58:11 +0000509Xquery syntax file. (Jean-Marc Vanel)
510
Bram Moolenaarb982ca52005-03-28 21:02:15 +0000511Moved all the indent settings from the filetype plugin to the indent file.
512Implemented b:undo_indent to undo indent settings when setting 'filetype' to a
513different value.
514
Bram Moolenaar15d0a8c2004-09-06 17:44:46 +0000515
Bram Moolenaar47136d72004-10-12 20:02:24 +0000516New Keymaps: ~
517
518Sinhala (Sri Lanka) (Harshula Jayasuriya)
519
520
Bram Moolenaar15d0a8c2004-09-06 17:44:46 +0000521New message translations: ~
522
523The Ukranian messages are now also available in cp1251.
524
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000525Irish message translations. (Kevin Patrick Scannell)
526
Bram Moolenaar05159a02005-02-26 23:04:13 +0000527Vietnamese message translations and menu. (Phan Vinh Thinh)
528
Bram Moolenaar071d4272004-06-13 20:20:40 +0000529
Bram Moolenaarf4b8e572004-06-24 15:53:16 +0000530Others: ~
531
532Mac: Add the selection type to the clipboard, so that Block, line and
533character selections can be used between two Vims. (Eckehard Berns)
534Also fixes the problem that setting 'clipboard' to "unnamed" breaks using
535"yyp".
Bram Moolenaar071d4272004-06-13 20:20:40 +0000536
Bram Moolenaar592e0a22004-07-03 16:05:59 +0000537Mac: GUI font selector. (Peter "Rain Dog" Cucka)
538
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000539Mac: support for multi-byte characters. (Da Woon Jung)
540
Bram Moolenaar2079a602005-01-04 21:43:22 +0000541GUI font selector for Motif. (Marcin Dalecki)
Bram Moolenaar567e4de2004-12-31 21:01:02 +0000542
Bram Moolenaarbee0c5b2005-02-07 22:03:36 +0000543Nicer toolbar buttons for Motif. (Marcin Dalecki)
544
Bram Moolenaar2079a602005-01-04 21:43:22 +0000545Mnemonics for the Motif find/replace dialog. (Marcin Dalecki)
Bram Moolenaar567e4de2004-12-31 21:01:02 +0000546
Bram Moolenaar46c9c732004-12-12 11:37:09 +0000547Mac: better integration with Xcode. Post a fake mouse-up event after the odoc
548event and the drag receive handler to work around a stall after Vim loads a
549file. Fixed an off-by-one line number error. (Da Woon Jung)
550
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000551Added the t_SI and t_EI escape sequences for starting and ending Insert mode.
552To be used to set the cursor shape to a bar or a block. No default values,
553they are not supported by termcap/terminfo.
554
Bram Moolenaarb5bf5b82004-12-24 14:35:23 +0000555Autocommands can be defined local to a buffer. This means they will also work
556when the buffer does not have a name or no specific name. See
557|autocmd-buflocal|. (Yakov Lerner)
558
Bram Moolenaar19a09a12005-03-04 23:39:37 +0000559For xterm most combinations of modifiers with function keys are recognized.
560|xterm-modifier-keys|
561
Bram Moolenaar071d4272004-06-13 20:20:40 +0000562==============================================================================
563IMPROVEMENTS *improvements-7*
564
Bram Moolenaarf4b8e572004-06-24 15:53:16 +0000565":helpgrep" accepts a language specifier after the pattern: "pat@it".
566
Bram Moolenaar8299df92004-07-10 09:47:34 +0000567Move the help for printing to a separate help file. It's quite a lot now.
568
Bram Moolenaar8bf59b92005-03-06 23:40:56 +0000569The pattern matching code was changed from a recursive function to an
570iterative mechanism. This avoids out-of-stack errors. State is stored in
571allocated memory, running out of memory can always be detected. Allows
572matching more complex things, but Vim may seem to hang while doing that.
573
Bram Moolenaarf4b8e572004-06-24 15:53:16 +0000574":breakadd here" and ":breakdel here" can be used to set or delete a
575breakpoint at the cursor.
576
Bram Moolenaar843ee412004-06-30 16:16:41 +0000577The tutor was updated to make it simpler to use and added text to explain a
578few more important commands. Used ideas from Gabriel Zachmann.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000579
Bram Moolenaarcfbc5ee2004-07-02 15:38:35 +0000580Unix: When libcall() fails obtain an error message with dlerror() and display
581it. (Johannes Zellner)
582
Bram Moolenaar592e0a22004-07-03 16:05:59 +0000583Added "nbsp" in 'listchars'. (David Blanchet)
584
Bram Moolenaar21cf8232004-07-16 20:18:37 +0000585Added the "acwrite" value for the 'buftype' option. This is for a buffer that
586doesn not have a name that refers to a file and is written with BufWriteCmd
587autocommands.
588
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000589For lisp indenting and matching parenthesis: (Sergey Khorev)
590- square brackets are recognized properly
591- #\(, #\), #\[ and #\] are recognized as character literals
592- Lisp line comments (delimited by semicolon) are recognized
593
Bram Moolenaar89cb5e02004-07-19 20:55:54 +0000594Added the "count" argument to match(), matchend() and matchstr(). (Ilya Sher)
595
Bram Moolenaar5eb86f92004-07-26 12:53:41 +0000596winnr() takes an optional "$" and "#" arguments. (Nikolai Weibull, Yegappan
597Lakshmanan)
598
599Added 'n' flag to search(): don't move the cursor. (Nikolai Weibull)
600
Bram Moolenaard4755bb2004-09-02 19:12:26 +0000601When uncompressing fails in the gzip plugin, give an error message but don't
602delete the raw text. Helps if the file has a .gz extension but is not
603actually compressed. (Andrew Pimlott)
604
605When C, C++ or IDL syntax is used, may additionally load doxygen syntax.
606Also support setting the filetype to "cdoxygen" for C plus doxygen syntax.
607(Michael Geddes)
608
609The ":registers" command now displays multi-byte characters properly.
610
611VMS: In the usage message mention that a slash can be used to make a flag
612upper case. Add color support to the builtin vt320 terminal codes.
613(Zoltan Arpadffy)
614
Bram Moolenaar15d0a8c2004-09-06 17:44:46 +0000615For the '%' item in 'viminfo', allow a number to set a maximum for the number
616of buffers.
617
Bram Moolenaarb5bf5b82004-12-24 14:35:23 +0000618The 'statusline' option can be local to the window, so that each window can
619have a different value. (partly by Yegappan Lakshmanan)
620
Bram Moolenaar3fdfa4a2004-10-07 21:02:47 +0000621When a file looks like a shell script, check for an "exec" command that starts
622the tcl interpreter. (suggested by Alexios Zavras)
623
624Support conversion between utf-8 and latin9 (iso-8859-15) internally, so that
625digraphs still work when iconv is not available.
626
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000627When a session file is loaded while editing an unnamed, empty buffer that
628buffer is wiped out. Avoids that there is an unused buffer in the buffer
629list.
630
631Win32: When libintl.dll supports bind_textdomain_codeset(), use it.
632(NAKADAIRA Yukihiro)
633
634When foldtext() finds no text after removing the comment leader, use the
635second line of the fold. Helps for C-style /* */ comments where the first
636line is just "/*".
637
Bram Moolenaar1cd871b2004-12-19 22:46:22 +0000638When editing the same file from two systems (e.g., Unix and MS-Windows) there
639mostly was no warning for an existing swap file, because the name of the
640edited file differs (e.g., y:\dir\file vs /home/me/dir/file). Added a flag to
641the swap file to indicate it is in the same directory as the edited file. The
642used path then doesn't matter and the check for editing the same file is much
643more reliable.
644
645Client-server communication now supports 'encoding'. When setting 'encoding'
646in a Vim server to "utf-8", and using "vim --remote fname" in a console,
647"fname" is converted from the console encoding to utf-8. Also allows Vims
648with different 'encoding' settings to exchange messages.
649
Bram Moolenaar86b68352004-12-27 21:59:20 +0000650Internal: Changed ga_room into ga_maxlen, so that it doesn't need to be
651incremented/decremented each time.
652
Bram Moolenaar2079a602005-01-04 21:43:22 +0000653Included a few improvements for Motif from Marcin Dalecki. Draw label
Bram Moolenaar567e4de2004-12-31 21:01:02 +0000654contents ourselves to make them handle fonts in a way configurable by Vim and
655a bit less dependent on the X11 font management.
656
Bram Moolenaar49cd9572005-01-03 21:06:01 +0000657When a register is empty it is not stored in the viminfo file.
658
Bram Moolenaar8c711452005-01-14 21:53:12 +0000659Removed the tcltags script, it's obsolete.
660
Bram Moolenaar67fe1a12005-05-22 22:12:58 +0000661":redir @*>>" and ":redir @+>>" append to the clipboard. Better check for
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000662invalid characters after the register name. |:redir|
663
664":redir => variable" and ":redir =>> variable" write or append to a variable.
665(Yegappan Lakshmanan) |:redir|
Bram Moolenaardcaf10e2005-01-21 11:55:25 +0000666
Bram Moolenaar231334e2005-07-25 20:46:57 +0000667":redir @{a-z}>>" appends to register a to z. (Yegappan Lakshmanan)
Bram Moolenaar67fe1a12005-05-22 22:12:58 +0000668
Bram Moolenaar54ee7752005-05-31 22:22:17 +0000669The 'verbosefile' option can be used to log messages in a file. Verbose
670messages are not displayed then. The "-V{filename}" argument can be used to
671log startup messages.
672
Bram Moolenaardcaf10e2005-01-21 11:55:25 +0000673":let g:" lists global variables.
674":let b:" lists buffer-local variables.
675":let w:" lists window-local variables.
676":let v:" lists Vim variables.
677
Bram Moolenaard438e912005-01-31 19:21:46 +0000678The stridx() and strridx() functions take a third argument, where to start
679searching. (Yegappan Lakshmanan)
Bram Moolenaarb71ec9f2005-01-25 22:22:02 +0000680
Bram Moolenaar67fe1a12005-05-22 22:12:58 +0000681The getreg() function takes an extra argument to be able to get the expression
682for the '=' register instead of the result of evaluating it.
683
684The setline() function can take a List argument to set multiple lines. When
685the line number is just below the last line the line is appended.
686
Bram Moolenaarbee0c5b2005-02-07 22:03:36 +0000687g CTRL-G also shows the number of characters if it differs from the number of
688bytes.
689
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000690Completion for ":debug" and entering an expression for the '=' register. Skip
691":" between range and command name. (Peter winters)
692
693CTRL-Q in Insert mode now works like CTRL-V by default. Previously it was
694ignored.
695
696When "beep" is included in 'debug' a function or script that causes a beep
697will result in a message with the source of the error.
698
Bram Moolenaar05159a02005-02-26 23:04:13 +0000699When completing buffer names, match with "\(^\|[\/]\)" instead of "^", so that
700":buf stor<Tab>" finds both "include/storage.h" and "storage/main.c".
701
702To count items (pattern matches) without changing the buffer the 'n' flag has
703been added to |:substitute|. See |count-items|.
704
Bram Moolenaar038eb0e2005-02-27 22:43:26 +0000705The "screen.linux" $TERM name is recognized to set the default for
Bram Moolenaar19a09a12005-03-04 23:39:37 +0000706'background' to "dark". (Ciaran McCreesh) Also for "cygwin".
707
708The |FileChangedShell| autocommand event can now use the |v:fcs_reason|
709variable that specifies what triggered the event. |v:fcs_choice| can be used
710to reload the buffer or ask the user what to do.
Bram Moolenaar038eb0e2005-02-27 22:43:26 +0000711
Bram Moolenaar8bf59b92005-03-06 23:40:56 +0000712Not all modifiers were recognized for xterm function keys. Added the
713possibility in term codes to end in ";*X" or "O*X", where X is any character
714and the * stands for the modifier code.
715Added the <xUp>, <xDown>, <xLeft> and <xRight> keys, to be able to recognize
716the two forms that xterm can send their codes in and still handle all possible
717modifiers.
718
Bram Moolenaarc0761132005-03-18 20:30:32 +0000719getwinvar() now also works to obtain a buffer-local option from the specified
720window.
721
Bram Moolenaarb982ca52005-03-28 21:02:15 +0000722Added the "%s" item to 'errorformat'. (Yegappan Lakshmanan)
723
Bram Moolenaar34cdc3e2005-05-18 22:24:46 +0000724GTK GUI: use the GTK file dialog when it's available. Mix from patches by
725Grahame Bowland and Evan Webb.
726
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000727Added ":scriptnames" to bugreport.vim, so that we can see what plugins were
728used.
729
Bram Moolenaar520470a2005-06-16 21:59:56 +0000730Win32: If the user changes the setting for the number of lines a scroll wheel
731click scrolls it is now used immediately. Previously Vim would need to be
732restarted.
733
Bram Moolenaarb2ec3072005-06-17 22:02:20 +0000734When using @= in an expression the value is expression @= contains. ":let @=
735= value" can be used to set the register contents.
736
Bram Moolenaar51bab742005-07-08 22:31:03 +0000737A ! can be added to ":popup" to have the popup menu appear at the mouse
738pointer position instead of the text cursor.
739
Bram Moolenaard8e9bb22005-07-09 21:14:46 +0000740The table with encodings has been expanded with many MS-Windows codepages,
741such as cp1250 and cp737, so that these can also be used on Unix without
742prepending "8bit-".
743
744Added the "customlist" completion argument to a user-defined command. The
745user-defined completion function should return the completion candidates as a
Bram Moolenaar231334e2005-07-25 20:46:57 +0000746Vim List and the returned results are not filtered by Vim. (Yegappan
747Lakshmanan)
Bram Moolenaard8e9bb22005-07-09 21:14:46 +0000748
Bram Moolenaar342337a2005-07-21 21:11:17 +0000749Win32: Balloons can have multiple lines if common controls supports it.
750(Sergey Khorev)
751
Bram Moolenaar231334e2005-07-25 20:46:57 +0000752The 's' flag is added to the search() and searchpair() function to set the
753' mark if the cursor is moved. (Yegappan Lakshmanan)
754
Bram Moolenaar661b1822005-07-28 22:36:45 +0000755When 'verbose' is set the output of ":highlight" will show where a highlight
756item was last set.
757
Bram Moolenaar0be6e642005-08-04 21:32:22 +0000758For 'errorformat' it was not possible to have a file name that contains the
759character that follows after "%f". For example, in "%f:%l:%m" the file name
760could not contain ":". Now include the first ":" where the rest of the
761pattern matches. In the example a ":" not followed by a line number is
762included in the file name. (suggested by Emanuele Giaquinta)
763
Bram Moolenaar071d4272004-06-13 20:20:40 +0000764==============================================================================
765COMPILE TIME CHANGES *compile-changes-7*
766
Bram Moolenaar2079a602005-01-04 21:43:22 +0000767Dropped the support for the BeOS and Amiga GUI. They were not maintained and
768probably didn't work. If you want to work on this: get the Vim 6.x version
769and merge it back in.
770
Bram Moolenaarab79bcb2004-07-18 21:34:53 +0000771Mac: "make" now creates the Vim.app directory and "make install" copies it to
772its final destination. (Raf)
773
774Mac: Made it possible to compile with Motif, Athena or GTK without tricks and
775still being able to use the MacRoman conversion. Added the os_mac_conv.c
776file.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000777
Bram Moolenaar5313dcb2005-02-22 08:56:13 +0000778When running the tests and one of them fails to produce "test.out" the
779following tests are still executed. This helps when running out of memory.
780
Bram Moolenaarf461c8e2005-06-25 23:04:51 +0000781When compiling with EXITFREE defined and the ccmalloc library it is possible
782to detect memory leaks. Some memory will always reported as leaked, such as
783allocated by X11 library functions and the memory allocated in alloc_cmdbuff()
784to store the ":quit" command.
785
Bram Moolenaar231334e2005-07-25 20:46:57 +0000786Moved the code for printing to src/hardcopy.c.
787
788Moved some code from main() to separate functions to make it easier to see
789what is being done. Use a structure to avoid a lot of arguments to the
790functions.
791
792Moved unix_expandpath() to misc1.c, so that it can also be used by os_mac.c
793without copying the code.
794
Bram Moolenaar071d4272004-06-13 20:20:40 +0000795==============================================================================
796BUG FIXES *bug-fixes-7*
797
Bram Moolenaarf4b8e572004-06-24 15:53:16 +0000798When using PostScript printing on MS-DOS the default 'printexpr' used "lpr"
799instead of "copy". When 'printdevice' was empty the copy command did not
800work. Use "LPT1" then.
801
802The GTK font dialog uses a font size zero when the font name doesn't include a
803size. Use a default size of 10.
804
805This example in the documentation didn't work:
806 :e `=foo . ".c" `
807Skip over the expression in `=expr` when looking for comments, |, % and #.
808
809When ":helpgrep" doesn't find anything there is no error message.
810
811"L" and "H" did not take closed folds into account.
812
813Win32: The "-P title" argument stopped at the first title that matched, even
814when it doesn't support MDI.
815
816Mac GUI: CTRL-^ and CTRL-@ did not work.
817
818"2daw" on "word." at the end of a line didn't include the preceding white
819space.
820
821Win32: Using FindExecutable() doesn't work to find a program. Use
822SearchPath() instead. For executable() use $PATHEXT when the program searched
823for doesn't have an extension.
824
825When 'virtualedit' is set, moving the cursor up after appending a character
826may move it to a different column. Was caused by auto-formatting moving the
827cursor and not putting it back where it was.
828
829When indent was added automatically and then moving the cursor, the indent was
830not deleted (like when pressing ESC). The "I" flag in 'cpoptions' can be used
831to make it work the old way.
832
Bram Moolenaarf4b8e572004-06-24 15:53:16 +0000833When opening a command-line window, 'textwidth' gets set to 78 by the Vim
834filetype plugin. Reset 'textwidth' to 0 to avoid lines are broken.
835
836After using cursor(line, col) moving up/down doesn't keep the same column.
837
838Win32: Borland C before 5.5 requires using ".u." for LowPart and HighPart
839fields. (Walter Briscoe)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000840
Bram Moolenaar843ee412004-06-30 16:16:41 +0000841On Sinix SYS_NMLN isn't always defined. Define it ourselves. (Cristiano De
842Michele)
843
Bram Moolenaar325b7a22004-07-05 15:58:32 +0000844Printing with PostScript may keep the printer waiting for more. Append a
845CTRL-D to the printer output. (Mike Williams)
846
Bram Moolenaar2df6dcc2004-07-12 15:53:54 +0000847When converting a string with a hex or octal number the leading '-' was
848ignored. ":echo '-05' + 0" resulted in 5 instead of -5.
849
850Using "@:" to repeat a command line didn't work when it contains control
851characters.
852
Bram Moolenaar21cf8232004-07-16 20:18:37 +0000853When using file completion for a user command, it would not expand environment
854variables like for a regular command with a file argument.
855
856'cindent': When the argument of a #define looks like a C++ class the next line
857is indented too much.
858
859When 'comments' includes multi-byte characters inserting the middle part and
860alignment may go wrong. 'cindent' also suffers from this for right-aligned
861items.
862
Bram Moolenaar05159a02005-02-26 23:04:13 +0000863Win32: when 'encoding' is set to "utf-8" getenv() still returns strings in the
864active codepage. Convert to utf-8. Also for $HOME.
865
Bram Moolenaarab79bcb2004-07-18 21:34:53 +0000866The default for 'helplang' was "zh" for both "zh_cn" and "zh_tw". Now use
867"cn" or "tw" as intended.
868
Bram Moolenaar5eb86f92004-07-26 12:53:41 +0000869When 'bin' is set and 'eol' is not set then line2byte() added the line break
870after the last line while it's not there.
871
872Using foldlevel() in a WinEnter autocommand may not work. Noticed when
873resizing the GUI shell upon startup.
874
875Python: Using buffer.append(f.readlines()) didn't work. Allow appending a
876string with a trailing newline. The newline is ignored.
877
Bram Moolenaar269ec652004-07-29 08:43:53 +0000878When using the ":saveas f2" command for buffer "f1", the Buffers menu would
879contain "f2" twice, one of them leading to "f1". Also trigger the BufFilePre
880and BufFilePost events for the alternate buffer that gets the old name.
881
Bram Moolenaard4755bb2004-09-02 19:12:26 +0000882strridx() did not work well when the needle is empty. (Ciaran McCreesh)
883
884GTK: Avoid a potential hang in gui_mch_wait_for_chars() when input arrives
885just before it is invoked
886
887VMS: Occasionally CR characters were inserted in the file. Expansion of
888environment variables was not correct. (Zoltan Arpadffy)
889
890UTF-8: When 'delcombine' is set "dw" only deleted the last combining character
891from the first character of the word.
892
893When using ":sball" in an autocommand only the filetype in one buffer was
894detected. Reset did_filetype in enter_buffer().
895
896When using ":argdo" and the window already was at the first argument index,
897but not actually editing it, the current buffer would be used instead.
898
Bram Moolenaar15d0a8c2004-09-06 17:44:46 +0000899When ":next dir/*" includes many matches, adding the names to the argument
900list may take an awful lot of time and can't be interrupted. Allow
901interrupting this.
902
903When editing a file that was already loaded in a buffer, modelines were not
904used. Now window-local options in the modeline are set. Buffer-local options
905and global options remain unmodified.
906
907Win32: When 'encoding' is set to "utf-8" in the vimrc file, files from the
908command line with non-ASCII characters are not used correctly. Recode the
909file names when 'encoding' is set, using the Unicode command line.
910
Bram Moolenaarc0197e22004-09-13 20:26:32 +0000911Win32 console: When the default for 'encoding' ends up to be "latin1", the
912default value of 'isprint' was wrong.
913
914When an error message is given while waiting for a character (e.g., when an
915xterm reports the number of colors), the hit-enter prompt overwrote the last
916line. Don't reset msg_didout in normal_cmd() for K_IGNORE.
917
Bram Moolenaar3fdfa4a2004-10-07 21:02:47 +0000918Mac GUI: Shift-Tab didn't work.
919
920When defining tooltip text, don't translate terminal codes, since it's not
921going to be used like a command.
922
923GTK 2: Check the tooltip text for valid utf-8 characters to avoid getting a
924GTK error. Invalid characters may appear when 'encoding' is changed.
925
926GTK 2: Add a safety check for invalid utf-8 sequences, they can crash pango.
927
928Win32: When 'encoding' is changed while starting up, use the Unicode command
929line to convert the file arguments to 'encoding'. Both for the GUI and the
930console version.
931
932Win32 GUI: latin9 text (iso-8859-15) was not displayed correctly, because
933there is no codepage for latin9. Do our own conversion from latin9 to UCS2.
934
Bram Moolenaar7b0294c2004-10-11 10:16:09 +0000935When two versions of GTK+ 2 are installed it was possible to use the header
936files from one and the library from the other. Use GTK_LIBDIR to put the
937directory for the library early in the link flags.
938
939With the GUI find/replace dialog a replace only worked if the pattern was
940literal text. Now it works for any pattern.
941
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000942When 'equalalways' is set and 'eadirection' is "hor", ":quit" would still
943cause equalizing window heights in the vertical direction.
944
945When ":emenu" is used in a startup script the command was put in the typeahead
946buffer, causing a prompt for the crypt key to be messed up.
947
948Mac OS/X: The default for 'isprint' included characters 128-160, causes
949problems for Terminal.app.
950
951When a syntax item with "containedin" is used, it may match in the start or
952end of a region with a matchgroup, while this doesn't happen for a "contains"
953argument.
954
955When a transparent syntax items matches in another item where the highlighting
956has already stopped (because of a he= argument), the highlighting would come
957back.
958
959When cscope is used to set the quickfix error list, it didn't get set if there
960was only one match. (Sergey Khorev)
961
962When 'confirm' is set and using ":bdel" in a modified buffer, then selecting
963"cancel", would still give an error message.
964
965The PopUp menu items that started Visual mode didn't work when not in Normal
966mode. Switching between selecting a word and a line was not possible.
967
968Win32: The keypad decimal point always resulted in a '.', while on some
969keyboards it's a ','. Use MapVirtualKey(VK_DECIMAL, 2).
970
971Removed unused function DisplayCompStringOpaque() from gui_w32.c
972
973In Visual mode there is not always an indication whether the line break is
974selected or not. Highlight the character after the line when the line break
975is included, e.g., after "v$o".
976
977GTK: The <F10> key can't be mapped, it selects the menu. Disable that with a
978GTK setting and do select the menu when <F10> isn't mapped. (David Necas)
979
980After "Y" '[ and '] were not at start/end of the yanked text.
981
982When a telnet connection is dropped Vim preserves files and exits. While
983doing that a SIGHUP may arrive and disturbe us, thus ignore it. (Scott
Bram Moolenaar46c9c732004-12-12 11:37:09 +0000984Anderson) Also postpone SIGHUP, SIGQUIT and SIGTERM until it's safe to
985handle. Added handle_signal().
986
987When using "set laststatus=2 cmdheight=2" in the .gvimrc you may only get one
988line for the cmdline. (Christian Robinson) Invoke command_height() after the
989GUI has started up.
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000990
Bram Moolenaar1cd871b2004-12-19 22:46:22 +0000991When completing a file name on the command line backslashes are required for
992white space. Was only done for a space, not for a Tab.
993
994When configure could not find a terminal library, compiling continued for a
995long time before reporting the problem. Added a configure check for tgetent()
996being found in a library.
997
998When the cursor is on the first char of the last line a ":g/pat/s///" command
999may cause the cursor to be displayed below the text.
1000
1001Win32: Editing a file with non-ASCII characters doesn't work when 'encoding'
1002is "utf-8". use _wfullpath() instead of _fullpath(). (Yu-sung Moon)
1003
1004When recovering the 'fileformat' and 'fileencoding' were taken from the
1005original file instead of from the swapfile. When the file didn't exist, was
1006empty or the option was changed (e.g., with ":e ++fenc=cp123 file") it could
1007be wrong. Now store 'fileformat' and 'fileencoding' in the swapfile and use
1008the values when recovering.
1009
1010":bufdo g/something/p" overwrites each last printed text line with the file
1011message for the next buffer. Temporarily clear 'shortmess' to avoid that.
1012
Bram Moolenaarb5bf5b82004-12-24 14:35:23 +00001013Win32: Cannot edit a file starting with # with --remote. Do escape % and #
1014when building the ":drop" command.
1015
Bram Moolenaar86b68352004-12-27 21:59:20 +00001016A comment or | just after a expresion-backtick argument was not recognized.
1017E.g. in :e `="foo"`"comment.
1018
Bram Moolenaar567e4de2004-12-31 21:01:02 +00001019"(" does not stop at an empty sentence (single dot and white space) while ")"
1020does. Also breaks "das" on that dot.
1021
1022When doing "yy" with the cursor on a TAB the ruler could be wrong and "k"
1023moved the cursor to another column.
1024
1025When 'commentstring' is '"%s' and there is a double quote in the line a double
1026quote before the fold marker isn't removed in the text displayed for a closed
1027fold.
1028
1029In Visual mode, when 'bin' and 'eol' set, g CTRL-G counted the last line
1030break, resulting in "selected 202 of 201 bytes".
1031
Bram Moolenaar2079a602005-01-04 21:43:22 +00001032Motif: fonts were not used for dialog components. (Marcin Dalecki)
Bram Moolenaar567e4de2004-12-31 21:01:02 +00001033
Bram Moolenaar49cd9572005-01-03 21:06:01 +00001034Motif: After using a toolbar button the keyboard focus would be on the toolbar
Bram Moolenaar2079a602005-01-04 21:43:22 +00001035(Lesstif problem). (Marcin Dalecki)
Bram Moolenaar49cd9572005-01-03 21:06:01 +00001036
Bram Moolenaar1c2fda22005-01-02 11:43:19 +00001037When using "y<C-V>`x" where mark x is in the first column, the last line was
1038not included.
1039
1040Not all test scripts work properly on MS-Windows when checked out from CVS.
1041Use a Vim command to fix all fileformats to dos before executing the tests.
1042
1043When using ":new" and the file fits in the window, lines could still be above
1044the window. Now remove empty lines instead of keeping the relative position.
1045
Bram Moolenaar3d60ec22005-01-05 22:19:46 +00001046Cmdline completion didn't work after ":let var1 var<Tab>".
1047
Bram Moolenaarb7d6e722005-01-09 21:22:45 +00001048When using ":startinsert" or ":startreplace" when already in Insert mode
1049(possible when using CTRL-R =), pressing Esc would directly restart Insert
1050mode. (Peter Winters)
1051
Bram Moolenaar31c67ef2005-01-11 21:34:41 +00001052"2daw" didn't work at end of file if the last word is a single character.
1053
Bram Moolenaar8c711452005-01-14 21:53:12 +00001054Completion for ":next a'<Tab>" put a backslash before single quote, but it was
1055not removed when editing a file. Now halve backslashes in save_patterns().
Bram Moolenaar798c5a72005-01-16 22:06:30 +00001056Also fix expanding a file name with the shell that contains "\'".
Bram Moolenaar8c711452005-01-14 21:53:12 +00001057
Bram Moolenaarb71ec9f2005-01-25 22:22:02 +00001058When doing "1,6d|put" only "fewer lines" was reported. Now a following "more
1059lines" overwrites the message.
1060
1061Configure could not handle "-Dfoo=long\ long" in the TCL config output.
1062
Bram Moolenaarb2956cd2005-01-27 14:42:53 +00001063When searching backwards, using a pattern that matches a newline and uses \zs
1064after that, didn't find a match. Could also get a hang or end up in the right
1065column in the wrong line.
1066
Bram Moolenaard438e912005-01-31 19:21:46 +00001067When $LANG is "sl" for slovenian, the slovak menu was used, since "slovak"
1068starts with "sl".
1069
1070When 'paste' is set in the GUI the Paste toolbar button doesn't work. Clear
1071'paste' when starting the GUI.
1072
Bram Moolenaarf5836682005-02-02 23:09:45 +00001073A message about a wrong viminfo line included the trailing NL.
1074
Bram Moolenaar2a8d1f82005-02-05 21:43:56 +00001075When 'paste' is set in the GUI the toolbar button doesn't work in Insert mode.
1076Use ":exe" in menu.vim to avoid duplicating the commands, instead of using a
1077mapping.
1078
1079Treat "mlterm" as an xterm-like terminal. (Seiichi Sato)
1080
1081":z.4" and ":z=4" didn't work Vi compatible.
1082
Bram Moolenaarbee0c5b2005-02-07 22:03:36 +00001083When sourcing a file, editing it and sourcing it again, it could appear twice
1084in ":scriptnames" and get a new <SID>, because the inode has changed.
1085
1086When $SHELL is set but empty the 'shell' option would be empty. Don't use an
1087empty $SHELL value.
1088
1089A command "w! file" in .vimrc or $EXINIT didn't work. Now it writes an empty
1090file.
1091
1092When a CTRL-F command at the end of the file failed, the cursor was still
1093moved to the start of the line. Now it remains where it is.
1094
1095When using ":s" or "&" to repeat the last substitute and "$" was used to put
1096the cursor in the last column, put the cursor in the last column again. This
1097is Vi compatible.
1098
Bram Moolenaar4399ef42005-02-12 14:29:27 +00001099Vim is not fully POSIX compliant but sticks with traditional Vi behavior.
1100Added a few flags in 'cpoptions' to behave the POSIX way when wanted. The
1101$VIM_POSIX environment variable is checked to set the default.
1102
1103Appending to a register didn't insert a line break like Vi. Added the '>'
1104flag to 'cpoptions' for this.
1105
1106Using "I" in a line with only blanks appended to the line. This is not Vi
1107compatible. Added the 'H' flag in 'coptions' for this.
1108
1109When joining multiple lines the cursor would be at the last joint, but Vi
1110leaves it at the position where "J" would put it. Added the 'q' flag in
1111'cpoptions' for this.
1112
1113Autoindent didn't work for ":insert" and ":append".
1114
1115Using ":append" in an empty buffer kept the dummy line. Now it's deleted to
1116be Vi compatible.
1117
1118When reading commands from a file and stdout goes to a terminal, would still
1119request the xterm version. Vim can't read it, thus the output went to the
1120shell and caused trouble there.
1121
Bram Moolenaar5313dcb2005-02-22 08:56:13 +00001122When redirecting to a register with an invalid name the redirection would
1123still be done (after an error message). Now reset "redir_reg". (Yegappan
1124Lakshmanan)
1125
1126It was not possible to use a NL after a backslash in Ex mode. This is
1127sometimes used to feed multiple lines to a shell command.
1128
Bram Moolenaar05159a02005-02-26 23:04:13 +00001129When 'cmdheight' is set to 2 in .vimrc and the GUI uses the number of lines
1130from the terminal we actually get 3 lines for the cmdline in gvim.
1131
1132When setting $HOME allocated memory would leak.
1133
Bram Moolenaar19a09a12005-03-04 23:39:37 +00001134Win32: bold characters may sometimes write in another character cell. Use
1135unicodepdy[] as for UTF-8. (Taro Muraoka)
1136
1137":w fname" didn't work for files with 'buftype' set to "nofile".
1138
Bram Moolenaare2ac10d2005-03-07 23:26:06 +00001139The method used to locate user commands for completion differed from when they
1140are executed. Abiguous command names were not completed properly.
1141
Bram Moolenaar9062a9d2005-03-08 22:46:26 +00001142Incremental search may cause a crash when there is a custom statusline that
1143indirectly invokes ":normal".
1144
1145Diff mode failed when $DIFF_OPTIONS was set in the environment. Unset it
1146before invoking "diff".
1147
Bram Moolenaar4ad237d2005-03-11 22:49:40 +00001148Completion didn't work after ":argdo", ":windo" and ":bufdo". Also for ":set
1149&l:opt" and ":set &g:opt". (Peter Winters)
1150
1151When setting 'ttymouse' to "dec" in an xterm that supports the DEC mouse
1152locator it doesn't work. Now switch off the mouse before selecting another
1153mouse model.
1154
Bram Moolenaarfb269802005-03-15 22:46:30 +00001155When the CursorHold event is triggered and the commands peek for typed
1156characters the typeahead buffer may be messed up, e.g., when a mouse-up event
1157is received. Avoid invoking the autocommands from the function waiting for a
1158character, let it put K_CURSORHOLD in the input buffer.
1159
1160Removed the "COUNT" flag from ":argadd", to avoid ":argadd 1*" to be used like
Bram Moolenaarc0761132005-03-18 20:30:32 +00001161":1argadd *". Same for ":argdelete" and ":argedit".
Bram Moolenaarfb269802005-03-15 22:46:30 +00001162
1163Avoid that $LANG is used for the menus when LC_MESSAGES is "en_US".
1164
Bram Moolenaarc0761132005-03-18 20:30:32 +00001165Added backslashes before dashes in the vim.1 manual page to make the appear as
1166real dashes. (Pierr Habouzit)
1167
1168Where "gq" left the cursor depended on the value of 'formatprg'. Now "gq"
1169always leaves the cursor at the last line of the formatted text.
1170
1171When editing a compressed file, such as "changelog.Debian.gz" file, filetype
1172detection may try to check the contents of the file while it's still
1173compressed. Skip setting 'filetype' for compressed files until they have been
1174decompressed. Required for patterns that end in a "*".
1175
1176Starting with an argument "+cmd" or "-S script" causes the cursor the be moved
1177to the first line. That breaks a BufReadPost autocommand that uses g`".
1178Don't move the cursor if it's somewhere past the first line.
1179
1180"gg=G" while 'modifiable' is off was uninterruptable.
1181
Bram Moolenaar60c78922005-03-20 22:40:14 +00001182When 'encoding' is "sjis" inserting CTRL-V u d800 a few times causes a crash.
1183Don't insert a DBCS character with a NUL second byte.
1184
Bram Moolenaar2641f772005-03-25 21:58:17 +00001185In Insert mode CTRL-O <Home> didn't move the cursor. Made "ins_at_eol" global
1186and reset it in nv_home().
1187
Bram Moolenaarb982ca52005-03-28 21:02:15 +00001188Wildcard expansion failed: ":w /tmp/$$.`echo test`". Don't put quotes around
1189spaces inside backticks.
1190
Bram Moolenaar13fcaaf2005-04-15 21:13:42 +00001191After this sequence of commands: Y V p gv: the wrong line is selected. Now
1192let "gv" select the text that was put, since the original text is deleted.
1193This should be the most useful thing to do.
1194
1195":sleep 100u" sleeps for 100 seconds, not 100 usec as one might expect. Give
1196an error message when the argument isn't recognized.
1197
1198In gui_mch_draw_string() in gui_w32.c "unibuflen" wasn't static, resulting in
1199reallocating the buffer every time. (Alexei Alexandrov)
1200
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +00001201When using a Python "atexit" function it was not invoked when Vim exits. Now
1202call Py_Finalize() for that. (Ugo Di Girolamo)
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +00001203This breaks the thread stuff though, fixed by Ugo.
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +00001204
Bram Moolenaardba8a912005-04-24 22:08:39 +00001205GTK GUI: using a .vimrc with "set cmdheight=2 lines=43" and ":split" right
1206after startup, the window layout is messed up. (Michael Schaap) Added
1207win_new_shellsize() call in gui_init() to fix the topframe size.
1208
1209Trick to get ...MOUSE_NM not used when there are vertical splits. Now pass
1210column -1 for the left most window and add MOUSE_COLOFF for others. Limits
1211mouse column to 10000.
1212
1213searchpair() may hang when the end pattern has "\zs" at the end. Check that
1214we find the same position again and advance one character.
1215
1216When in diff mode and making a change that causes the "changed" highlighting
1217to disappear or reappear, it was still highlighted in another window.
1218
Bram Moolenaar34cdc3e2005-05-18 22:24:46 +00001219When a ":next" command fails because the user selects "Abort" at the ATTENTION
1220prompt the argument index was advanced anyway.
1221
1222When "~" is in 'iskeyword' the "gd" doesn't work, it's used for the previous
1223substitute pattern. Put "\V" in the pattern to avoid that.
1224
Bram Moolenaar555b2802005-05-19 21:08:39 +00001225Use of sprintf() sometimes didn't check properly for buffer overflow. Also
1226when using smsg(). Included code for snprintf() to avoid having to do size
1227checks where invoking them
1228
Bram Moolenaarf4630b62005-05-20 21:31:17 +00001229":help \=<Tab>" didn't find "sub-replace-\=". Wild menu for help tags didn't
1230show backslashes. ":he :s\=" didn't work.
1231
1232When reading an errorfile "~/" in a file name was not expanded.
1233
1234GTK GUI: When adding a scrollbar (e.g. when using ":vsplit") in a script or
1235removing it the window size may change. GTK sends us resize events when we
1236change the window size ourselves, but they may come at an unexpected moment.
1237Peek for a character to get any window resize events and fix 'columns' and
1238'lines' to undo this.
1239
Bram Moolenaar67fe1a12005-05-22 22:12:58 +00001240After deleting files from the argument list a session file generated with
1241":mksession" may contain invalid ":next" commands.
1242
1243When 'shortmess' is empty and 'keymap' set to accents, in Insert mode CTRL-N
1244may cause the hit-enter prompt. Typing 'a then didn't result in the accented
1245character. Put the character typed at the prompt back in the typeahead buffer
1246so that mapping is done in the right mode.
1247
Bram Moolenaarb2ec3072005-06-17 22:02:20 +00001248setbufvar() and setwinvar() did not give error messages.
1249
1250It was possible to set a variable with an illegal name, e.g. with setbufvar().
Bram Moolenaard857f0e2005-06-21 22:37:39 +00001251It was possible to define a function with illegal name, e.t. ":func F{-1}()"
1252
1253CTRL-W F and "gf" didn't use the same method to get the file name.
Bram Moolenaarb2ec3072005-06-17 22:02:20 +00001254
Bram Moolenaar42eeac32005-06-29 22:40:58 +00001255When reporting a conversion error the line number of the last error could be
1256given. Now report the first encountered error.
1257
1258When using ":e ++enc=name file" and iconv() was used for conversion an error
1259caused a fallback to no conversion. Now replace a character with '?' and
1260continue.
1261
Bram Moolenaar51bab742005-07-08 22:31:03 +00001262When opening a new buffer the local value of 'bomb' was not initialized from
1263the global value.
1264
Bram Moolenaare759a7a2005-07-12 22:50:18 +00001265Win32: When using the "Edit with Vim" entry the file name was limited to about
1266200 characters.
1267
Bram Moolenaar342337a2005-07-21 21:11:17 +00001268When using command line completion for ":e *foo" and the file "+foo" exists
1269the resulting command ":e +foo" doesn't work. Now insert a backslash: ":e
1270\+foo".
1271
Bram Moolenaar87e25fd2005-07-27 21:13:01 +00001272When the translation of "-- More --" was not 10 characters long the following
1273message would be in the wrong position.
1274
1275At the more-prompt the last character in the last line wasn't drawn.
1276
1277When deleting non-existing text while 'virtualedit' is set the '[ and '] marks
1278were not set.
1279
Bram Moolenaar0be6e642005-08-04 21:32:22 +00001280Win32: Could not use "**/" in 'path', it had to be "**\".
1281
Bram Moolenaar071d4272004-06-13 20:20:40 +00001282 vim:tw=78:ts=8:ft=help:norl: