Skip to main content

Jupyterlab fix disguised as extension to fix action 'jump to definition' from notebook to the source file / definition within the context of the notebook's kernel. Without the fix package would need to be installed in the same environment as jupyterlab to allo jump to definition

Project description

jupyterlab_jump_to_definition_fix

GitHub Actions npm version PyPI version Total PyPI downloads JupyterLab 4 Brought To You By KOLOMOLO

JupyterLab extension that fixes "jump to definition" functionality for notebooks using Jedi static analysis in the kernel environment. This allows jumping to source code definitions for packages installed in the notebook's kernel, even if those packages are not installed in JupyterLab's own environment.

[!WARNING] This extension is a temporary fix until the jupyterlab-lsp project implements native support for kernel-aware jump-to-definition. Track the upstream issue: jupyter-lsp/jupyterlab-lsp#1096. Once merged and released, this extension will be deprecated.

The Problem

JupyterLab's built-in LSP "jump to definition" only works for packages installed in the same Python environment as JupyterLab itself. Notebooks often run with kernels in different environments (conda envs, virtual envs, containers) where packages are actually installed, making the stock LSP functionality useless for kernel-installed packages.

The Fix

This extension replaces the stock LSP "jump to definition" command for Python notebooks with a Jedi-based implementation that runs in the kernel's Python environment.

How it works:

  • Executes Jedi static analysis directly in the notebook's kernel
  • Uses kernel's sys.path for module resolution, finding packages installed in kernel environment
  • Analyzes all notebook cells as concatenated source to understand full context
  • Converts absolute filesystem paths to JupyterLab-relative paths for file opening
  • Seamlessly overrides stock LSP command - same keyboard shortcut, same menu entry

Implementation details:

  • Frontend: Collects all code cell sources, calculates cursor position across cells, sends to kernel
  • Backend: Provides Jedi introspection code template executed in kernel
  • Jedi: Runs Script.goto() with follow_imports=True using kernel's module search paths
  • Path resolution: Calculates server root from kernel CWD and notebook path

Fix Implementation Details

The extension consists of frontend TypeScript code and backend Python code working together to provide kernel-aware jump-to-definition.

Frontend Implementation (src/index.ts):

  • Command Registration: app.commands.addCommand(commandId) creates notebook:jump-to-definition-kernel command that collects notebook context and executes Jedi analysis
  • Cell Source Collection: Command execute function iterates through notebook.content.widgets, concatenates code cell sources, and calculates absolute cursor position accounting for multi-cell structure. Jedi requires 1-based line numbers
  • Kernel Execution: kernel.requestExecute() sends Jedi introspection code to kernel, future.onIOPub handler captures stdout (JSON result) while filtering stderr (debug logs)
  • Path Conversion: Secondary kernel execution gets CWD via os.getcwd(), calculates JupyterLab server root from notebook path, converts absolute filesystem paths to server-relative paths for docManager.openOrReveal()
  • Stock LSP Override: overrideLSPCommand() function dynamically intercepts lsp:jump-to-definition command when it loads, preserves original icon and label, routes Python notebooks to Jedi implementation while delegating others to stock LSP

Backend Implementation (jupyterlab_jump_to_definition_fix/routes.py):

  • Introspection Code Template: IntrospectionCodeHandler.get() method provides Python code template executed in kernel environment that imports Jedi, creates jedi.Project with kernel's sys.path, runs Script.goto() with follow_imports=True, and returns JSON with file path and line number
  • API Handler: Route registered at /jupyterlab_jump_to_definition_fix/introspection-code endpoint serves template to frontend

Key Implementation Components:

  • jedi.Project(path=notebook_path, sys_path=sys.path): Creates Jedi project using kernel's module search paths for accurate resolution
  • jedi.Script(...).goto(follow_imports=True): Performs static analysis to find symbol definitions, following import chains
  • kernel.requestExecute(): Executes Jedi code in kernel's Python environment where target packages are installed
  • IOPub message filtering: Separates stdout (JSON result) from stderr (debug output) for clean parsing
  • Path calculation: kernelCwd.endsWith(notebookDir) logic strips server root from absolute paths

Features

  • Replaces stock LSP: Overrides lsp:jump-to-definition command for Python notebooks
  • Kernel-aware: Uses kernel's Python environment and sys.path for module resolution
  • Static analysis: Jedi finds definitions without requiring code execution
  • Same UX: Identical keyboard shortcut (Ctrl+B / Cmd+B) and menu entries as stock LSP
  • Automatic fallback: Delegates to stock LSP for non-Python notebooks

Usage

  1. Open a Jupyter notebook with a Python kernel
  2. Place your cursor on or select a symbol (function name, class name, module attribute, etc.)
  3. Press Ctrl+B (or Cmd+B on Mac), or run "Jump to Definition (Kernel Context)" from the command palette
  4. The source file will open at the definition location

Examples of symbols you can jump to:

  • Module: numpy or pandas
  • Function: np.array, pd.DataFrame
  • Method: MyClass.my_method
  • Nested attributes: sklearn.ensemble.RandomForestClassifier

This extension is composed of a Python package named jupyterlab_jump_to_definition_fix for the server extension and a NPM package named jupyterlab_jump_to_definition_fix for the frontend extension.

Requirements

  • JupyterLab >= 4.0.0
  • Python kernel (IPython/ipykernel)

Install

To install the extension, execute:

pip install jupyterlab_jump_to_definition_fix

Uninstall

To remove the extension, execute:

pip uninstall jupyterlab_jump_to_definition_fix

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

jupyterlab_jump_to_definition_fix-1.0.63.tar.gz (207.7 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file jupyterlab_jump_to_definition_fix-1.0.63.tar.gz.

File metadata

File hashes

Hashes for jupyterlab_jump_to_definition_fix-1.0.63.tar.gz
Algorithm Hash digest
SHA256 a0aecc4db6c45df1e29392d7f1a9bcb07bdca5c2d6bf340352543804faf82942
MD5 988b845d592935586d51d8090ffdbfc0
BLAKE2b-256 9f6e964a285a25311933aa1f6576d31a077825f7966b8614607f0314fdec31aa

See more details on using hashes here.

File details

Details for the file jupyterlab_jump_to_definition_fix-1.0.63-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyterlab_jump_to_definition_fix-1.0.63-py3-none-any.whl
Algorithm Hash digest
SHA256 2350d8f9349209d0ca458018bf3a8a654e62b0cc1b1225ee61af9f1b37aa9a41
MD5 153b55576ef0527e1fd5125bd92f0958
BLAKE2b-256 9e9dee77de6387076a8b751054d382a4bd6aee9894d571e96aa136476c687831

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