Skip to main content

A terminal-first Competitive Programming Knowledge Base

Project description

Competitive Programming Knowledge Base (CPKB)

CPKB TUI Gallery

CPKB is a local, terminal-first knowledge base designed to store, search, and track usages of competitive programming snippets, algorithms, and tricks. It uses SQLite for storage, keeping your snippets incredibly fast and perfectly organised.

Version 2.0 Features

  • Store snippets: Add code snippets with metadata like title, use case, and tags.
  • Search snippets: Full-text search across titles, descriptions, tags, and code.
  • Track usage: Record every time you use a snippet in a problem, linking to the file and optionally taking notes.
  • Textual TUI: A beautiful terminal UI for browsing and copying your snippets.
  • FZF Integration: Fuzzy find snippets directly in the terminal.
  • Snippet Insertion: Instantly copy code to the clipboard or append to files.
  • Spaced Repetition (SM-2): Revise your knowledge base using the revise command with a true SM-2 spaced-repetition algorithm that tracks ease, interval, and repetitions per snippet.
  • Optional Password-based Encryption: Encrypt your database at rest with a password (PBKDF2-HMAC-SHA256 key derivation). No keys stored on disk. Requires the cpkb[encrypt] extra and encryption.enabled in config.
  • XDG Base Directory compliant: Stores your data safely in ~/.local/share/cpkb.

Installation

The recommended install method is pipx:

pipx install cpkb
cpkb setup

You can also install it with pip:

python -m pip install cpkb
cpkb setup

The pip and pipx packages install the Python dependencies declared by CPKB, including Textual for cpkb tui.

Homebrew

macOS and Linux users can install CPKB from the Homebrew tap:

brew tap Aaravshah2907/cpkb
brew trust --formula Aaravshah2907/cpkb/cpkb
brew install cpkb
cpkb setup

The Homebrew package runs CPKB with your global python3 instead of a private Homebrew virtualenv, so Python packages you install globally are visible to cpkb. If cpkb tui reports that Textual is missing, install it into that same Python with the command printed by CPKB.

Optional Encryption

Encryption support is opt-in because it depends on cryptography, which can make source-based package manager installs much heavier.

For encryption support, install with the encrypt extra:

pipx install "cpkb[encrypt]"
cpkb setup --enable-encryption

Then enable encryption in your CPKB config:

cpkb config

Open the printed config.json path and set:

{
  "encryption": {
    "enabled": true
  }
}

If encryption is disabled or the extra is not installed, encrypted commands print the install/config steps instead of failing with a Python traceback.

From Source

git clone https://github.com/Aaravshah2907/cpkb.git
cd cpkb
python -m pip install -e .

Local Development & Testing

If you wish to contribute to the codebase or run the unit tests locally to verify the CLI and TUI functionality, set up a virtual environment and run pytest:

# 1. Create and activate a virtual environment
python3 -m venv venv
source venv/bin/activate  # On Windows use: venv\Scripts\activate

# 2. Install CPKB and test dependencies
python -m pip install -e ".[dev]"

# 3. Run the test suite
pytest

Platform‑specific dependencies

Platform Clipboard utility Fuzzy finder
macOS pbcopy (built‑in) brew install fzf
Linux xclip or xsel sudo apt-get install fzf
Windows clip (built‑in) scoop install fzf or choco install fzf

Optional Integrations

CPKB includes an optional SketchyBar integration for macOS. It adds a menu bar item that opens a snippet search dialog and copies the selected snippet.

See integrations/sketchybar for the plugin script and sketchybarrc snippet.

Usage

Here are the commands available in Version 2.0:

