Skip to main content

A language server for Jedi!

Project description

jedi-language-server

image-version image-license image-python-versions

A Language Server for the latest version(s) of Jedi. If using Neovim/Vim, we recommend using with coc-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-language-server

-U ensures that you're pulling the latest version from pypi.

Alternatively, consider using pipx to keep jedi-language-server isolated from your other Python dependencies. Don't worry, jedi is smart enough to figure out which Virtual environment you're currently using!

Capabilities

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 capabilities:

Language Features

Text Synchronization (for diagnostics)

Editor Setup

The following instructions show how to use jedi-language-server with your development tooling. The instructions assume you have already installed jedi-language-server.

Vim / Neovim

Use coc.nvim with coc-jedi.

Emacs

Use lsp-jedi.

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.

Configuration

We recommend using coc-jedi and following its configuration instructions.

If you are configuring manually, jedi-language-server supports the following initializationOptions:

...
  "initializationOptions": {
    "markupKindPreferred": null,
    "jediSettings": {
      "autoImportModules": []
    },
    "completion": {
      "disableSnippets": false
    },
    "diagnostics": {
      "enable": true,
      "didOpen": true,
      "didChange": true,
      "didSave": true
    }
  }
...

See coc-jedi's configuration instructions for an explanation of the above configurations.

Additional Diagnostics

jedi-langugage-server currently provides diagnostics about syntax errors, powered by Jedi. If you would like additional diagnostics, we suggest using the powerful diagnostic-language-server.

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 pygls instead 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

jedi-language-server-0.17.1.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jedi_language_server-0.17.1-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

Details for the file jedi-language-server-0.17.1.tar.gz.

File metadata

  • Download URL: jedi-language-server-0.17.1.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/4.15.0-1081-oem

File hashes

Hashes for jedi-language-server-0.17.1.tar.gz
Algorithm Hash digest
SHA256 4e8ba1cea11cfb68c954bd09e460de0998aa2511b65f2cca927e3e4d650ea19a
MD5 1b0b59ed257d5ea80ad4fd0e5c016355
BLAKE2b-256 f1d29a4de3e38c1d80d7e64d1e6d617b568f6d9590d6afb4c2bfd26f8610f0de

See more details on using hashes here.

File details

Details for the file jedi_language_server-0.17.1-py3-none-any.whl.

File metadata

File hashes

Hashes for jedi_language_server-0.17.1-py3-none-any.whl
Algorithm Hash digest
SHA256 838ecc3b95529e7d57dff90a168756a8c104cc00c2d0520f0c8a3783d9f2b706
MD5 8bde30b03d0a963cf1f2c62058ba4dbf
BLAKE2b-256 6160a2617de0c522918e7c22aa5ae4ba2ee17d427baa3f08ae008d3e98a9fc95

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page