A language server for Jedi!
Project description
jedi-language-server
A Language Server for the latest version(s) of Jedi.
Note: this tool is actively used by its primary author. He's happy to review pull requests / respond to issues you may discover.
Installation
From your command line (bash / zsh), run:
pip install -U jedi jedi-language-server
-U ensures that you're pulling the latest version from pypi.
Overview
jedi-language-server aims to support all of Jedi's capabilities and expose them through the Language Server Protocol. It currently supports the following Language Server requests:
- textDocument/completion
- textDocument/definition
- textDocument/documentSymbol
- textDocument/hover
- textDocument/references
- textDocument/rename
- workspace/symbol
These language server requests are not currently configurable by the user, but we expect to relax this constraint in a future release.
Usage
The following instructions show how to use jedi-language-server with your development tooling. The instructions assume you have already installed jedi-language-server.
Command line (bash / zsh)
At your terminal prompt:
jedi-language-server
jedi-language-server currently works only over IO. This may change in the future.
Neovim
Configure jedi-language-server with coc.nvim. For diagnostics, we recommend installing and using the latest version of coc-diagnostic with pylint.
~/.config/nvim/coc-settings.json:
"languageserver": {
"jls": {
"command": "jedi-language-server",
"args": [],
"filetypes": ["python"]
}
},
"diagnostic-languageserver.filetypes": {
"python": "pylint"
},
"diagnostic-languageserver.linters": {
"pylint": {
"sourceName": "pylint",
"command": "pylint",
"args": [
"--output-format",
"text",
"--score",
"no",
"--msg-template",
"'{line}:{column}:{category}:{msg} ({msg_id}:{symbol})'",
"%file"
],
"formatPattern": [
"^(\\d+?):(\\d+?):([a-z]+?):(.*)$",
{
"line": 1,
"column": 2,
"security": 3,
"message": 4
}
],
"securities": {
"informational": "hint",
"refactor": "info",
"convention": "info",
"warning": "warning",
"error": "error",
"fatal": "error"
},
"offsetColumn": 1,
"formatLines": 1
}
}
Local Development
To build and run this project from source:
Dependencies
Install the following tools manually:
Recommended
Get source code
Fork this repository and clone the fork to your development machine:
git clone https://github.com/<YOUR-USERNAME>/jedi-language-server
cd jedi-language-server
Set up development environment
make setup
Run tests
make test
Inspiration
Palantir's python-language-server inspired this project. Unlike python-language-server, jedi-language-server:
- Uses
pyglsinstead of creating its own low-level Language Server Protocol bindings - Supports one powerful 3rd party library: Jedi. By only supporting Jedi, we can focus on supporting all Jedi features without exposing ourselves to too many broken 3rd party dependencies (I'm looking at you, rope).
- Is supremely simple because of its scope constraints. Leave complexity to the Jedi master. If the force is strong with you, please submit a PR!
Written by
Samuel Roeca samuel.roeca@gmail.com
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file jedi-language-server-0.4.2.tar.gz.
File metadata
- Download URL: jedi-language-server-0.4.2.tar.gz
- Upload date:
- Size: 10.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/4.15.0-1079-oem
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f9388f3623333d4e0f88b6abbc289f2d0ceec693cd9fb1e91876eec4dd2fb22c
|
|
| MD5 |
395a0e486efc425ad5eb71154fbfff7a
|
|
| BLAKE2b-256 |
be7580bbdf795728fe546a937d048bb7d9ef8ef7567ed5825f251a639efb5e63
|
File details
Details for the file jedi_language_server-0.4.2-py3-none-any.whl.
File metadata
- Download URL: jedi_language_server-0.4.2-py3-none-any.whl
- Upload date:
- Size: 11.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/4.15.0-1079-oem
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a246987ad7718a6999764096aa10044c65af599507bee65c8e39d4f44f5c58fc
|
|
| MD5 |
6c19b201f60591951448c2976ccb7881
|
|
| BLAKE2b-256 |
201ab819872d1cd78c94afc9346b74a7c531131501b68ca6d8856f2f1afd86c8
|