Core V1 Commands

  • cpkb add: Add a new snippet interactively.
  • cpkb list: List all snippets.
  • cpkb show <id>: Show details, code, and usages of a specific snippet.
  • cpkb search <query>: Search for snippets matching multiple words.
  • cpkb use <id> <file>: Record the usage of a snippet in a specific file.
  • cpkb usages <id>: List all recorded usages for a snippet.
  • cpkb stats: Show basic database statistics.
  • cpkb random: Show a random snippet for review or practice.
  • cpkb edit <id>: Edit a snippet's metadata and code in your default $EDITOR.
  • cpkb edit-usage <id>: Edit a past usage record.
  • cpkb delete <id>: Delete a snippet permanently.
  • cpkb recent: Show the 10 most recently added snippets.
  • cpkb export: Export your entire knowledge base to a single Markdown file.
  • cpkb export-db [--encrypted]: Export your SQLite database, optionally encrypted with a password.
  • cpkb import <file-or-url>: Append snippets from a CPKB db, json, md, or html export.
  • cpkb import --defaults: Import bundled C++ STL competitive-programming cheatsheets with special cp_ IDs.
  • cpkb import --list-defaults: Preview the bundled cheatsheets before importing.
  • cpkb backup: Manually trigger a backup of the SQLite database.
  • cpkb setup: Set up app directories, config, optional encryption settings, and bundled defaults after pip or Homebrew install.

New V2 Commands

  • cpkb tui: Launch the interactive Textual TUI (press c to copy a snippet).
  • cpkb fzf: Interactively fuzzy search snippets using fzf.
  • cpkb copy <id> [-f <file>]: Instantly copy the snippet's code to your system clipboard (uses pbcopy on macOS, xclip/xsel on Linux, clip on Windows) or append to a file.
  • cpkb revise: Start a spaced-repetition session — the SM-2 algorithm selects the most overdue snippet, shows the title, then reveals the code. Rate your recall (0–5) to schedule the next review.
  • cpkb srs-stats: Show spaced-repetition statistics (total reviewed, due now, avg ease factor).
  • cpkb encrypt-db: Encrypt the database with a password (PBKDF2 + Fernet). Requires optional encryption support.
  • cpkb decrypt-db: Decrypt the database by entering your password. Requires optional encryption support.

Directory Structure

Data is kept completely separate from the code repo. The application automatically creates the required directories on first run:

~/.local/share/cpkb/
├── snippets.db
├── attachments/
├── backups/
├── exports/
├── imports/
└── logs/

Requirements

  • Python 3.11+
  • textual
  • cryptography via cpkb[encrypt] (optional, for encrypt-db / decrypt-db)
  • fzf (Optional, for cpkb fzf)
  • A platform clipboard helper: pbcopy on macOS, xclip or xsel on Linux, clip on Windows

License

MIT License.

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

cpkb-2.0.4.tar.gz (40.6 kB view details)

Uploaded Source

Built Distribution

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

cpkb-2.0.4-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

File details

Details for the file cpkb-2.0.4.tar.gz.

File metadata

  • Download URL: cpkb-2.0.4.tar.gz
  • Upload date:
  • Size: 40.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cpkb-2.0.4.tar.gz
Algorithm Hash digest
SHA256 abf0c06193e67c3fa40d9103c18aa892c2cb3ad5fca78510854ff9647b01282d
MD5 dbeadfe2027778a3e59bb0283f3f8fa8
BLAKE2b-256 0d84f43f2a798a74e800a6f66da7bd8b36a2acafbc45720080536c2c5de28682

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpkb-2.0.4.tar.gz:

Publisher: publish.yml on Aaravshah2907/cpkb

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

File details

Details for the file cpkb-2.0.4-py3-none-any.whl.

File metadata

  • Download URL: cpkb-2.0.4-py3-none-any.whl
  • Upload date:
  • Size: 32.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cpkb-2.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e5d96e1a23487fda4f9d32722c5da36ee05bf5e451feac9304361796f7deb599
MD5 78e56ac014dd5969151f21a4b796cd5b
BLAKE2b-256 81f88b980d04205c9d5fda2e09d6ec4cfc6a83f38ecac8dac190fd04895f8d90

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpkb-2.0.4-py3-none-any.whl:

Publisher: publish.yml on Aaravshah2907/cpkb

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