summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2004-12-19 22:46:22 +0000
committerBram Moolenaar <Bram@vim.org>2004-12-19 22:46:22 +0000
commit1cd871b5341bf43ee99e136844e3131014880f92 (patch)
tree6bd9573dbc14de3c4ec85e424cbec9c8d1ee0ed8
parent46c9c73de8def79baf8f0a34a12549f6c14944f3 (diff)
updated for version 7.0023v7.0023
-rw-r--r--runtime/doc/autocmd.txt8
-rw-r--r--runtime/doc/change.txt11
-rw-r--r--runtime/doc/editing.txt553
-rw-r--r--runtime/doc/intro.txt4
-rw-r--r--runtime/doc/mbyte.txt4
-rw-r--r--runtime/doc/options.txt17
-rw-r--r--runtime/doc/os_mac.txt8
-rw-r--r--runtime/doc/pattern.txt3
-rw-r--r--runtime/doc/tags3
-rw-r--r--runtime/doc/todo.txt83
-rw-r--r--runtime/doc/version7.txt60
-rw-r--r--runtime/filetype.vim8
-rw-r--r--runtime/ftplugin/make.vim5
-rw-r--r--runtime/makemenu.vim3
-rw-r--r--runtime/syntax/2html.vim24
-rw-r--r--runtime/syntax/iss.vim102
-rw-r--r--runtime/syntax/netrc.vim55
-rw-r--r--runtime/syntax/sudoers.vim290
-rw-r--r--src/INSTALLpc.txt8
-rw-r--r--src/Make_bc5.mak3
-rw-r--r--src/Make_cyg.mak16
-rw-r--r--src/Make_ming.mak10
-rw-r--r--src/Make_mvc.mak2
-rw-r--r--src/Make_vms.mms284
-rwxr-xr-xsrc/auto/configure386
-rw-r--r--src/buffer.c13
-rw-r--r--src/charset.c58
-rw-r--r--src/configure.in28
-rw-r--r--src/eval.c35
-rw-r--r--src/ex_cmds.c11
-rw-r--r--src/ex_cmds2.c64
-rw-r--r--src/ex_docmd.c21
-rw-r--r--src/ex_getln.c13
-rw-r--r--src/fileio.c23
-rw-r--r--src/fold.c7
-rw-r--r--src/getchar.c2
-rw-r--r--src/gui.c7
-rw-r--r--src/gui_gtk.c6
-rw-r--r--src/gui_gtk_x11.c8
-rw-r--r--src/gui_kde.cc464
-rw-r--r--src/gui_w32.c2
-rw-r--r--src/gui_x11.c1
-rw-r--r--src/if_xcmdsrv.c90
-rw-r--r--src/macros.h18
-rw-r--r--src/main.c45
-rw-r--r--src/mark.c6
-rw-r--r--src/mbyte.c15
-rw-r--r--src/memline.c211
-rw-r--r--src/menu.c19
-rw-r--r--src/message.c19
-rw-r--r--src/misc1.c79
-rw-r--r--src/misc2.c94
-rw-r--r--src/ops.c24
-rw-r--r--src/option.c63
-rw-r--r--src/option.h3
-rw-r--r--src/os_amiga.c14
-rw-r--r--src/os_mac.c15
-rw-r--r--src/os_msdos.c28
-rw-r--r--src/os_mswin.c144
-rw-r--r--src/os_unix.c25
-rw-r--r--src/os_win32.c16
-rw-r--r--src/proto/ex_cmds2.pro1
-rw-r--r--src/proto/main.pro1
-rw-r--r--src/proto/memline.pro2
-rw-r--r--src/proto/misc1.pro1
-rw-r--r--src/proto/misc2.pro4
-rw-r--r--src/proto/option.pro1
-rw-r--r--src/proto/os_mswin.pro2
-rw-r--r--src/regexp.c72
-rw-r--r--src/screen.c26
-rw-r--r--src/tag.c8
-rw-r--r--src/term.c2
-rw-r--r--src/ui.c7
-rw-r--r--src/version.h4
-rw-r--r--src/vim.h6
-rw-r--r--src/vim.rc18
76 files changed, 2401 insertions, 1395 deletions
diff --git a/runtime/doc/autocmd.txt b/runtime/doc/autocmd.txt
index eddfead8a0..1c7b73c181 100644
--- a/runtime/doc/autocmd.txt
+++ b/runtime/doc/autocmd.txt
@@ -1,4 +1,4 @@
-*autocmd.txt* For Vim version 7.0aa. Last change: 2004 Sep 17
+*autocmd.txt* For Vim version 7.0aa. Last change: 2004 Dec 16
VIM REFERENCE MANUAL by Bram Moolenaar
@@ -230,8 +230,10 @@ BufWritePost After writing the whole buffer to a file
*BufWriteCmd*
BufWriteCmd Before writing the whole buffer to a file.
Should do the writing of the file and reset
- 'modified' if successful. The buffer contents
- should not be changed. |Cmd-event|
+ 'modified' if successful, unless '+' is in
+ 'cpo' and writing to another file |cpo-+|.
+ The buffer contents should not be changed.
+ |Cmd-event|
*FileWritePre*
FileWritePre Before writing to a file, when not writing the
whole buffer. Use the '[ and '] marks for the
diff --git a/runtime/doc/change.txt b/runtime/doc/change.txt
index 5e45ec7ac9..08fdc1d544 100644
--- a/runtime/doc/change.txt
+++ b/runtime/doc/change.txt
@@ -1,4 +1,4 @@
-*change.txt* For Vim version 7.0aa. Last change: 2004 Nov 30
+*change.txt* For Vim version 7.0aa. Last change: 2004 Dec 17
VIM REFERENCE MANUAL by Bram Moolenaar
@@ -351,7 +351,8 @@ The CTRL-A and CTRL-X commands work for (signed) decimal numbers, unsigned
octal and hexadecimal numbers and alphabetic characters. This depends on the
'nrformats' option.
- When 'nrformats' includes "octal", Vim considers numbers starting with a '0'
- to be octal. Other numbers are decimal and may have a preceding minus sign.
+ to be octal, unless the number includes a '8' or '9'. Other numbers are
+ decimal and may have a preceding minus sign.
If the cursor is on a number, the commands apply to that number; otherwise
Vim uses the number to the right of the cursor.
- When 'nrformats' includes "hex", Vim assumes numbers starting with '0x' or
@@ -365,9 +366,13 @@ octal and hexadecimal numbers and alphabetic characters. This depends on the
For numbers with leading zeros (including all octal and hexadecimal numbers),
Vim preserves the number of characters in the number when possible. CTRL-A on
"0077" results in "0100", CTRL-X on "0x100" results in "0x0ff".
+There is one exception: When a number that starts with a zero is found not to
+be octal (it contains a '8' or '9'), but 'nrformats' does include "octal",
+leading zeros are removed to avoid that the result may be recognized as an
+octal number.
Note that when 'nrformats' includes "octal", decimal numbers with leading
-zeros are impossible because they are indistinguishable from octal numbers.
+zeros cause mistakes, because they can be confused with octal numbers.
The CTRL-A command is very useful in a macro. Example: Use the following
steps to make a numbered list.
diff --git a/runtime/doc/editing.txt b/runtime/doc/editing.txt
index 4462515775..753e2ac235 100644
--- a/runtime/doc/editing.txt
+++ b/runtime/doc/editing.txt
@@ -1,4 +1,4 @@
-*editing.txt* For Vim version 7.0aa. Last change: 2004 Oct 12
+*editing.txt* For Vim version 7.0aa. Last change: 2004 Dec 16
VIM REFERENCE MANUAL by Bram Moolenaar
@@ -8,21 +8,22 @@ Editing files *edit-files*
1. Introduction |edit-intro|
2. Editing a file |edit-a-file|
-3. Dialogs |edit-dialogs|
-4. The current directory |current-directory|
-5. The argument list |argument-list|
-6. Writing |writing|
-7. Writing and quitting |write-quit|
+3. The argument list |argument-list|
+4. Writing |writing|
+5. Writing and quitting |write-quit|
+6. Dialogs |edit-dialogs|
+7. The current directory |current-directory|
8. Editing binary files |edit-binary|
9. Encryption |encryption|
10. Timestamps |timestamps|
+11. File Searching |file-searching|
==============================================================================
1. Introduction *edit-intro*
Editing a file with Vim means:
-1. reading the file into the internal buffer
+1. reading the file into a buffer
2. changing the buffer with editor commands
3. writing the buffer into a file
@@ -30,12 +31,13 @@ Editing a file with Vim means:
As long as you don't write the buffer, the original file remains unchanged.
If you start editing a file (read a file into the buffer), the file name is
remembered as the "current file name". This is also known as the name of the
-current buffer.
+current buffer. It can be used with "%" on the command line |:_%|.
*alternate-file*
If there already was a current file name, then that one becomes the alternate
-file name. It can later be used with "#" on the command line |:_#|. However,
-the alternate file name is not changed when |:keepalt| is used.
+file name. It can be used with "#" on the command line |:_#| and you can use
+the |CTRL-^| command to toggle between the current and the alternate file.
+However, the alternate file name is not changed when |:keepalt| is used.
*:keepalt* *:keepa*
:keepalt {cmd} Execute {cmd} while keeping the current alternate file
@@ -43,12 +45,13 @@ the alternate file name is not changed when |:keepalt| is used.
with a function) may still set the alternate file
name. {not in Vi}
-All file names are remembered in the file list. When you enter a file name,
+All file names are remembered in the buffer list. When you enter a file name,
for editing (e.g., with ":e filename") or writing (e.g., with (:w file name"),
-the file name is added to the list. You can use this list to remember which
-files you edited and to quickly switch from one file to another with the
-CTRL-^ command (e.g., to copy text). First type the number of the file and
-then hit CTRL-^. {Vi: only one alternate file name}
+the file name is added to the list. You can use the buffer list to remember
+which files you edited and to quickly switch from one file to another (e.g.,
+to copy text) with the |CTRL-^| command. First type the number of the file
+and then hit CTRL-^. {Vi: only one alternate file name is remembered}
+
CTRL-G or *CTRL-G* *:f* *:fi* *:file*
:f[ile] Prints the current file name (as typed), the
@@ -215,11 +218,10 @@ If you want to keep the changed buffer without saving it, switch on the
{Vi: no ++opt}
:e[dit] [++opt] [+cmd] #[count]
- Edit the [count]th alternate file name (as shown by
- :files). This command does the same as
- [count] CTRL-^. But ":e #" doesn't work if the
- alternate buffer doesn't have a file name, while
- CTRL-^ still works then.
+ Edit the [count]th buffer (as shown by |:files|).
+ This command does the same as [count] CTRL-^. But ":e
+ #" doesn't work if the alternate buffer doesn't have a
+ file name, while CTRL-^ still works then.
Also see |++opt| and |+cmd|.
{Vi: no ++opt}
@@ -268,10 +270,10 @@ If you want to keep the changed buffer without saving it, switch on the
'readonly' option for this buffer. {not in Vi}
*CTRL-^* *CTRL-6*
-[count]CTRL-^ Edit [count]th alternate file (equivalent to ":e
- #[count]"). Without count this gets you to the
- previously edited file. This is a quick way to toggle
- between two (or more) files.
+CTRL-^ Edit the alternate file (equivalent to ":e #").
+ Mostly the alternate file is the previously edited
+ file. This is a quick way to toggle between two
+ files.
If the 'autowrite' or 'autowriteall' option is on and
the buffer was changed, write it.
Mostly the ^ character is positioned on the 6 key,
@@ -279,6 +281,12 @@ If you want to keep the changed buffer without saving it, switch on the
But on some non-US keyboards CTRL-^ is produced in
another way.
+{count}CTRL-^ Edit [count]th file in the buffer list (equivalent to
+ ":e #[count]"). This is a quick way to switch between
+ files.
+ See |CTRL-^| above for further details.
+ {not in Vi}
+
[count]]f *]f* *[f*
[count][f Same as "gf". Deprecated.
@@ -335,11 +343,12 @@ current file name.
Note for systems other than Unix and MS-DOS: When using a command that
accepts a single file name (like ":edit file") spaces in the file name are
allowed, but trailing spaces are ignored. This is useful on systems that
-allow file names with embedded spaces (like the Amiga). Example: The command
-":e Long File Name " will edit the file "Long File Name". When using a
-command that accepts more than one file name (like ":next file1 file2")
-embedded spaces must be escaped with a backslash.
+allow file names with embedded spaces (like MS-Windows and the Amiga).
+Example: The command ":e Long File Name " will edit the file "Long File
+Name". When using a command that accepts more than one file name (like ":next
+file1 file2") embedded spaces must be escaped with a backslash.
+ *wildcard*
Wildcards in {file} are expanded. Which wildcards are supported depends on
the system. These are the common ones:
* matches anything, including nothing
@@ -351,7 +360,8 @@ as a wildcard when "[" is in the 'isfname' option. A simple way to avoid this
is to use "path\[[]abc]". Then the file "path[abc]" literally.
*backtick-expansion* *`-expansion*
-On Unix you can also use backticks in the file name, for example: >
+On Unix and a few other systems you can also use backticks in the file name,
+for example: >
:e `find . -name ver\\*.c -print`
The backslashes before the star are required to prevent "ver*.c" to be
expanded by the shell before executing the find program.
@@ -360,12 +370,11 @@ backticks must be around the whole item. It is not possible to have text
directly before the first or just after the last backtick.
*`=*
-You can have the backticks expanded as a Vim expression, instead of
-an external command, by using the syntax `={expr}` e.g.: >
- :let foo='bar'
- :e `=foo . ".c" `
-This will edit "bar.c". The expression can contain just about anything, thus
-this can also be used to avoid the special meaning of '"', '|', '%' and '#'.
+You can have the backticks expanded as a Vim expression, instead of an
+external command, by using the syntax `={expr}` e.g.: >
+ :e `=tempname()`
+The expression can contain just about anything, thus this can also be used to
+avoid the special meaning of '"', '|', '%' and '#'.
*++opt* *[++opt]*
The [++opt] argument can be used to force the value of 'fileformat' or
@@ -470,241 +479,17 @@ You can encrypt files that are written by setting the 'key' option. This
provides some security against others reading your files. |encryption|
-File Searching *file-searching*
-
-{not available when compiled without the |+path_extra| feature}
-
-The file searching is currently used for the 'path', 'cdpath' and 'tags'
-options. There are three different types of searching:
-
-1) Downward search:
- Downward search uses the wildcards '*', '**' and possibly others
- supported by your operating system. '*' and '**' are handled inside Vim, so
- they work on all operating systems.
-
- The usage of '*' is quite simple: It matches 0 or more characters.
-
- '**' is more sophisticated:
- - It ONLY matches directories.
- - It matches up to 30 directories deep, so you can use it to search an
- entire directory tree
- - The maximum number of levels matched can be given by appending a number
- to '**'.
- Thus '/usr/**2' can match: >
- /usr
- /usr/include
- /usr/include/sys
- /usr/include/g++
- /usr/lib
- /usr/lib/X11
- ....
-< It does NOT match '/usr/include/g++/std' as this would be three
- levels.
- The allowed number range is 0 ('**0' is removed) to 255.
- If the given number is smaller than 0 it defaults to 30, if it's
- bigger than 255 it defaults to 255.
- - '**' can only be at the end of the path or be followed by a path
- separator or by a number and a path separator.
-
- You can combine '*' and '**' in any order: >
- /usr/**/sys/*
- /usr/*/sys/**
- /usr/**2/sys/*
-
-2) Upward search:
- Here you can give a directory and then search the directory tree upward for
- a file. You could give stop-directories to limit the upward search. The
- stop-directories are appended to the path (for the 'path' option) or to
- the filename (for the 'tags' option) with a ';'. If you want several
- stop-directories separate them with ';'. If you want no stop-directory
- ("search upward till the root directory) just use ';'. >
- /usr/include/sys;/usr
-< will search in: >
- /usr/include/sys
- /usr/include
- /usr
-<
- If you use a relative path the upward search is started in Vim's current
- directory or in the directory of the current file (if the relative path
- starts with './' and 'd' is not included in 'cpoptions').
-
- If Vim's current path is /u/user_x/work/release and you do >
- :set path=include;/u/user_x
-< and then search for a file with |gf| the file is searched in: >
- /u/user_x/work/release/include
- /u/user_x/work/include
- /u/user_x/include
-
-3) Combined up/downward search
- If Vim's current path is /u/user_x/work/release and you do >
- set path=**;/u/user_x
-< and then search for a file with |gf| the file is searched in: >
- /u/user_x/work/release/**
- /u/user_x/work/**
- /u/user_x/**
-<
- BE CAREFUL! This might consume a lot of time, as the search of
- '/u/user_x/**' includes '/u/user_x/work/**' and
- '/u/user_x/work/release/**'. So '/u/user_x/work/release/**' is searched
- three and '/u/user_x/work/**' is searched two times.
-
- In the above example you might want to set path to: >
- :set path=**,/u/user_x/**
-< This searches: >
- /u/user_x/work/release/**
- /u/user_x/**
-< This searches the same directories, but in a different order.
-
-==============================================================================
-3. Dialogs *edit-dialogs*
-
- *:confirm* *:conf*
-:conf[irm] {command} Execute {command}, and use a dialog when an
- operation has to be confirmed. Can be used on the
- ":q", ":qa" and ":w" commands (the latter to over-ride
- a read-only setting).
-
-Examples: >
- :confirm w foo
-< Will ask for confirmation when "foo" already exists. >
- :confirm q
-< Will ask for confirmation when there are changes. >
- :confirm qa
-< If any modified, unsaved buffers exist, you will be prompted to save
- or abandon each one. There are also choices to "save all" or "abandon
- all".
-
-If you want to always use ":confirm", set the 'confirm' option.
-
- *:browse* *:bro* *E338* *E614* *E615* *E616* *E578*
-:bro[wse] {command} Open a file selection dialog for an argument to
- {command}. At present this works for |:e|, |:w|,
- |:r|, |:saveas|, |:sp|, |:mkexrc|, |:mkvimrc| and
- |:mksession|.
- {only in Win32, Athena, Motif, GTK and Mac GUI}
- When ":browse" is not possible you get an error
- message. If the |+browse| feature is missing or the
- {command} doesn't support browsing, the {command} is
- executed without a dialog.
- ":browse set" works like |:options|.
-
-The syntax is best shown via some examples: >
- :browse e $vim/foo
-< Open the browser in the $vim/foo directory, and edit the
- file chosen. >
- :browse e
-< Open the browser in the directory specified with 'browsedir',
- and edit the file chosen. >
- :browse w
-< Open the browser in the directory of the current buffer,
- with the current buffer filename as default, and save the
- buffer under the filename chosen. >
- :browse w C:/bar
-< Open the browser in the C:/bar directory, with the current
- buffer filename as default, and save the buffer under the
- filename chosen.
-Also see the |'browsedir'| option.
-For versions of Vim where browsing is not supported, the command is executed
-unmodified.
-
- *browsefilter*
-For MS Windows, you can modify the filters that are used in the browse dialog.
-By setting the g:browsefilter or b:browsefilter variables, you can change the
-filters globally or locally to the buffer. The variable is set to a string in
-the format "{filter label}\t{pattern};{pattern}\n" where {filter label} is the
-text that appears in the "Files of Type" comboBox, and {pattern} is the
-pattern which filters the filenames. Several patterns can be given, separated
-by ';'.
-
-For Motif the same format is used, but only the very first pattern is actually
-used (Motif only offers one pattern, but you can edit it).
-
-For example, to have only Vim files in the dialog, you could use the following
-command: >
-
- let g:browsefilter="Vim Scripts\t*.vim\nVim Startup Files\t*vimrc\n"
-
-You can override the filter setting on a per-buffer basis by setting the
-b:browsefilter variable. You would most likely set b:browsefilter in a
-filetype plugin, so that the browse dialog would contain entries related to
-the type of file you are currently editing. Disadvantage: This makes it
-difficult to start editing a file of a different type. To overcome this, you
-may want to add "All Files\t*.*\n" as the final filter, so that the user can
-still access any desired file.
-
-==============================================================================
-4. The current directory *current-directory*
-
-You may use the |:cd| and |:lcd| commands to change to another directory, so
-you will not have to type that directory name in front of the file names. It
-also makes a difference for executing external commands, e.g. ":!ls".
-
- *:cd* *E472*
-:cd On non-Unix systems: Print the current directory
- name. On Unix systems: Change the current directory
- to the home directory. Use |:pwd| to print the
- current directory on all systems.
-
-:cd {path} Change the current directory to {path}.
- If {path} is relative, it is searched for in the
- directories listed in |'cdpath'|.
- Does not change the meaning of an already opened file,
- because its full path name is remembered. Files from
- the |arglist| may change though!
- On MS-DOS this also changes the active drive.
- To change to the directory of the current file: >
- :cd %:h
-<
- *:cd-* *E186*
-:cd - Change to the previous current directory (before the
- previous ":cd {path}" command). {not in Vi}
-
- *:chd* *:chdir*
-:chd[ir] [path] Same as |:cd|.
-
- *:lc* *:lcd*
-:lc[d] {path} Like |:cd|, but only set the current directory for the
- current window. The current directory for other
- windows is not changed. {not in Vi}
-
- *:lch* *:lchdir*
-:lch[dir] Same as |:lcd|. {not in Vi}
-
- *:pw* *:pwd* *E187*
-:pw[d] Print the current directory name. {Vi: no pwd}
- Also see |getcwd()|.
-
-So long as no |:lcd| command has been used, all windows share the same current
-directory. Using a command to jump to another window doesn't change anything
-for the current directory.
-When a |:lcd| command has been used for a window, the specified directory
-becomes the current directory for that window. Windows where the |:lcd|
-command has not been used stick to the