Yet another Jedi Python language server
Project description
anakin-language-server
Yet another Jedi Python language server
Requirements
- Python >= 3.6
- pygls ~= 0.9
- Jedi ~= 0.17
- pyflakes ~= 2.2
- pycodestyle ~= 2.5
Optional requirements
- mypy
Implemented features
textDocument/completion
textDocument/hover
textDocument/signatureHelp
textDocument/definition
textDocument/references
textDocument/publishDiagnostics
textDocument/documentSymbol
textDocument/codeAction
(Inline variable)
Initialization option
venv
- path to virtualenv. This option will be passed to Jedi's create_environment.
Also one can set VIRTUAL_ENV
or CONDA_PREFIX
before running anakinls
so Jedi will find proper environment. See get_default_environment.
Diagnostics
Diagnostics are published on document open and save.
Diagnostics providers:
-
Jedi
See get_syntax_errors.
-
pyflakes
-
pycodestyle
Server restart is needed after changing one of the configuration files.
-
mypy
Install
mypy
in the same environment asanakinls
and setmypy_enabled
configuration option.
Configuration options
Configuration options must be passed under anakinls
key in workspace/didChangeConfiguration
notification.
Available options:
-
pyflakes_errors
- Diagnostic severity will be set toError
if Pyflakes message class name is in this list. See Pyflakes messages.Default:
['UndefinedName']
. -
help_on_hover
- Usehelp
instead ofinfer
fortextDocument/hover
.Default:
True
. -
mypy_enabled
- Usemypy
to provide diagnostics.Default:
False
. -
pycodestyle_config
- In addition to project and user level config, specify pycodestyle config file. Same as--config
option forpycodestyle
.Default:
None
.
Configuration example
Here is eglot configuration:
(defvar my/lsp-venv nil
"Name of virtualenv.
Set it in project's dir-locals file.")
(defclass my/eglot-anakinls (eglot-lsp-server) ()
:documentation
"Own eglot server class.")
(cl-defmethod eglot-initialization-options ((_server my/eglot-anakinls))
"Pass initialization param to anakinls."
`(:venv ,(when my/lsp-venv
(expand-file-name
(concat "~/.virtualenvs/" my/lsp-venv)))))
;; Add this server to eglot programs to handle python-mode and run `anakinls'
(add-to-list 'eglot-server-programs
'(python-mode my/eglot-anakinls "anakinls"))
;; Also treat UnusedVariable as error
(setq-default eglot-workspace-configuration
'((:anakinls :pyflakes_errors ["UndefinedName" "UnusedVariable"])))
Installation
pip install anakin-language-server
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for anakin-language-server-1.5.1.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 298c3da0e8553ee0f9f11dc80eda76412c3eea5ef13d282fc1ea051dc2256599 |
|
MD5 | 1cbb4150c1c3d48269793933834a5895 |
|
BLAKE2b-256 | afb2a4f7781543baadb7e970f0f61b7792080c31a997f9b3dca7d62feac03c86 |
Hashes for anakin_language_server-1.5.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 03d80189cfa17e07fd23f4237867070ec44fe0c8245dac5c78a119b08c8638ba |
|
MD5 | 12d9705401a18b65e73ced2cd2e4af79 |
|
BLAKE2b-256 | 40d26327a1219c92c58674902dc22cbc180176a009b9b138139f2f72a90bf038 |