mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
provider/pythonx: Merge s:check_version() and s:check_interpreter().
This commit is contained in:
parent
4dc3c84c5a
commit
cfa278c72e
@ -13,7 +13,7 @@ function! provider#pythonx#Detect(major_ver) abort
|
|||||||
let skip = exists(skip_var) ? {skip_var} : 0
|
let skip = exists(skip_var) ? {skip_var} : 0
|
||||||
if exists(host_var)
|
if exists(host_var)
|
||||||
" Disable auto detection.
|
" Disable auto detection.
|
||||||
let [result, err, _] = s:check_interpreter({host_var}, a:major_ver, skip)
|
let [result, err] = s:check_interpreter({host_var}, a:major_ver, skip)
|
||||||
if result
|
if result
|
||||||
return [{host_var}, err]
|
return [{host_var}, err]
|
||||||
endif
|
endif
|
||||||
@ -27,12 +27,9 @@ function! provider#pythonx#Detect(major_ver) abort
|
|||||||
|
|
||||||
let errors = []
|
let errors = []
|
||||||
for prog in map(prog_suffixes, "'python' . v:val")
|
for prog in map(prog_suffixes, "'python' . v:val")
|
||||||
let [result, err, prog_ver] = s:check_interpreter(prog, a:major_ver, skip)
|
let [result, err] = s:check_interpreter(prog, a:major_ver, skip)
|
||||||
if result
|
if result
|
||||||
let [result, err] = s:check_version(prog, prog_ver, a:major_ver, skip)
|
return [prog, err]
|
||||||
if result
|
|
||||||
return [prog, err]
|
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" Accumulate errors in case we don't find
|
" Accumulate errors in case we don't find
|
||||||
@ -45,26 +42,13 @@ function! provider#pythonx#Detect(major_ver) abort
|
|||||||
\ . ":\n" . join(errors, "\n")]
|
\ . ":\n" . join(errors, "\n")]
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:check_version(prog, prog_ver, major_ver, skip) abort
|
|
||||||
if a:skip
|
|
||||||
return [1, '']
|
|
||||||
endif
|
|
||||||
|
|
||||||
let min_version = (a:major_ver == 2) ? '2.6' : '3.3'
|
|
||||||
if a:prog_ver =~ '^' . a:major_ver && a:prog_ver >= min_version
|
|
||||||
return [1, '']
|
|
||||||
endif
|
|
||||||
return [0, a:prog . ' is Python ' . prog_ver . ' and cannot provide Python '
|
|
||||||
\ . a:major_ver . '.']
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
function! s:check_interpreter(prog, major_ver, skip) abort
|
function! s:check_interpreter(prog, major_ver, skip) abort
|
||||||
if !executable(a:prog)
|
if !executable(a:prog)
|
||||||
return [0, a:prog . ' does not exist or is not executable.', '']
|
return [0, a:prog . ' does not exist or is not executable.']
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if a:skip
|
if a:skip
|
||||||
return [1, '', '']
|
return [1, '']
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" Try to load neovim module, and output Python version.
|
" Try to load neovim module, and output Python version.
|
||||||
@ -77,8 +61,14 @@ function! s:check_interpreter(prog, major_ver, skip) abort
|
|||||||
\ )
|
\ )
|
||||||
if v:shell_error
|
if v:shell_error
|
||||||
return [0, a:prog . ' does have not have the neovim module installed. '
|
return [0, a:prog . ' does have not have the neovim module installed. '
|
||||||
\ . 'See ":help nvim-python".', prog_ver]
|
\ . 'See ":help nvim-python".']
|
||||||
endif
|
endif
|
||||||
return [1, '', prog_ver]
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
|
let min_version = (a:major_ver == 2) ? '2.6' : '3.3'
|
||||||
|
if prog_ver =~ '^' . a:major_ver && prog_ver >= min_version
|
||||||
|
return [1, '']
|
||||||
|
endif
|
||||||
|
|
||||||
|
return [0, a:prog . ' is Python ' . prog_ver . ' and cannot provide Python '
|
||||||
|
\ . a:major_ver . '.']
|
||||||
|
endfunction
|
||||||
|
Loading…
Reference in New Issue
Block a user