Skip to main content

Workspace/symbol search and inlay hints for python-lsp-server via Jedi

Project description

pylsp-workspace-symbols

CI PyPI PyPI - Python Version Downloads License: MIT

A python-lsp-server plugin that adds workspace/symbol search and inlay hints via Jedi.

Why? pylsp does not implement workspace/symbol natively, and its inlay hints support is limited. This plugin fills both gaps, enabling "Go to Symbol in Workspace" and rich type inference hints in any LSP client — including CudaText, Neovim, Emacs, and others.


✨ Features

  • 🔍 Workspace-wide symbol search — find functions, classes, and modules across all files in the project
  • 💡 Inlay hints — inline type annotations inferred by Jedi for assignments, return types, raised exceptions, and parameter names at call sites
  • Fast — results in ~130ms after the first call (Jedi cache warm)
  • 🔤 Case-insensitive substring matcharea finds calculate_area, Cal finds Calculator
  • 📁 Smart folder exclusion — automatically skips .git, __pycache__, node_modules, .venv, dist, build, and more
  • ⚙️ Configurable — tune all options via pylsp settings
  • 🐍 Python 3.8+ — compatible with all modern Python versions

📦 Installation

pip install pylsp-workspace-symbols

The plugin is discovered automatically by pylsp via its entry point — no manual configuration needed.

⚙️ Configuration

Add to your LSP client's pylsp settings (e.g. in settings.json or equivalent):

{
  "pylsp": {
    "plugins": {
      "jedi_workspace_symbols": {
        "enabled": true,
        "max_symbols": 500,
        "ignore_folders": []
      },
      "inlay_hints": {
        "enabled": true,
        "show_assign_types": true,
        "show_return_types": true,
        "show_raises": true,
        "show_parameter_hints": true,
        "max_hints_per_file": 200
      }
    }
  }
}

Workspace symbol options

Option Type Default Description
enabled bool true Enable/disable workspace symbol search
max_symbols int 500 Maximum symbols returned. 0 means no limit
ignore_folders list [] Extra folder names to skip (merged with built-in list)

Inlay hint options

Option Type Default Description
enabled bool true Enable/disable all inlay hints
show_assign_types bool true Show inferred types for unannotated assignments (x = 42: int)
show_return_types bool true Show inferred return types for unannotated functions (def f():-> str)
show_raises bool true Show raised exception types (raise ValueError(...)Raises: ValueError)
show_parameter_hints bool true Show parameter names at call sites (f(1, 2)a=1, b=2)
max_hints_per_file int 200 Maximum hints per file. 0 means no limit

Built-in ignored folders

.git, .hg, .svn, __pycache__, .mypy_cache, .ruff_cache, .pytest_cache, node_modules, .venv, venv, .env, env, dist, build, .eggs, egg-info

🚀 Usage

Workspace symbol search

Once installed, your LSP client will receive workspaceSymbolProvider: true in the server capabilities. Use your client's "Go to Symbol in Workspace" command (typically Ctrl+T or # in the symbol picker).

Inlay hints

Your LSP client will receive inlayHintProvider: true in the server capabilities. Hints are rendered inline by the client automatically. The following hint types are supported:

  • Assignment hints — unannotated variable assignments, including self.attr in __init__
  • Return hints — unannotated def and async def functions, inferred from the first return statement
  • Raise hintsraise ExceptionType(...) statements
  • Parameter hints — positional argument names at call sites (keyword args are skipped as self-documenting)

Inlay hints respect type annotations already present in the source — annotated functions and variables are never hinted twice.

🔍 How it works

Workspace symbols

pylsp does not define a pylsp_workspace_symbols hookspec, so this plugin uses two hooks:

  1. pylsp_experimental_capabilities — advertises workspaceSymbolProvider: true to the client during the initialize handshake.
  2. pylsp_dispatchers — registers a custom JSON-RPC handler for workspace/symbol that calls Jedi's project.complete_search() and filters results client-side by case-insensitive substring match.

Note: workspace/symbol returns module-level definitions (functions, classes, modules). Local variables inside functions are not indexed — this is standard LSP behaviour, consistent with pyright and other Python language servers.

Inlay hints

The plugin handles the textDocument/inlayHint request using a hybrid approach:

  1. Regex scan — fast pass over the source to locate def, assignment, raise, and call patterns.
  2. _literal_type fast-path — resolves common literals ("str", 42, True, [...], etc.) without calling Jedi.
  3. Jedi inference — for non-literal expressions, script.infer() and script.get_signatures() are used to resolve types.
  4. Signature fallback — for self.attr = param assignments, the enclosing def signature is inspected for type annotations or default values.

🧪 Tests

pip install -e ".[dev]"
pytest

🤝 Contributing

Issues and pull requests are welcome! Please open an issue before submitting a large change.

📚 References

👤 Author

Bruno Eduardo — github.com/Hanatarou

📄 License

MIT

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

pylsp_workspace_symbols-0.2.0.tar.gz (19.6 kB view details)

Uploaded Source

Built Distribution

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

pylsp_workspace_symbols-0.2.0-py3-none-any.whl (15.8 kB view details)

Uploaded Python 3

File details

Details for the file pylsp_workspace_symbols-0.2.0.tar.gz.

File metadata

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

File hashes

Hashes for pylsp_workspace_symbols-0.2.0.tar.gz
Algorithm Hash digest
SHA256 f73fd28e8831f6444afbd29f5315da9ab51909705f1a497347dd522d913b603e
MD5 c7202ed5fefe3b196b2d15151b40b4ca
BLAKE2b-256 1ed8d16c928e0b625eabfc18fe7f9910672773121bd3ca7f5717c6626b3ce651

See more details on using hashes here.

Provenance

The following attestation bundles were made for pylsp_workspace_symbols-0.2.0.tar.gz:

Publisher: publish.yml on Hanatarou/pylsp-workspace-symbols

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

File details

Details for the file pylsp_workspace_symbols-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pylsp_workspace_symbols-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 16986aea6126d08ed959bf79a353c2ced2805785e83adcfb7a1d456380e4eb25
MD5 9cf800f496f73ea772b7f577f6652861
BLAKE2b-256 46f10f433fecec18311eed70825d84510a01ed5fc3f6a8b8789d1ed8af0c8d5d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pylsp_workspace_symbols-0.2.0-py3-none-any.whl:

Publisher: publish.yml on Hanatarou/pylsp-workspace-symbols

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