blob: 574aa35b0fa53c3894b507a78697d158f0faae97 [file] [log] [blame]
Bram Moolenaar071d4272004-06-13 20:20:40 +00001*gui_w32.txt* For Vim version 7.0aa. Last change: 2004 May 03
2
3
4 VIM REFERENCE MANUAL by Bram Moolenaar
5
6
7Vim's Win32 Graphical User Interface *gui-w32* *win32-gui*
8
91. Starting the GUI |gui-w32-start|
102. Vim as default editor |vim-default-editor|
113. Using the clipboard |gui-clipboard|
124. Shell Commands |gui-shell-win32|
135. Special colors |win32-colors|
146. Windows dialogs & browsers |gui-w32-dialogs|
157. Command line arguments |gui-w32-cmdargs|
168. Various |gui-w32-various|
17
18Other relevant documentation:
19|gui.txt| For generic items of the GUI.
20|os_win32.txt| For Win32 specific items.
21
22{Vi does not have a Windows GUI}
23
24==============================================================================
251. Starting the GUI *gui-w32-start*
26
27The Win32 GUI version of Vim will always start the GUI, no matter how you
28start it or what it's called.
29
30The GUI will always run in the Windows subsystem. Mostly shells automatically
31return with a command prompt after starting gvim. If not, you should use the
32"start" command: >
33 start gvim [options] file ..
34
35Note: All fonts (bold, italic) must be of the same size!!! If you don't do
36this, text will disappear or mess up the display. Vim does not check the font
37sizes. It's the size in screen pixels that must be the same. Note that some
38fonts that have the same point size don't have the same pixel size!
39Additionally, the positioning of the fonts must be the same (ascent and
40descent).
41
42The Win32 GUI has an extra menu item: "Edit/Select Font". It brings up the
43standard Windows font selector.
44
45Setting the menu height doesn't work for the Win32 GUI.
46
47 *gui-win32-maximized*
48If you want Vim to start with a maximized window, add this command to your
49vimrc or gvimrc file: >
50 au GUIEnter * simalt ~x
51<
52 *gui-w32s*
53There is a specific version of gvim.exe that runs under the Win32s subsystem
54of Windows 3.1 or 3.11. See |win32s|.
55
56==============================================================================
572. Vim as default editor *vim-default-editor*
58
59To set Vim as the default editor for a file type:
601. Start a Windows Explorer
612. Chose View/Options -> File Types
623. Select the path to gvim for every file type that you want to use it for.
63 (you can also use three spaces in the file type field, for files without an
64 extension).
65 In the "open" action, use: >
66 gvim "%1"
67< The quotes are required for using file names with embedded spaces.
68 You can also use this: >
69 gvim "%L"
70< This should avoid short (8.3 character) file names in some situations. But
71 I'm not sure if this works everywhere.
72
73When you open a file in Vim by double clicking it, Vim changes to that
74file's directory.
75
76If you want Vim to start full-screen, use this for the Open action: >
77 gvim -c "simalt ~x" "%1"
78
79Another method, which also works when you put Vim in another directory (e.g.,
80when you have got a new version):
811. select a file you want to use Vim with
822. <Shift-F10>
833. select "Open With..." menu entry
844. click "Other..."
855. browse to the (new) location of Vim and click "Open"
866. make "Always Use this program..." checked
877. <OK>
88
89 *send-to-menu* *sendto*
90You can also install Vim in the "Send To" menu:
911. Start a Windows Explorer
922. Navigate to your sendto directory:
93 Windows 95: %windir%\sendto (e.g. "c:\windows\sendto")
94 Windows NT: %windir%\profiles\%user%\sendto (e.g.
95 "c:\winnt\profiles\mattha\sendto").
963. Right-click in the file pane and select New->Shortcut
974. Follow the shortcut wizard, using the full path to VIM/GVIM.
98
99When you 'send a file to Vim', Vim changes to that file's directory. Note,
100however, that any long directory names will appear in their short (MS-DOS)
101form. This is a limitation of the Windows "Send To" mechanism.
102
103 *notepad*
104You could replace notepad.exe with gvim.exe, but that has a few side effects.
105Some programs rely on notepad arguments, which are not recognized by Vim. For
106example "notepad -p" is used by some applications to print a file. It's
107better to leave notepad where it is and use another way to start Vim.
108
109 *win32-popup-menu*
110A more drastic approach is to install an "Edit with Vim" entry in the popup
111menu for the right mouse button. With this you can edit any file with Vim.
112
113This can co-exist with the file associations mentioned above. The difference
114is that the file associations will make starting Vim the default action. With
115the "Edit with Vim" menu entry you can keep the existing file association for
116double clicking on the file, and edit the file with Vim when you want. For
117example, you can associate "*.mak" with your make program. You can execute
118the makefile by double clicking it and use the "Edit with Vim" entry to edit
119the makefile.
120
121You can select any files and right-click to see a menu option called "Edit
122with gvim". Chosing this menu option will invoke gvim with the file you have
123selected. If you select multiple files, you will find two gvim-related menu
124options:
125"Edit with multiple gvims" -- one gvim for each file in the selection
126"Edit with single gvim" -- one gvim for all the files in the selection
127And if there already is a gvim running:
128"Edit with existing gvim" -- edit the file with the running gvim
129
130 *install-registry*
131You can add the "Edit with Vim" menu entry in an easy way by using the
132"install.exe" program. It will add several registry entries for you.
133
134You can also do this by hand. This is complicated! Use the install.exe if
135you can.
136
1371. Start the registry editor with "regedit".
1382. Add these keys:
139 key value name value ~
140 HKEY_CLASSES_ROOT\CLSID\{51EEE242-AD87-11d3-9C1E-0090278BBD99}
141 {default} Vim Shell Extension
142 HKEY_CLASSES_ROOT\CLSID\{51EEE242-AD87-11d3-9C1E-0090278BBD99}\InProcServer32
143 {default} {path}\gvimext.dll
144 ThreadingModel Apartment
145 HKEY_CLASSES_ROOT\*\shellex\ContextMenuHandlers\gvim
146 {default} {51EEE242-AD87-11d3-9C1E-0090278BBD99}
147 HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Shell Extensions\Approved
148 {51EEE242-AD87-11d3-9C1E-0090278BBD99}
149 Vim Shell Extension
150 HKEY_LOCAL_MACHINE\Software\Vim\Gvim
151 path {path}\gvim.exe
152 HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Uninstall\vim 5.6
153 DisplayName Vim 5.6: Edit with Vim popup menu entry
154 UninstallString {path}\uninstal.exe
155
156 Replace {path} with the path that leads to the executable.
157 Don't type {default}, this is the value for the key itself.
158
159To remove "Edit with Vim" from the popup menu, just remove the registry
160entries mentioned above. The "uninstal.exe" program can do this for you. You
161can also use the entry in the Windows standard "Add/Remove Programs" list.
162
163If you notice that this entry overrules other file type associations, set
164those associations again by hand (using Windows Explorer, see above). This
165only seems to happen on some Windows NT versions (Windows bug?). Procedure:
1661. Find the name of the file type. This can be done by starting the registry
167 editor, and searching for the extension in \\HKEY_CLASSES_ROOT
1682. In a Windows Explorer, use View/Options/File Types. Search for the file
169 type in the list and click "Edit". In the actions list, you can select on
170 to be used as the default (normally the "open" action) and click on the
171 "Set Default" button.
172
173
174Vim in the "Open With..." context menu *win32-open-with-menu*
175
176If you use the Vim install program you have the choice to add Vim to the "Open
177With..." menu. This means you can use Vim to edit many files. Not every file
178(for unclear reasons...), thus the "Edit with Vim" menu entry is still useful.
179
180One reason to add this is to be able to edit HTML files directly from Internet
181Explorer. To enable this use the "Tools" menu, "Internet Options..." entry.
182In the dialog select the "Programs" tab and select Vim in the "HTML editor"
183choice. If it's not there than installing didn't work properly.
184
185Doing this manually can be done with this script:
186
187----------------------------------------------------------
188REGEDIT4
189
190[HKEY_CLASSES_ROOT\Applications\gvim.exe]
191
192[HKEY_CLASSES_ROOT\Applications\gvim.exe\shell]
193
194[HKEY_CLASSES_ROOT\Applications\gvim.exe\shell\edit]
195
196[HKEY_CLASSES_ROOT\Applications\gvim.exe\shell\edit\command]
197@="c:\\vim\\vim62\\gvim.exe \"%1\""
198
199[HKEY_CLASSES_ROOT\.htm\OpenWithList\gvim.exe]
200
201[HKEY_CLASSES_ROOT\*\OpenWithList\gvim.exe]
202
203----------------------------------------------------------
204
205Change the "c:\\vim\\vim62" bit to where gvim.exe is actually located.
206
207To uninstall this run the Vim uninstall program or manually delete the
208registry entries with "regedit".
209
210==============================================================================
2113. Using the clipboard *gui-clipboard*
212
213Windows has a clipboard, where you can copy text to, and paste text from. Vim
214supports this in several ways. For other systems see |gui-selections|.
215
216The "* register reflects the contents of the clipboard. |quotestar|
217
218When the "unnamed" string is included in the 'clipboard' option, the unnamed
219register is the same. Thus you can yank to and paste from the clipboard
220without prepending "* to commands.
221
222The 'a' flag in 'guioptions' is not included by default. This means that text
223is only put on the clipboard when an operation is performed on it. Just
224Visually selecting text doesn't put it on the clipboard. When the 'a' flag is
225included, the text is copied to the clipboard even when it is not operated
226upon.
227
228 *mswin.vim*
229To use the standard MS-Windows way of CTRL-X, CTRL-C and CTRL-V, use the
230$VIMRUNTIME/mswin.vim script. You could add this line to your _vimrc file: >
231 source $VIMRUNTIME/mswin.vim
232
233Since CTRL-C is used to copy the text to the clipboard, it can't be used to
234cancel an operation. Use CTRL-Break for that.
235
236 *CTRL-V-alternative*
237Since CTRL-V is used to paste, you can't use it to start a blockwise Visual
238selection. You can use CTRL-Q instead. You can also use CTRL-Q in Insert
239mode and Command-line mode to get the old meaning of CTRL-V. But CTRL-Q
240doesn't work for terminals when it's used for control flow.
241
242NOTE: The clipboard support still has a number of bugs. See |todo|.
243
244==============================================================================
2454. Shell Commands *gui-shell-win32*
246
247Vim uses another window for external commands, to make it possible to run any
248command. The external command gets its own environment for running, just like
249it was started from a DOS prompt.
250
251 *win32-vimrun*
252Executing an external command is done indirectly by the "vimrun" command. The
253"vimrun.exe" must be in the path for this to work. Or it must be in the same
254directory as the Vim executable. If "vimrun" cannot be found, the command is
255executed directly, but then the DOS window closes immediately after the
256external command has finished.
257WARNING: If you close this window with the "X" button, and confirm the
258question if you really want to kill the application, Vim may be killed too!
259(This does not apply to commands run asynchronously with ":!start".)
260
261In Windows 95, the window in which the commands are executed is always 25x80
262characters, to be as DOS compatible as possible (this matters!). The default
263system font is used. On NT, the window will be the default you have set up for
264"Console" in Control Panel. On Win32s, the properties of the DOS box are
265determined by _default.pif in the windows directory.
266
267 *msdos-mode*
268If you get a dialog that says "This program is set to run in MS-DOS mode..."
269when you run an external program, you can solve this by changing the
270properties of the associated shortcut:
271- Use a Windows Explorer to find the command.com that is used. It can be
272 c:\command.com, c:\dos\command.com, c:\windows\command.com, etc.
273- With the right mouse button, select properties of this command.com.
274- In the Program tab select "Advanced".
275- Unselect "MS-DOS mode".
276- Click "OK" twice.
277
278 *win32-!start*
279Normally, Vim waits for a command to complete before continuing (this makes
280sense for most shell commands which produce output for Vim to use). If you
281want Vim to start a program and return immediately, you can use the following
282syntax on W95 & NT: >
283 :!start {command}
284On Win32s, you will have to go to another window instead. Don't forget that
285you must tell Windows 3.1x to keep executing a DOS command in the background
286while you switch back to Vim.
287
288==============================================================================
2895. Special colors *win32-colors*
290
291On Win32, the normal DOS colors can be used. See |dos-colors|.
292
293Additionally the system configured colors can also be used. These are known
294by the names Sys_XXX, where XXX is the appropriate system color name, from the
295following list (see the Win32 documentation for full descriptions). Case is
296ignored. note: On Win32s not all of these colors are supported.
297
298Sys_3DDKShadow Sys_3DFace Sys_BTNFace
299Sys_3DHilight Sys_3DHighlight Sys_BTNHilight
300Sys_BTNHighlight Sys_3DLight Sys_3DShadow
301Sys_BTNShadow Sys_ActiveBorder Sys_ActiveCaption
302Sys_AppWorkspace Sys_Background Sys_Desktop
303Sys_BTNText Sys_CaptionText Sys_GrayText
304Sys_Highlight Sys_HighlightText Sys_InactiveBorder
305Sys_InactiveCaption Sys_InactiveCaptionText Sys_InfoBK
306Sys_InfoText Sys_Menu Sys_MenuText
307Sys_ScrollBar Sys_Window Sys_WindowFrame
308Sys_WindowText
309
310Probably the most useful values are
311 Sys_Window Normal window background
312 Sys_WindowText Normal window text
313 Sys_Highlight Highlighted background
314 Sys_HighlightText Highlighted text
315
316These extra colors are also available:
317Gray, Grey, LightYellow, SeaGreen, Orange, Purple, SlateBlue, Violet,
318
319 *rgb.txt*
320Additionally, colors defined by a "rgb.txt" file can be used. This file is
321well known from X11. A few lines from it: >
322
323 255 218 185 peach puff
324 205 133 63 peru
325 255 181 197 pink
326
327This shows the layout of the file: First the R, G and B value as a decimal
328number, followed by the name of the color. The four fields are separated by
329spaces.
330
331You can get an rgb.txt file from any X11 distribution. It is located in a
332directory like "/usr/X11R6/lib/X11/". For Vim it must be located in the
333$VIMRUNTIME directory. Thus the file can be found with "$VIMRUNTIME/rgb.txt".
334
335==============================================================================
336 *gui-w32-dialogs* *dialog*
3376. Windows dialogs & browsers
338
339The Win32 GUI can use familiar Windows components for some operations, as well
340as the traditional interface shared with the console version.
341
342
3436.1 Dialogs
344
345The dialogs displayed by the "confirm" family (i.e. the 'confirm' option,
346|:confirm| command and |confirm()| function) are GUI-based rather than the
347console-based ones used by other versions. The 'c' flag in 'guioptions'
348changes this.
349
350
3516.2 File Browsers
352
353When prepending ":browse" before file editing commands, a file requester is
354used to allow you to select an existing file. See |:browse|.
355
356
3576.3 Tearoff Menus
358
359The Win32 GUI emulates Motif's tear-off menus. At the top of each menu you
360will see a small graphic "rip here" sign. Selecting it will cause a floating
361window to be created with the same menu entries on it. The floating menu can
362then be accessed just as if it was the original (including sub-menus), but
363without having to go to the menu bar each time.
364This is most useful if you find yourself using a command buried in a sub-menu
365over and over again.
366The tearoff menus can be positioned where you like, and always stay just above
367the Main Vim window. You can get rid of them by closing them as usual; they
368also of course close when you exit Vim.
369
370 *:tearoff* *:te*
371:te[aroff] {name} Tear-off the menu {name}. The menu named must have at
372 least one subentry, but need not appear on the
373 menu-bar (see |win32-hidden-menus|).
374
375Example: >
376 :tearoff File
377will make the "File" menu (if there is one) appear as a tearoff menu. >
378
379 :amenu ]Toolbar.Make :make<CR>
380 :tearoff ]Toolbar
381This creates a floating menu that doesn't exist on the main menu-bar.
382
383Note that a menu that starts with ']' will not be displayed.
384
385==============================================================================
3867. Command line arguments *gui-w32-cmdargs*
387
388Analysis of a command line into parameters is not standardised in MS Windows.
389Gvim has to provide logic to analyse a command line. This logic is likely to
390be different from the default logic provided by a compilation system used to
391build vim. The differences relate to unusual double quote (") usage.
392The arguments "C:\My Music\freude.txt" and "+/Sch\"iller" are handled in the
393same way. The argument "+/Sch""iller" may be handled different by gvim and
394vim, depending what it was compiled with.
395
396The rules are:
397 a) A parameter is a sequence of graphic characters.
398 b) Parameters are separated by white space.
399 c) A parameter can be enclosed in double quotes to include white space.
400 d) A sequence of zero or more backslashes (\) and a double quote (")
401 is special. The effective number of backslashes is halved, rounded
402 down. An even number of backslashes reverses the acceptability of
403 spaces and tabs, an odd number of backslashes produces a literal
404 double quote.
405
406So:
407 " is a special double quote
408 \" is a literal double quote
409 \\" is a literal backslash and a special double quote
410 \\\" is a literal backslash and a literal double quote
411 \\\\" is 2 literal backslashes and a special double quote
412 \\\\\" is 2 literal backslashes and a literal double quote
413 etc.
414
415Example: >
416 gvim "C:\My Music\freude" +"set ignorecase" +/"\"foo\\" +\"bar\\\"
417
418opens "C:\My Music\freude" and executes the line mode commands: >
419 set ignorecase; /"foo\ and /bar\"
420
421==============================================================================
4228. Various *gui-w32-various*
423
424 *gui-w32-printing*
425The "File/Print" menu prints the text with syntax highlighting, see
426|:hardcopy|. If you just want to print the raw text and have a default
427printer installed this should also work: >
428 :w >>prn
429
430Vim supports a number of standard MS Windows features. Some of these are
431detailed elsewhere: see |'mouse'|, |win32-hidden-menus|.
432
433 *drag-n-drop-win32*
434You can drag and drop one or more files into the Vim window, where they will
435be opened as normal. See |drag-n-drop|.
436
437 *:simalt* *:si*
438:sim[alt] {key} simulate pressing {key} while holding Alt pressed.
439 {not in Vi} {only for Win32 versions}
440
441Normally, Vim takes control of all Alt-<Key> combinations, to increase the
442number of possible mappings. This clashes with the standard use of Alt as the
443key for accessing menus.
444The quick way of getting standard behavior is to set the 'winaltkeys' option
445to "yes". This however prevents you from mapping Alt keys at all.
446Another way is to set 'winaltkeys' to "menu". Menu shortcut keys are then
447handled by windows, other ALT keys can be mapped. This doesn't allow a
448dependency on the current state though.
449To get round this, the :simalt command allows Vim (when 'winaltkeys' is not
450"yes") to fake a Windows-style Alt keypress. You can use this to map Alt key
451combinations (or anything else for that matter) to produce standard Windows
452actions. Here are some examples: >
453
454 :map <M-f> :simalt f<CR>
455This makes Alt-F pop down the 'File' menu (with the stock Menu.vim) by
456simulating the keystrokes Alt, F. >
457 :map <M-Space> :simalt ~<CR>
458This maps Alt-Space to pop down the system menu for the Vim window. Note that
459~ is used by simalt to represent the <Space> character. >
460 :map <C-n> :simalt ~n<CR>
461Maps Control-N to produce the keys Alt-Space followed by N. This minimizes the
462Vim window via the system menu.
463
464 *intellimouse-wheel-problems*
465When using the Intellimouse mouse wheel causes Vim to stop accepting input, go
466to:
467 ControlPanel - Mouse - Wheel - UniversalScrolling - Exceptions
468
469And add gvim to the list of applications. This problem only appears to happen
470with the Intellimouse driver 2.2 and when "Universal Scrolling" is turned on.
471
472 vim:tw=78:sw=4:ts=8:ft=help:norl: