Usr_31
Nvim :help
pages, generated
from source
using the tree-sitter-vimdoc parser.
VIM USER MANUAL - by Bram Moolenaar
Exploiting the GUI
Vim works well in a terminal, but the GUI has a few extra items. A file
browser can be used for commands that use a file. A dialog to make a choice
between alternatives. Use keyboard shortcuts to access menu items quickly.
31.1 The file browser
31.2 Confirmation
31.3 Menu shortcuts
31.4 Vim window position and size
31.5 Various
The file browser
When using the File/Open... menu you get a file browser. This makes it easier
to find the file you want to edit. But what if you want to split a window to
edit another file? There is no menu entry for this. You could first use
Window/Split and then File/Open..., but that's more work.
Since you are typing most commands in Vim, opening the file browser with a
typed command is possible as well. To make the split command use the file
browser, prepend "browse":
:browse split
Select a file and then the ":split" command will be executed with it. If you
cancel the file dialog nothing happens, the window isn't split.
You can also specify a file name argument. This is used to tell the file
browser where to start. Example:
:browse split /etc
The file browser will pop up, starting in the directory "/etc".
The ":browse" command can be prepended to just about any command that opens a
file.
If no directory is specified, Vim will decide where to start the file
browser. By default it uses the same directory as the last time. Thus when
you used ":browse split" and selected a file in "/usr/local/share", the next
time you use a ":browse" it will start in "/usr/local/share" again.
This can be changed with the
'browsedir' option. It can have one of three
values:
last Use the last directory browsed (default)
buffer Use the same directory as the current buffer
current use the current directory
For example, when you are in the directory "/usr", editing the file
"/usr/local/share/readme", then the command:
:set browsedir=buffer
:browse edit
Will start the browser in "/usr/local/share". Alternatively:
:set browsedir=current
:browse edit
Will start the browser in "/usr".
Note:
To avoid using the mouse, most file browsers offer using key presses
to navigate. Since this is different for every system, it is not
explained here. Vim uses a standard browser when possible, your
system documentation should contain an explanation on the keyboard
shortcuts somewhere.
When you are not using the GUI version, you could use the file explorer window
to select files like in a file browser. However, this doesn't work for the
":browse" command. See
netrw-browse.
Vim protects you from accidentally overwriting a file and other ways to lose
changes. If you do something that might be a bad thing to do, Vim produces an
error message and suggests appending ! if you really want to do it.
To avoid retyping the command with the !, you can make Vim give you a
dialog. You can then press "OK" or "Cancel" to tell Vim what you want.
For example, you are editing a file and made changes to it. You start
editing another file with:
:confirm edit foo.txt
Vim will pop up a dialog that looks something like this:
+-----------------------------------+
| |
| ? Save changes to "bar.txt"? |
| |
| YES NO CANCEL |
+-----------------------------------+
Now make your choice. If you do want to save the changes, select "YES". If
you want to lose the changes for ever: "NO". If you forgot what you were
doing and want to check what really changed use "CANCEL". You will be back in
the same file, with the changes still there.
Just like ":browse", the ":confirm" command can be prepended to most commands
that edit another file. They can also be combined:
:confirm browse edit
This will produce a dialog when the current buffer was changed. Then it will
pop up a file browser to select the file to edit.
Note:
In the dialog you can use the keyboard to select the choice.
Typically the <Tab>
key and the cursor keys change the choice.
Pressing <Enter>
selects the choice. This depends on the system
though.
When you are not using the GUI, the ":confirm" command works as well. Instead
of popping up a dialog, Vim will print the message at the bottom of the Vim
window and ask you to press a key to make a choice.
:confirm edit main.c
Save changes to "Untitled"?
[Y]es, (N)o, (C)ancel:
You can now press the single key for the choice. You don't have to press
<Enter>
, unlike other typing on the command line.
The keyboard is used for all Vim commands. The menus provide a simple way to
select commands, without knowing what they are called. But you have to move
your hand from the keyboard and grab the mouse.
Menus can often be selected with keys as well. This depends on your
system, but most often it works this way. Use the <Alt>
key in combination
with the underlined letter of a menu. For example, <A-w>
(<Alt>
and w) pops
up the Window menu.
In the Window menu, the "split" item has the p underlined. To select it,
let go of the <Alt>
key and press p.
After the first selection of a menu with the <Alt>
key, you can use the cursor
keys to move through the menus. <Right>
selects a submenu and <left>
closes
it. <Esc>
also closes a menu. <Enter>
selects a menu item.
There is a conflict between using the
<Alt>
key to select menu items, and
using
<Alt>
key combinations for mappings. The
'winaltkeys' option tells Vim
what it should do with the
<Alt>
key.
The default value "menu" is the smart choice: If the key combination is a
menu shortcut it can't be mapped. All other keys are available for mapping.
The value "no" doesn't use any
<Alt>
keys for the menus. Thus you must use
the mouse for the menus, and all
<Alt>
keys can be mapped.
The value "yes" means that Vim will use any
<Alt>
keys for the menus. Some
<Alt>
key combinations may also do other things than selecting a menu.
31.4 Vim window position and size
To see the current Vim window position on the screen use:
:winpos
This will only work in the GUI. The output may look like this:
Window position: X 272, Y 103
The position is given in screen pixels. Now you can use the numbers to move
Vim somewhere else. For example, to move it to the left a hundred pixels:
:winpos 172 103
Note:
There may be a small offset between the reported position and where
the window moves. This is because of the border around the window.
This is added by the window manager.
You can use this command in your startup script to position the window at a
specific position.
The size of the Vim window is computed in characters. Thus this depends on
the size of the font being used. You can see the current size with this
command:
:set lines columns
To change the size set the
'lines' and/or
'columns' options to a new value:
:set lines=50
:set columns=80
Obtaining the size works in a terminal just like in the GUI. Setting the size
is not possible in most terminals.
You can start the X-Windows version of gvim with an argument to specify the
size and position of the window:
gvim -geometry {width}x{height}+{x-offset}+{y-offset}
{width}
and
{height}
are in characters,
{x-offset}
and
{y-offset}
are in
pixels. Example:
gvim -geometry 80x25+100+300
You can use gvim to edit an e-mail message. In your e-mail program you must
select gvim to be the editor for messages. When you try that, you will
see that it doesn't work: The mail program thinks that editing is finished,
while gvim is still running!
What happens is that gvim disconnects from the shell it was started in.
That is fine when you start gvim in a terminal, so that you can do other work
in that terminal. But when you really want to wait for gvim to finish, you
must prevent it from disconnecting. The "-f" argument does this:
gvim -f file.txt
The "-f" stands for foreground. Now Vim will block the shell it was started
in until you finish editing and exit.
DELAYED START OF THE GUI
On Unix it's possible to first start Vim in a terminal. That's useful if you
do various tasks in the same shell. If you are editing a file and decide you
want to use the GUI after all, you can start it with:
:gui
Vim will open the GUI window and no longer use the terminal. You can continue
using the terminal for something else. The "-f" argument is used here to run
the GUI in the foreground. You can also use ":gui -f".