Skip to main content

A JupyterLab extension for managing multiple checkpoints

Project description

JupyterCheckpoints

A JupyterLab extension for managing multiple checkpoints, allowing users to save and restore multiple historical versions of files.

Features

  • Maintains up to 5 checkpoints for each file (configurable)
  • Restore to any checkpoint directly from the JupyterLab interface
  • Supports notebooks (.ipynb) and regular text files
  • Provides a user-friendly interface showing checkpoint creation time and relative time (e.g., "5 minutes ago")
  • Automatically manages checkpoints, removing older versions

Installation

Using pip

pip install jupyter-checkpoints

From Source

  1. Clone the repository
git clone https://github.com/yourusername/jupyter-checkpoints.git
cd jupyter-checkpoints
  1. Install the Python package
pip install -e .
  1. Install the frontend extension
jupyter labextension develop --overwrite .

Usage

After installation, JupyterCheckpoints will be automatically activated. A "Restore Checkpoint" button will be added to the toolbar of each open notebook and file editor.

Restoring to a Checkpoint

  1. Open any file or notebook
  2. Click the "Restore Checkpoint" button (undo icon) in the toolbar
  3. Select the checkpoint to restore from the dropdown menu
  4. Confirm the restore operation

Configuration

You can set the maximum number of checkpoints to keep for each file in your Jupyter configuration file:

c.AsyncMultiCheckpoints.max_checkpoints = 10  # Default is 5

Development

Prerequisites

  • JupyterLab >= 4.0.0
  • Python >= 3.12
  • Node.js

Setting Up Development Environment

  1. Clone the repository
git clone https://github.com/yourusername/jupyter-checkpoints.git
cd jupyter-checkpoints
  1. Create and activate a virtual environment
python -m venv .venv
source .venv/bin/activate  # Linux/Mac
# or
.venv\Scripts\activate  # Windows
  1. Install development dependencies
pip install -e .
  1. Install JavaScript dependencies and build
cd js
npm install
npm run build
  1. Install the extension in development mode
jupyter labextension develop --overwrite .

Development Workflow

  • After modifying Python code, restart the Jupyter server
  • After modifying JavaScript code:
    cd js
    npm run build
    
    Then refresh the JupyterLab page

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

jupyter_checkpoints-0.2.0.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

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

jupyter_checkpoints-0.2.0-py3-none-any.whl (40.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: jupyter_checkpoints-0.2.0.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.13

File hashes

Hashes for jupyter_checkpoints-0.2.0.tar.gz
Algorithm Hash digest
SHA256 9fc1ca2a0ba296a113a50478eff3cf0b484e455213947345a3040fee88e1e49a
MD5 577e00e64496d22e0b60a4e78003aefc
BLAKE2b-256 0e2b201244fc75e4ddc4ada7853af52734a0aa5ac10885a6cb1eadcd5572072e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for jupyter_checkpoints-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8fbb0adcd25bb3f440d45e937b4501d0fea1e66895011a05d1d50143dac9ac1b
MD5 9d8137f3b33452a728b8744ba06afbd0
BLAKE2b-256 8f84d506669323c1dac462967fc646fa1e72fbf583439dead8be8d3d99479ea0

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