Skip to main content

SageMath Language Server Protocol

Project description

sage-lsp

Description

Release Platform License GitHub repo size GitHub last commit Python SageMath

SageMath Language Server Protocol

[!TIP] This project may work well with SageMath 10.8+. Other versions lack stubs for Cython files, so they may have limited functionality.

However, until now (2026-2-13), SageMath 10.8 is not accessible from conda-forge (but it released on github). Meanwhile, maintainer doesn't include .pyi files in the build system, so you can't simply install it from pip either.

You may need to install it from source code. And edit some code.

git clone --branch 10.8 --single-branch https://github.com/sagemath/sage.git
cd sage
mamba env create --file environment-3.12-linux.yml --name sage10.8
mamba activate sage10.8

Edit ./tools/update-meson.py like this

@@ -93,3 +93,3 @@
       python_files = sorted(
-            list(folder.glob("*.py")) + list(folder.glob('*.pxd')) + list(folder.glob('*.pyx'))
+            list(folder.glob("*.py")) + list(folder.glob('*.pxd')) + list(folder.glob('*.pyx')) + list(folder.glob('*.pyi'))
       )  # + list(folder.glob('*.pxd')) + list(folder.glob('*.h')))

Run ./tools/update-meson.py to regenerate meson.build files. Then you can install it.

python ./tools/update-meson.py
pip install .

Using sage --version to check if successfully installed.

[!WARNING] If raising error about ImportError: cysignals.signals does not export expected C function _do_raise_exception, using following command to fix it.

pip uninstall cysignals
conda install cysignals

Features

Supported from plugins(very thanks to those projects, they finished a lot of work):

  • pygls basic LSP server framework
  • pycodestyle linter for style checking
  • autopep8 formatter for code formatting
  • pyflakes linter for error checking
  • jedi definition, type definiton, hover, references provider
  • parso(dependency of jedi) for folding
  • docstring-to-markdown praser for converting docstrings to markdown for hover information

Supported from native code:

  • Only support using from sage.xxx import xxx or import sage.xxx (no alias)
  • Local symbols cache for Sage
  • Custom formatting rules for Sage
  • Custom error checking for Sage
  • Custom definition for Sage symbols
  • Custom hover information for Sage symbols
  • Check references for Sage (only in current file)
  • Jump to definiton in Cython files (.pyx) from Stubs (.pyi) in Sage 10.8+
  • Support type inference for Sage (depend on .pyi in Sage 10.8+)
  • Support type hints hover info for unfollowed variables
  • Quick fix for undefined name in Sage
  • Completion for Sage (depend on .pyi in Sage 10.8+)

Install

From source code:

git clone https://github.com/SeanDictionary/sage-lsp && cd sage-lsp
pip install .

From pip: (not released yet)

pip install sage-lsp

Usage

Directly run the server

sagelsp --help  // print usage information
sagelsp --sage  // print if SageMath is available and its version
sagelsp -l      // set log level (default: INFO)
sagelsp --clear // clear local symbols cache and exit

Support global config file ~/.config/pycodestyle or local config file in project root .pycodestyle, setup.cfg, tox.ini for pycodestyle and autopep8, see more details in pycodestyle docs

Both pycodestyle and autopep8 config write in the same file under [pycodestyle] section, for example:

[pycodestyle]
max-line-length = 100
...

Using with extension SageMath-for-VScode

not released yet

Change Logs

See CHANGELOG.md

Contributing

See CONTRIBUTING.md

License

This project is licensed under the GPL-3.0 License. See the LICENSE file for details.

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

sage_lsp-1.0.1.tar.gz (38.7 kB view details)

Uploaded Source

Built Distribution

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

sage_lsp-1.0.1-py3-none-any.whl (45.6 kB view details)

Uploaded Python 3

File details

Details for the file sage_lsp-1.0.1.tar.gz.

File metadata

  • Download URL: sage_lsp-1.0.1.tar.gz
  • Upload date:
  • Size: 38.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sage_lsp-1.0.1.tar.gz
Algorithm Hash digest
SHA256 bf66bb5115491b749abfab8d8a8066d92c89ccec99e0c0a56b3065ed04933afc
MD5 c2dc79668ce94b309904f3d894b4867a
BLAKE2b-256 9b4ee3e8f1fef648682490b83e44b66bb081de11cc404a5b27a18a1210c3d1a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for sage_lsp-1.0.1.tar.gz:

Publisher: publish.yml on SeanDictionary/sage-lsp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sage_lsp-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: sage_lsp-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 45.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sage_lsp-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 678a80df2a182ee63fdccc70ccce9ae25eabe2d432c4e4a071f06e31c70c884d
MD5 1067935bb56f8b64f888087116209a89
BLAKE2b-256 96d345cf00dea39e6830a9904b467dd3db6afe4ffd868a3a85e4ef20e3aa7e03

See more details on using hashes here.

Provenance

The following attestation bundles were made for sage_lsp-1.0.1-py3-none-any.whl:

Publisher: publish.yml on SeanDictionary/sage-lsp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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