1*os_dos.txt*    For Vim version 7.3.  Last change: 2006 Mar 30
2
3
4		  VIM REFERENCE MANUAL    by Bram Moolenaar
5
6
7							*dos* *DOS*
8This file documents the common particularities of the MS-DOS and Win32
9versions of Vim.  Also see |os_win32.txt| and |os_msdos.txt|.
10
111. File locations		|dos-locations|
122. Using backslashes		|dos-backslash|
133. Standard mappings		|dos-standard-mappings|
144. Screen output and colors	|dos-colors|
155. File formats			|dos-file-formats|
166. :cd command			|dos-:cd|
177. Interrupting			|dos-CTRL-Break|
188. Temp files			|dos-temp-files|
199. Shell option default		|dos-shell|
20
21==============================================================================
221. File locations					*dos-locations*
23
24If you keep the Vim executable in the directory that contains the help and
25syntax subdirectories, there is no need to do anything special for Vim to
26work.  No registry entries or environment variables need to be set.  Just make
27sure that the directory is in your search path, or use a shortcut on the
28desktop.
29
30Your vimrc files ("_vimrc" and "_gvimrc") are normally located one directory
31up from the runtime files.  If you want to put them somewhere else, set the
32environment variable $VIM to the directory where you keep them.  Example: >
33	set VIM=C:\user\piet
34Will find "c:\user\piet\_vimrc".
35Note: This would only be needed when the computer is used by several people.
36Otherwise it's simpler to keep your _vimrc file in the default place.
37
38If you move the executable to another location, you also need to set the $VIM
39environment variable.  The runtime files will be found in "$VIM/vim{version}".
40Example: >
41	set VIM=E:\vim
42Will find the version 5.4 runtime files in "e:\vim\vim54".
43Note: This is _not_ recommended.  The preferred way is to keep the executable
44in the runtime directory.
45
46If you move your executable AND want to put your "_vimrc" and "_gvimrc" files
47somewhere else, you must set $VIM to where you vimrc files are, and set
48$VIMRUNTIME to the runtime files.  Example: >
49	set VIM=C:\usr\piet
50	set VIMRUNTIME=E:\vim\vim54
51Will find "c:\user\piet\_vimrc" and the runtime files in "e:\vim\vim54".
52
53See |$VIM| and |$VIMRUNTIME| for more information.
54
55Under Windows 95, you can set $VIM in your C:\autoexec.bat file.  For
56example: >
57  set VIM=D:\vim
58Under Windows NT, you can set environment variables for each user separately
59under "Start/Settings/Control Panel->System", or through the properties in the
60menu of "My Computer", under the Environment Tab.
61
62==============================================================================
632. Using backslashes					*dos-backslash*
64
65Using backslashes in file names can be a problem.  Vi halves the number of
66backslashes for some commands.  Vim is a bit more tolerant and does not remove
67backslashes from a file name, so ":e c:\foo\bar" works as expected.  But when
68a backslash occurs before a special character (space, comma, backslash, etc.),
69Vim removes the backslash.  Use slashes to avoid problems: ":e c:/foo/bar"
70works fine.  Vim replaces the slashes with backslashes internally to avoid
71problems with some MS-DOS programs and Win32 programs.
72
73When you prefer to use forward slashes, set the 'shellslash' option.  Vim will
74then replace backslashes with forward slashes when expanding file names.  This
75is especially useful when using a Unix-like 'shell'.
76
77==============================================================================
783. Standard mappings				*dos-standard-mappings*
79
80The mappings for CTRL-PageUp and CTRL-PageDown have been removed, they now
81jump to the next or previous tab page |<C-PageUp>| |<C-PageDown>|
82
83If you want them to move to the first and last screen line you can use these
84mappings:
85
86key		key code     Normal/Visual mode	    Insert mode ~
87CTRL-PageUp	<M-N><M-C-D>	    H		    <C-O>H
88CTRL-PageDown	<M-N>v		    L$		    <C-O>L<C-O>$
89
90Additionally, these keys are available for copy/cut/paste.  In the Win32
91and DJGPP versions, they also use the clipboard.
92
93Shift-Insert	paste text (from clipboard)			*<S-Insert>*
94CTRL-Insert	copy Visual text (to clipboard)			*<C-Insert>*
95CTRL-Del	cut Visual text (to clipboard)			*<C-Del>*
96Shift-Del	cut Visual text (to clipboard)			*<S-Del>*
97
98These mappings accomplish this (Win32 and DJGPP versions of Vim):
99
100key		key code     Normal	Visual	    Insert ~
101Shift-Insert	<M-N><M-T>   "*P	"-d"*P      <C-R><C-O>*
102CTRL-Insert	<M-N><M-U>		"*y
103Shift-Del	<M-N><M-W>		"*d
104CTRL-Del	<M-N><M-X>		"*d
105
106Or these mappings (non-Win32 version of Vim):
107
108key		key code     Normal	Visual	    Insert ~
109Shift-Insert	<M-N><M-T>   P		"-dP	    <C-R><C-O>"
110CTRL-Insert	<M-N><M-U>		y
111Shift-Del	<M-N><M-W>		d
112CTRL-Del	<M-N><M-X>		d
113
114When the clipboard is supported, the "* register is used.
115
116==============================================================================
1174. Screen output and colors				*dos-colors*
118
119The default output method for the screen is to use bios calls.  This works
120right away on most systems.  You do not need ansi.sys.  You can use ":mode" to
121set the current screen mode.  See |:mode|.
122
123To change the screen colors that Vim uses, you can use the |:highlight|
124command.  The Normal highlight group specifies the colors Vim uses for normal
125text.  For example, to get grey text on a blue background: >
126	:hi Normal ctermbg=Blue ctermfg=grey
127See |highlight-groups| for other groups that are available.
128
129A DOS console does not support attributes like bold and underlining.  You can
130set the color used in five modes with nine terminal options.  Note that this
131is not necessary since you can set the color directly with the ":highlight"
132command; these options are for backward compatibility with older Vim versions.
133The |'highlight'| option specifies which of the five modes is used for which
134action. >
135
136	:set t_mr=^V^[\|xxm		start of invert mode
137	:set t_md=^V^[\|xxm		start of bold mode
138	:set t_me=^V^[\|xxm		back to normal text
139
140	:set t_so=^V^[\|xxm		start of standout mode
141	:set t_se=^V^[\|xxm		back to normal text
142
143	:set t_us=^V^[\|xxm		start of underline mode
144	:set t_ue=^V^[\|xxm		back to normal text
145
146	:set t_ZH=^V^[\|xxm		start of italics mode
147	:set t_ZR=^V^[\|xxm		back to normal text
148
149^V is CTRL-V
150^[ is <Esc>
151You must replace xx with a decimal code, which is the foreground color number
152and background color number added together:
153
154COLOR			FOREGROUND	BACKGROUND	~
155Black			    0		    0
156DarkBlue		    1		   16
157DarkGreen		    2		   32
158DarkCyan		    3		   48
159DarkRed			    4		   64
160DarkMagenta		    5		   80
161Brown, DarkYellow	    6		   96
162LightGray		    7		  112
163DarkGray		    8		  128 *
164Blue, LightBlue		    9		  144 *
165Green, LightGreen	   10		  160 *
166Cyan, LightCyan		   11		  176 *
167Red, LightRed		   12		  192 *
168Magenta, LightMagenta	   13		  208 *
169Yellow, LightYellow	   14		  224 *
170White			   15		  240 *
171
172* Depending on the display mode, the color codes above 128 may not be
173  available, and code 128 will make the text blink.
174
175When you use 0, the color is reset to the one used when you started Vim
176(usually 7, lightgray on black, but you can override this.  If you have
177overridden the default colors in a command prompt, you may need to adjust
178some of the highlight colors in your vimrc---see below).
179This is the default for t_me.
180
181The defaults for the various highlight modes are:
182	t_mr	112	 reverse mode: Black text (0) on LightGray (112)
183	t_md	 15	 bold mode: White text (15) on Black (0)
184	t_me	  0	 normal mode (revert to default)
185
186	t_so	 31	 standout mode: White (15) text on DarkBlue (16)
187	t_se	  0	 standout mode end (revert to default)
188
189	t_czh	225	 italic mode: DarkBlue text (1) on Yellow (224)
190	t_czr	  0	 italic mode end (revert to default)
191
192	t_us	 67	 underline mode: DarkCyan text (3) on DarkRed (64)
193	t_ue	  0	 underline mode end (revert to default)
194
195These colors were chosen because they also look good when using an inverted
196display, but you can change them to your liking.
197
198Example: >
199  :set t_mr=^V^[\|97m	" start of invert mode: DarkBlue (1) on Brown (96)
200  :set t_md=^V^[\|67m	" start of bold mode: DarkCyan (3) on DarkRed (64)
201  :set t_me=^V^[\|112m	" back to normal mode: Black (0) on LightGray (112)
202
203  :set t_so=^V^[\|37m	" start of standout mode: DarkMagenta (5) on DarkGreen
204									(32)
205  :set t_se=^V^[\|112m	" back to normal mode: Black (0) on LightGray (112)
206
207==============================================================================
2085. File formats						*dos-file-formats*
209
210If the 'fileformat' option is set to "dos" (which is the default), Vim accepts
211a single <NL> or a <CR><NL> pair for end-of-line (<EOL>).  When writing a
212file, Vim uses <CR><NL>.  Thus, if you edit a file and write it, Vim replaces
213<NL> with <CR><NL>.
214
215If the 'fileformat' option is set to "unix", Vim uses a single <NL> for <EOL>
216and shows <CR> as ^M.
217
218You can use Vim to replace <NL> with <CR><NL> by reading in any mode and
219writing in Dos mode (":se ff=dos").
220You can use Vim to replace <CR><NL> with <NL> by reading in Dos mode and
221writing in Unix mode (":se ff=unix").
222
223Vim sets 'fileformat' automatically when 'fileformats' is not empty (which is
224the default), so you don't really have to worry about what you are doing.
225					|'fileformat'| |'fileformats'|
226
227If you want to edit a script file or a binary file, you should set the
228'binary' option before loading the file.  Script files and binary files may
229contain single <NL> characters which Vim would replace with <CR><NL>.  You can
230set 'binary' automatically by starting Vim with the "-b" (binary) option.
231
232==============================================================================
2336. :cd command						*dos-:cd*
234
235The ":cd" command recognizes the drive specifier and changes the current
236drive.  Use ":cd c:" to make drive C the active drive.  Use ":cd d:\foo" to go
237to the directory "foo" in the root of drive D.  Vim also recognizes UNC names
238if the system supports them; e.g., ":cd \\server\share\dir".  |:cd|
239
240==============================================================================
2417. Interrupting						*dos-CTRL-Break*
242
243Use CTRL-Break instead of CTRL-C to interrupt searches.  Vim does not detect
244the CTRL-C until it tries to read a key.
245
246==============================================================================
2478. Temp files						*dos-temp-files*
248
249Only for the 16 bit and 32 bit DOS version:
250Vim puts temporary files (for filtering) in the first of these directories
251that exists and in which Vim can create a file:
252	$TMP
253	$TEMP
254	C:\TMP
255	C:\TEMP
256	current directory
257
258For the Win32 version (both console and GUI):
259Vim uses standard Windows functions to obtain a temporary file name (for
260filtering).  The first of these directories that exists and in which Vim can
261create a file is used:
262	$TMP
263	$TEMP
264	current directory
265
266==============================================================================
2679. Shell option default					*dos-shell*
268
269The default for the 'sh' ('shell') option is "command.com" on Windows 95 and
270"cmd.exe" on Windows NT.  If SHELL is defined, Vim uses SHELL instead, and if
271SHELL is not defined but COMSPEC is, Vim uses COMSPEC.  Vim starts external
272commands with "<shell> /c <command_name>".  Typing CTRL-Z starts a new command
273subshell.  Return to Vim with "exit".	|'shell'| |CTRL-Z|
274
275If you are running a third-party shell, you may need to set the
276|'shellcmdflag'| ('shcf') and |'shellquote'| ('shq') or |'shellxquote'|
277('sxq') options.  Unfortunately, this also depends on the version of Vim used.
278For example, with the MKS Korn shell or with bash, the values of the options
279should be:
280
281		DOS 16 bit	    DOS 32 bit		Win32  ~
282'shellcmdflag'	   -c			-c		 -c
283'shellquote'	   "
284'shellxquote'						 "
285
286For Dos 16 bit this starts the shell as:
287	<shell> -c "command name" >file
288For Win32 as:
289	<shell> -c "command name >file"
290For DOS 32 bit, DJGPP does this internally somehow.
291
292When starting up, Vim checks for the presence of "sh" anywhere in the 'shell'
293option.  If it is present, Vim sets the 'shellcmdflag' and 'shellquote' or
294'shellxquote' options will be set as described above.
295
296 vim:tw=78:ts=8:ft=help:norl:
297