Claude Code's Tool API Details Revealed

Claude Code's Tool API Structure
A Reddit user documented their conversation with Claude Code about its internal tool API. The AI assistant revealed specific details about how it interacts with the environment.
Tool Categories and Functions
File System Tools:
Read— reads files by absolute path, returns content with line numbers (cat -n style). Supports images, PDFs, Jupyter notebooks.Write— overwrites or creates files. Must Read first before Writing to existing files.Edit— performs surgical string replacement. Requires the old_string to be unique in the file, otherwise it fails. Must Read first.Glob— finds files by pattern (e.g., *.py), sorted by modification time.Grep— ripgrep-based content search. Supports regex, file type filters, and context lines.
Execution Tools:
Bash— runs shell commands with a 2-minute default timeout (up to 10 minutes). Working directory persists between calls, but shell state doesn't carry over (no environment variables, aliases, etc.). Has a run_in_background option.
Web Tools:
WebFetch— fetches URL content.WebSearch— searches the web.
AI Agents:
Agent— spawns subagents (general-purpose, Explore, Plan, etc.) with their own tool access and context. Can run in background. Returns a single message when done.
Special Tools:
Skill— invokes named "skills" (slash commands like /commit) that expand into full prompts.ToolSearch— fetches schemas for "deferred tools" (tools known by name but can't be called until their schema is fetched).
Key Implementation Details
Tool Call Structure: Claude Code doesn't use special tokens to trigger tools — it's a standard function-calling API. The response includes structured tool call blocks, and results come back as tool result messages.
Tool Call Format: The blocks use XML-like syntax with an antml:function_calls wrapper containing one or more antml:invoke elements with the tool name as an attribute. Each parameter is an antml:parameter element with a name attribute and the value as text content.
Example structure for a Bash call:
- Outer tag:
antml:function_calls - Inner tag:
antml:invokewith attributename="Bash" - Parameter tag:
antml:parameterwithname="command"containing the command text
Operational Behaviors
- Linter interactions: When editing files, git hooks or configured "hooks" can run automatically after tool calls and modify files further. The tool result indicates "file was modified by another process," requiring re-reading before editing again.
- Tool call visibility: Every tool call appears in the terminal for user approval (depending on permission mode). Users can deny any tool call.
- Parallel execution: Multiple tool calls can be issued in a single response and execute concurrently, useful for reading several files at once.
- Context management: Long conversations get compressed automatically — earlier messages get summarized to free up context. Memory persistence occurs through a directory structure:
/home/tpreal/.claude/projects/...
📖 Read the full source: r/ClaudeAI
👀 See Also

Mymir: An Open-Source Project Graph for Coding Agents via MCP
Mymir gives agents a graph-based project map with dependencies, decisions, acceptance criteria, and previous execution notes, delivered via MCP to avoid re-explaining state across sessions.

200+ App Design Specs in Markdown – Drag into Claude or Cursor for Exact UI Clones
A curated library of 200+ popular apps as structured markdown design specs with exact hex codes, type scale, spacing, every screen state, and nav graph. Drop into Claude, Cursor, or any AI agent to generate SwiftUI, Jetpack Compose, or Expo UI clones without guessing colors or spacing.

Claude Code Used to Simulate 4,000+ Blind Werewolf Games with LLMs
A developer used Claude Code to build a simulator where LLMs play blind one-night Werewolf, running ~4,600 games across OpenAI and xAI models. The experiment revealed consistent name-based voting patterns despite minimal game signals.

Community-voted Model Leaderboard for OpenClaw Released
A new community-voted leaderboard for models compatible with OpenClaw is now available, with Opus 4.5 currently leading.