mirror of
https://github.com/dense-analysis/ale
synced 2025-01-18 05:00:46 +00:00
Close #2472 - Add support for pyright
This commit is contained in:
parent
9bdabce8df
commit
19229e8e27
43
ale_linters/python/pyright.vim
Normal file
43
ale_linters/python/pyright.vim
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
call ale#Set('python_pyright_executable', 'pyright-langserver')
|
||||||
|
call ale#Set('python_pyright_config', {})
|
||||||
|
|
||||||
|
function! ale_linters#python#pyright#GetConfig(buffer) abort
|
||||||
|
let l:config = deepcopy(ale#Var(a:buffer, 'python_pyright_config'))
|
||||||
|
|
||||||
|
if !has_key(l:config, 'python')
|
||||||
|
let l:config.python = {}
|
||||||
|
endif
|
||||||
|
|
||||||
|
if type(l:config.python) is v:t_dict
|
||||||
|
" Automatically detect the virtualenv path and use it.
|
||||||
|
if !has_key(l:config.python, 'venvPath')
|
||||||
|
let l:venv = ale#python#FindVirtualenv(a:buffer)
|
||||||
|
|
||||||
|
if !empty(l:venv)
|
||||||
|
let l:config.python.venvPath = l:venv
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
" Automatically use the version of Python in virtualenv.
|
||||||
|
if type(get(l:config.python, 'venvPath')) is v:t_string
|
||||||
|
\&& !empty(l:config.python.venvPath)
|
||||||
|
\&& !has_key(l:config.python, 'pythonPath')
|
||||||
|
let l:config.python.pythonPath = ale#path#Simplify(
|
||||||
|
\ l:config.python.venvPath
|
||||||
|
\ . (has('win32') ? '/Scripts/python' : '/bin/python')
|
||||||
|
\)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
return l:config
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call ale#linter#Define('python', {
|
||||||
|
\ 'name': 'pyright',
|
||||||
|
\ 'lsp': 'stdio',
|
||||||
|
\ 'executable': {b -> ale#Var(b, 'python_pyright_executable')},
|
||||||
|
\ 'command': '%e --stdio',
|
||||||
|
\ 'project_root': function('ale#python#FindProjectRoot'),
|
||||||
|
\ 'completion_filter': 'ale#completion#python#CompletionItemFilter',
|
||||||
|
\ 'lsp_config': function('ale_linters#python#pyright#GetConfig'),
|
||||||
|
\})
|
@ -44,7 +44,7 @@ let s:default_ale_linters = {
|
|||||||
\ 'help': [],
|
\ 'help': [],
|
||||||
\ 'perl': ['perlcritic'],
|
\ 'perl': ['perlcritic'],
|
||||||
\ 'perl6': [],
|
\ 'perl6': [],
|
||||||
\ 'python': ['flake8', 'mypy', 'pylint'],
|
\ 'python': ['flake8', 'mypy', 'pylint', 'pyright'],
|
||||||
\ 'rust': ['cargo'],
|
\ 'rust': ['cargo'],
|
||||||
\ 'spec': [],
|
\ 'spec': [],
|
||||||
\ 'text': [],
|
\ 'text': [],
|
||||||
|
@ -598,6 +598,7 @@ g:ale_python_pylint_use_msg_id *g:ale_python_pylint_use_msg_id*
|
|||||||
Use message for output (e.g. I0011) instead of symbolic name of the message
|
Use message for output (e.g. I0011) instead of symbolic name of the message
|
||||||
(e.g. locally-disabled).
|
(e.g. locally-disabled).
|
||||||
|
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
pyls *ale-python-pyls*
|
pyls *ale-python-pyls*
|
||||||
|
|
||||||
@ -682,6 +683,65 @@ g:ale_python_pyre_auto_pipenv *g:ale_python_pyre_auto_pipenv*
|
|||||||
if true. This is overridden by a manually-set executable.
|
if true. This is overridden by a manually-set executable.
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
pyright *ale-python-pyright*
|
||||||
|
|
||||||
|
The `pyrlight` linter requires a recent version of `pyright` which includes
|
||||||
|
the `pyright-langserver` executable. You can install `pyright` on your system
|
||||||
|
through `npm` with `sudo npm install -g pyright` or similar.
|
||||||
|
|
||||||
|
Refer to their README for installation instructions:
|
||||||
|
https://github.com/Microsoft/pyright
|
||||||
|
|
||||||
|
`pyright` needs to know the path to your Python executable and probably a
|
||||||
|
virtualenv to run. ALE will try to detect these automatically.
|
||||||
|
See |g:ale_python_pyright_config|.
|
||||||
|
|
||||||
|
|
||||||
|
g:ale_python_pyright_executable *g:ale_python_pyright_executable*
|
||||||
|
*b:ale_python_pyright_executable*
|
||||||
|
Type: |String|
|
||||||
|
Default: `'pyright-langserver'`
|
||||||
|
|
||||||
|
The executable for running `pyright`, which is typically installed globally.
|
||||||
|
|
||||||
|
|
||||||
|
g:ale_python_pyright_config *g:ale_python_pyright_config*
|
||||||
|
*b:ale_python_pyright_config*
|
||||||
|
Type: |Dictionary|
|
||||||
|
Default: `{}`
|
||||||
|
|
||||||
|
Settings for configuring the `pyright` language server.
|
||||||
|
|
||||||
|
See pyright's documentation for a full list of options:
|
||||||
|
https://github.com/microsoft/pyright/blob/master/docs/settings.md
|
||||||
|
|
||||||
|
ALE will automatically try to set defaults for `venvPath` and `pythonPath`
|
||||||
|
so your project can automatically be checked with the right libraries.
|
||||||
|
You can override these settings with whatever you want in your ftplugin
|
||||||
|
file like so: >
|
||||||
|
|
||||||
|
let b:ale_python_pyright_config = {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': '/bin/python',
|
||||||
|
\ 'venvPath': '/other/dir',
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
<
|
||||||
|
If `venvPath` is set, but `pythonPath` is not,
|
||||||
|
ALE will use `venvPath . '/bin/python'` or similar as `pythonPath`.
|
||||||
|
|
||||||
|
A commonly used setting for `pyright` is disabling language services
|
||||||
|
apart from type checking and "hover" (|ale-hover|), you can set this
|
||||||
|
setting like so, or use whatever other settings you want: >
|
||||||
|
|
||||||
|
let b:ale_python_pyright_config = {
|
||||||
|
\ 'pyright': {
|
||||||
|
\ 'disableLanguageServices': v:true,
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
<
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
reorder-python-imports *ale-python-reorder_python_imports*
|
reorder-python-imports *ale-python-reorder_python_imports*
|
||||||
|
|
||||||
|
@ -372,6 +372,7 @@ Notes:
|
|||||||
* `pylint`!!
|
* `pylint`!!
|
||||||
* `pyls`
|
* `pyls`
|
||||||
* `pyre`
|
* `pyre`
|
||||||
|
* `pyright`
|
||||||
* `reorder-python-imports`
|
* `reorder-python-imports`
|
||||||
* `vulture`!!
|
* `vulture`!!
|
||||||
* `yapf`
|
* `yapf`
|
||||||
|
@ -1290,7 +1290,7 @@ g:ale_linters *g:ale_linters*
|
|||||||
\ 'help': [],
|
\ 'help': [],
|
||||||
\ 'perl': ['perlcritic'],
|
\ 'perl': ['perlcritic'],
|
||||||
\ 'perl6': [],
|
\ 'perl6': [],
|
||||||
\ 'python': ['flake8', 'mypy', 'pylint'],
|
\ 'python': ['flake8', 'mypy', 'pylint', 'pyright'],
|
||||||
\ 'rust': ['cargo'],
|
\ 'rust': ['cargo'],
|
||||||
\ 'spec': [],
|
\ 'spec': [],
|
||||||
\ 'text': [],
|
\ 'text': [],
|
||||||
@ -2578,6 +2578,7 @@ documented in additional help files.
|
|||||||
pylint................................|ale-python-pylint|
|
pylint................................|ale-python-pylint|
|
||||||
pyls..................................|ale-python-pyls|
|
pyls..................................|ale-python-pyls|
|
||||||
pyre..................................|ale-python-pyre|
|
pyre..................................|ale-python-pyre|
|
||||||
|
pyright...............................|ale-python-pyright|
|
||||||
reorder-python-imports................|ale-python-reorder_python_imports|
|
reorder-python-imports................|ale-python-reorder_python_imports|
|
||||||
vulture...............................|ale-python-vulture|
|
vulture...............................|ale-python-vulture|
|
||||||
yapf..................................|ale-python-yapf|
|
yapf..................................|ale-python-yapf|
|
||||||
|
@ -380,6 +380,7 @@ formatting.
|
|||||||
* [pylama](https://github.com/klen/pylama) :floppy_disk:
|
* [pylama](https://github.com/klen/pylama) :floppy_disk:
|
||||||
* [pylint](https://www.pylint.org/) :floppy_disk:
|
* [pylint](https://www.pylint.org/) :floppy_disk:
|
||||||
* [pyls](https://github.com/palantir/python-language-server) :warning:
|
* [pyls](https://github.com/palantir/python-language-server) :warning:
|
||||||
|
* [pyright](https://github.com/microsoft/pyright)
|
||||||
* [pyre](https://github.com/facebook/pyre-check) :warning:
|
* [pyre](https://github.com/facebook/pyre-check) :warning:
|
||||||
* [reorder-python-imports](https://github.com/asottile/reorder_python_imports)
|
* [reorder-python-imports](https://github.com/asottile/reorder_python_imports)
|
||||||
* [vulture](https://github.com/jendrikseipp/vulture) :warning: :floppy_disk:
|
* [vulture](https://github.com/jendrikseipp/vulture) :warning: :floppy_disk:
|
||||||
|
116
test/command_callback/test_pyright_command_callback.vader
Normal file
116
test/command_callback/test_pyright_command_callback.vader
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
Before:
|
||||||
|
call ale#assert#SetUpLinterTest('python', 'pyright')
|
||||||
|
|
||||||
|
let b:bin_dir = has('win32') ? 'Scripts' : 'bin'
|
||||||
|
|
||||||
|
After:
|
||||||
|
unlet! b:bin_dir
|
||||||
|
unlet! b:executable
|
||||||
|
|
||||||
|
call ale#assert#TearDownLinterTest()
|
||||||
|
|
||||||
|
Execute(The command callback should return the correct default string):
|
||||||
|
AssertLinter
|
||||||
|
\ 'pyright-langserver',
|
||||||
|
\ ale#Escape('pyright-langserver') . ' --stdio'
|
||||||
|
|
||||||
|
Execute(The executable should be configurable):
|
||||||
|
let g:ale_python_pyright_executable = '/bin/foo-bar'
|
||||||
|
|
||||||
|
AssertLinter
|
||||||
|
\ '/bin/foo-bar',
|
||||||
|
\ ale#Escape('/bin/foo-bar') . ' --stdio'
|
||||||
|
|
||||||
|
Execute(The default configuration should be mostly empty):
|
||||||
|
" The default configuration needs to have at least one key in it,
|
||||||
|
" or the server won't start up properly.
|
||||||
|
AssertLSPConfig {'python': {}}
|
||||||
|
|
||||||
|
let b:ale_python_pyright_config = {}
|
||||||
|
|
||||||
|
AssertLSPConfig {'python': {}}
|
||||||
|
|
||||||
|
Execute(virtualenv paths should be set in configuration by default):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
AssertLSPConfig {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': ale#path#Simplify(g:dir . '/python_paths/with_virtualenv/env/' . b:bin_dir . '/python'),
|
||||||
|
\ 'venvPath': ale#path#Simplify(g:dir . '/python_paths/with_virtualenv/env'),
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
Execute(The pythonPath should be set based on whatever the ovveride for the venvPath is set to):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
" This overrides the default detection of the path.
|
||||||
|
let b:ale_python_pyright_config = {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'venvPath': '/foo/bar',
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
AssertLSPConfig {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': ale#path#Simplify('/foo/bar/' . b:bin_dir . '/python'),
|
||||||
|
\ 'venvPath': '/foo/bar',
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
Execute(You should be able to override pythonPath when venvPath is detected):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
" This overrides the default detection of the path.
|
||||||
|
let b:ale_python_pyright_config = {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': '/bin/python',
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
AssertLSPConfig {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': '/bin/python',
|
||||||
|
\ 'venvPath': ale#path#Simplify(g:dir . '/python_paths/with_virtualenv/env'),
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
Execute(You should be able to override both pythonPath and venvPath):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
" This overrides the default detection of the path.
|
||||||
|
let b:ale_python_pyright_config = {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': '/bin/python',
|
||||||
|
\ 'venvPath': '/other/dir',
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
AssertLSPConfig {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'pythonPath': '/bin/python',
|
||||||
|
\ 'venvPath': '/other/dir',
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
Execute(You should be able to define other settings):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
let b:ale_python_pyright_config = {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'analysis': {'logLevel': 'warning'},
|
||||||
|
\ },
|
||||||
|
\ 'pyright': {
|
||||||
|
\ 'disableLanguageServices': v:true,
|
||||||
|
\ },
|
||||||
|
\}
|
||||||
|
|
||||||
|
AssertLSPConfig {
|
||||||
|
\ 'python': {
|
||||||
|
\ 'analysis': {'logLevel': 'warning'},
|
||||||
|
\ 'pythonPath': ale#path#Simplify(g:dir . '/python_paths/with_virtualenv/env/' . b:bin_dir . '/python'),
|
||||||
|
\ 'venvPath': ale#path#Simplify(g:dir . '/python_paths/with_virtualenv/env'),
|
||||||
|
\ },
|
||||||
|
\ 'pyright': {
|
||||||
|
\ 'disableLanguageServices': v:true,
|
||||||
|
\ },
|
||||||
|
\}
|
@ -32,7 +32,7 @@ Execute(The defaults for the help filetype should be correct):
|
|||||||
AssertEqual [], GetLinterNames('help')
|
AssertEqual [], GetLinterNames('help')
|
||||||
|
|
||||||
Execute(The defaults for the python filetype should be correct):
|
Execute(The defaults for the python filetype should be correct):
|
||||||
AssertEqual ['flake8', 'mypy', 'pylint'], GetLinterNames('python')
|
AssertEqual ['flake8', 'mypy', 'pylint', 'pyright'], GetLinterNames('python')
|
||||||
|
|
||||||
let g:ale_linters_explicit = 1
|
let g:ale_linters_explicit = 1
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user