blob: 925c7e0915c994eec353ffa88554f23e04803e3e [file] [log] [blame]
Bram Moolenaar98056532019-12-12 14:18:35 +01001*os_dos.txt* For Vim version 8.2. Last change: 2006 Mar 30
Bram Moolenaar071d4272004-06-13 20:20:40 +00002
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
Bram Moolenaar8024f932020-01-14 19:29:13 +010042Will find the version 8.2 runtime files in "e:\vim\vim82".
Bram Moolenaar071d4272004-06-13 20:20:40 +000043Note: 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
Bram Moolenaar8024f932020-01-14 19:29:13 +010050 set VIMRUNTIME=E:\vim\vim82
51Will find "c:\user\piet\_vimrc" and the runtime files in "e:\vim\vim82".
Bram Moolenaar071d4272004-06-13 20:20:40 +000052
53See |$VIM| and |$VIMRUNTIME| for more information.
54
Bram Moolenaarade0d392020-01-21 22:33:58 +010055You can set environment variables for each user separately through the
56System Properties dialog box. The steps to do that:
571. Type Windows Key + R to open the "Run" dialog box.
582. Enter "sysdm.cpl" and press the "OK" button. The "System Properties"
59 dialog box will open.
603. Select the "Advanced" tab and press the "Environment Variables..." button.
61 The "Environment Variables" dialog box will open.
624. Select an existing variable in the "User variables" list and press the
63 "Edit..." button to edit it. Or press the "New..." button to add a new
64 variable.
655. After you finished editing variables, press the "OK" button to save the
66 changes.
Bram Moolenaar071d4272004-06-13 20:20:40 +000067
68==============================================================================
692. Using backslashes *dos-backslash*
70
71Using backslashes in file names can be a problem. Vi halves the number of
72backslashes for some commands. Vim is a bit more tolerant and does not remove
73backslashes from a file name, so ":e c:\foo\bar" works as expected. But when
74a backslash occurs before a special character (space, comma, backslash, etc.),
75Vim removes the backslash. Use slashes to avoid problems: ":e c:/foo/bar"
76works fine. Vim replaces the slashes with backslashes internally to avoid
77problems with some MS-DOS programs and Win32 programs.
78
79When you prefer to use forward slashes, set the 'shellslash' option. Vim will
80then replace backslashes with forward slashes when expanding file names. This
81is especially useful when using a Unix-like 'shell'.
82
83==============================================================================
843. Standard mappings *dos-standard-mappings*
85
Bram Moolenaar910f66f2006-04-05 20:41:53 +000086The mappings for CTRL-PageUp and CTRL-PageDown have been removed, they now
87jump to the next or previous tab page |<C-PageUp>| |<C-PageDown>|
Bram Moolenaar071d4272004-06-13 20:20:40 +000088
Bram Moolenaar910f66f2006-04-05 20:41:53 +000089If you want them to move to the first and last screen line you can use these
90mappings:
Bram Moolenaar071d4272004-06-13 20:20:40 +000091
92key key code Normal/Visual mode Insert mode ~
93CTRL-PageUp <M-N><M-C-D> H <C-O>H
94CTRL-PageDown <M-N>v L$ <C-O>L<C-O>$
95
96Additionally, these keys are available for copy/cut/paste. In the Win32
97and DJGPP versions, they also use the clipboard.
98
99Shift-Insert paste text (from clipboard) *<S-Insert>*
100CTRL-Insert copy Visual text (to clipboard) *<C-Insert>*
101CTRL-Del cut Visual text (to clipboard) *<C-Del>*
102Shift-Del cut Visual text (to clipboard) *<S-Del>*
Bram Moolenaare0fa3742016-02-20 15:47:01 +0100103CTRL-X cut Visual text (to clipboard)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000104
105These mappings accomplish this (Win32 and DJGPP versions of Vim):
106
107key key code Normal Visual Insert ~
108Shift-Insert <M-N><M-T> "*P "-d"*P <C-R><C-O>*
109CTRL-Insert <M-N><M-U> "*y
110Shift-Del <M-N><M-W> "*d
111CTRL-Del <M-N><M-X> "*d
Bram Moolenaare0fa3742016-02-20 15:47:01 +0100112CTRL-X <C-X> "*d
Bram Moolenaar071d4272004-06-13 20:20:40 +0000113
114Or these mappings (non-Win32 version of Vim):
115
116key key code Normal Visual Insert ~
117Shift-Insert <M-N><M-T> P "-dP <C-R><C-O>"
118CTRL-Insert <M-N><M-U> y
119Shift-Del <M-N><M-W> d
120CTRL-Del <M-N><M-X> d
121
122When the clipboard is supported, the "* register is used.
123
124==============================================================================
1254. Screen output and colors *dos-colors*
126
127The default output method for the screen is to use bios calls. This works
128right away on most systems. You do not need ansi.sys. You can use ":mode" to
129set the current screen mode. See |:mode|.
130
131To change the screen colors that Vim uses, you can use the |:highlight|
132command. The Normal highlight group specifies the colors Vim uses for normal
133text. For example, to get grey text on a blue background: >
134 :hi Normal ctermbg=Blue ctermfg=grey
135See |highlight-groups| for other groups that are available.
136
137A DOS console does not support attributes like bold and underlining. You can
Bram Moolenaar1d2ba7f2006-02-14 22:29:30 +0000138set the color used in five modes with nine terminal options. Note that this
139is not necessary since you can set the color directly with the ":highlight"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000140command; these options are for backward compatibility with older Vim versions.
141The |'highlight'| option specifies which of the five modes is used for which
142action. >
143
144 :set t_mr=^V^[\|xxm start of invert mode
145 :set t_md=^V^[\|xxm start of bold mode
146 :set t_me=^V^[\|xxm back to normal text
147
148 :set t_so=^V^[\|xxm start of standout mode
149 :set t_se=^V^[\|xxm back to normal text
150
151 :set t_us=^V^[\|xxm start of underline mode
152 :set t_ue=^V^[\|xxm back to normal text
153
154 :set t_ZH=^V^[\|xxm start of italics mode
155 :set t_ZR=^V^[\|xxm back to normal text
156
157^V is CTRL-V
158^[ is <Esc>
159You must replace xx with a decimal code, which is the foreground color number
160and background color number added together:
161
162COLOR FOREGROUND BACKGROUND ~
163Black 0 0
164DarkBlue 1 16
165DarkGreen 2 32
166DarkCyan 3 48
167DarkRed 4 64
168DarkMagenta 5 80
169Brown, DarkYellow 6 96
170LightGray 7 112
171DarkGray 8 128 *
172Blue, LightBlue 9 144 *
173Green, LightGreen 10 160 *
174Cyan, LightCyan 11 176 *
175Red, LightRed 12 192 *
176Magenta, LightMagenta 13 208 *
177Yellow, LightYellow 14 224 *
178White 15 240 *
179
180* Depending on the display mode, the color codes above 128 may not be
181 available, and code 128 will make the text blink.
182
183When you use 0, the color is reset to the one used when you started Vim
184(usually 7, lightgray on black, but you can override this. If you have
185overridden the default colors in a command prompt, you may need to adjust
186some of the highlight colors in your vimrc---see below).
187This is the default for t_me.
188
189The defaults for the various highlight modes are:
190 t_mr 112 reverse mode: Black text (0) on LightGray (112)
191 t_md 15 bold mode: White text (15) on Black (0)
192 t_me 0 normal mode (revert to default)
193
194 t_so 31 standout mode: White (15) text on DarkBlue (16)
195 t_se 0 standout mode end (revert to default)
196
197 t_czh 225 italic mode: DarkBlue text (1) on Yellow (224)
198 t_czr 0 italic mode end (revert to default)
199
200 t_us 67 underline mode: DarkCyan text (3) on DarkRed (64)
201 t_ue 0 underline mode end (revert to default)
202
203These colors were chosen because they also look good when using an inverted
204display, but you can change them to your liking.
205
206Example: >
207 :set t_mr=^V^[\|97m " start of invert mode: DarkBlue (1) on Brown (96)
208 :set t_md=^V^[\|67m " start of bold mode: DarkCyan (3) on DarkRed (64)
209 :set t_me=^V^[\|112m " back to normal mode: Black (0) on LightGray (112)
210
211 :set t_so=^V^[\|37m " start of standout mode: DarkMagenta (5) on DarkGreen
212 (32)
213 :set t_se=^V^[\|112m " back to normal mode: Black (0) on LightGray (112)
214
215==============================================================================
2165. File formats *dos-file-formats*
217
218If the 'fileformat' option is set to "dos" (which is the default), Vim accepts
219a single <NL> or a <CR><NL> pair for end-of-line (<EOL>). When writing a
220file, Vim uses <CR><NL>. Thus, if you edit a file and write it, Vim replaces
221<NL> with <CR><NL>.
222
223If the 'fileformat' option is set to "unix", Vim uses a single <NL> for <EOL>
224and shows <CR> as ^M.
225
226You can use Vim to replace <NL> with <CR><NL> by reading in any mode and
227writing in Dos mode (":se ff=dos").
228You can use Vim to replace <CR><NL> with <NL> by reading in Dos mode and
229writing in Unix mode (":se ff=unix").
230
231Vim sets 'fileformat' automatically when 'fileformats' is not empty (which is
232the default), so you don't really have to worry about what you are doing.
233 |'fileformat'| |'fileformats'|
234
235If you want to edit a script file or a binary file, you should set the
236'binary' option before loading the file. Script files and binary files may
237contain single <NL> characters which Vim would replace with <CR><NL>. You can
238set 'binary' automatically by starting Vim with the "-b" (binary) option.
239
240==============================================================================
2416. :cd command *dos-:cd*
242
243The ":cd" command recognizes the drive specifier and changes the current
244drive. Use ":cd c:" to make drive C the active drive. Use ":cd d:\foo" to go
245to the directory "foo" in the root of drive D. Vim also recognizes UNC names
246if the system supports them; e.g., ":cd \\server\share\dir". |:cd|
247
248==============================================================================
2497. Interrupting *dos-CTRL-Break*
250
251Use CTRL-Break instead of CTRL-C to interrupt searches. Vim does not detect
252the CTRL-C until it tries to read a key.
253
254==============================================================================
2558. Temp files *dos-temp-files*
256
257Only for the 16 bit and 32 bit DOS version:
258Vim puts temporary files (for filtering) in the first of these directories
259that exists and in which Vim can create a file:
260 $TMP
261 $TEMP
262 C:\TMP
263 C:\TEMP
264 current directory
265
266For the Win32 version (both console and GUI):
267Vim uses standard Windows functions to obtain a temporary file name (for
268filtering). The first of these directories that exists and in which Vim can
269create a file is used:
270 $TMP
271 $TEMP
272 current directory
273
274==============================================================================
2759. Shell option default *dos-shell*
276
277The default for the 'sh' ('shell') option is "command.com" on Windows 95 and
278"cmd.exe" on Windows NT. If SHELL is defined, Vim uses SHELL instead, and if
279SHELL is not defined but COMSPEC is, Vim uses COMSPEC. Vim starts external
280commands with "<shell> /c <command_name>". Typing CTRL-Z starts a new command
281subshell. Return to Vim with "exit". |'shell'| |CTRL-Z|
282
283If you are running a third-party shell, you may need to set the
284|'shellcmdflag'| ('shcf') and |'shellquote'| ('shq') or |'shellxquote'|
285('sxq') options. Unfortunately, this also depends on the version of Vim used.
286For example, with the MKS Korn shell or with bash, the values of the options
287should be:
288
289 DOS 16 bit DOS 32 bit Win32 ~
290'shellcmdflag' -c -c -c
291'shellquote' "
292'shellxquote' "
293
294For Dos 16 bit this starts the shell as:
295 <shell> -c "command name" >file
296For Win32 as:
297 <shell> -c "command name >file"
298For DOS 32 bit, DJGPP does this internally somehow.
299
300When starting up, Vim checks for the presence of "sh" anywhere in the 'shell'
301option. If it is present, Vim sets the 'shellcmdflag' and 'shellquote' or
302'shellxquote' options will be set as described above.
303
Bram Moolenaar91f84f62018-07-29 15:07:52 +0200304 vim:tw=78:ts=8:noet:ft=help:norl: