diff options
| author | Florian Walch <florian@fwalch.com> | 2015-06-09 13:31:02 +0300 |
|---|---|---|
| committer | Florian Walch <florian@fwalch.com> | 2015-06-09 13:31:02 +0300 |
| commit | 6270d431aaeed71e7a8782411f36409ab8e0ee35 (patch) | |
| tree | 3aa7f3d7c27a5311901b492e1238bcd90c69abdc /runtime/autoload/provider/python3.vim | |
| parent | 232c40b40a56eb30c7a6732368eb631e1e58fc7c (diff) | |
| parent | e8c68aa7ee64aaa8363b2900ea97a97e7eb8ba4b (diff) | |
| download | rneovim-6270d431aaeed71e7a8782411f36409ab8e0ee35.tar.gz rneovim-6270d431aaeed71e7a8782411f36409ab8e0ee35.tar.bz2 rneovim-6270d431aaeed71e7a8782411f36409ab8e0ee35.zip | |
Merge #2735 'provider: Only call system() once, don't use Python 3 interpreter for +python, improve messages'.
Diffstat (limited to 'runtime/autoload/provider/python3.vim')
| -rw-r--r-- | runtime/autoload/provider/python3.vim | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/runtime/autoload/provider/python3.vim b/runtime/autoload/provider/python3.vim index 1a52ade0ef..f469bf55aa 100644 --- a/runtime/autoload/provider/python3.vim +++ b/runtime/autoload/provider/python3.vim @@ -10,10 +10,6 @@ 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 @@ -23,6 +19,11 @@ function! provider#python3#Error() return s:err endfunction +if s:prog == '' + " Detection failed + finish +endif + let s:plugin_path = expand('<sfile>:p:h').'/script_host.py' " The Python3 provider plugin will run in a separate instance of the Python3 @@ -31,6 +32,9 @@ 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 s:err != '' + return + endif if !exists('s:host') let s:rpcrequest = function('rpcrequest') @@ -38,10 +42,12 @@ function! provider#python3#Call(method, args) try let s:host = remote#host#Require('legacy-python3-provider') catch + let s:err = v:exception + echohl WarningMsg echomsg v:exception + echohl None finish endtry endif - return call(s:rpcrequest, insert(insert(a:args, 'python_'.a:method), s:host)) endfunction |