jupyterlab-lsp


Namejupyterlab-lsp JSON
Version 5.1.0 PyPI version JSON
download
home_page
SummaryCoding assistance for JupyterLab with Language Server Protocol
upload_time2024-02-26 15:39:45
maintainer
docs_urlNone
authorJupyterLab-LSP Development Team
requires_python>=3.8
licenseBSD-3-Clause
keywords interactive language server lsp jupyterlab jupyterlab4
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Language Server Protocol integration for Jupyter(Lab)

[![tests](https://github.com/jupyter-lsp/jupyterlab-lsp/workflows/CI/badge.svg)](https://github.com/jupyter-lsp/jupyterlab-lsp/actions?query=workflow%3ACI+branch%3Amain)
[![Documentation Status](https://readthedocs.org/projects/jupyterlab-lsp/badge/?version=latest)](https://jupyterlab-lsp.readthedocs.io/en/latest/?badge=latest)
[![Python Demo](https://img.shields.io/badge/demo-Python-blue)](https://mybinder.org/v2/gh/jupyter-lsp/demo-python/main?urlpath=lab)
[![R Demo](https://img.shields.io/badge/demo-R-blue)](https://mybinder.org/v2/gh/jupyter-lsp/demo-r/main?urlpath=lab)
[![Julia Demo](https://img.shields.io/badge/demo-Julia-blue)](https://mybinder.org/v2/gh/jupyter-lsp/demo-julia/main?urlpath=lab)
[![Binder](https://img.shields.io/badge/launch-dev_version-blue)](https://mybinder.org/v2/gh/jupyter-lsp/jupyterlab-lsp/main?urlpath=lab%2Ftree%2Fexamples%2FPython.ipynb)

**[Installation](#installation) | [Configuring](./docs/Configuring.ipynb) | [Changelog](./CHANGELOG.md) | [Roadmap](./docs/Roadmap.ipynb) | [Contributing](./CONTRIBUTING.md) | [Extending](./docs/Extending.ipynb)**

## Features

> Examples show Python code, but most features also work in R, bash, typescript, and [many other languages][language-servers].

### Hover

Hover over any piece of code; if an underline appears, you can press <kbd>Ctrl</kbd>
to get a tooltip with function/class signature, module documentation or any other
piece of information that the language server provides

![hover](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/hover.png)

### Diagnostics

Critical errors have red underline, warnings are orange, etc. Hover
over the underlined code to see a more detailed message

![inspections](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/inspections.png)

### Jump to Definition and References

Use the context menu entry, or <kbd>Alt</kbd> + :computer_mouse: to jump to definitions/references (you can change it to <kbd>Ctrl</kbd>/<kbd>⌘</kbd> in settings); use <kbd>Alt</kbd> + <kbd>o</kbd> to jump back.

![jump](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/jump_to_definition.png)

### Highlight References

Place your cursor on a variable, function, etc and all the usages will be highlighted

### Automatic Completion and Continuous Hinting

- Certain characters, for example '.' (dot) in Python, will automatically trigger
  completion.
- You can choose to receive the completion suggestions as you type by enabling `continuousHinting` setting.

![invoke](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/autocompletion.gif)

### Automatic Signature Suggestions

Function signatures will automatically be displayed

![signature](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/signature.png)

### Kernel-less Autocompletion

Advanced static-analysis autocompletion without a running kernel

![autocompletion](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/completions-Julia-Python-R.gif)

#### The runtime kernel suggestions are still there

When a kernel is available the suggestions from the kernel (such as keys of a
dict and columns of a DataFrame) are merged with the suggestions
from the Language Server (in notebook).

If the kernel is too slow to respond promptly only the Language Server suggestions will be shown (default threshold: 0.6s).
You can configure the completer to not attempt to fetch the kernel completions if the kernel is busy (skipping the 0.6s timeout).

You can deactivate the kernel suggestions by adding `"Kernel"` to the `disableCompletionsFrom` in the `completion` section
of _Advanced Settings_. Alternatively if you _only_ want kernel completions you can add `"LSP"` to the same
setting; Or add both if you like to code in hardcore mode and get no completions, or if another provider has been added.

### Rename

Rename variables, functions and more, in both: notebooks and the file editor.
Use the context menu option or the <kbd>F2</kbd> shortcut to invoke.

![rename](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/rename.png)

### Diagnostics panel

Sort and jump between the diagnostics using the diagnostics panel.
Open it searching for "Show diagnostics panel" in JupyterLab commands palette or from the context menu.
Use context menu on rows in the panel to filter out diagnostics or copy their message.

![panel](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/panel.png)

## Prerequisites

You will need to have both of the following installed:

- JupyterLab >=4.1.0,<5.0.0a0
- Python 3.8+

In addition, if you wish to use javascript, html, markdown or any other NodeJS-based language server you will need to have appropriate NodeJS version installed.

> Note: Installation for JupyterLab 2.x requires a different procedure, please consult the documentation for the extension [version 2.x][version 2.x docs].

## Installation

> For more extensive installation instructions, see the [documentation][installation-documentation].

For the current stable version, the following steps are recommended.
Use of a python `virtualenv` or a conda env is also recommended.

1. install python 3

   ```bash
   conda install -c conda-forge python=3
   ```

1. install JupyterLab and the extensions

   ```bash
   conda install -c conda-forge 'jupyterlab>=4.1.0,<5.0.0a0' jupyterlab-lsp
   # or
   pip install 'jupyterlab>=4.1.0,<5.0.0a0' jupyterlab-lsp
   ```

   > Note: `jupyterlab-lsp` provides both the server extension and the lab extension.

   > Note: With conda, you could take advantage of the bundles: `jupyter-lsp-python`
   > or `jupyter-lsp-r` to install both the server extension and the language server.

1. install LSP servers for languages of your choice; for example, for Python
   ([pylsp](https://github.com/python-lsp/python-lsp-server)) and
   R ([languageserver](https://github.com/REditorSupport/languageserver)) servers:

   ```bash
   pip install 'python-lsp-server[all]'
   R -e 'install.packages("languageserver")'
   ```

   or from `conda-forge`

   ```bash
   conda install -c conda-forge python-lsp-server r-languageserver
   ```

   Please see our full list of
   [supported language servers][language-servers]
   which includes installation hints for the common package managers (npm/pip/conda).
   In general, any LSP server from the
   [Microsoft list](https://microsoft.github.io/language-server-protocol/implementors/servers/)
   should work after [some additional configuration](./CONTRIBUTING.md#specs).

   Note: it is worth visiting the repository of each server you install as
   many provide additional configuration options.

1. Restart JupyterLab

   If JupyterLab is running when you installed the extension, a restart is required
   for the server extension and any language servers to be recognized by JupyterLab.

1. (Optional, IPython users only) to improve the performance of autocompletion,
   disable Jedi in IPython (the LSP servers for Python use Jedi too).
   You can do that temporarily with:

   ```ipython
   %config Completer.use_jedi = False
   ```

   or permanently by setting `c.Completer.use_jedi = False` in your
   [`ipython_config.py` file](https://ipython.readthedocs.io/en/stable/config/intro.html?highlight=ipython_config.py#systemwide-configuration).

1. (Optional, Linux/OSX-only) As a security measure by default Jupyter server only allows
   access to files under the Jupyter root directory (the place where you launch the Jupyter server).
   Thus, in order to allow `jupyterlab-lsp` to navigate to external files such as packages
   installed system-wide or to libraries inside a virtual environment (`conda`,
   `pip`, ...) this access control mechanism needs to be circumvented: inside your Jupyter
   root directory create a symlink named _.lsp_symlink_ pointing to your system root `/`.

   ```
   ln -s / .lsp_symlink
   ```

   As this symlink is a hidden file the Jupyter server must be instructed to
   serve hidden files. Either use the appropriate command line flag:

   ```
   jupyter lab --ContentsManager.allow_hidden=True
   ```

   or, alternatively, set the corresponding setting inside your `jupyter_server_config.py`.

   Help in implementing a custom [`ContentsManager`](https://github.com/jupyter-lsp/jupyterlab-lsp/issues/850)
   which will enable navigating to external files without the symlink is welcome.

### Configuring the servers

Server configurations can be edited using the Advanced Settings editor in JupyterLab (_Settings > Advanced Settings Editor_). For settings specific to each server, please see the [table of language servers][language-servers]. Example settings might include:

```json
{
  "language_servers": {
    "pylsp": {
      "serverSettings": {
        "pylsp.plugins.pydocstyle.enabled": true,
        "pylsp.plugins.pyflakes.enabled": false,
        "pylsp.plugins.flake8.enabled": true
      }
    },
    "r-languageserver": {
      "serverSettings": {
        "r.lsp.debug": false,
        "r.lsp.diagnostics": false
      }
    }
  }
}
```

The `serverSettings` key specifies the configurations sent to the language servers. These can be written using stringified dot accessors like above (in the VSCode style), or as nested JSON objects, e.g.:

```json
{
  "language_servers": {
    "pylsp": {
      "serverSettings": {
        "pylsp": {
          "plugins": {
            "pydocstyle": {
              "enabled": true
            },
            "pyflakes": {
              "enabled": false
            },
            "flake8": {
              "enabled": true
            }
          }
        }
      }
    }
  }
}
```

#### Other configuration methods

Some language servers, such as `pylsp`, provide other configuration methods _in addition_ to language-server configuration messages (accessed using the Advanced Settings Editor). For example, `pylsp` allows users to configure the server using a local configuration file. You can change the inspection/diagnostics for server plugins like `pycodestyle` there.

The exact configuration details will vary between operating systems (please see the [configuration section of pycodestyle documentation](https://pycodestyle.readthedocs.io/en/latest/intro.html#configuration)), but as an example, on Linux you would simply need to create a file called `~/.config/pycodestyle`, which may look like that:

```cfg
[pycodestyle]
ignore = E402, E703
max-line-length = 120
```

In the example above:

- ignoring E402 allows imports which are not on the very top of the file,
- ignoring E703 allows terminating semicolon (useful for matplotlib plots),
- the maximal allowed line length is increased to 120.

After changing the configuration you may need to restart the JupyterLab, and please be advised that the errors in configuration may prevent the servers from functioning properly.

Again, please do check the pycodestyle documentation for specific error codes, and check the configuration of other feature providers and language servers as needed.

## Acknowledgements

This would not be possible without the fantastic initial work at
[wylieconlon/lsp-editor-adapter](https://github.com/wylieconlon/lsp-editor-adapter).

[language-servers]: https://jupyterlab-lsp.readthedocs.io/en/latest/Language%20Servers.html
[installation-documentation]: https://jupyterlab-lsp.readthedocs.io/en/latest/Installation.html
[version 2.x docs]: https://jupyterlab-lsp.readthedocs.io/en/2.x/Installation.html

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "jupyterlab-lsp",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "",
    "keywords": "Interactive,Language Server,LSP,JupyterLab,JupyterLab4",
    "author": "JupyterLab-LSP Development Team",
    "author_email": "project.jupyter@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/b8/49/b6bc55457ebac72928c9db6e5c23c6e0a1d3a5640fc4b4abb4275f10ef7c/jupyterlab-lsp-5.1.0.tar.gz",
    "platform": null,
    "description": "# Language Server Protocol integration for Jupyter(Lab)\n\n[![tests](https://github.com/jupyter-lsp/jupyterlab-lsp/workflows/CI/badge.svg)](https://github.com/jupyter-lsp/jupyterlab-lsp/actions?query=workflow%3ACI+branch%3Amain)\n[![Documentation Status](https://readthedocs.org/projects/jupyterlab-lsp/badge/?version=latest)](https://jupyterlab-lsp.readthedocs.io/en/latest/?badge=latest)\n[![Python Demo](https://img.shields.io/badge/demo-Python-blue)](https://mybinder.org/v2/gh/jupyter-lsp/demo-python/main?urlpath=lab)\n[![R Demo](https://img.shields.io/badge/demo-R-blue)](https://mybinder.org/v2/gh/jupyter-lsp/demo-r/main?urlpath=lab)\n[![Julia Demo](https://img.shields.io/badge/demo-Julia-blue)](https://mybinder.org/v2/gh/jupyter-lsp/demo-julia/main?urlpath=lab)\n[![Binder](https://img.shields.io/badge/launch-dev_version-blue)](https://mybinder.org/v2/gh/jupyter-lsp/jupyterlab-lsp/main?urlpath=lab%2Ftree%2Fexamples%2FPython.ipynb)\n\n**[Installation](#installation) | [Configuring](./docs/Configuring.ipynb) | [Changelog](./CHANGELOG.md) | [Roadmap](./docs/Roadmap.ipynb) | [Contributing](./CONTRIBUTING.md) | [Extending](./docs/Extending.ipynb)**\n\n## Features\n\n> Examples show Python code, but most features also work in R, bash, typescript, and [many other languages][language-servers].\n\n### Hover\n\nHover over any piece of code; if an underline appears, you can press <kbd>Ctrl</kbd>\nto get a tooltip with function/class signature, module documentation or any other\npiece of information that the language server provides\n\n![hover](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/hover.png)\n\n### Diagnostics\n\nCritical errors have red underline, warnings are orange, etc. Hover\nover the underlined code to see a more detailed message\n\n![inspections](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/inspections.png)\n\n### Jump to Definition and References\n\nUse the context menu entry, or <kbd>Alt</kbd> + :computer_mouse: to jump to definitions/references (you can change it to <kbd>Ctrl</kbd>/<kbd>\u2318</kbd> in settings); use <kbd>Alt</kbd> + <kbd>o</kbd> to jump back.\n\n![jump](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/jump_to_definition.png)\n\n### Highlight References\n\nPlace your cursor on a variable, function, etc and all the usages will be highlighted\n\n### Automatic Completion and Continuous Hinting\n\n- Certain characters, for example '.' (dot) in Python, will automatically trigger\n  completion.\n- You can choose to receive the completion suggestions as you type by enabling `continuousHinting` setting.\n\n![invoke](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/autocompletion.gif)\n\n### Automatic Signature Suggestions\n\nFunction signatures will automatically be displayed\n\n![signature](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/signature.png)\n\n### Kernel-less Autocompletion\n\nAdvanced static-analysis autocompletion without a running kernel\n\n![autocompletion](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/completions-Julia-Python-R.gif)\n\n#### The runtime kernel suggestions are still there\n\nWhen a kernel is available the suggestions from the kernel (such as keys of a\ndict and columns of a DataFrame) are merged with the suggestions\nfrom the Language Server (in notebook).\n\nIf the kernel is too slow to respond promptly only the Language Server suggestions will be shown (default threshold: 0.6s).\nYou can configure the completer to not attempt to fetch the kernel completions if the kernel is busy (skipping the 0.6s timeout).\n\nYou can deactivate the kernel suggestions by adding `\"Kernel\"` to the `disableCompletionsFrom` in the `completion` section\nof _Advanced Settings_. Alternatively if you _only_ want kernel completions you can add `\"LSP\"` to the same\nsetting; Or add both if you like to code in hardcore mode and get no completions, or if another provider has been added.\n\n### Rename\n\nRename variables, functions and more, in both: notebooks and the file editor.\nUse the context menu option or the <kbd>F2</kbd> shortcut to invoke.\n\n![rename](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/rename.png)\n\n### Diagnostics panel\n\nSort and jump between the diagnostics using the diagnostics panel.\nOpen it searching for \"Show diagnostics panel\" in JupyterLab commands palette or from the context menu.\nUse context menu on rows in the panel to filter out diagnostics or copy their message.\n\n![panel](https://raw.githubusercontent.com/jupyter-lsp/jupyterlab-lsp/main/examples/screenshots/panel.png)\n\n## Prerequisites\n\nYou will need to have both of the following installed:\n\n- JupyterLab >=4.1.0,<5.0.0a0\n- Python 3.8+\n\nIn addition, if you wish to use javascript, html, markdown or any other NodeJS-based language server you will need to have appropriate NodeJS version installed.\n\n> Note: Installation for JupyterLab 2.x requires a different procedure, please consult the documentation for the extension [version 2.x][version 2.x docs].\n\n## Installation\n\n> For more extensive installation instructions, see the [documentation][installation-documentation].\n\nFor the current stable version, the following steps are recommended.\nUse of a python `virtualenv` or a conda env is also recommended.\n\n1. install python 3\n\n   ```bash\n   conda install -c conda-forge python=3\n   ```\n\n1. install JupyterLab and the extensions\n\n   ```bash\n   conda install -c conda-forge 'jupyterlab>=4.1.0,<5.0.0a0' jupyterlab-lsp\n   # or\n   pip install 'jupyterlab>=4.1.0,<5.0.0a0' jupyterlab-lsp\n   ```\n\n   > Note: `jupyterlab-lsp` provides both the server extension and the lab extension.\n\n   > Note: With conda, you could take advantage of the bundles: `jupyter-lsp-python`\n   > or `jupyter-lsp-r` to install both the server extension and the language server.\n\n1. install LSP servers for languages of your choice; for example, for Python\n   ([pylsp](https://github.com/python-lsp/python-lsp-server)) and\n   R ([languageserver](https://github.com/REditorSupport/languageserver)) servers:\n\n   ```bash\n   pip install 'python-lsp-server[all]'\n   R -e 'install.packages(\"languageserver\")'\n   ```\n\n   or from `conda-forge`\n\n   ```bash\n   conda install -c conda-forge python-lsp-server r-languageserver\n   ```\n\n   Please see our full list of\n   [supported language servers][language-servers]\n   which includes installation hints for the common package managers (npm/pip/conda).\n   In general, any LSP server from the\n   [Microsoft list](https://microsoft.github.io/language-server-protocol/implementors/servers/)\n   should work after [some additional configuration](./CONTRIBUTING.md#specs).\n\n   Note: it is worth visiting the repository of each server you install as\n   many provide additional configuration options.\n\n1. Restart JupyterLab\n\n   If JupyterLab is running when you installed the extension, a restart is required\n   for the server extension and any language servers to be recognized by JupyterLab.\n\n1. (Optional, IPython users only) to improve the performance of autocompletion,\n   disable Jedi in IPython (the LSP servers for Python use Jedi too).\n   You can do that temporarily with:\n\n   ```ipython\n   %config Completer.use_jedi = False\n   ```\n\n   or permanently by setting `c.Completer.use_jedi = False` in your\n   [`ipython_config.py` file](https://ipython.readthedocs.io/en/stable/config/intro.html?highlight=ipython_config.py#systemwide-configuration).\n\n1. (Optional, Linux/OSX-only) As a security measure by default Jupyter server only allows\n   access to files under the Jupyter root directory (the place where you launch the Jupyter server).\n   Thus, in order to allow `jupyterlab-lsp` to navigate to external files such as packages\n   installed system-wide or to libraries inside a virtual environment (`conda`,\n   `pip`, ...) this access control mechanism needs to be circumvented: inside your Jupyter\n   root directory create a symlink named _.lsp_symlink_ pointing to your system root `/`.\n\n   ```\n   ln -s / .lsp_symlink\n   ```\n\n   As this symlink is a hidden file the Jupyter server must be instructed to\n   serve hidden files. Either use the appropriate command line flag:\n\n   ```\n   jupyter lab --ContentsManager.allow_hidden=True\n   ```\n\n   or, alternatively, set the corresponding setting inside your `jupyter_server_config.py`.\n\n   Help in implementing a custom [`ContentsManager`](https://github.com/jupyter-lsp/jupyterlab-lsp/issues/850)\n   which will enable navigating to external files without the symlink is welcome.\n\n### Configuring the servers\n\nServer configurations can be edited using the Advanced Settings editor in JupyterLab (_Settings > Advanced Settings Editor_). For settings specific to each server, please see the [table of language servers][language-servers]. Example settings might include:\n\n```json\n{\n  \"language_servers\": {\n    \"pylsp\": {\n      \"serverSettings\": {\n        \"pylsp.plugins.pydocstyle.enabled\": true,\n        \"pylsp.plugins.pyflakes.enabled\": false,\n        \"pylsp.plugins.flake8.enabled\": true\n      }\n    },\n    \"r-languageserver\": {\n      \"serverSettings\": {\n        \"r.lsp.debug\": false,\n        \"r.lsp.diagnostics\": false\n      }\n    }\n  }\n}\n```\n\nThe `serverSettings` key specifies the configurations sent to the language servers. These can be written using stringified dot accessors like above (in the VSCode style), or as nested JSON objects, e.g.:\n\n```json\n{\n  \"language_servers\": {\n    \"pylsp\": {\n      \"serverSettings\": {\n        \"pylsp\": {\n          \"plugins\": {\n            \"pydocstyle\": {\n              \"enabled\": true\n            },\n            \"pyflakes\": {\n              \"enabled\": false\n            },\n            \"flake8\": {\n              \"enabled\": true\n            }\n          }\n        }\n      }\n    }\n  }\n}\n```\n\n#### Other configuration methods\n\nSome language servers, such as `pylsp`, provide other configuration methods _in addition_ to language-server configuration messages (accessed using the Advanced Settings Editor). For example, `pylsp` allows users to configure the server using a local configuration file. You can change the inspection/diagnostics for server plugins like `pycodestyle` there.\n\nThe exact configuration details will vary between operating systems (please see the [configuration section of pycodestyle documentation](https://pycodestyle.readthedocs.io/en/latest/intro.html#configuration)), but as an example, on Linux you would simply need to create a file called `~/.config/pycodestyle`, which may look like that:\n\n```cfg\n[pycodestyle]\nignore = E402, E703\nmax-line-length = 120\n```\n\nIn the example above:\n\n- ignoring E402 allows imports which are not on the very top of the file,\n- ignoring E703 allows terminating semicolon (useful for matplotlib plots),\n- the maximal allowed line length is increased to 120.\n\nAfter changing the configuration you may need to restart the JupyterLab, and please be advised that the errors in configuration may prevent the servers from functioning properly.\n\nAgain, please do check the pycodestyle documentation for specific error codes, and check the configuration of other feature providers and language servers as needed.\n\n## Acknowledgements\n\nThis would not be possible without the fantastic initial work at\n[wylieconlon/lsp-editor-adapter](https://github.com/wylieconlon/lsp-editor-adapter).\n\n[language-servers]: https://jupyterlab-lsp.readthedocs.io/en/latest/Language%20Servers.html\n[installation-documentation]: https://jupyterlab-lsp.readthedocs.io/en/latest/Installation.html\n[version 2.x docs]: https://jupyterlab-lsp.readthedocs.io/en/2.x/Installation.html\n",
    "bugtrack_url": null,
    "license": "BSD-3-Clause",
    "summary": "Coding assistance for JupyterLab with Language Server Protocol",
    "version": "5.1.0",
    "project_urls": {
        "Bug Tracker": "https://github.com/jupyter-lsp/jupyterlab-lsp/issues",
        "Documentation": "https://jupyterlab-lsp.readthedocs.io/",
        "Source Code": "https://github.com/jupyter-lsp/jupyterlab-lsp"
    },
    "split_keywords": [
        "interactive",
        "language server",
        "lsp",
        "jupyterlab",
        "jupyterlab4"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c7ab706cb5b018c6a8f32cea5c0d7b55d77f42d78410c4dcbb25b11b210cc972",
                "md5": "26f7f75d58673fcddc10db23069eb020",
                "sha256": "290f473b001c7ebe1edfe391a545f50bc4aefe89d4a64db4f17e8de301db3a37"
            },
            "downloads": -1,
            "filename": "jupyterlab_lsp-5.1.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "26f7f75d58673fcddc10db23069eb020",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 1564965,
            "upload_time": "2024-02-26T15:39:40",
            "upload_time_iso_8601": "2024-02-26T15:39:40.748780Z",
            "url": "https://files.pythonhosted.org/packages/c7/ab/706cb5b018c6a8f32cea5c0d7b55d77f42d78410c4dcbb25b11b210cc972/jupyterlab_lsp-5.1.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b849b6bc55457ebac72928c9db6e5c23c6e0a1d3a5640fc4b4abb4275f10ef7c",
                "md5": "9f416d6db3d85b367256b5f42d1b586d",
                "sha256": "aeac84093ada6d20ef57ae0e97811cc5796a0cab7237b32f8eddf993c0bb0356"
            },
            "downloads": -1,
            "filename": "jupyterlab-lsp-5.1.0.tar.gz",
            "has_sig": false,
            "md5_digest": "9f416d6db3d85b367256b5f42d1b586d",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 760295,
            "upload_time": "2024-02-26T15:39:45",
            "upload_time_iso_8601": "2024-02-26T15:39:45.693029Z",
            "url": "https://files.pythonhosted.org/packages/b8/49/b6bc55457ebac72928c9db6e5c23c6e0a1d3a5640fc4b4abb4275f10ef7c/jupyterlab-lsp-5.1.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-02-26 15:39:45",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "jupyter-lsp",
    "github_project": "jupyterlab-lsp",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "jupyterlab-lsp"
}
        
Elapsed time: 0.24726s