aboutsummaryrefslogtreecommitdiff
path: root/runtime/autoload
diff options
context:
space:
mode:
authorDaniel Hahler <git@thequod.de>2015-05-01 04:28:54 +0200
committerFlorian Walch <florian@fwalch.com>2015-06-09 10:29:45 +0300
commit75db0c37a78c1fed601120f6780cd42f0909f2d8 (patch)
treecfe6ee4bff2280692c089fa59efe8c9694751eb2 /runtime/autoload
parent232c40b40a56eb30c7a6732368eb631e1e58fc7c (diff)
downloadrneovim-75db0c37a78c1fed601120f6780cd42f0909f2d8.tar.gz
rneovim-75db0c37a78c1fed601120f6780cd42f0909f2d8.tar.bz2
rneovim-75db0c37a78c1fed601120f6780cd42f0909f2d8.zip
provider/pythonx: only call system("python") once
`s:check_interpreter` will query/return the version also, so that `s:check_version` can just use that, without calling "python" again.
Diffstat (limited to 'runtime/autoload')
-rw-r--r--runtime/autoload/provider/pythonx.vim25
1 files changed, 12 insertions, 13 deletions
diff --git a/runtime/autoload/provider/pythonx.vim b/runtime/autoload/provider/pythonx.vim
index 6137d16fcb..1fe6c066ab 100644
--- a/runtime/autoload/provider/pythonx.vim
+++ b/runtime/autoload/provider/pythonx.vim
@@ -13,7 +13,7 @@ function! provider#pythonx#Detect(ver) abort
let skip = exists(skip_var) ? {skip_var} : 0
if exists(host_var)
" Disable auto detection
- let [check, err] = s:check_interpreter({host_var}, a:ver, skip)
+ let [check, err, _] = s:check_interpreter({host_var}, a:ver, skip)
return check ? [{host_var}, err] : ['', err]
endif
@@ -22,9 +22,9 @@ function! provider#pythonx#Detect(ver) abort
\ : ['3.5', '3.4', '3.3', '3.2', '3', '']
for prog in map(detect_versions, "'python' . v:val")
- let [check, err] = s:check_interpreter(prog, a:ver, skip)
+ let [check, err, ver] = s:check_interpreter(prog, a:ver, skip)
if check
- let [check, err] = s:check_version(prog, a:ver, skip)
+ let [check, err] = s:check_version(prog, ver, skip)
return [prog, err]
endif
endfor
@@ -39,31 +39,30 @@ function! s:check_version(prog, ver, skip) abort
return [1, '']
endif
- let get_version =
- \ ' -c "import sys; sys.stdout.write(str(sys.version_info[0]) + '.
- \ '\".\" + str(sys.version_info[1]))"'
- let min_version = (a:ver == 2) ? '2.6' : '3.3'
- if system(a:prog . get_version) >= min_version
+ let min_version = (a:ver[0] == 2) ? '2.6' : '3.3'
+ if a:ver >= min_version
return [1, '']
endif
- return [0, 'Python ' . get_version . ' interpreter is not supported.']
+ return [0, 'Python ' . a:ver . ' interpreter is not supported.']
endfunction
function! s:check_interpreter(prog, ver, skip) abort
if !executable(a:prog)
- return [0, 'Python'.a:ver.' interpreter is not executable.']
+ return [0, 'Python'.a:ver.' interpreter is not executable.', '']
endif
if a:skip
- return [1, '']
+ return [1, '', '']
endif
" Load neovim module check
- call system(a:prog . ' -c ' .
+ let ver = system(a:prog . ' -c ' .
+ \ '''import sys; sys.stdout.write(str(sys.version_info[0]) + '.
+ \ '"." + str(sys.version_info[1])); '''.
\ (a:ver == 2 ?
\ '''import pkgutil; exit(pkgutil.get_loader("neovim") is None)''':
\ '''import importlib; exit(importlib.find_loader("neovim") is None)''')
\ )
- return [!v:shell_error, 'Python'.a:ver.' interpreter have not neovim module.']
+ return [!v:shell_error, 'Python'.a:ver.' interpreter have not neovim module.', ver]
endfunction