2017-03-21 09:08:19 -07:00
|
|
|
*terminal_emulator.txt* Nvim
|
2015-03-28 08:33:19 -07:00
|
|
|
|
|
|
|
|
|
|
|
NVIM REFERENCE MANUAL by Thiago de Arruda
|
|
|
|
|
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
Terminal emulator *terminal-emulator*
|
2015-03-28 08:33:19 -07:00
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
Nvim embeds a VT220/xterm terminal emulator based on libvterm. The terminal is
|
|
|
|
presented as a special buffer type, asynchronously updated from the virtual
|
|
|
|
terminal as data is received from the program connected to it.
|
2015-03-28 08:33:19 -07:00
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
Terminal buffers behave mostly like normal 'nomodifiable' buffers, except:
|
|
|
|
- Plugins can set 'modifiable' to modify text, but lines cannot be deleted.
|
|
|
|
- 'scrollback' controls how many off-screen lines are kept.
|
|
|
|
- Terminal output is followed if the cursor is on the last line.
|
2015-03-28 08:33:19 -07:00
|
|
|
|
|
|
|
==============================================================================
|
2017-02-21 07:16:48 -07:00
|
|
|
Spawning *terminal-emulator-spawning*
|
2015-03-28 08:33:19 -07:00
|
|
|
|
|
|
|
There are 3 ways to create a terminal buffer:
|
|
|
|
|
|
|
|
- By invoking the |:terminal| ex command.
|
|
|
|
- By calling the |termopen()| function.
|
|
|
|
- By editing a file with a name matching `term://(.{-}//(\d+:)?)?\zs.*`.
|
|
|
|
For example:
|
|
|
|
>
|
2016-07-03 02:21:57 -07:00
|
|
|
:edit term://bash
|
|
|
|
:vsplit term://top
|
2015-03-28 08:33:19 -07:00
|
|
|
<
|
2016-07-03 02:21:57 -07:00
|
|
|
Note: The "term://" pattern is handled by a BufReadCmd handler, so the
|
|
|
|
|autocmd-nested| modifier is required to use it in an autocmd. >
|
|
|
|
autocmd VimEnter * nested split term://sh
|
2017-02-21 07:16:48 -07:00
|
|
|
< This is only mentioned for reference; use |:terminal| instead.
|
2016-07-03 02:21:57 -07:00
|
|
|
|
2015-03-28 08:33:19 -07:00
|
|
|
When the terminal spawns the program, the buffer will start to mirror the
|
2017-02-21 07:16:48 -07:00
|
|
|
terminal display and change its name to `term://{cwd}//{pid}:{cmd}`.
|
|
|
|
The "term://..." scheme enables |:mksession| to "restore" a terminal buffer by
|
|
|
|
restarting the {cmd} when the session is loaded.
|
2015-03-28 08:33:19 -07:00
|
|
|
|
|
|
|
==============================================================================
|
2017-02-21 07:16:48 -07:00
|
|
|
Input *terminal-emulator-input*
|
|
|
|
|
|
|
|
To send input, enter terminal mode using any command that would enter "insert
|
|
|
|
mode" in a normal buffer, such as |i| or |:startinsert|. In this mode all keys
|
|
|
|
except <C-\><C-N> are sent to the underlying program. Use <C-\><C-N> to return
|
|
|
|
to normal mode. |CTRL-\_CTRL-N|
|
|
|
|
|
|
|
|
Terminal mode has its own |:tnoremap| namespace for mappings, this can be used
|
|
|
|
to automate any terminal interaction. To map <Esc> to exit terminal mode: >
|
2015-03-28 08:33:19 -07:00
|
|
|
:tnoremap <Esc> <C-\><C-n>
|
|
|
|
<
|
2017-02-21 07:16:48 -07:00
|
|
|
Navigating to other windows is only possible in normal mode. For convenience,
|
|
|
|
you could use these mappings: >
|
2015-03-28 08:33:19 -07:00
|
|
|
:tnoremap <A-h> <C-\><C-n><C-w>h
|
|
|
|
:tnoremap <A-j> <C-\><C-n><C-w>j
|
|
|
|
:tnoremap <A-k> <C-\><C-n><C-w>k
|
|
|
|
:tnoremap <A-l> <C-\><C-n><C-w>l
|
|
|
|
:nnoremap <A-h> <C-w>h
|
|
|
|
:nnoremap <A-j> <C-w>j
|
|
|
|
:nnoremap <A-k> <C-w>k
|
|
|
|
:nnoremap <A-l> <C-w>l
|
|
|
|
<
|
2017-02-21 07:16:48 -07:00
|
|
|
Then you can use `Alt+{h,j,k,l}` to navigate between windows from any mode.
|
2015-03-28 08:33:19 -07:00
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
Mouse input is supported, and has the following behavior:
|
2015-03-28 08:33:19 -07:00
|
|
|
|
|
|
|
- If the program has enabled mouse events, the corresponding events will be
|
|
|
|
forwarded to the program.
|
|
|
|
- If mouse events are disabled (the default), terminal focus will be lost and
|
|
|
|
the event will be processed as in a normal buffer.
|
|
|
|
- If another window is clicked, terminal focus will be lost and nvim will jump
|
|
|
|
to the clicked window
|
|
|
|
- If the mouse wheel is used while the mouse is positioned in another window,
|
|
|
|
the terminal wont lose focus and the hovered window will be scrolled.
|
|
|
|
|
|
|
|
==============================================================================
|
2017-02-21 07:16:48 -07:00
|
|
|
Configuration *terminal-emulator-configuration*
|
|
|
|
|
|
|
|
Options: 'scrollback'
|
|
|
|
Events: |TermOpen|, |TermClose|
|
|
|
|
Highlight groups: |hl-TermCursor|, |hl-TermCursorNC|
|
2015-03-28 08:33:19 -07:00
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
Terminal colors can be customized with these variables:
|
2015-03-28 08:33:19 -07:00
|
|
|
|
|
|
|
- `{g,b}:terminal_color_$NUM`: The terminal color palette, where `$NUM` is the
|
2015-10-30 13:22:43 -07:00
|
|
|
color index, between 0 and 255 inclusive. This setting only affects UIs with
|
|
|
|
RGB capabilities; for normal terminals the color index is simply forwarded.
|
2015-03-28 08:33:19 -07:00
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
The `{g,b}:terminal_color_$NUM` variables are processed only when the terminal
|
|
|
|
starts (after |TermOpen|).
|
2015-04-08 04:34:27 -07:00
|
|
|
|
2016-07-10 12:41:07 -07:00
|
|
|
==============================================================================
|
2017-02-21 07:16:48 -07:00
|
|
|
Status Variables *terminal-emulator-status*
|
2016-07-10 12:41:07 -07:00
|
|
|
|
|
|
|
Terminal buffers maintain some information about the terminal in buffer-local
|
|
|
|
variables:
|
|
|
|
|
|
|
|
- *b:term_title* The settable title of the terminal, typically displayed in
|
|
|
|
the window title or tab title of a graphical terminal emulator. Programs
|
|
|
|
running in the terminal can set this title via an escape sequence.
|
|
|
|
- *b:terminal_job_id* The nvim job ID of the job running in the terminal. See
|
|
|
|
|job-control| for more information.
|
|
|
|
- *b:terminal_job_pid* The PID of the top-level process running in the
|
|
|
|
terminal.
|
|
|
|
|
2017-02-21 07:16:48 -07:00
|
|
|
These variables are initialized before TermOpen, so you can use them in
|
|
|
|
a local 'statusline'. Example: >
|
2016-07-10 12:41:07 -07:00
|
|
|
:autocmd TermOpen * setlocal statusline=%{b:term_title}
|
|
|
|
<
|
2015-03-28 08:33:19 -07:00
|
|
|
==============================================================================
|
|
|
|
vim:tw=78:ts=8:noet:ft=help:norl:
|