aboutsummaryrefslogtreecommitdiff
path: root/runtime/autoload/provider/python3.vim
diff options
context:
space:
mode:
authorShougo Matsushita <Shougo.Matsu@gmail.com>2015-03-21 07:55:39 +0900
committerShougo Matsushita <Shougo.Matsu@gmail.com>2015-04-21 06:20:23 +0900
commit42de617974b6befaf5d25037bf6d92c2b889068b (patch)
tree3145cd37e5937ae3f6d000c02b8b146f2678fb81 /runtime/autoload/provider/python3.vim
parent84891f2802a0db1a257580f341d70a5fdb0f6c75 (diff)
downloadrneovim-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.vim47
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