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.

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.61.tar.gz (207.4 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.61.tar.gz.

File metadata

File hashes

Hashes for jupyterlab_jump_to_definition_fix-1.0.61.tar.gz
Algorithm Hash digest
SHA256 99fe77b5d87bce2920873b1649c538f8bead4a3ed7fba09f38969dbf6851fe9a
MD5 29b8c865e53791dc2fc4e95a0eec5187
BLAKE2b-256 cf4737e50823158535be036c5c1fec797e12c691ad32d1e5a610796431317e03

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for jupyterlab_jump_to_definition_fix-1.0.61-py3-none-any.whl
Algorithm Hash digest
SHA256 21cd9b33e3c2acbdcaf8b322ebd8f94b47e821acbddc307da35ad8999457b0da
MD5 39cab1fe1ca29390032bd02d1f6b9941
BLAKE2b-256 93748cdab2c7e32b4a41ed462558d7ba1ea8c81f6a14de078f4cc01e0c0fc746

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