README.md

May 13, 2026 · View on GitHub

Your Claude is coding blind

claude-devtools

Your Claude is coding blind. See everything it did.

The debugging tool for Claude Code. Read session transcripts, inspect tool calls, track token usage — directly from the Claude Code logs on your machine.

GitHub stars  Website  Latest Release  Downloads  Platform  Mentioned in Awesome Claude Code


Download for macOS    Download for Linux    Download for Windows    Deploy with Docker    Install with Homebrew



The Problem

Claude Code started hiding what it does.

Since v2.1.20, Claude Code replaced detailed output with opaque summaries. Read 3 files. Searched for 1 pattern. Edited 2 files. No file paths. No content. No line numbers. The community backlash was immediate.

But the problem goes deeper than collapsed file paths:

  • Thinking steps — Claude's chain-of-thought reasoning is completely invisible in the terminal
  • Tool call details — you see a one-line summary, not the actual input/output
  • Subagent activity — agents spawn agents, but you only see the final result
  • Context window — a three-segment progress bar with no breakdown of what's consuming your tokens
  • Team coordination — teammate messages, task delegation, shutdown requests — all buried

The only workaround is --verbose, which dumps raw JSON, internal system prompts, and thousands of lines of noise. There is no middle ground.

The Solution

claude-devtools is the debugging tool for Claude Code. It reads the Claude Code logs and session transcripts already saved to ~/.claude/ on your machine, and reconstructs everything.

What the terminal hidesWhat claude-devtools shows
Read 3 filesExact file paths, syntax-highlighted content with line numbers
Searched for 1 patternThe regex pattern, every matching file, matched lines
Edited 2 filesInline diffs with added/removed highlighting
Three-segment context barPer-turn token attribution across 7 categories with compaction visualization
Collapsed subagent outputFull execution trees per agent with tool traces, tokens, duration, cost
Nothing about thinkingExtended thinking content, fully visible
--verbose JSON dumpStructured, filterable, navigable interface — no noise
Per-project Claude memory hidden in ~/.claude/projects/.../memory/MEMORY.md rendered as a clickable index of layers; open any layer in your editor
Copy from terminal = wrapped lines, ANSI codes, broken MarkdownReal selectable text, one-click copy on every message and code block

Zero configuration. No API keys. No wrappers. Works with every session you've ever run.

Tip

If claude-devtools saves you time debugging Claude Code, leaving a ⭐ on the repo is the single best way to support the project — it helps other developers find it.


Installation

Homebrew (macOS)

brew install --cask claude-devtools

Direct Download

PlatformDownloadNotes
macOS (Apple Silicon).dmgDownload the arm64 asset. Drag to Applications. On first launch: right-click → Open
macOS (Intel).dmgDownload the x64 asset. Drag to Applications. On first launch: right-click → Open
Linux.AppImage / .deb / .rpm / .pacmanChoose the package format for your distro
Windows.exeStandard installer. May trigger SmartScreen — click "More info" → "Run anyway"
Dockerdocker compose upOpen http://localhost:3456. See Docker deployment

Key Features

Context Reconstruction

context

Per-turn token attribution across 7 categories — CLAUDE.md (global, project, directory), skills, @-mentioned files, tool I/O, thinking, team overhead, user text. See exactly what's in the context window at any point.

Terminal-Friendly Copy & Paste

Copying Claude Code output from the terminal mangles it — selection wraps at the terminal width, ANSI color codes leak into the clipboard, and code blocks lose their Markdown formatting. claude-devtools renders every message, tool call, and output as real selectable text with one-click copy on every code block, plus full-session export to Markdown / JSON / plain text.

Project Memory

Project memory viewer with layer list, frontmatter card, and Open-in launcher

Claude Code stores per-project memory at ~/.claude/projects/<project>/memory/ — a MEMORY.md index plus one .md file per layer (working style, architecture notes, etc.). claude-devtools surfaces this as a sidebar entry that opens a dedicated pane: layer list on the left, full markdown rendering on the right with frontmatter shown as a metadata card, Obsidian-style [[wikilinks]] for cross-layer navigation, and an icon-driven "Open in…" launcher that hands any layer (or the whole memory folder) off to Finder/Explorer, Cursor, VS Code, Zed, Xcode, iTerm, Ghostty, Terminal — or copies the absolute path.

Team & Subagent Trees

Isolated execution trees per agent with tool traces, token metrics, duration, and cost. Nested agents render recursively.

Tool Call Inspector

Every tool call expanded with specialized viewers — syntax-highlighted Read calls, inline Edit diffs, Bash output, and full subagent trees.

SSH Remote Sessions

Inspect sessions on any remote machine over SSH. Reads ~/.ssh/config, supports agent forwarding and key auth.

Compaction Visualization

See the moment your context hits the limit. Visualizes how context fills, compresses, and refills — so you know exactly what was lost. (Why did Claude forget? — debugging walkthrough)

Notification Triggers

System notifications for .env access, tool errors, high token usage, and custom regex patterns on any field.

Command Palette & Multi-Pane Layout

Cmd+K for cross-session search. Open multiple sessions side-by-side with drag-and-drop tabs.

📖 Full documentation: claude-dev.tools/docs · Copy from Claude Code: claude-dev.tools/docs/copy-paste · JSONL format reference: claude-dev.tools/docs/jsonl-format · claude --verbose comparison: claude-dev.tools/docs/verbose-vs-devtools


Not a Wrapper

claude-devtools does not wrap, modify, or interfere with Claude Code. It reads session logs that already exist on your machine. Works with sessions from the terminal, IDEs, or any tool that uses Claude Code.


Docker / Standalone Deployment

Run without Electron — in Docker, on a remote server, or anywhere Node.js runs.

docker compose up
# Open http://localhost:3456

Or manually:

docker build -t claude-devtools .
docker run -p 3456:3456 -v ~/.claude:/data/.claude:ro claude-devtools
VariableDefaultDescription
CLAUDE_ROOT~/.claudePath to the .claude data directory
HOST0.0.0.0Bind address
PORT3456Listen port

The standalone server has zero outbound network calls. For maximum isolation: docker run --network none -p 3456:3456 -v ~/.claude:/data/.claude:ro claude-devtools. See SECURITY.md.


Development

Build from source

Prerequisites: Node.js 20+, pnpm 10+

git clone https://github.com/matt1398/claude-devtools.git
cd claude-devtools
pnpm install
pnpm dev
CommandDescription
pnpm devDevelopment with hot reload
pnpm buildProduction build
pnpm typecheckTypeScript type checking
pnpm testRun all tests
pnpm checkFull quality gate (types + lint + test + build)

Community

Contributing

See CONTRIBUTING.md for guidelines. Please read our Code of Conduct.

Security

IPC handlers validate all inputs with strict path containment checks. File reads are constrained to the project root and ~/.claude. See SECURITY.md.

License

MIT


Star History

Star History Chart

Found this useful? ⭐ Star the repo — it’s the easiest way to help other developers discover claude-devtools.