Skip to main content

An implementation of the client side of the LSP protocol, useful for embedding easily in your editor.

Project description

sansio-lsp-client

This is an implementation of the client side of the langserver (LSP) protocol, useful for embedding easily in your editor. It is used in Porcupine, and will soon be used in Biscuit too.

The "sans io" part of the name means "without IO". It means that this library doesn't do IO, and you do it instead. Specifically:

  • You start a langserver process
  • You read data from the stdout of the langserver process
  • You feed the data to this library
  • This library returns data to be written to the stdin of the langserver process
  • You write the data to the stdin of the langserver process.

This way, this library is very flexible. It assumes nothing about how IO works, so you can use it with threads, without threads, with sync code, with async code, or with any other kind of IO thing.

Usage

Unfortunately, there isn't much documentation. Hopefully someone will write some docs eventually :)

If you want to add langserver support to a text editor, you could look at Porcupine's langserver plugin to get started. Porcupine is MIT licensed, so you can use its code in your projects as long as you credit Porcupine accordingly. You can also look at this project's tests, which are simple in principle, but kind of messy in practice.

Maintenance Status

Currently (2024) there are two maintainers (Akuli and PurpleMyst) who merge and review pull requests. Also, the project cannot become totally broken, because Akuli uses Porcupine almost every day, and langserver support is an essential part of Porcupine.

New features are usually added by someone else than the two maintainers. We recommend just adding what you need for your use case and making a pull request.

Developing

$ git clone https://github.com/PurpleMyst/sansio-lsp-client
$ cd sansio-lsp-client
$ python3 -m venv env
$ source env/bin/activate
(env)$ pip install --upgrade pip
(env)$ pip install poetry
(env)$ poetry install

Most tests don't work on Windows, but GitHub Actions runs tests of all pull requests and uploads coverage files from them. TODO: add instructions for looking at coverage files on Windows

To run tests, first download the langservers you need. You can mostly read .github/workflows/test.yml, but the Go langserver is a bit of a gotcha. You will need to install go from https://golang.org/, because the one from sudo apt install golang is too old. Extract it inside where you cloned sansio-lsp-client so that you get an executable named sansio-lsp-client/go/bin/go.

$ tar xf ~/Downloads/go1.16.5.linux-amd64.tar.gz

Once you have installed all langservers you want, you can run the tests:

(env)$ PATH="$PATH:$(pwd)/go/bin" poetry run pytest -v

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sansio_lsp_client-0.13.0.tar.gz (15.2 kB view details)

Uploaded Source

Built Distribution

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

sansio_lsp_client-0.13.0-py3-none-any.whl (16.2 kB view details)

Uploaded Python 3

File details

Details for the file sansio_lsp_client-0.13.0.tar.gz.

File metadata

  • Download URL: sansio_lsp_client-0.13.0.tar.gz
  • Upload date:
  • Size: 15.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.10.16 Linux/6.8.0-1021-azure

File hashes

Hashes for sansio_lsp_client-0.13.0.tar.gz
Algorithm Hash digest
SHA256 4409da067017cfd668769ccc4b1ece6e5d2614344069b85c1c8ca90994720077
MD5 519d870d8e09fa1cef18b9adb9820d5e
BLAKE2b-256 bd49be68e7eef46f382bcdffde57a9596622be29ec2750017360cba8163f4911

See more details on using hashes here.

File details

Details for the file sansio_lsp_client-0.13.0-py3-none-any.whl.

File metadata

  • Download URL: sansio_lsp_client-0.13.0-py3-none-any.whl
  • Upload date:
  • Size: 16.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.10.16 Linux/6.8.0-1021-azure

File hashes

Hashes for sansio_lsp_client-0.13.0-py3-none-any.whl
Algorithm Hash digest
SHA256 36e838f68c4c34d7378bc3c6d51cbe8c45a92a284fddc90d3de785269221d5eb
MD5 95ac273af75fbdde387d52ea3d39b2bb
BLAKE2b-256 efce686f94cd12b8ea19248027b1f035ef5d0d294b41159ece26f72e2612611f

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