mirror of
https://github.com/neovim/neovim.git
synced 2025-01-01 17:23:36 -07:00
159 lines
5.6 KiB
Plaintext
159 lines
5.6 KiB
Plaintext
*provider.txt* {Nvim}
|
|
|
|
|
|
NVIM REFERENCE MANUAL by Thiago de Arruda
|
|
|
|
|
|
Providers *provider*
|
|
|
|
Nvim delegates some features to dynamic "providers".
|
|
|
|
==============================================================================
|
|
Python integration *provider-python*
|
|
|
|
Nvim supports the Vim legacy |python-vim| and |python3| interfaces via
|
|
external Python interpreters connected via |RPC|,
|
|
|
|
Note: Only the Vim 7.3 API is supported; bindeval (Vim 7.4) is not.
|
|
|
|
|
|
PYTHON QUICKSTART ~
|
|
|
|
If you used a package manager to install Nvim there's a good chance that
|
|
it also provides the `neovim` Python package. If it doesn't, follow these
|
|
steps to install the package with Python's package manager, `pip`.
|
|
|
|
Note: Depending on your system, `pip` might refer to Python 2 or Python 3,
|
|
which is why the following instructions mention `pip2` or `pip3`
|
|
explicitly. If one of these is not available, try `pip`.
|
|
|
|
To use Vim Python 2/3 plugins with Nvim:
|
|
|
|
- For Python 2 plugins, make sure an interpreter for Python 2.6 or 2.7 is
|
|
available in your `$PATH`, then install the `neovim` Python package systemwide: >
|
|
$ sudo pip2 install --upgrade neovim
|
|
<
|
|
or for the current user: >
|
|
$ pip2 install --user --upgrade neovim
|
|
<
|
|
- For Python 3 plugins, make sure an interpreter for Python 3.3 or above is
|
|
available in your `$PATH`, then install the `neovim` Python package systemwide: >
|
|
$ sudo pip3 install --upgrade neovim
|
|
<
|
|
or for the current user: >
|
|
$ pip3 install --user --upgrade neovim
|
|
<
|
|
Note: The `--upgrade` flag ensures you have the latest version even if
|
|
a previous version was already installed.
|
|
|
|
PYTHON PROVIDER CONFIGURATION ~
|
|
*g:python_host_prog*
|
|
Set `g:python_host_prog` to point Nvim to a specific Python 2 interpreter: >
|
|
let g:python_host_prog = '/path/to/python'
|
|
<
|
|
*g:python3_host_prog*
|
|
Set `g:python3_host_prog` to point Nvim to a specific Python 3 interpreter: >
|
|
let g:python3_host_prog = '/path/to/python3'
|
|
<
|
|
*g:loaded_python_provider*
|
|
To disable Python 2 support: >
|
|
let g:loaded_python_provider = 1
|
|
<
|
|
*g:loaded_python3_provider*
|
|
To disable Python 3 support: >
|
|
let g:loaded_python3_provider = 1
|
|
<
|
|
*g:python_host_skip_check*
|
|
Set `g:python_host_skip_check` to disable the Python 2 interpreter check.
|
|
Note: This requires you to install the python-neovim module properly. >
|
|
let g:python_host_skip_check = 1
|
|
<
|
|
*g:python3_host_skip_check*
|
|
Set `g:python3_host_skip_check` to disable the Python 3 interpreter check.
|
|
Note: This requires you to install the python3-neovim module properly. >
|
|
let g:python3_host_skip_check = 1
|
|
|
|
|
|
TROUBLESHOOTING *python-trouble*
|
|
|
|
If you have trouble with a plugin that uses the `neovim` Python client, use
|
|
the |:CheckHealth| command to diagnose your setup.
|
|
|
|
*:CheckHealth*
|
|
:CheckHealth[!] Check your setup for common problems that may be keeping a
|
|
plugin from functioning correctly. Include the output of
|
|
this command in bug reports to help reduce the amount of
|
|
time it takes to address your issue. With "!" the output
|
|
will be placed in a new buffer which can make it easier to
|
|
save to a file or copy to the clipboard.
|
|
|
|
==============================================================================
|
|
Ruby integration *provider-ruby*
|
|
|
|
Nvim supports the Vim legacy |ruby-vim| interface via external Ruby
|
|
interpreters connected via |RPC|.
|
|
|
|
|
|
RUBY QUICKSTART ~
|
|
|
|
To use Vim Ruby plugins with Nvim, just install the latest `neovim` RubyGem: >
|
|
$ gem install neovim
|
|
|
|
|
|
RUBY PROVIDER CONFIGURATION ~
|
|
*g:loaded_ruby_provider*
|
|
To disable Ruby support: >
|
|
let g:loaded_ruby_provider = 1
|
|
|
|
|
|
==============================================================================
|
|
Clipboard integration *provider-clipboard* *clipboard*
|
|
|
|
Nvim has no direct connection to the system clipboard. Instead it is
|
|
accessible through a |provider| which transparently uses shell commands for
|
|
communicating with the clipboard.
|
|
|
|
Clipboard access is implicitly enabled if any of the following clipboard tools
|
|
are found in your `$PATH`.
|
|
|
|
- xclip
|
|
- xsel (newer alternative to xclip)
|
|
- pbcopy/pbpaste (Mac OS X)
|
|
- lemonade (for SSH) https://github.com/pocke/lemonade
|
|
- doitclient (for SSH) http://www.chiark.greenend.org.uk/~sgtatham/doit/
|
|
|
|
The presence of a suitable clipboard tool implicitly enables the '+' and '*'
|
|
registers.
|
|
|
|
If you want to ALWAYS use the clipboard for ALL operations (as opposed
|
|
to interacting with the '+' and/or '*' registers explicitly), set the
|
|
following option:
|
|
>
|
|
set clipboard+=unnamedplus
|
|
<
|
|
See 'clipboard' for details and more options.
|
|
|
|
==============================================================================
|
|
X11 selection mechanism *clipboard-x11* *x11-selection*
|
|
|
|
The clipboard providers for X11 store text in what is known as "selections".
|
|
Selections are "owned" by an application, so when the application is closed,
|
|
the selection text is lost.
|
|
|
|
The contents of selections are held by the originating application (e.g., upon
|
|
a copy), and only passed on to another application when that other application
|
|
asks for them (e.g., upon a paste).
|
|
|
|
*quoteplus* *quote+*
|
|
|
|
There are three documented X11 selections: `PRIMARY`, `SECONDARY`, and `CLIPBOARD`.
|
|
`CLIPBOARD` is typically used in X11 applications for copy/paste operations
|
|
(`Ctrl-c`/`v`), while `PRIMARY` is used for the last selected text, which is
|
|
generally inserted with the middle mouse button.
|
|
|
|
Nvim's X11 clipboard providers only utilize the `PRIMARY` and `CLIPBOARD`
|
|
selections, used for the '*' and '+' registers, respectively.
|
|
|
|
==============================================================================
|
|
vim:tw=78:ts=8:noet:ft=help:norl:
|