{"id":49009698,"url":"https://github.com/getagentseal/codeburn","last_synced_at":"2026-04-25T01:04:33.633Z","repository":{"id":351195023,"uuid":"1209889782","full_name":"getagentseal/codeburn","owner":"getagentseal","description":"See where your AI coding tokens go. Interactive TUI dashboard for Claude Code, Codex, and Cursor cost observability.","archived":false,"fork":false,"pushed_at":"2026-04-19T23:58:04.000Z","size":3914,"stargazers_count":2887,"open_issues_count":22,"forks_count":214,"subscribers_count":11,"default_branch":"main","last_synced_at":"2026-04-20T04:02:57.467Z","etag":null,"topics":["ai-coding","claude-code","cli","codex","cost-tracking","cursor-ide","developer-tools","observability","terminal-ui","token-usage"],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/getagentseal.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null},"funding":{"github":"agentseal"}},"created_at":"2026-04-13T22:11:53.000Z","updated_at":"2026-04-20T04:01:23.000Z","dependencies_parsed_at":"2026-04-20T04:03:16.367Z","dependency_job_id":null,"html_url":"https://github.com/getagentseal/codeburn","commit_stats":null,"previous_names":["agentseal/codeburn","getagentseal/codeburn"],"tags_count":38,"template":false,"template_full_name":null,"purl":"pkg:github/getagentseal/codeburn","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/getagentseal%2Fcodeburn","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/getagentseal%2Fcodeburn/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/getagentseal%2Fcodeburn/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/getagentseal%2Fcodeburn/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/getagentseal","download_url":"https://codeload.github.com/getagentseal/codeburn/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/getagentseal%2Fcodeburn/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32139429,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-22T13:27:12.868Z","status":"ssl_error","status_checked_at":"2026-04-22T13:26:44.791Z","response_time":58,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ai-coding","claude-code","cli","codex","cost-tracking","cursor-ide","developer-tools","observability","terminal-ui","token-usage"],"created_at":"2026-04-18T22:15:10.463Z","updated_at":"2026-04-25T01:04:33.624Z","avatar_url":"https://github.com/getagentseal.png","language":"TypeScript","readme":"\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://cdn.jsdelivr.net/gh/getagentseal/codeburn@main/assets/logo.png\" alt=\"CodeBurn\" width=\"120\" /\u003e\n\u003c/p\u003e\n\n\u003ch1 align=\"center\"\u003eCodeBurn\u003c/h1\u003e\n\n\u003cp align=\"center\"\u003eSee where your AI coding tokens go.\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://www.npmjs.com/package/codeburn\"\u003e\u003cimg src=\"https://img.shields.io/npm/v/codeburn.svg\" alt=\"npm version\" /\u003e\u003c/a\u003e\n  \u003ca href=\"https://www.npmjs.com/package/codeburn\"\u003e\u003cimg src=\"https://img.shields.io/npm/dt/codeburn.svg\" alt=\"total downloads\" /\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/getagentseal/codeburn/blob/main/LICENSE\"\u003e\u003cimg src=\"https://img.shields.io/npm/l/codeburn.svg\" alt=\"license\" /\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/getagentseal/codeburn\"\u003e\u003cimg src=\"https://img.shields.io/badge/node-%3E%3D20-brightgreen.svg\" alt=\"node version\" /\u003e\u003c/a\u003e\n  \u003ca href=\"https://discord.gg/pJ2DMWvtAx\"\u003e\u003cimg src=\"https://img.shields.io/badge/discord-join-5865F2?logo=discord\u0026logoColor=white\" alt=\"Discord\" /\u003e\u003c/a\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://raw.githubusercontent.com/getagentseal/codeburn/main/assets/dashboard.jpg\" alt=\"CodeBurn TUI dashboard\" width=\"620\" /\u003e\n\u003c/p\u003e\n\nBy task type, tool, model, MCP server, and project. Supports **Claude Code**, **Codex** (OpenAI), **Cursor**, **cursor-agent**, **OpenCode**, **Pi**, **[OMP](https://github.com/can1357/oh-my-pi)** (Oh My Pi), and **GitHub Copilot** with a provider plugin system. Tracks one-shot success rate per activity type so you can see where the AI nails it first try vs. burns tokens on edit/test/fix retries. Interactive TUI dashboard with gradient charts, responsive panels, and keyboard navigation. Native macOS menubar app in `mac/`. CSV/JSON export.\n\nWorks by reading session data directly from disk. No wrapper, no proxy, no API keys. Pricing from LiteLLM (auto-cached, all models supported).\n\n## Install\n\n```bash\nnpm install -g codeburn\n```\n\nOr run without installing:\n\n```bash\nnpx codeburn\n```\n\n### Requirements\n\n- Node.js 20+\n- Claude Code (`~/.claude/projects/`), Codex (`~/.codex/sessions/`), Cursor, OpenCode, Pi (`~/.pi/agent/sessions/`), OMP (`~/.omp/agent/sessions/`), and/or GitHub Copilot (`~/.copilot/session-state/`)\n- For Cursor/OpenCode support: `better-sqlite3` is installed automatically as an optional dependency\n\n## Usage\n\n```bash\ncodeburn                        # interactive dashboard (default: 7 days)\ncodeburn today                  # today's usage\ncodeburn month                  # this month's usage\ncodeburn report -p 30days       # rolling 30-day window\ncodeburn report -p all          # every recorded session\ncodeburn report --from 2026-04-01 --to 2026-04-10  # exact date range\ncodeburn report --format json   # full dashboard data as JSON\ncodeburn report --refresh 60    # auto-refresh every 60s (default: 30s)\ncodeburn status                 # compact one-liner (today + month)\ncodeburn status --format json\ncodeburn export                 # CSV with today, 7 days, 30 days\ncodeburn export -f json         # JSON export\ncodeburn optimize               # find waste, get copy-paste fixes\ncodeburn optimize -p week       # scope the scan to last 7 days\n```\n\nArrow keys switch between Today / 7 Days / 30 Days / Month / All Time. Press `q` to quit, `1` `2` `3` `4` `5` as shortcuts, `c` to open model comparison. The dashboard auto-refreshes every 30 seconds by default (`--refresh 0` to disable). The dashboard also shows average cost per session and the five most expensive sessions across all projects.\n\n### JSON output\n\n`report`, `today`, and `month` support `--format json` to output the full dashboard data as structured JSON to stdout:\n\n```bash\ncodeburn report --format json             # 7-day JSON report\ncodeburn today --format json              # today's data as JSON\ncodeburn month --format json              # this month as JSON\ncodeburn report -p 30days --format json   # 30-day window\n```\n\nThe JSON includes all dashboard panels: overview (cost, calls, sessions, cache hit %), daily breakdown, projects (with `avgCostPerSession`), models with token counts, activities with one-shot rates, core tools, MCP servers, and shell commands. Pipe to `jq` for filtering:\n\n```bash\ncodeburn report --format json | jq '.projects'\ncodeburn today --format json | jq '.overview.cost'\n```\n\nFor the lighter `status --format json` (today + month totals only) or file-based exports (`export -f json`), see above.\n\n## Providers\n\nCodeBurn auto-detects which AI coding tools you use. If multiple providers have session data on disk, press `p` in the dashboard to toggle between them.\n\n```bash\ncodeburn report                      # all providers combined (default)\ncodeburn report --provider claude    # Claude Code only\ncodeburn report --provider codex     # Codex only\ncodeburn report --provider cursor    # Cursor only\ncodeburn report --provider cursor-agent  # cursor-agent CLI only\ncodeburn report --provider opencode  # OpenCode only\ncodeburn report --provider pi        # Pi only\ncodeburn report --provider copilot   # GitHub Copilot only\ncodeburn report --provider omp        # OMP only\ncodeburn today --provider codex      # Codex today\ncodeburn export --provider claude    # export Claude data only\n```\n\nThe `--provider` flag works on all commands: `report`, `today`, `month`, `status`, `export`.\n\n### Project filtering\n\nFilter results by project name (case-insensitive substring match). Both flags are repeatable:\n\n```bash\ncodeburn report --project myapp                  # show only projects matching \"myapp\"\ncodeburn report --exclude myapp                  # show everything except \"myapp\"\ncodeburn report --exclude myapp --exclude tests  # exclude multiple projects\ncodeburn month --project api --project web       # include multiple projects\ncodeburn export --project inventory              # export only \"inventory\" project data\n```\n\nThe `--project` and `--exclude` flags work on all commands and can be combined with `--provider`.\n\n### Date range filtering\n\nBeyond the preset periods, specify an exact window with `--from` and `--to` (`YYYY-MM-DD`, local time):\n\n```bash\ncodeburn report --from 2026-04-01 --to 2026-04-10   # explicit window\ncodeburn report --from 2026-04-01                    # this date through today\ncodeburn report --to 2026-04-10                      # earliest data through this date\ncodeburn report --from 2026-04-01 --to 2026-04-10 --format json\n```\n\nEither flag alone is valid. Inverted or malformed dates exit with a clear error. In the TUI, the custom range sets the initial load only -- pressing `1`-`5` switches back to predefined periods.\n\n### Supported providers\n\n| Provider | Data location | Status |\n|----------|--------------|--------|\n| Claude Code | `~/.claude/projects/` | Supported |\n| Claude Desktop | `~/Library/Application Support/Claude/local-agent-mode-sessions/` | Supported |\n| Codex (OpenAI) | `~/.codex/sessions/` | Supported |\n| Cursor | `~/Library/Application Support/Cursor/User/globalStorage/state.vscdb` | Supported |\n| OpenCode | `~/.local/share/opencode/` (SQLite) | Supported |\n| Pi | `~/.pi/agent/sessions/` | Supported |\n| OMP | `~/.omp/agent/sessions/` | Supported |\n| GitHub Copilot | `~/.copilot/session-state/` | Supported (output tokens only) |\n| Amp | -- | Planned (provider plugin system) |\n\nCodex tool names are normalized to match Claude's conventions (`exec_command` shows as `Bash`, `read_file` as `Read`, etc.) so the activity classifier and tool breakdown work across providers.\n\nCursor reads token usage from its local SQLite database. Since Cursor's \"Auto\" mode hides the actual model used, costs are estimated using Sonnet pricing (labeled \"Auto (Sonnet est.)\" in the dashboard). The Cursor view shows a **Languages** panel (extracted from code blocks) instead of Core Tools/Shell/MCP panels, since Cursor does not log individual tool calls. First run on a large Cursor database may take up to a minute; results are cached and subsequent runs are instant.\n\nGitHub Copilot only logs output tokens in its session state, so Copilot cost rows sit below actual API cost. The model is tracked via `session.model_change` events; messages before the first model change are skipped to avoid silent misattribution.\n\n### Adding a provider\n\nThe provider plugin system makes adding a new provider a single file. Each provider implements session discovery, JSONL parsing, tool normalization, and model display names. See `src/providers/codex.ts` for an example.\n\n## Model aliases\n\nIf you see `$0.00` for some models, the model name reported by your provider doesn't match any entry in the LiteLLM pricing data. This commonly happens when using a proxy that rewrites model names.\n\nMap any model name to a canonical one:\n\n```bash\ncodeburn model-alias \"my-proxy-model\" \"claude-opus-4-6\"   # add alias\ncodeburn model-alias --list                                # show configured aliases\ncodeburn model-alias --remove \"my-proxy-model\"             # remove alias\n```\n\nAliases are stored in `~/.config/codeburn/config.json` and applied at runtime before pricing lookup. The target name can be anything in the [LiteLLM model list](https://github.com/BerriAI/litellm/blob/main/model_prices_and_context_window.json) or a canonical name from the fallback table (e.g. `claude-sonnet-4-6`, `claude-opus-4-5`, `gpt-4o`).\n\nBuilt-in aliases ship for known proxy model name variants (such as `anthropic--claude-4.6-opus`). User-configured aliases take precedence over built-ins.\n\n## Currency\n\nBy default, costs are shown in USD. To display in a different currency:\n\n```bash\ncodeburn currency GBP          # set to British Pounds\ncodeburn currency AUD          # set to Australian Dollars\ncodeburn currency JPY          # set to Japanese Yen\ncodeburn currency              # show current setting\ncodeburn currency --reset      # back to USD\n```\n\nAny [ISO 4217 currency code](https://en.wikipedia.org/wiki/ISO_4217#List_of_ISO_4217_currency_codes) is supported (162 currencies). Exchange rates are fetched from [Frankfurter](https://www.frankfurter.app/) (European Central Bank data, free, no API key) and cached for 24 hours at `~/.cache/codeburn/`. Config is stored at `~/.config/codeburn/config.json`.\n\nThe currency setting applies everywhere: dashboard, status bar, menu bar widget, CSV/JSON exports, and JSON API output.\n\nThe menu bar widget includes a currency picker with 17 common currencies. For any currency not listed, use the CLI command above.\n\n## Plans (subscription tracking)\n\nIf you're on Claude Pro, Claude Max, or Cursor Pro, set your plan so the dashboard shows subscription-relative usage:\n\n```bash\ncodeburn plan set claude-max                                  # $200/month\ncodeburn plan set claude-pro                                  # $20/month\ncodeburn plan set cursor-pro                                  # $20/month\ncodeburn plan set custom --monthly-usd 150 --provider claude # custom\ncodeburn plan set none                                        # disable plan view\ncodeburn plan                                                 # show current\ncodeburn plan reset                                           # remove plan config\n```\n\nThe progress bar shows API-equivalent cost vs subscription price. Presets use publicly stated plan prices (as of April 2026); they do not model exact token allowances, because vendors do not publish precise consumer-plan limits.\n\n## Menu Bar\n\n\u003cimg src=\"https://cdn.jsdelivr.net/gh/getagentseal/codeburn@main/assets/menubar-0.8.0.png\" alt=\"CodeBurn macOS menubar app\" width=\"420\" /\u003e\n\n```bash\nnpx codeburn menubar\n```\n\nOne command: downloads the latest `.app`, installs into `~/Applications`, and launches it. Re-run with `--force` to reinstall. Native Swift + SwiftUI app lives in `mac/` (see `mac/README.md` for build details). Shows today's cost with a flame icon, opens a popover with agent tabs, period switcher (Today / 7 Days / 30 Days / Month / All), Trend / Forecast / Pulse / Stats / Plan insights, activity and model breakdowns, optimize findings, and CSV/JSON export. Refreshes live via FSEvents plus a 15-second poll.\n\n**Compact mode** shrinks the menubar item to fit the text, dropping decimals (e.g. `$110` instead of `$110.20`). Opt in with:\n\n```bash\ndefaults write CodeBurnMenubar CodeBurnMenubarCompact -bool true\n```\n\nRelaunch the app to apply. To revert: `defaults delete CodeBurnMenubar CodeBurnMenubarCompact`.\n\n## What it tracks\n\n**13 task categories** classified from tool usage patterns and user message keywords. No LLM calls, fully deterministic.\n\n| Category | What triggers it |\n|---|---|\n| Coding | Edit, Write tools |\n| Debugging | Error/fix keywords + tool usage |\n| Feature Dev | \"add\", \"create\", \"implement\" keywords |\n| Refactoring | \"refactor\", \"rename\", \"simplify\" |\n| Testing | pytest, vitest, jest in Bash |\n| Exploration | Read, Grep, WebSearch without edits |\n| Planning | EnterPlanMode, TaskCreate tools |\n| Delegation | Agent tool spawns |\n| Git Ops | git push/commit/merge in Bash |\n| Build/Deploy | npm build, docker, pm2 |\n| Brainstorming | \"brainstorm\", \"what if\", \"design\" |\n| Conversation | No tools, pure text exchange |\n| General | Skill tool, uncategorized |\n\n**Breakdowns**: daily cost chart, per-project, per-model (Opus/Sonnet/Haiku/GPT-5/GPT-4o/Gemini), per-activity with one-shot rate, core tools, shell commands, MCP servers.\n\n**One-shot rate**: For categories that involve code edits, CodeBurn detects edit/test/fix retry cycles (Edit -\u003e Bash -\u003e Edit patterns). The 1-shot column shows the percentage of edit turns that succeeded without retries. Coding at 90% means the AI got it right first try 9 out of 10 times.\n\n**Pricing**: Fetched from [LiteLLM](https://github.com/BerriAI/litellm) model prices (auto-cached 24h at `~/.cache/codeburn/`). Handles input, output, cache write, cache read, and web search costs. Fast mode multiplier for Claude. Hardcoded fallbacks for all Claude and GPT-5 models to prevent fuzzy matching mispricing.\n\n## Reading the dashboard\n\nCodeBurn surfaces the data, you read the story. A few patterns worth knowing:\n\n| Signal you see | What it might mean |\n|---|---|\n| Cache hit \u003c 80% | System prompt or context isn't stable, or caching not enabled |\n| Lots of `Read` calls per session | Agent re-reading same files, missing context |\n| Low 1-shot rate (Coding 30%) | Agent struggling with edits, retry loops |\n| Opus 4.6 dominating cost on small turns | Overpowered model for simple tasks |\n| `dispatch_agent` / `task` heavy | Sub-agent fan-out, expected or excessive |\n| No MCP usage shown | Either you don't use MCP servers, or your config is broken |\n| Bash dominated by `git status`, `ls` | Agent exploring instead of executing |\n| Conversation category dominant | Agent talking instead of doing |\n\nThese are starting points, not verdicts. A 60% cache hit on a single experimental session is fine. A persistent 60% cache hit across weeks of work is a config issue.\n\n## Optimize\n\nOnce you know what to look for, `codeburn optimize` scans your sessions and your `~/.claude/` setup for the most common waste patterns and hands back exact, copy-paste fixes. It never writes to your files.\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://raw.githubusercontent.com/getagentseal/codeburn/main/assets/optimize.jpg\" alt=\"CodeBurn optimize output\" width=\"720\" /\u003e\n\u003c/p\u003e\n\n```bash\ncodeburn optimize                       # scan the last 30 days\ncodeburn optimize -p today              # today only\ncodeburn optimize -p week               # last 7 days\ncodeburn optimize --provider claude     # restrict to one provider\n```\n\n**What it detects**\n\n- Files Claude re-reads across sessions (same content, same context, over and over)\n- Low Read:Edit ratio (editing without reading leads to retries and wasted tokens)\n- Wasted bash output (uncapped `BASH_MAX_OUTPUT_LENGTH`, trailing noise)\n- Unused MCP servers still paying their tool-schema overhead every session\n- Ghost agents, skills, and slash commands defined in `~/.claude/` but never invoked\n- Bloated `CLAUDE.md` files (with `@-import` expansion counted)\n- Cache creation overhead and junk directory reads\n\nEach finding shows the estimated token and dollar savings plus a ready-to-paste fix: a `CLAUDE.md` line, an environment variable, or a `mv` command to archive unused items. Findings are ranked by urgency (impact weighted against observed waste) and rolled up into an A-F setup health grade. Repeat runs classify each finding as new, improving, or resolved against a 48-hour recent window.\n\nYou can also open it inline from the dashboard: press `o` when a finding count appears in the status bar, `b` to return.\n\n## Compare\n\nSide-by-side model comparison across any two models in your session data. Pick any pair and see how they stack up on real usage from your own sessions.\n\n```bash\ncodeburn compare                        # interactive model picker (default: all time)\ncodeburn compare -p week                # last 7 days\ncodeburn compare -p today               # today only\ncodeburn compare --provider claude      # Claude Code sessions only\n```\n\nOr press `c` in the dashboard to enter compare mode. Arrow keys switch periods, `b` to return.\n\n**Metrics compared**\n\n| Section | Metric | What it measures |\n|---------|--------|-----------------|\n| Performance | One-shot rate | Edits that succeed without retries |\n| Performance | Retry rate | Average retries per edit turn |\n| Performance | Self-correction | Turns where the model corrected its own mistake |\n| Efficiency | Cost / call | Average cost per API call |\n| Efficiency | Cost / edit | Average cost per edit turn |\n| Efficiency | Output tok / call | Average output tokens per call |\n| Efficiency | Cache hit rate | Proportion of input from cache |\n\n**Per-category one-shot rates.** Breaks down one-shot success by task category (Coding, Debugging, Feature Dev, etc.) so you can see where each model excels or struggles.\n\n**Working style.** Compares delegation rate (agent spawns), planning rate (TaskCreate, TaskUpdate, TodoWrite usage), average tools per turn, and fast mode usage.\n\nAll metrics are computed from your local session data. No LLM calls, fully deterministic.\n\n## How it reads data\n\n**Claude Code** stores session transcripts as JSONL at `~/.claude/projects/\u003csanitized-path\u003e/\u003csession-id\u003e.jsonl`. Each assistant entry contains model name, token usage (input, output, cache read, cache write), tool_use blocks, and timestamps.\n\n**Codex** stores sessions at `~/.codex/sessions/YYYY/MM/DD/rollout-*.jsonl` with `token_count` events containing per-call and cumulative token usage, and `function_call` entries for tool tracking.\n\n**Cursor** stores session data in a SQLite database at `~/Library/Application Support/Cursor/User/globalStorage/state.vscdb` (macOS), `~/.config/Cursor/User/globalStorage/state.vscdb` (Linux), or `%APPDATA%/Cursor/User/globalStorage/state.vscdb` (Windows). Token counts are in `cursorDiskKV` table entries with `bubbleId:` key prefix. Requires `better-sqlite3` (installed as optional dependency). Parsed results are cached at `~/.cache/codeburn/cursor-results.json` and auto-invalidate when the database changes.\n\n**OpenCode** stores sessions in SQLite databases at `~/.local/share/opencode/opencode*.db`. CodeBurn queries the `session`, `message`, and `part` tables read-only, extracts token counts and tool usage, and recalculates cost using the LiteLLM pricing engine. Falls back to OpenCode's own cost field for models not in our pricing data. Subtask sessions (`parent_id IS NOT NULL`) are excluded to avoid double-counting. Supports multiple channel databases and respects `XDG_DATA_HOME`.\n\n**Pi / OMP** stores sessions as JSONL at `~/.pi/agent/sessions/\u003csanitized-cwd\u003e/*.jsonl` (Pi) and `~/.omp/agent/sessions/\u003csanitized-cwd\u003e/*.jsonl` (OMP). Each assistant message carries token usage (input, output, cacheRead, cacheWrite) plus inline `toolCall` content blocks. CodeBurn extracts token counts, normalizes tool names to the standard set (`bash` -\u003e `Bash`, `dispatch_agent` -\u003e `Agent`), and pulls bash commands from `toolCall.arguments.command` for the shell breakdown.\n\nCodeBurn reads these files, deduplicates messages (by API message ID for Claude, by cumulative token cross-check for Codex, by conversation/timestamp for Cursor, by session+message ID for OpenCode, by responseId for Pi/OMP), filters by date range per entry, and classifies each turn.\n\n## Environment variables\n\n| Variable | Description |\n|----------|-------------|\n| `CLAUDE_CONFIG_DIR` | Override Claude Code data directory (default: `~/.claude`) |\n| `CODEX_HOME` | Override Codex data directory (default: `~/.codex`) |\n\n## Project structure\n\n```\nsrc/\n  cli.ts          Commander.js entry point\n  dashboard.tsx   Ink TUI (React for terminals)\n  parser.ts       JSONL reader, dedup, date filter, provider orchestration\n  models.ts       LiteLLM pricing, cost calculation\n  classifier.ts   13-category task classifier\n  compare-stats.ts Model comparison engine (metrics, category breakdown, working style)\n  types.ts        Type definitions\n  format.ts       Text rendering (status bar)\n  menubar-json.ts Payload builder consumed by the native macOS menubar app in mac/\n  export.ts       CSV/JSON multi-period export\n  config.ts       Config file management (~/.config/codeburn/)\n  currency.ts     Currency conversion, exchange rates, Intl formatting\n  sqlite.ts       SQLite adapter (lazy-loads better-sqlite3)\n  cursor-cache.ts Cursor result cache (file-based, auto-invalidating)\n  providers/\n    types.ts      Provider interface definitions\n    index.ts      Provider registry (lazy-loads Cursor, OpenCode)\n    claude.ts     Claude Code session discovery\n    codex.ts      Codex session discovery and JSONL parsing\n    cursor.ts     Cursor SQLite parsing, language extraction\n    opencode.ts   OpenCode SQLite session discovery and parsing\n    pi.ts         Pi/OMP agent JSONL session discovery and parsing\n```\n\n## Star History\n\n\u003ca href=\"https://www.star-history.com/?repos=getagentseal%2Fcodeburn\u0026type=date\u0026legend=top-left\"\u003e\n \u003cpicture\u003e\n   \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"https://api.star-history.com/chart?repos=getagentseal/codeburn\u0026type=date\u0026theme=dark\u0026legend=top-left\" /\u003e\n   \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"https://api.star-history.com/chart?repos=getagentseal/codeburn\u0026type=date\u0026legend=top-left\" /\u003e\n   \u003cimg alt=\"Star History Chart\" src=\"https://api.star-history.com/chart?repos=getagentseal/codeburn\u0026type=date\u0026legend=top-left\" /\u003e\n \u003c/picture\u003e\n\u003c/a\u003e\n\n## License\n\nMIT\n\n## Credits\n\nInspired by [ccusage](https://github.com/ryoppippi/ccusage) and [CodexBar](https://github.com/nicklama/codexbar). Pricing data from [LiteLLM](https://github.com/BerriAI/litellm). Exchange rates from [Frankfurter](https://www.frankfurter.app/).\n\nBuilt by [AgentSeal](https://agentseal.org).\n","funding_links":["https://github.com/sponsors/agentseal"],"categories":["TypeScript"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgetagentseal%2Fcodeburn","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fgetagentseal%2Fcodeburn","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgetagentseal%2Fcodeburn/lists"}