Skip to main content

Export Cursor / Claude Code / Codex chats and build a git-tracked, LLM-friendly project timeline.

Project description

chat-timeline

Export chat history from Cursor, Claude Code, and Codex and build a git-tracked, LLM-friendly project timeline.

The result is three artifacts that live inside your repo:

  • timeline/timeline.md — chronological, compact, ready for an LLM to read.
  • timeline/contents/timeline.json — referenced content keyed by entry ID.
  • timeline/sessions/session.md — full chat exports + git index context.

A built-in git pre-commit hook keeps the timeline in sync with your commits automatically.

Works on Windows, macOS, and Linux. Pure stdlib — no runtime dependencies.


Install + configure (one command)

pipx install chat-timeline && timeline init

pipx not available? The equivalent is:

python -m pip install --user chat-timeline && timeline init

timeline init is idempotent and does everything for you:

  1. Resolves the project root (git rev-parse --show-toplevel).
  2. Creates timeline/ with chats/, sessions/, contents/, and the archive folder.
  3. Writes timeline/.gitignore and a managed block in the project's .gitignore.
  4. Installs LLM_INSTRUCTIONS.md for downstream prompts.
  5. Installs the git pre-commit hook (calls timeline -p on each commit).

To reverse: timeline deinit removes the hook and the managed .gitignore block. Your exported data is left untouched.


Daily use

timeline                  # interactive selector → exports + session + timeline
timeline claude           # claude only
timeline cursor 1-5       # cursor chats #1..#5
timeline -t               # rebuild timeline only (incremental)
timeline -t -rt           # rebuild timeline from scratch
timeline -p               # pre-commit standalone (auto-detects modified chats)

Equivalent: python -m chat_timeline ….

Full flag reference: timeline --help.

Interactive selector keys

Key Action
↑ ↓ move pointer
PgUp PgDn page
Home End jump to first/last
Space toggle chat (or entry, when expanded)
expand chat to entries
collapse / jump back to parent
a toggle select-all
t cycle tracking mode (chat) or toggle exclude/force-add (entry). Hold 3s to clear tracking.
p toggle pre-commit auto mode
o toggle timeline archive rotation for this run
h toggle "hot entries only" filter
Tab switch list ↔ numeric input
Enter confirm · Esc cancel

What it reads (per source)

Source Storage location Notes
Cursor %APPDATA%/Cursor/User/workspaceStorage/ (Win), ~/Library/Application Support/Cursor/User/workspaceStorage/ (mac), ~/.config/Cursor/User/workspaceStorage/ (linux) SQLite
Claude Code ~/.claude/projects/<slug>/*.jsonl Cross-runtime: Windows reads WSL data, WSL reads Windows data
Codex ~/.codex/sessions/**/*.jsonl Same cross-runtime discovery

Nothing is transmitted anywhere. Everything runs locally on your machine.


Configuration

Env var Effect
TIMELINE_PROJECT_ROOT Override the auto-detected git toplevel.
TIMELINE_HOME Override the default <project>/timeline location.
TIMELINE_AMEND Set by the pre-commit hook on git commit --amend.

Pre-commit hook details

The hook is a POSIX shell script that:

  1. Detects git commit --amend from the parent process's cmdline.
  2. Calls the installed timeline entry point, with fallbacks to python -m chat_timeline and wsl.exe timeline.
  3. Stages any updated timeline files into the commit.

On Windows it runs under Git Bash (which ships with Git for Windows).


Status

v0.1.0 ships a working CLI based on a vendored monolithic implementation (chat_timeline._legacy). v0.2.0 will split it into clean modules (sources/, tui/, session.py, timeline.py) without breaking the CLI or the on-disk format.


Contributing

See CONTRIBUTING.md. Bug reports welcome — please include the output of timeline --version and your OS + Python version.

License

MIT. See 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

chat_timeline-0.1.1.tar.gz (55.5 kB view details)

Uploaded Source

Built Distribution

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

chat_timeline-0.1.1-py3-none-any.whl (63.2 kB view details)

Uploaded Python 3

File details

Details for the file chat_timeline-0.1.1.tar.gz.

File metadata

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

File hashes

Hashes for chat_timeline-0.1.1.tar.gz
Algorithm Hash digest
SHA256 0ee2142b4661e0a6ae80872535dbf87c9b3e218be9ef8e253615dd57197a7363
MD5 c58974ae96b9a034b6f7e10c1b59aaa5
BLAKE2b-256 c6d8a8388f531fd8e69bcd87fc5840dc57db8b581ac33ac4af1cad5b017384cc

See more details on using hashes here.

Provenance

The following attestation bundles were made for chat_timeline-0.1.1.tar.gz:

Publisher: release.yml on fredfts/chat-timeline

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

File details

Details for the file chat_timeline-0.1.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for chat_timeline-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 213cb7bd17dc617962ddee6a0eed0d88114a454698b1a26ed92014526afc6ca3
MD5 d83908eda1a5dda57e3f1a8aa53dcc36
BLAKE2b-256 f1d4c5a32c6f3612f596db564f5cdca7012dedb03951b72b99caf3befe24da85

See more details on using hashes here.

Provenance

The following attestation bundles were made for chat_timeline-0.1.1-py3-none-any.whl:

Publisher: release.yml on fredfts/chat-timeline

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