diff options
| author | Shougo Matsushita <Shougo.Matsu@gmail.com> | 2015-03-21 07:55:39 +0900 |
|---|---|---|
| committer | Shougo Matsushita <Shougo.Matsu@gmail.com> | 2015-04-21 06:20:23 +0900 |
| commit | 42de617974b6befaf5d25037bf6d92c2b889068b (patch) | |
| tree | 3145cd37e5937ae3f6d000c02b8b146f2678fb81 /runtime/autoload/provider/python3.vim | |
| parent | 84891f2802a0db1a257580f341d70a5fdb0f6c75 (diff) | |
| download | rneovim-42de617974b6befaf5d25037bf6d92c2b889068b.tar.gz rneovim-42de617974b6befaf5d25037bf6d92c2b889068b.tar.bz2 rneovim-42de617974b6befaf5d25037bf6d92c2b889068b.zip | |
Add if_python3 support
Reviewed-by: Michael Reed <m.reed@mykolab.com>, Daniel Hahler <github@thequod.de>
Helped-by: Daniel Hahler <github@thequod.de>
Diffstat (limited to 'runtime/autoload/provider/python3.vim')
| -rw-r--r-- | runtime/autoload/provider/python3.vim | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/runtime/autoload/provider/python3.vim b/runtime/autoload/provider/python3.vim new file mode 100644 index 0000000000..1a52ade0ef --- /dev/null +++ b/runtime/autoload/provider/python3.vim @@ -0,0 +1,47 @@ +" The Python3 provider uses a Python3 host to emulate an environment for running +" python3 plugins. See ":help nvim-provider" for more information. +" +" Associating the plugin with the Python3 host is the first step because +" plugins will be passed as command-line arguments + +if exists('g:loaded_python3_provider') + finish +endif +let g:loaded_python3_provider = 1 + +let [s:prog, s:err] = provider#pythonx#Detect(3) +if s:prog == '' + " Detection failed + finish +endif + +function! provider#python3#Prog() + return s:prog +endfunction + +function! provider#python3#Error() + return s:err +endfunction + +let s:plugin_path = expand('<sfile>:p:h').'/script_host.py' + +" The Python3 provider plugin will run in a separate instance of the Python3 +" host. +call remote#host#RegisterClone('legacy-python3-provider', 'python3') +call remote#host#RegisterPlugin('legacy-python3-provider', s:plugin_path, []) + +function! provider#python3#Call(method, args) + if !exists('s:host') + let s:rpcrequest = function('rpcrequest') + + " Ensure that we can load the Python3 host before bootstrapping + try + let s:host = remote#host#Require('legacy-python3-provider') + catch + echomsg v:exception + finish + endtry + endif + + return call(s:rpcrequest, insert(insert(a:args, 'python_'.a:method), s:host)) +endfunction |