Skip to main content

A clipboard history manager for your terminal. Track, search, and manage everything you copy.

Project description

yankit mascot

yankit

A clipboard history manager for your terminal.
Yank it, track it, find it.

Features

  • Interactive TUI — Browse, search, and copy entries with keyboard navigation
  • Watch — Monitor your clipboard in real-time (foreground or daemon mode)
  • List — View your clipboard history with timestamps and word counts
  • Search — Find anything you've copied with highlighted results
  • Stats — See statistics about your clipboard usage
  • Copy back — Re-copy any past entry back to your clipboard
  • Export — Export your clipboard history as JSON
  • Prune — Auto-cleanup old entries to keep your database lean
  • Daemon mode — Run in background with stop and status commands

Installation

With uvx (recommended, no install needed)

uvx yankit watch

With uv

uv tool install yankit

With pip

pip install yankit

Quick Start

1. Start watching your clipboard

# Foreground mode (Ctrl+C to stop)
yankit watch

# Background daemon mode
yankit watch --daemon

2. Browse with the Interactive TUI

The primary way to use yankit is through its interactive interface. Simply running yankit without any arguments will launch the TUI, where you can navigate your history, preview long texts, and copy entries back to your clipboard.

# Launch the interactive browser
yankit

# Launch the interactive browser with a pre-filled search query
yankit search "password"

# (Optional) Alias for simply running `yankit`
yankit list

Keybindings:

Key Action
/ Navigate between entries
c Copy highlighted entry to clipboard
Enter / Open detail panel (full content, scrollable)
/ Escape Close detail panel / search
s Open search
d Delete highlighted entry
r Refresh entries
q Quit

3. Check watcher status / stop it

yankit status
yankit stop

4. View statistics

yankit stats

5. Export history

yankit export
yankit export --output history.json

6. Cleanup

# Delete entries older than 30 days
yankit prune --older-than 30

# Delete all history
yankit clear

How It Works

yankit polls your system clipboard every 0.5 seconds and stores new entries in a local SQLite database. It deduplicates consecutive copies and enforces a configurable maximum entry limit (default: 10,000) to prevent unbounded growth.

yankit watch ──► polls clipboard ──► new content? ──► store in SQLite
                   every 0.5s              │
                                    same as last? ──► skip

Database Location

All data is stored locally at ~/.yankit/history.db. No data is ever sent anywhere.

Database Size Management

  • Max entries limit: yankit watch --max-entries 5000
  • Age-based pruning: yankit prune --older-than 30 (days)
  • Full reset: yankit clear
  • Monitor size: yankit stats shows current DB size

Platform Support

Platform Status Notes
macOS Uses pbcopy/pbpaste (pre-installed)
Linux Requires xclip or xsel

Linux Prerequisites

# Debian/Ubuntu
sudo apt-get install xclip

# Arch
sudo pacman -S xclip

# Fedora
sudo dnf install xclip

Development

git clone https://github.com/oktaysabak/yankit.git
cd yankit

uv sync
uv run yankit --help

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

yankit-0.3.1.tar.gz (363.6 kB view details)

Uploaded Source

Built Distribution

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

yankit-0.3.1-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

Details for the file yankit-0.3.1.tar.gz.

File metadata

  • Download URL: yankit-0.3.1.tar.gz
  • Upload date:
  • Size: 363.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.18 {"installer":{"name":"uv","version":"0.9.18","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for yankit-0.3.1.tar.gz
Algorithm Hash digest
SHA256 91a0cdc31d53bdb65a2be5952a551979430dbcf7b379c930b8d7893b9ab07849
MD5 cdd42fe5a27dac75bfd43b25cd10b6b5
BLAKE2b-256 dd729d6e6ef8b372f65890b150c286e7eca3b3131d13d9f500ed77aaadd09978

See more details on using hashes here.

File details

Details for the file yankit-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: yankit-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 18.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.18 {"installer":{"name":"uv","version":"0.9.18","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for yankit-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 af0d9ccf59f817b39965cc9c834ba1e1d8ea5f1953bd5d91417fc095daa31574
MD5 2feaa596c104ad87b675cd523da247d5
BLAKE2b-256 390a7ec5c5688038ec79c1fde676249487b42f28151b5090ac3c825fd613dffb

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