blob: 93f68bd3d38545e7b9b71ec221d8d369314b70ea [file] [log] [blame]
Bram Moolenaar47c532e2022-03-19 15:18:53 +00001*gui_w32.txt* For Vim version 8.2. Last change: 2022 Mar 09
Bram Moolenaar071d4272004-06-13 20:20:40 +00002
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.
Bram Moolenaarfa13eef2013-02-06 17:34:04 +010020|os_win32.txt| For Win32 specific items.
Bram Moolenaar071d4272004-06-13 20:20:40 +000021
Bram Moolenaar071d4272004-06-13 20:20:40 +000022
23==============================================================================
241. Starting the GUI *gui-w32-start*
25
26The Win32 GUI version of Vim will always start the GUI, no matter how you
27start it or what it's called.
28
29The GUI will always run in the Windows subsystem. Mostly shells automatically
30return with a command prompt after starting gvim. If not, you should use the
31"start" command: >
32 start gvim [options] file ..
Bram Moolenaarafde13b2019-04-28 19:46:49 +020033< *E988*
34The console version with the |-g| option may also start the GUI by executing
35gvim.exe: >
36 vim -g [options] file ..
37To make this work, gvim.exe must exist in the same directory as the vim.exe,
38and this feature must be enabled at compile time.
39
40One may also use `:gui` from the console version. However, this is an
41experimental feature and this feature must be enabled at compile time.
42It uses a session file to recreate the current state of the console Vim in the
43GUI Vim.
Bram Moolenaar071d4272004-06-13 20:20:40 +000044
45Note: All fonts (bold, italic) must be of the same size!!! If you don't do
46this, text will disappear or mess up the display. Vim does not check the font
47sizes. It's the size in screen pixels that must be the same. Note that some
48fonts that have the same point size don't have the same pixel size!
49Additionally, the positioning of the fonts must be the same (ascent and
50descent).
51
52The Win32 GUI has an extra menu item: "Edit/Select Font". It brings up the
53standard Windows font selector.
54
55Setting the menu height doesn't work for the Win32 GUI.
56
57 *gui-win32-maximized*
58If you want Vim to start with a maximized window, add this command to your
59vimrc or gvimrc file: >
60 au GUIEnter * simalt ~x
61<
Bram Moolenaar78e17622007-08-30 10:26:19 +000062
63Using Vim as a plugin *gui-w32-windowid*
64
65When gvim starts up normally, it creates its own top level window. If you
66pass Vim the command-line option |--windowid| with a decimal or hexadecimal
67value, Vim will create a window that is a child of the window with the given
68ID. This enables Vim to act as a plugin in another application. This really
69is a programmer's interface, and is of no use without a supporting application
70to spawn Vim correctly.
71
Bram Moolenaar071d4272004-06-13 20:20:40 +000072==============================================================================
732. Vim as default editor *vim-default-editor*
74
75To set Vim as the default editor for a file type:
761. Start a Windows Explorer
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000772. Choose View/Options -> File Types
Bram Moolenaar071d4272004-06-13 20:20:40 +0000783. Select the path to gvim for every file type that you want to use it for.
79 (you can also use three spaces in the file type field, for files without an
80 extension).
81 In the "open" action, use: >
82 gvim "%1"
83< The quotes are required for using file names with embedded spaces.
84 You can also use this: >
85 gvim "%L"
86< This should avoid short (8.3 character) file names in some situations. But
87 I'm not sure if this works everywhere.
88
89When you open a file in Vim by double clicking it, Vim changes to that
90file's directory.
91
92If you want Vim to start full-screen, use this for the Open action: >
93 gvim -c "simalt ~x" "%1"
94
95Another method, which also works when you put Vim in another directory (e.g.,
96when you have got a new version):
971. select a file you want to use Vim with
982. <Shift-F10>
993. select "Open With..." menu entry
1004. click "Other..."
1015. browse to the (new) location of Vim and click "Open"
1026. make "Always Use this program..." checked
1037. <OK>
104
105 *send-to-menu* *sendto*
106You can also install Vim in the "Send To" menu:
1071. Start a Windows Explorer
1082. Navigate to your sendto directory:
Bram Moolenaarcea912a2016-10-12 14:20:24 +0200109 Windows XP: C:\Documents and Settings\%user%\SendTo
110 Windows Vista: C:\Users\%user%\AppData\Roaming\Microsoft\Windows\SendTo .
Bram Moolenaar071d4272004-06-13 20:20:40 +00001113. Right-click in the file pane and select New->Shortcut
1124. Follow the shortcut wizard, using the full path to VIM/GVIM.
113
114When you 'send a file to Vim', Vim changes to that file's directory. Note,
Bram Moolenaar8024f932020-01-14 19:29:13 +0100115however, that any long directory names will appear in their short (MS-DOS)
116form on some Windows versions. This is a limitation of the Windows "Send To"
117mechanism.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000118
119 *notepad*
120You could replace notepad.exe with gvim.exe, but that has a few side effects.
121Some programs rely on notepad arguments, which are not recognized by Vim. For
122example "notepad -p" is used by some applications to print a file. It's
123better to leave notepad where it is and use another way to start Vim.
124
125 *win32-popup-menu*
126A more drastic approach is to install an "Edit with Vim" entry in the popup
127menu for the right mouse button. With this you can edit any file with Vim.
128
129This can co-exist with the file associations mentioned above. The difference
130is that the file associations will make starting Vim the default action. With
131the "Edit with Vim" menu entry you can keep the existing file association for
132double clicking on the file, and edit the file with Vim when you want. For
133example, you can associate "*.mak" with your make program. You can execute
134the makefile by double clicking it and use the "Edit with Vim" entry to edit
135the makefile.
136
137You can select any files and right-click to see a menu option called "Edit
Bram Moolenaarc236c162008-07-13 17:41:49 +0000138with gvim". Choosing this menu option will invoke gvim with the file you have
Bram Moolenaar071d4272004-06-13 20:20:40 +0000139selected. If you select multiple files, you will find two gvim-related menu
140options:
141"Edit with multiple gvims" -- one gvim for each file in the selection
142"Edit with single gvim" -- one gvim for all the files in the selection
143And if there already is a gvim running:
144"Edit with existing gvim" -- edit the file with the running gvim
145
Bram Moolenaar5302d9e2011-09-14 17:55:08 +0200146The "edit with existing Vim" entries can be disabled by adding an entry in the
147registry under HKLM\Software\Vim\Gvim, named DisableEditWithExisting, and with
148any value.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000149 *install-registry*
150You can add the "Edit with Vim" menu entry in an easy way by using the
151"install.exe" program. It will add several registry entries for you.
152
153You can also do this by hand. This is complicated! Use the install.exe if
154you can.
155
1561. Start the registry editor with "regedit".
1572. Add these keys:
158 key value name value ~
159 HKEY_CLASSES_ROOT\CLSID\{51EEE242-AD87-11d3-9C1E-0090278BBD99}
160 {default} Vim Shell Extension
161 HKEY_CLASSES_ROOT\CLSID\{51EEE242-AD87-11d3-9C1E-0090278BBD99}\InProcServer32
162 {default} {path}\gvimext.dll
163 ThreadingModel Apartment
164 HKEY_CLASSES_ROOT\*\shellex\ContextMenuHandlers\gvim
165 {default} {51EEE242-AD87-11d3-9C1E-0090278BBD99}
166 HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Shell Extensions\Approved
167 {51EEE242-AD87-11d3-9C1E-0090278BBD99}
168 Vim Shell Extension
169 HKEY_LOCAL_MACHINE\Software\Vim\Gvim
170 path {path}\gvim.exe
Bram Moolenaar8024f932020-01-14 19:29:13 +0100171 HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Uninstall\vim 8.2
172 DisplayName Vim 8.2: Edit with Vim popup menu entry
Bram Moolenaar38f1eea2019-09-27 14:19:09 +0200173 UninstallString {path}\uninstall.exe
Bram Moolenaar071d4272004-06-13 20:20:40 +0000174
175 Replace {path} with the path that leads to the executable.
176 Don't type {default}, this is the value for the key itself.
177
178To remove "Edit with Vim" from the popup menu, just remove the registry
Bram Moolenaar38f1eea2019-09-27 14:19:09 +0200179entries mentioned above. The "uninstall.exe" program can do this for you.
180You can also use the entry in the Windows standard "Add/Remove Programs" list.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000181
182If you notice that this entry overrules other file type associations, set
183those associations again by hand (using Windows Explorer, see above). This
184only seems to happen on some Windows NT versions (Windows bug?). Procedure:
1851. Find the name of the file type. This can be done by starting the registry
186 editor, and searching for the extension in \\HKEY_CLASSES_ROOT
1872. In a Windows Explorer, use View/Options/File Types. Search for the file
188 type in the list and click "Edit". In the actions list, you can select on
189 to be used as the default (normally the "open" action) and click on the
190 "Set Default" button.
191
192
193Vim in the "Open With..." context menu *win32-open-with-menu*
194
195If you use the Vim install program you have the choice to add Vim to the "Open
196With..." menu. This means you can use Vim to edit many files. Not every file
197(for unclear reasons...), thus the "Edit with Vim" menu entry is still useful.
198
199One reason to add this is to be able to edit HTML files directly from Internet
200Explorer. To enable this use the "Tools" menu, "Internet Options..." entry.
201In the dialog select the "Programs" tab and select Vim in the "HTML editor"
Bram Moolenaard1caa942020-04-10 22:10:56 +0200202choice. If it's not there then installing didn't work properly.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000203
204Doing this manually can be done with this script:
205
206----------------------------------------------------------
207REGEDIT4
208
209[HKEY_CLASSES_ROOT\Applications\gvim.exe]
210
211[HKEY_CLASSES_ROOT\Applications\gvim.exe\shell]
212
213[HKEY_CLASSES_ROOT\Applications\gvim.exe\shell\edit]
214
215[HKEY_CLASSES_ROOT\Applications\gvim.exe\shell\edit\command]
Bram Moolenaar8024f932020-01-14 19:29:13 +0100216@="c:\\vim\\vim82\\gvim.exe \"%1\""
Bram Moolenaar071d4272004-06-13 20:20:40 +0000217
218[HKEY_CLASSES_ROOT\.htm\OpenWithList\gvim.exe]
219
220[HKEY_CLASSES_ROOT\*\OpenWithList\gvim.exe]
221
222----------------------------------------------------------
223
Bram Moolenaar8024f932020-01-14 19:29:13 +0100224Change the "c:\\vim\\vim82" bit to where gvim.exe is actually located.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000225
226To uninstall this run the Vim uninstall program or manually delete the
227registry entries with "regedit".
228
229==============================================================================
2303. Using the clipboard *gui-clipboard*
231
232Windows has a clipboard, where you can copy text to, and paste text from. Vim
233supports this in several ways. For other systems see |gui-selections|.
234
235The "* register reflects the contents of the clipboard. |quotestar|
236
237When the "unnamed" string is included in the 'clipboard' option, the unnamed
238register is the same. Thus you can yank to and paste from the clipboard
Bram Moolenaar47c532e2022-03-19 15:18:53 +0000239without prepending "* to commands. If this doesn't work use the "unnamedplus"
240string in the 'clipboard' option.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000241
242The 'a' flag in 'guioptions' is not included by default. This means that text
243is only put on the clipboard when an operation is performed on it. Just
244Visually selecting text doesn't put it on the clipboard. When the 'a' flag is
245included, the text is copied to the clipboard even when it is not operated
246upon.
247
248 *mswin.vim*
249To use the standard MS-Windows way of CTRL-X, CTRL-C and CTRL-V, use the
250$VIMRUNTIME/mswin.vim script. You could add this line to your _vimrc file: >
251 source $VIMRUNTIME/mswin.vim
252
253Since CTRL-C is used to copy the text to the clipboard, it can't be used to
254cancel an operation. Use CTRL-Break for that.
255
Bram Moolenaar9964e462007-05-05 17:54:07 +0000256CTRL-Z is used for undo. This means you can't suspend Vim with this key, use
257|:suspend| instead (if it's supported at all).
Bram Moolenaar6f7926c2005-01-07 21:45:22 +0000258
Bram Moolenaardf177f62005-02-22 08:39:57 +0000259 *CTRL-V-alternative* *CTRL-Q*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000260Since CTRL-V is used to paste, you can't use it to start a blockwise Visual
261selection. You can use CTRL-Q instead. You can also use CTRL-Q in Insert
262mode and Command-line mode to get the old meaning of CTRL-V. But CTRL-Q
263doesn't work for terminals when it's used for control flow.
264
265NOTE: The clipboard support still has a number of bugs. See |todo|.
266
267==============================================================================
2684. Shell Commands *gui-shell-win32*
269
270Vim uses another window for external commands, to make it possible to run any
271command. The external command gets its own environment for running, just like
272it was started from a DOS prompt.
273
274 *win32-vimrun*
275Executing an external command is done indirectly by the "vimrun" command. The
276"vimrun.exe" must be in the path for this to work. Or it must be in the same
277directory as the Vim executable. If "vimrun" cannot be found, the command is
278executed directly, but then the DOS window closes immediately after the
279external command has finished.
280WARNING: If you close this window with the "X" button, and confirm the
281question if you really want to kill the application, Vim may be killed too!
282(This does not apply to commands run asynchronously with ":!start".)
283
Bram Moolenaarcea912a2016-10-12 14:20:24 +0200284The window in which the commands are executed will be the default you have set
285up for "Console" in Control Panel.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000286
287 *win32-!start*
288Normally, Vim waits for a command to complete before continuing (this makes
289sense for most shell commands which produce output for Vim to use). If you
290want Vim to start a program and return immediately, you can use the following
Bram Moolenaarcea912a2016-10-12 14:20:24 +0200291syntax: >
Bram Moolenaar2a8a3ec2011-01-08 16:06:37 +0100292 :!start [/min] {command}
293The optional "/min" causes the window to be minimized.
294
Bram Moolenaar071d4272004-06-13 20:20:40 +0000295==============================================================================
2965. Special colors *win32-colors*
297
298On Win32, the normal DOS colors can be used. See |dos-colors|.
299
300Additionally the system configured colors can also be used. These are known
301by the names Sys_XXX, where XXX is the appropriate system color name, from the
302following list (see the Win32 documentation for full descriptions). Case is
Bram Moolenaarcea912a2016-10-12 14:20:24 +0200303ignored.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000304
305Sys_3DDKShadow Sys_3DFace Sys_BTNFace
306Sys_3DHilight Sys_3DHighlight Sys_BTNHilight
307Sys_BTNHighlight Sys_3DLight Sys_3DShadow
308Sys_BTNShadow Sys_ActiveBorder Sys_ActiveCaption
309Sys_AppWorkspace Sys_Background Sys_Desktop
310Sys_BTNText Sys_CaptionText Sys_GrayText
311Sys_Highlight Sys_HighlightText Sys_InactiveBorder
312Sys_InactiveCaption Sys_InactiveCaptionText Sys_InfoBK
313Sys_InfoText Sys_Menu Sys_MenuText
314Sys_ScrollBar Sys_Window Sys_WindowFrame
315Sys_WindowText
316
317Probably the most useful values are
318 Sys_Window Normal window background
319 Sys_WindowText Normal window text
320 Sys_Highlight Highlighted background
321 Sys_HighlightText Highlighted text
322
323These extra colors are also available:
324Gray, Grey, LightYellow, SeaGreen, Orange, Purple, SlateBlue, Violet,
325
326 *rgb.txt*
Drew Vogele30d1022021-10-24 20:35:07 +0100327Additionally, colors defined by a default color list can be used. For more
328info see |:colorscheme|. These colors used to be defined in
329$VIMRUNTIME/rgb.txt, now they are in |v:colornames| which is initialized from
330$VIMRUNTIME/colors/lists/default.vim.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000331
332==============================================================================
333 *gui-w32-dialogs* *dialog*
3346. Windows dialogs & browsers
335
336The Win32 GUI can use familiar Windows components for some operations, as well
337as the traditional interface shared with the console version.
338
339
3406.1 Dialogs
341
342The dialogs displayed by the "confirm" family (i.e. the 'confirm' option,
343|:confirm| command and |confirm()| function) are GUI-based rather than the
344console-based ones used by other versions. The 'c' flag in 'guioptions'
345changes this.
346
347
3486.2 File Browsers
349
350When prepending ":browse" before file editing commands, a file requester is
351used to allow you to select an existing file. See |:browse|.
352
353
3546.3 Tearoff Menus
355
356The Win32 GUI emulates Motif's tear-off menus. At the top of each menu you
357will see a small graphic "rip here" sign. Selecting it will cause a floating
358window to be created with the same menu entries on it. The floating menu can
359then be accessed just as if it was the original (including sub-menus), but
360without having to go to the menu bar each time.
361This is most useful if you find yourself using a command buried in a sub-menu
362over and over again.
363The tearoff menus can be positioned where you like, and always stay just above
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000364the Main Vim window. You can get rid of them by closing them as usual; they
Bram Moolenaar071d4272004-06-13 20:20:40 +0000365also of course close when you exit Vim.
366
367 *:tearoff* *:te*
368:te[aroff] {name} Tear-off the menu {name}. The menu named must have at
369 least one subentry, but need not appear on the
370 menu-bar (see |win32-hidden-menus|).
371
372Example: >
373 :tearoff File
374will make the "File" menu (if there is one) appear as a tearoff menu. >
375
376 :amenu ]Toolbar.Make :make<CR>
377 :tearoff ]Toolbar
378This creates a floating menu that doesn't exist on the main menu-bar.
379
380Note that a menu that starts with ']' will not be displayed.
381
382==============================================================================
3837. Command line arguments *gui-w32-cmdargs*
384
Bram Moolenaar01164a62017-11-02 22:58:42 +0100385Command line arguments behave the same way as with the console application,
386see |win32-cmdargs|.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000387
388==============================================================================
3898. Various *gui-w32-various*
390
391 *gui-w32-printing*
392The "File/Print" menu prints the text with syntax highlighting, see
393|:hardcopy|. If you just want to print the raw text and have a default
394printer installed this should also work: >
395 :w >>prn
396
Bram Moolenaar130cbfc2021-04-07 21:07:20 +0200397Vim supports a number of standard MS-Windows features. Some of these are
Bram Moolenaar071d4272004-06-13 20:20:40 +0000398detailed elsewhere: see |'mouse'|, |win32-hidden-menus|.
399
400 *drag-n-drop-win32*
401You can drag and drop one or more files into the Vim window, where they will
402be opened as normal. See |drag-n-drop|.
403
Bram Moolenaar8feef4f2015-01-07 16:57:10 +0100404 *:simalt* *:sim*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000405:sim[alt] {key} simulate pressing {key} while holding Alt pressed.
Bram Moolenaar25c9c682019-05-05 18:13:34 +0200406 {only for Win32 versions}
Bram Moolenaar8feef4f2015-01-07 16:57:10 +0100407 Note: ":si" means ":s" with the "i" flag.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000408
409Normally, Vim takes control of all Alt-<Key> combinations, to increase the
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000410number of possible mappings. This clashes with the standard use of Alt as the
Bram Moolenaar071d4272004-06-13 20:20:40 +0000411key for accessing menus.
412The quick way of getting standard behavior is to set the 'winaltkeys' option
413to "yes". This however prevents you from mapping Alt keys at all.
414Another way is to set 'winaltkeys' to "menu". Menu shortcut keys are then
415handled by windows, other ALT keys can be mapped. This doesn't allow a
416dependency on the current state though.
417To get round this, the :simalt command allows Vim (when 'winaltkeys' is not
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000418"yes") to fake a Windows-style Alt keypress. You can use this to map Alt key
Bram Moolenaar071d4272004-06-13 20:20:40 +0000419combinations (or anything else for that matter) to produce standard Windows
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000420actions. Here are some examples: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000421
422 :map <M-f> :simalt f<CR>
423This makes Alt-F pop down the 'File' menu (with the stock Menu.vim) by
424simulating the keystrokes Alt, F. >
425 :map <M-Space> :simalt ~<CR>
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000426This maps Alt-Space to pop down the system menu for the Vim window. Note that
Bram Moolenaar071d4272004-06-13 20:20:40 +0000427~ is used by simalt to represent the <Space> character. >
428 :map <C-n> :simalt ~n<CR>
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000429Maps Control-N to produce the keys Alt-Space followed by N. This minimizes the
Bram Moolenaar071d4272004-06-13 20:20:40 +0000430Vim window via the system menu.
431
Bram Moolenaar9964e462007-05-05 17:54:07 +0000432Note that the key changes depending on the language you are using.
433
Bram Moolenaar071d4272004-06-13 20:20:40 +0000434 *intellimouse-wheel-problems*
435When using the Intellimouse mouse wheel causes Vim to stop accepting input, go
436to:
437 ControlPanel - Mouse - Wheel - UniversalScrolling - Exceptions
438
439And add gvim to the list of applications. This problem only appears to happen
440with the Intellimouse driver 2.2 and when "Universal Scrolling" is turned on.
441
Bram Moolenaar9b451252012-08-15 17:43:31 +0200442
443XPM support *w32-xpm-support*
444
Bram Moolenaare7b1ea02020-08-07 19:54:59 +0200445GVim can be built on MS-Windows with support for XPM files. |+xpm_w32|
Bram Moolenaar9b451252012-08-15 17:43:31 +0200446See the Make_mvc.mak file for instructions, search for XPM.
447
448To try out if XPM support works do this: >
449 :help
Bram Moolenaar191acfd2020-03-27 20:42:43 +0100450 :let runtime = escape($VIMRUNTIME, ' \')
451 :exe 'sign define vimxpm icon=' .. runtime .. '\\vim16x16.xpm'
452 :exe 'sign place 1 line=1 name=vimxpm file=' .. expand('%:p')
Bram Moolenaar9b451252012-08-15 17:43:31 +0200453<
Bram Moolenaar191acfd2020-03-27 20:42:43 +0100454You may need to get the vim16x16.xpm file from github:
455https://github.com/vim/vim/blob/master/runtime/vim16x16.xpm
456
Bram Moolenaar9b451252012-08-15 17:43:31 +0200457
Bram Moolenaar91f84f62018-07-29 15:07:52 +0200458 vim:tw=78:sw=4:ts=8:noet:ft=help:norl: