vim-hug-neovim-rpc
This is an experimental project, trying to build a compatibility layer for neovim rpc client working on vim8. I started this project because I want to fix the vim8 support issue for nvim-completion-manager.
Since this is a general purpose module, other plugins needing rpc support may benefit from this project. However, there're many neovim rpc methods I haven't implemented yet, which make this an experimental plugin. Please fork and open a PR if you get any idea on improving it.
Tip: for porting neovim rplugin to vim8, you might need roxma/nvim-yarp
Requirements
- vim8
- If has('pythonx')andset pyxversion=3- same requirements as 4. has('python3')
 
- same requirements as 
- Else if has('pythonx')andset pyxversion=2- same requirements as 5. has('python')
 
- same requirements as 
- Else if has('python3')- neovim/python-client. (pip3 install neovim). There should be no error when you execute:python3 import neovim
 
- neovim/python-client. (
- Else if has('python')- neovim/python-client. (pip install neovim). There should be no error when you execute:python import neovim
 
- neovim/python-client. (
- set encoding=utf-8in your vimrc.
Use :echo neovim_rpc#serveraddr() to test the installation. It should print
something like 127.0.0.1:51359.
API
| Function | Similar to neovim's | 
|---|---|
| neovim_rpc#serveraddr() | v:servername | 
| neovim_rpc#jobstart(cmd,...) | jobstart({cmd}[, {opts}]) | 
| neovim_rpc#jobstop(jobid) | jobstop({job}) | 
| neovim_rpc#rpcnotify(channel,event,...) | rpcnotify({channel}, {event}[, {args}...]) | 
| neovim_rpc#rpcrequest(channel, event, ...) | rpcrequest({channel}, {method}[, {args}...]) | 
Note that neovim_rpc#jobstart only support these options:
- on_stdout
- on_stderr
- on_exit
- detach
Incompatibility issues
- Cannot pass Funcrefobject to python client. Pass function name instead.
- Python Nonewill be converted to''instead ofv:nullinto vimscript. See vim#2246
- The following neovim-only API will be ignored quietly:
- nvim_buf_add_highlight
- nvim_buf_clear_highlight
 
Overall Implementation
   "vim-hug-neovim-rpc - Sequence Diagram"
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
┌───┐            ┌──────────┐                  ┌───────────┐                    ┌──────┐
│VIM│            │VIM Server│                  │NVIM Server│                    │Client│
└─┬─┘            └────┬─────┘                  └─────┬─────┘                    └──┬───┘
  │   Launch thread   │                              │                             │
  │───────────────────>                              │                             │
  │                   │                              │                             │
  │                  Launch thread                   │                             │
  │─────────────────────────────────────────────────>│                             │
  │                   │                              │                             │
  │ `ch_open` connect │                              │                             │
  │───────────────────>                              │                             │
  │                   │                              │                             │
  │                   │────┐                         │                             │
  │                   │    │ Launch VimHandler thread│                             │
  │                   │<───┘                         │                             │
  │                   │                              │                             │
  │                   │                              │           Connect           │
  │                   │                              │<─────────────────────────────
  │                   │                              │                             │
  │                   │                              ────┐
  │                   │                                  │ Launch NvimHandler thread
  │                   │                              <───┘
  │                   │                              │                             │
  │                   │                              │    Request (msgpack rpc)    │
  │                   │                              │<─────────────────────────────
  │                   │                              │                             │
  │                   │                              ────┐                         │
  │                   │                                  │ Request enqueue         │
  │                   │                              <───┘                         │
  │                   │                              │                             │
  │                   │     notify (method call)     │                             │
  │                   │ <────────────────────────────│                             │
  │                   │                              │                             │
  │ notify (json rpc) │                              │                             │
  │<───────────────────                              │                             │
  │                   │                              │                             │
  ────┐                                              │                             │
      │ Request dequeue                              │                             │
  <───┘                                              │                             │
  │                   │                              │                             │
  ────┐               │                              │                             │
      │ Process       │                              │                             │
  <───┘               │                              │                             │
  │                   │                              │                             │
  │                   │      Send response (msgpack rpc)                           │
  │────────────────────────────────────────────────────────────────────────────────>
┌─┴─┐            ┌────┴─────┐                  ┌─────┴─────┐                    ┌──┴───┐
│VIM│            │VIM Server│                  │NVIM Server│                    │Client│
└───┘            └──────────┘                  └───────────┘                    └──────┘
Debugging
Add logging settigns to your vimrc. Log files will be generated with prefix
/tmp/nvim_log. An alternative is to export environment variables before
starting vim/nvim.
let $NVIM_PYTHON_LOG_FILE="/tmp/nvim_log"
let $NVIM_PYTHON_LOG_LEVEL="DEBUG"
