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.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | c40b84ae0da19d8700932f5213f3efde483df1c609b328a11412257ffc2fe3ba |
|
MD5 | 6d649f2d07a69411654ef28a4245ff32 |
|
BLAKE2b-256 | cfdfde4ba801114ca3a121d63d995fa82bf011adee7b2931f2ba5b9c5b845987 |
Hashes for anakin_language_server-1.5-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1d2a03010b7d9999daad4f27ea08a5b41a07c849da716e593e3feb3d71dac229 |
|
MD5 | 962563a3cb4610144f570338644f2e45 |
|
BLAKE2b-256 | 353492b33327f2f8dda867f46c3b548c72a1de0b2b975397d91e97c0bf9ec572 |