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.0.tar.gz (54.4 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.0-py3-none-any.whl (62.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: chat_timeline-0.1.0.tar.gz
  • Upload date:
  • Size: 54.4 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.0.tar.gz
Algorithm Hash digest
SHA256 4eecd29c8f6761b4fb3d4fb93761e48fcaa23fc4d4b1bc3ff1b89c8ebbb0d50d
MD5 7e0a77029893cd5d7dd94ac4e13aba38
BLAKE2b-256 d373c1f10d4de93e4a364eff252750c29df7ed56865aebf1fc86b328f1a6d1e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for chat_timeline-0.1.0.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.0-py3-none-any.whl.

File metadata

  • Download URL: chat_timeline-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 62.5 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d7be42b8fd481f27c37b37d3bb31f46f167f6ebb4e9c000f8de91b6563e927cb
MD5 e7b1034fd0fd8a1db6e4a5ba3470a4e9
BLAKE2b-256 8c2d896966205473f9d6ae19d7313c072e5ff13318f06f39461470817df0de7c

See more details on using hashes here.

Provenance

The following attestation bundles were made for chat_timeline-0.1.0-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