lsp-types


Namelsp-types JSON
Version 0.10.0 PyPI version JSON
download
home_pageNone
SummaryZero-dependency Python library for Language Server Protocol types
upload_time2025-08-03 05:17:58
maintainerNone
docs_urlNone
authorNone
requires_python>=3.11
licenseNone
keywords development-tools editor-tools ide language-server-protocol lsp
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # LSP Types

[![PyPI version](https://badge.fury.io/py/lsp-types.svg)](https://badge.fury.io/py/lsp-types)
[![Python](https://img.shields.io/badge/python-3.11%2B-blue.svg)](https://www.python.org/downloads/)
[![Tests](https://github.com/Mazyod/lsp-python-types/actions/workflows/python-tests.yml/badge.svg)](https://github.com/Mazyod/lsp-python-types/actions/workflows/python-tests.yml)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

_Publish the excellent work of [Sublime LSP](https://github.com/sublimelsp/lsp-python-types) as a PyPI package._

![image](https://github.com/user-attachments/assets/12b6016a-8e62-4058-8c74-26fcdee1122a)


__LSP Types__ is a Python package that aims to provide a fully typed interface to Language Server Protocol (LSP) interactions. It can be used to simply utilize the types, or to interact with an LSP server over stdio.

It is a goal to maintain zero-dependency status for as long as possible.

## Installation

```sh
pip install lsp-types
```

## Usage

Using the LSP types:

```python
import lsp_types

# Use the types
```

Using an LSP process through stdio:

> [!TIP]
> Recommend using [basedpyright](https://github.com/DetachHead/basedpyright) for extended features.

```python
from lsp_types.process import LSPProcess, ProcessLaunchInfo

process_info = ProcessLaunchInfo(cmd=[
    "pyright-langserver", "--stdio"
])

async with LSPProcess(process_info) as process:
    # Initialize the process
    ...

    # Grab a typed listener
    diagnostics_listener = process.notify.on_publish_diagnostics(timeout=1.0)

    # Send a notification (`await` is optional. It ensures messages have been drained)
    await process.notify.did_open_text_document(...)

    # Wait for diagnostics to come in
    diagnostics = await diagnostics_listener
```

## LSPs

The following LSPs are available out of the box:

### Pyright

```python
async def test_pyright_session():
    code = """\
def greet(name: str) -> str:
    return 123
"""

    pyright_session = await Session.create(PyrightBackend(), initial_code=code)
    diagnostics = await pyright_session.get_diagnostics()

    assert diagnostics != []

    code = """\
def greet(name: str) -> str:
    return f"Hello, {name}"
"""

    assert await pyright_session.update_code(code) == 2

    diagnostics = await pyright_session.get_diagnostics()
    assert diagnostics == []
```

## Development

- Requires Python 3.11+.
- Requires `uv` for dev dependencies.

Generate latest types in one go:
```sh
make generate-latest-types
```

Download the latest json schema:
```sh
make download-schemas
```

Generate the types:
```sh
make generate-schemas
```

Copy the `lsp_types/types.py` file to your project.

NOTE: Do not import types that begin with `__`. These types are internal types and are not meant to be used.

### TODOs

- Automate package releases on Github.
- Support server request handlers.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "lsp-types",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.11",
    "maintainer_email": null,
    "keywords": "development-tools, editor-tools, ide, language-server-protocol, lsp",
    "author": null,
    "author_email": "Mazyad Alabduljaleel <mazjaleel@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/5a/cd/7f31f4e5decce0a9953a1bd5e111e3d6f6416b0a7f8f18a33ccde2126beb/lsp_types-0.10.0.tar.gz",
    "platform": null,
    "description": "# LSP Types\n\n[![PyPI version](https://badge.fury.io/py/lsp-types.svg)](https://badge.fury.io/py/lsp-types)\n[![Python](https://img.shields.io/badge/python-3.11%2B-blue.svg)](https://www.python.org/downloads/)\n[![Tests](https://github.com/Mazyod/lsp-python-types/actions/workflows/python-tests.yml/badge.svg)](https://github.com/Mazyod/lsp-python-types/actions/workflows/python-tests.yml)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n\n_Publish the excellent work of [Sublime LSP](https://github.com/sublimelsp/lsp-python-types) as a PyPI package._\n\n![image](https://github.com/user-attachments/assets/12b6016a-8e62-4058-8c74-26fcdee1122a)\n\n\n__LSP Types__ is a Python package that aims to provide a fully typed interface to Language Server Protocol (LSP) interactions. It can be used to simply utilize the types, or to interact with an LSP server over stdio.\n\nIt is a goal to maintain zero-dependency status for as long as possible.\n\n## Installation\n\n```sh\npip install lsp-types\n```\n\n## Usage\n\nUsing the LSP types:\n\n```python\nimport lsp_types\n\n# Use the types\n```\n\nUsing an LSP process through stdio:\n\n> [!TIP]\n> Recommend using [basedpyright](https://github.com/DetachHead/basedpyright) for extended features.\n\n```python\nfrom lsp_types.process import LSPProcess, ProcessLaunchInfo\n\nprocess_info = ProcessLaunchInfo(cmd=[\n    \"pyright-langserver\", \"--stdio\"\n])\n\nasync with LSPProcess(process_info) as process:\n    # Initialize the process\n    ...\n\n    # Grab a typed listener\n    diagnostics_listener = process.notify.on_publish_diagnostics(timeout=1.0)\n\n    # Send a notification (`await` is optional. It ensures messages have been drained)\n    await process.notify.did_open_text_document(...)\n\n    # Wait for diagnostics to come in\n    diagnostics = await diagnostics_listener\n```\n\n## LSPs\n\nThe following LSPs are available out of the box:\n\n### Pyright\n\n```python\nasync def test_pyright_session():\n    code = \"\"\"\\\ndef greet(name: str) -> str:\n    return 123\n\"\"\"\n\n    pyright_session = await Session.create(PyrightBackend(), initial_code=code)\n    diagnostics = await pyright_session.get_diagnostics()\n\n    assert diagnostics != []\n\n    code = \"\"\"\\\ndef greet(name: str) -> str:\n    return f\"Hello, {name}\"\n\"\"\"\n\n    assert await pyright_session.update_code(code) == 2\n\n    diagnostics = await pyright_session.get_diagnostics()\n    assert diagnostics == []\n```\n\n## Development\n\n- Requires Python 3.11+.\n- Requires `uv` for dev dependencies.\n\nGenerate latest types in one go:\n```sh\nmake generate-latest-types\n```\n\nDownload the latest json schema:\n```sh\nmake download-schemas\n```\n\nGenerate the types:\n```sh\nmake generate-schemas\n```\n\nCopy the `lsp_types/types.py` file to your project.\n\nNOTE: Do not import types that begin with `__`. These types are internal types and are not meant to be used.\n\n### TODOs\n\n- Automate package releases on Github.\n- Support server request handlers.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Zero-dependency Python library for Language Server Protocol types",
    "version": "0.10.0",
    "project_urls": {
        "Documentation": "https://github.com/mazyod/lsp-python-types#readme",
        "Homepage": "https://github.com/mazyod/lsp-python-types",
        "Repository": "https://github.com/mazyod/lsp-python-types"
    },
    "split_keywords": [
        "development-tools",
        " editor-tools",
        " ide",
        " language-server-protocol",
        " lsp"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "f1c8374ef5d053af09c1e9c5889e75a9f9e419484a792b36cc600bc80e5ef27e",
                "md5": "b3b47a46e6fb6e1589bba0f0eb8f2537",
                "sha256": "53fe04ed3807472ce165a51cbe6c7be487ccb8b0891e4008a2fc111acffc0283"
            },
            "downloads": -1,
            "filename": "lsp_types-0.10.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "b3b47a46e6fb6e1589bba0f0eb8f2537",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.11",
            "size": 67142,
            "upload_time": "2025-08-03T05:17:54",
            "upload_time_iso_8601": "2025-08-03T05:17:54.389341Z",
            "url": "https://files.pythonhosted.org/packages/f1/c8/374ef5d053af09c1e9c5889e75a9f9e419484a792b36cc600bc80e5ef27e/lsp_types-0.10.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "5acd7f31f4e5decce0a9953a1bd5e111e3d6f6416b0a7f8f18a33ccde2126beb",
                "md5": "8cf747776dc8092f22867f54e90c1440",
                "sha256": "38bd384f6bc90577fa8d38c3b262d020f263329e779e08a72517f44c73653e88"
            },
            "downloads": -1,
            "filename": "lsp_types-0.10.0.tar.gz",
            "has_sig": false,
            "md5_digest": "8cf747776dc8092f22867f54e90c1440",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.11",
            "size": 64807,
            "upload_time": "2025-08-03T05:17:58",
            "upload_time_iso_8601": "2025-08-03T05:17:58.460703Z",
            "url": "https://files.pythonhosted.org/packages/5a/cd/7f31f4e5decce0a9953a1bd5e111e3d6f6416b0a7f8f18a33ccde2126beb/lsp_types-0.10.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-08-03 05:17:58",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "mazyod",
    "github_project": "lsp-python-types#readme",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "lsp-types"
}
        
Elapsed time: 2.45291s