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

OpenClaw Context Meter Plugin Shows Telegram Token Usage Percentage
A new OpenClaw plugin displays token usage percentage after every Telegram bot response, showing values like '45k / 200k (22%)' and detecting compaction events. The plugin avoids OOM issues by hardcoding context windows instead of using execSync.

General Bots: Open-source AI agent platform for self-hosted enterprise automation
General Bots is an open-source platform started in 2019 that provides AI agents, workflow automation, document processing, and integrations with local AI model support, designed for organizations needing full control over their infrastructure.

IronBee: Open-source verification layer for Claude Code and Cursor
IronBee is an open-source verification layer that forces AI coding agents to test changes in a real browser before completing tasks. In testing, it caught bugs in 82% of Claude Code sessions that would have shipped without verification.

OpenSwarm: Multi-Agent Claude CLI Orchestrator for Linear and GitHub
OpenSwarm orchestrates multiple Claude Code CLI instances as autonomous agents that pull Linear issues and run Worker/Reviewer/Test/Documenter pipelines. It uses LanceDB with multilingual-e5 embeddings for memory and includes Discord bot control, PR auto-improvement, and a web dashboard.