欢迎回来

登录 EAKE AI,继续您的智能之旅

忘记密码?
还没有账号?立即注册

Claude Code 编码代理

2026-05-22 · Skills中心

Claude Code 编码代理

委派编码任务给 Claude Code CLI(功能开发、PR 提交)

Claude Code — Hermes Orchestration Guide

Delegate coding tasks to Claude Code (Anthropic's autonomous coding agent CLI) via the Hermes terminal. Claude Code v2.x can read files, write code, run shell commands, spawn subagents, and manage git workflows autonomously.

前置条件

  • Install: npm install -g @anthropic-ai/claude-code
  • Auth: run claude once to log in (browser OAuth for Pro/Max, or set ANTHROPIC_API_KEY)
  • Console auth: claude auth login --console for API key billing
  • SSO auth: claude auth login --sso for Enterprise
  • Check status: claude auth status (JSON) or claude auth status --text (human-readable)
  • Health check: claude doctor — checks auto-updater and installation health
  • Version check: claude --version (requires v2.x+)
  • Update: claude update or claude upgrade
  • Two Orchestration Modes

    Hermes interacts with Claude Code in two fundamentally different ways. Choose based on the task.

    Mode 1: Print Mode (`-p`) — Non-Interactive (PREFERRED for most tasks)

    Print mode runs a one-shot task, returns the result, and exits. No PTY needed. No interactive prompts. This is the cleanest integration path.

    
    terminal(command="claude -p 'Add error handling to all API calls in src/' --allowedTools 'Read,Edit' --max-turns 10", workdir="/path/to/project", timeout=120)
    

    When to use print mode:

  • One-shot coding tasks (fix a bug, add a feature, refactor)
  • CI/CD automation and scripting
  • Structured data extraction with --json-schema
  • Piped input processing (cat file | claude -p "analyze this")
  • Any task where you don't need multi-turn conversation
  • Print mode skips ALL interactive dialogs — no workspace trust prompt, no permission confirmations. This makes it ideal for automation.

    Mode 2: Interactive PTY via tmux — Multi-Turn Sessions

    Interactive mode gives you a full conversational REPL where you can send follow-up prompts, use slash commands, and watch Claude work in real time. Requires tmux orchestration.

    
    # Start a tmux session
    terminal(command="tmux new-session -d -s claude-work -x 140 -y 40")
    
    # Launch Claude Code inside it
    terminal(command="tmux send-keys -t claude-work 'cd /path/to/project && claude' Enter")
    
    # Wait for startup, then send your task
    # (after ~3-5 seconds for the welcome screen)
    terminal(command="sleep 5 && tmux send-keys -t claude-work 'Refactor the auth module to use JWT tokens' Enter")
    
    # Monitor progress by capturing the pane
    terminal(command="sleep 15 && tmux capture-pane -t claude-work -p -S -50")
    
    # Send follow-up tasks
    terminal(command="tmux send-keys -t claude-work 'Now add unit tests for the new JWT code' Enter")
    
    # Exit when done
    terminal(command="tmux send-keys -t claude-work '/exit' Enter")
    

    When to use interactive mode:

  • Multi-turn iterative work (refactor → review → fix → test cycle)
  • Tasks requiring human-in-the-loop decisions
  • Exploratory coding sessions
  • When you need to use Claude's slash commands (/compact, /review, /model)
  • PTY Dialog Handling (CRITICAL for Interactive Mode)

    Claude Code presents up to two confirmation dialogs on first launch. You MUST handle these via tmux send-keys:

    Dialog 1: Workspace Trust (first visit to a directory)

    
    ❯ 1. Yes, I trust this folder    ← DEFAULT (just press Enter)
      2. No, exit
    

    Handling: tmux send-keys -t Enter — default selection is correct.

    Dialog 2: Bypass Permissions Warning (only with --dangerously-skip-permissions)

    
    ❯ 1. No, exit                    ← DEFAULT (WRONG choice!)
      2. Yes, I accept
    

    Handling: Must navigate DOWN first, then Enter:

    
    tmux send-keys -t  Down && sleep 0.3 && tmux send-keys -t  Enter
    

    Robust Dialog Handling Pattern

    
    # Launch with permissions bypass
    terminal(command="tmux send-keys -t claude-work 'claude --dangerously-skip-permissions "your task"' Enter")
    
    # Handle trust dialog (Enter for default "Yes")
    terminal(command="sleep 4 && tmux send-keys -t claude-work Enter")
    
    # Handle permissions dialog (Down then Enter for "Yes, I accept")
    terminal(command="sleep 3 && tmux send-keys -t claude-work Down && sleep 0.3 && tmux send-keys -t claude-work Enter")
    
    # Now wait for Claude to work
    terminal(command="sleep 15 && tmux capture-pane -t claude-work -p -S -60")
    

    Note: After the first trust acceptance for a directory, the trust dialog won't appear again. Only the permissions dialog recurs each time you use --dangerously-skip-permissions.

    CLI Subcommands

    SubcommandPurpose
    `claude`Start interactive REPL
    `claude "query"`Start REPL with initial prompt
    `claude -p "query"`Print mode (non-interactive, exits when done)
    `cat file claude -p "query"`Pipe content as stdin context
    `claude -c`Continue the most recent conversation in this directory
    `claude -r "id"`Resume a specific session by ID or name
    `claude auth login`Sign in (add `--console` for API billing, `--sso` for Enterprise)
    `claude auth status`Check login status (returns JSON; `--text` for human-readable)
    `claude mcp add -- `Add an MCP server
    `claude mcp list`List configured MCP servers
    `claude mcp remove `Remove an MCP server
    `claude agents`List configured agents
    `claude doctor`Run health checks on installation and auto-updater
    `claude update` / `claude upgrade`Update Claude Code to latest version
    `claude remote-control`Start server to control Claude from claude.ai or mobile app
    `claude install [target]`Install native build (stable, latest, or specific version)
    `claude setup-token`Set up long-lived auth token (requires subscription)
    `claude plugin` / `claude plugins`Manage Claude Code plugins

    Print Mode Deep Dive

    Structured JSON Output

    
    terminal(command="claude -p 'Analyze auth.py for security issues' --output-format json --max-turns 5", workdir="/project", timeout=120)
    

    Returns a JSON object with:

    
    {
      "type": "result",
      "subtype": "success",
      "result": "The analysis text...",
      "session_id": "75e2167f-...",
      "num_turns": 3,
      "total_cost_usd": 0.0787,
      "duration_ms": 10276,
      "stop_reason": "end_turn",
      "terminal_reason": "completed",
      "usage": { "input_tokens": 5, "output_tokens": 603, ... },
      "modelUsage": { "claude-sonnet-4-6": { "costUSD": 0.078, "contextWindow": 200000 } }
    }
    

    Key fields: session_id for resumption, num_turns for agentic loop count, total_cost_usd for spend tracking, subtype for success/error detection (success, error_max_turns, error_budget).

    Streaming JSON Output

    For real-time token streaming, use stream-json with --verbose:

    
    terminal(command="claude -p 'Write a summary' --output-format stream-json --verbose --include-partial-messages", timeout=60)
    

    Returns newline-delimited JSON events. Filter with jq for live text:

    
    claude -p "Explain X" --output-format stream-json --verbose --include-partial-messages | 
      jq -rj 'select(.type == "stream_event" and .event.delta.type? == "text_delta") | .event.delta.text'
    

    Stream events include system/api_retry with attempt, max_retries, and error fields (e.g., rate_limit, billing_error).

    Bidirectional Streaming

    For real-time input AND output streaming:

    
    claude -p "task" --input-format stream-json --output-format stream-json --replay-user-messages
    

    --replay-user-messages re-emits user messages on stdout for acknowledgment.

    Piped Input

    
    # Pipe a file for analysis
    terminal(command="cat src/auth.py | claude -p 'Review this code for bugs' --max-turns 1", timeout=60)
    
    # Pipe multiple files
    terminal(command="cat src/*.py | claude -p 'Find all TODO comments' --max-turns 1", timeout=60)
    
    # Pipe command output
    terminal(command="git diff HEAD~3 | claude -p 'Summarize these changes' --max-turns 1", timeout=60)
    

    JSON Schema for Structured Extraction

    
    terminal(command="claude -p 'List all functions in src/' --output-format json --json-schema '{"type":"object","properties":{"functions":{"type":"array","items":{"type":"string"}}},"required":["functions"]}' --max-turns 5", workdir="/project", timeout=90)
    

    Parse structured_output from the JSON result. Claude validates output against the schema before returning.

    Session Continuation

    
    # Start a task
    terminal(command="claude -p 'Start refactoring the database layer' --output-format json --max-turns 10 > /tmp/session.json", workdir="/project", timeout=180)
    
    # Resume with session ID
    terminal(command="claude -p 'Continue and add connection pooling' --resume $(cat /tmp/session.json | python3 -c 'import json,sys; print(json.load(sys.stdin)["session_id"])') --max-turns 5", workdir="/project", timeout=120)
    
    # Or resume the most recent session in the same directory
    terminal(command="claude -p 'What did you do last time?' --continue --max-turns 1", workdir="/project", timeout=30)
    
    # Fork a session (new ID, keeps history)
    terminal(command="claude -p 'Try a different approach' --resume  --fork-session --max-turns 10", workdir="/project", timeout=120)
    

    Bare Mode for CI/Scripting

    
    terminal(command="claude --bare -p 'Run all tests and report failures' --allowedTools 'Read,Bash' --max-turns 10", workdir="/project", timeout=180)
    

    --bare skips hooks, plugins, MCP discovery, and CLAUDE.md loading. Fastest startup. Requires ANTHROPIC_API_KEY (skips OAuth).

    To selectively load context in bare mode:

    `claude auto-mode`Inspect auto mode classifier configuration
    To loadFlag
    System prompt additions`--append-system-prompt "text"` or `--append-system-prompt-file path`
    Settings`--settings `
    MCP servers`--mcp-config `

    Fallback Model for Overload

    
    terminal(command="claude -p 'task' --fallback-model haiku --max-turns 5", timeout=90)
    

    Automatically falls back to the specified model when the default is overloaded (print mode only).

    Complete CLI Flags Reference

    Session & Environment

    Custom agents`--agents ''`
    FlagEffect
    `-p, --print`Non-interactive one-shot mode (exits when done)
    `-c, --continue`Resume most recent conversation in current directory
    `-r, --resume `Resume specific session by ID or name (interactive picker if no ID)
    `--fork-session`When resuming, create new session ID instead of reusing original
    `--session-id `Use a specific UUID for the conversation
    `--no-session-persistence`Don't save session to disk (print mode only)
    `--add-dir `Grant Claude access to additional working directories
    `-w, --worktree [name]`Run in an isolated git worktree at `.claude/worktrees/`
    `--tmux`Create a tmux session for the worktree (requires `--worktree`)
    `--ide`Auto-connect to a valid IDE on startup
    `--chrome` / `--no-chrome`Enable/disable Chrome browser integration for web testing
    `--from-pr [number]`Resume session linked to a specific GitHub PR

    Model & Performance

    `--file `File resources to download at startup (format: `file_id:relative_path`)
    FlagEffect
    `--model `Model selection: `sonnet`, `opus`, `haiku`, or full name like `claude-sonnet-4-6`
    `--effort `Reasoning depth: `low`, `medium`, `high`, `max`, `auto`Both
    `--max-turns `Limit agentic loops (print mode only; prevents runaway)
    `--max-budget-usd `Cap API spend in dollars (print mode only)
    `--fallback-model `Auto-fallback when default model is overloaded (print mode only)

    Permission & Safety

    `--betas `Beta headers to include in API requests (API key users only)
    FlagEffect
    `--dangerously-skip-permissions`Auto-approve ALL tool use (file writes, bash, network, etc.)
    `--allow-dangerously-skip-permissions`Enable bypass as an *option* without enabling it by default
    `--permission-mode ``default`, `acceptEdits`, `plan`, `auto`, `dontAsk`, `bypassPermissions`
    `--allowedTools `Whitelist specific tools (comma or space-separated)
    `--disallowedTools `Blacklist specific tools

    Output & Input Format

    `--tools `Override built-in tool set (`""` = none, `"default"` = all, or tool names)
    FlagEffect
    `--output-format ``text` (default), `json` (single result object), `stream-json` (newline-delimited)
    `--input-format ``text` (default) or `stream-json` (real-time streaming input)
    `--json-schema `Force structured JSON output matching a schema
    `--verbose`Full turn-by-turn output
    `--include-partial-messages`Include partial message chunks as they arrive (stream-json + print)

    System Prompt & Context

    `--replay-user-messages`Re-emit user messages on stdout (stream-json bidirectional)
    FlagEffect
    `--append-system-prompt `**Add** to the default system prompt (preserves built-in capabilities)
    `--append-system-prompt-file `**Add** file contents to the default system prompt
    `--system-prompt `**Replace** the entire system prompt (use --append instead usually)
    `--system-prompt-file `**Replace** the system prompt with file contents
    `--bare`Skip hooks, plugins, MCP discovery, CLAUDE.md, OAuth (fastest startup)
    `--agents ''`Define custom subagents dynamically as JSON
    `--mcp-config `Load MCP servers from JSON file (repeatable)
    `--strict-mcp-config`Only use MCP servers from `--mcp-config`, ignoring all other MCP configs
    `--settings `Load additional settings from a JSON file or inline JSON
    `--setting-sources `Comma-separated sources to load: `user`, `project`, `local`
    `--plugin-dir `Load plugins from directories for this session only

    Debugging

    `--disable-slash-commands`Disable all skills/slash commands
    FlagEffect
    `-d, --debug [filter]`Enable debug logging with optional category filter (e.g., `"api,hooks"`, `"!1p,!file"`)

    Agent Teams

    `--debug-file `Write debug logs to file (implicitly enables debug mode)
    FlagEffect
    `--teammate-mode `How agent teams display: `auto`, `in-process`, or `tmux`

    Tool Name Syntax for --allowedTools / --disallowedTools

    
    Read                    # All file reading
    Edit                    # File editing (existing files)
    Write                   # File creation (new files)
    Bash                    # All shell commands
    Bash(git *)             # Only git commands
    Bash(git commit *)      # Only git commit commands
    Bash(npm run lint:*)    # Pattern matching with wildcards
    WebSearch               # Web search capability
    WebFetch                # Web page fetching
    mcp____   # Specific MCP tool
    

    Settings & Configuration

    Settings Hierarchy (highest to lowest priority)

  • CLI flags — override everything
  • Local project: .claude/settings.local.json (personal, gitignored)
  • Project: .claude/settings.json (shared, git-tracked)
  • User: ~/.claude/settings.json (global)
  • Permissions in Settings

    
    {
      "permissions": {
        "allow": ["Bash(npm run lint:*)", "WebSearch", "Read"],
        "ask": ["Write(*.ts)", "Bash(git push*)"],
        "deny": ["Read(.env)", "Bash(rm -rf *)"]
      }
    }
    

    Memory Files (CLAUDE.md) Hierarchy

  • Global: ~/.claude/CLAUDE.md — applies to all projects
  • Project: ./CLAUDE.md — project-specific context (git-tracked)
  • Local: .claude/CLAUDE.local.md — personal project overrides (gitignored)
  • Use the # prefix in interactive mode to quickly add to memory: # Always use 2-space indentation.

    Interactive Session: Slash Commands

    Session & Context

    `--brief`Enable `SendUserMessage` tool for agent-to-user communication
    CommandPurpose
    `/help`Show all commands (including custom and MCP commands)
    `/compact [focus]`Compress context to save tokens; CLAUDE.md survives compaction. E.g., `/compact focus on auth logic`
    `/clear`Wipe conversation history for a fresh start
    `/context`Visualize context usage as a colored grid with optimization tips
    `/cost`View token usage with per-model and cache-hit breakdowns
    `/resume`Switch to or resume a different session
    `/rewind`Revert to a previous checkpoint in conversation or code
    `/btw `Ask a side question without adding to context cost
    `/status`Show version, connectivity, and session info
    `/todos`List tracked action items from the conversation

    Development & Review

    `/exit` or `Ctrl+D`End session
    CommandPurpose
    `/review`Request code review of current changes
    `/security-review`Perform security analysis of current changes
    `/plan [description]`Enter Plan mode with auto-start for task planning
    `/loop [interval]`Schedule recurring tasks within the session

    配置 & Tools

    `/batch`Auto-create worktrees for large parallel changes (5-30 worktrees)
    CommandPurpose
    `/model [model]`Switch models mid-session (use arrow keys to adjust effort)
    `/effort [level]`Set reasoning effort: `low`, `medium`, `high`, `max`, or `auto`
    `/init`Create a CLAUDE.md file for project memory
    `/memory`Open CLAUDE.md for editing
    `/config`Open interactive settings configuration
    `/permissions`View/update tool permissions
    `/agents`Manage specialized subagents
    `/mcp`Interactive UI to manage MCP servers
    `/add-dir`Add additional working directories (useful for monorepos)
    `/usage`Show plan limits and rate limit status
    `/voice`Enable push-to-talk voice mode (20 languages; hold Space to record, release to send)

    Custom Slash Commands

    Create .claude/commands/.md (project-shared) or ~/.claude/commands/.md (personal):

    
    # .claude/commands/deploy.md
    Run the deploy pipeline:
    1. Run all tests
    2. Build the Docker image
    3. Push to registry
    4. Update the $ARGUMENTS environment (default: staging)
    

    Usage: /deploy production$ARGUMENTS is replaced with the user's input.

    Skills (Natural Language Invocation)

    Unlike slash commands (manually invoked), skills in .claude/skills/ are markdown guides that Claude invokes automatically via natural language when the task matches:

    
    # .claude/skills/database-migration.md
    When asked to create or modify database migrations:
    1. Use Alembic for migration generation
    2. Always create a rollback function
    3. Test migrations against a local database copy
    

    Interactive Session: Keyboard Shortcuts

    General Controls

    `/release-notes`Interactive picker for version release notes
    KeyAction
    `Ctrl+C`Cancel current input or generation
    `Ctrl+D`Exit session
    `Ctrl+R`Reverse search command history
    `Ctrl+B`Background a running task
    `Ctrl+V`Paste image into conversation
    `Ctrl+O`Transcript mode — see Claude's thinking process
    `Ctrl+G` or `Ctrl+X Ctrl+E`Open prompt in external editor

    Mode Toggles

    `Esc Esc`Rewind conversation or code state / summarize
    KeyAction
    `Shift+Tab`Cycle permission modes (Normal → Auto-Accept → Plan)
    `Alt+P`Switch model
    `Alt+T`Toggle thinking mode

    Multiline Input

    `Alt+O`Toggle Fast Mode
    KeyAction
    `` + `Enter`Quick newline
    `Shift+Enter`Newline (alternative)

    Input Prefixes

    `Ctrl+J`Newline (alternative)
    PrefixAction
    `!`Execute bash directly, bypassing AI (e.g., `!npm test`). Use `!` alone to toggle shell mode.
    `@`Reference files/directories with autocomplete (e.g., `@./src/api/`)
    `#`Quick add to CLAUDE.md memory (e.g., `# Use 2-space indentation`)

    Pro Tip: "ultrathink"

    Use the keyword "ultrathink" in your prompt for maximum reasoning effort on a specific turn. This triggers the deepest thinking mode regardless of the current /effort setting.

    PR Review Pattern

    Quick Review (Print Mode)

    
    terminal(command="cd /path/to/repo && git diff main...feature-branch | claude -p 'Review this diff for bugs, security issues, and style problems. Be thorough.' --max-turns 1", timeout=60)
    

    Deep Review (Interactive + Worktree)

    
    terminal(command="tmux new-session -d -s review -x 140 -y 40")
    terminal(command="tmux send-keys -t review 'cd /path/to/repo && claude -w pr-review' Enter")
    terminal(command="sleep 5 && tmux send-keys -t review Enter")  # Trust dialog
    terminal(command="sleep 2 && tmux send-keys -t review 'Review all changes vs main. Check for bugs, security issues, race conditions, and missing tests.' Enter")
    terminal(command="sleep 30 && tmux capture-pane -t review -p -S -60")
    

    PR Review from Number

    
    terminal(command="claude -p 'Review this PR thoroughly' --from-pr 42 --max-turns 10", workdir="/path/to/repo", timeout=120)
    

    Claude Worktree with tmux

    
    terminal(command="claude -w feature-x --tmux", workdir="/path/to/repo")
    

    Creates an isolated git worktree at .claude/worktrees/feature-x AND a tmux session for it. Uses iTerm2 native panes when available; add --tmux=classic for traditional tmux.

    Parallel Claude Instances

    Run multiple independent Claude tasks simultaneously:

    
    # Task 1: Fix backend
    terminal(command="tmux new-session -d -s task1 -x 140 -y 40 && tmux send-keys -t task1 'cd ~/project && claude -p "Fix the auth bug in src/auth.py" --allowedTools "Read,Edit" --max-turns 10' Enter")
    
    # Task 2: Write tests
    terminal(command="tmux new-session -d -s task2 -x 140 -y 40 && tmux send-keys -t task2 'cd ~/project && claude -p "Write integration tests for the API endpoints" --allowedTools "Read,Write,Bash" --max-turns 15' Enter")
    
    # Task 3: Update docs
    terminal(command="tmux new-session -d -s task3 -x 140 -y 40 && tmux send-keys -t task3 'cd ~/project && claude -p "Update README.md with the new API endpoints" --allowedTools "Read,Edit" --max-turns 5' Enter")
    
    # Monitor all
    terminal(command="sleep 30 && for s in task1 task2 task3; do echo '=== '$s' ==='; tmux capture-pane -t $s -p -S -5 2>/dev/null; done")
    

    CLAUDE.md — Project Context File

    Claude Code auto-loads CLAUDE.md from the project root. Use it to persist project context:

    
    # Project: My API
    
    ## Architecture
    - FastAPI backend with SQLAlchemy ORM
    - PostgreSQL database, Redis cache
    - pytest for testing with 90% coverage target
    
    ## Key Commands
    - `make test` — run full test suite
    - `make lint` — ruff + mypy
    - `make dev` — start dev server on :8000
    
    ## Code Standards
    - Type hints on all public functions
    - Docstrings in Google style
    - 2-space indentation for YAML, 4-space for Python
    - No wildcard imports
    

    Be specific. Instead of "Write good code", use "Use 2-space indentation for JS" or "Name test files with .test.ts suffix." Specific instructions save correction cycles.

    Rules Directory (Modular CLAUDE.md)

    For projects with many rules, use the rules directory instead of one massive CLAUDE.md:

  • Project rules: .claude/rules/*.md — team-shared, git-tracked
  • User rules: ~/.claude/rules/*.md — personal, global
  • Each .md file in the rules directory is loaded as additional context. This is cleaner than cramming everything into a single CLAUDE.md.

    Auto-Memory

    Claude automatically stores learned project context in ~/.claude/projects//memory/.

  • Limit: 25KB or 200 lines per project
  • This is separate from CLAUDE.md — it's Claude's own notes about the project, accumulated across sessions
  • Custom Subagents

    Define specialized agents in .claude/agents/ (project), ~/.claude/agents/ (personal), or via --agents CLI flag (session):

    Agent Location Priority

  • .claude/agents/ — project-level, team-shared
  • --agents CLI flag — session-specific, dynamic
  • ~/.claude/agents/ — user-level, personal
  • Creating an Agent

    
    # .claude/agents/security-reviewer.md
    ---
    name: security-reviewer
    description: Security-focused code review
    model: opus
    tools: [Read, Bash]
    ---
    You are a senior security engineer. Review code for:
    - Injection vulnerabilities (SQL, XSS, command injection)
    - Authentication/authorization flaws
    - Secrets in code
    - Unsafe deserialization
    

    Invoke via: @security-reviewer review the auth module

    Dynamic Agents via CLI

    
    terminal(command="claude --agents '{"reviewer": {"description": "Reviews code", "prompt": "You are a code reviewer focused on performance"}}' -p 'Use @reviewer to check auth.py'", timeout=120)
    

    Claude can orchestrate multiple agents: "Use @db-expert to optimize queries, then @security to audit the changes."

    Hooks — Automation on Events

    Configure in .claude/settings.json (project) or ~/.claude/settings.json (global):

    
    {
      "hooks": {
        "PostToolUse": [{
          "matcher": "Write(*.py)",
          "hooks": [{"type": "command", "command": "ruff check --fix $CLAUDE_FILE_PATHS"}]
        }],
        "PreToolUse": [{
          "matcher": "Bash",
          "hooks": [{"type": "command", "command": "if echo "$CLAUDE_TOOL_INPUT" | grep -q 'rm -rf'; then echo 'Blocked!' && exit 2; fi"}]
        }],
        "Stop": [{
          "hooks": [{"type": "command", "command": "echo 'Claude finished a response' >> /tmp/claude-activity.log"}]
        }]
      }
    }
    

    All 8 Hook Types

    `/`Slash commands
    HookWhen it firesCommon use
    `UserPromptSubmit`Before Claude processes a user promptInput validation, logging
    `PreToolUse`Before tool executionSecurity gates, block dangerous commands (exit 2 = block)
    `PostToolUse`After a tool finishesAuto-format code, run linters
    `Notification`On permission requests or input waitsDesktop notifications, alerts
    `Stop`When Claude finishes a responseCompletion logging, status updates
    `SubagentStop`When a subagent completesAgent orchestration
    `PreCompact`Before context memory is clearedBackup session transcripts

    Hook Environment Variables

    `SessionStart`When a session beginsLoad dev context (e.g., `git status`)
    VariableContent
    `CLAUDE_PROJECT_DIR`Current project path
    `CLAUDE_FILE_PATHS`Files being modified

    安全说明 Hook Examples

    
    {
      "PreToolUse": [{
        "matcher": "Bash",
        "hooks": [{"type": "command", "command": "if echo "$CLAUDE_TOOL_INPUT" | grep -qE 'rm -rf|git push.*--force|:(){ :|:& };:'; then echo 'Dangerous command blocked!' && exit 2; fi"}]
      }]
    }
    

    MCP Integration

    Add external tool servers for databases, APIs, and services:

    
    # GitHub integration
    terminal(command="claude mcp add -s user github -- npx @modelcontextprotocol/server-github", timeout=30)
    
    # PostgreSQL queries
    terminal(command="claude mcp add -s local postgres -- npx @anthropic-ai/server-postgres --connection-string postgresql://localhost/mydb", timeout=30)
    
    # Puppeteer for web testing
    terminal(command="claude mcp add puppeteer -- npx @anthropic-ai/server-puppeteer", timeout=30)
    

    MCP Scopes

    `CLAUDE_TOOL_INPUT`Tool parameters as JSON
    FlagScopeStorage
    `-s user`Global (all projects)`~/.claude.json`
    `-s local`This project (personal)`.claude/settings.local.json` (gitignored)

    MCP in Print/CI Mode

    
    terminal(command="claude --bare -p 'Query database' --mcp-config mcp-servers.json --strict-mcp-config", timeout=60)
    

    --strict-mcp-config ignores all MCP servers except those from --mcp-config.

    Reference MCP resources in chat: @github:issue://123

    MCP Limits & Tuning

  • Tool descriptions: 2KB cap per server for tool descriptions and server instructions
  • Result size: Default capped; use maxResultSizeChars annotation to allow up to 500K characters for large outputs
  • Output tokens: export MAX_MCP_OUTPUT_TOKENS=50000 — cap output from MCP servers to prevent context flooding
  • Transports: stdio (local process), http (remote), sse (server-sent events)
  • Monitoring Interactive Sessions

    Reading the TUI Status

    
    # Periodic capture to check if Claude is still working or waiting for input
    terminal(command="tmux capture-pane -t dev -p -S -10")
    

    Look for these indicators:

  • at bottom = waiting for your input (Claude is done or asking a question)
  • lines = Claude is actively using tools (reading, writing, running commands)
  • ⏵⏵ bypass permissions on = status bar showing permissions mode
  • ◐ medium · /effort = current effort level in status bar
  • ctrl+o to expand = tool output was truncated (can be expanded interactively)
  • Context Window Health

    Use /context in interactive mode to see a colored grid of context usage. Key thresholds:

  • < 70% — Normal operation, full precision
  • 70-85% — Precision starts dropping, consider /compact
  • > 85% — Hallucination risk spikes significantly, use /compact or /clear
  • 环境要求 Variables

    `-s project`This project (team-shared)`.claude/settings.json` (git-tracked)
    VariableEffect
    `ANTHROPIC_API_KEY`API key for authentication (alternative to OAuth)
    `CLAUDE_CODE_EFFORT_LEVEL`Default effort: `low`, `medium`, `high`, `max`, or `auto`
    `MAX_THINKING_TOKENS`Cap thinking tokens (set to `0` to disable thinking entirely)
    `MAX_MCP_OUTPUT_TOKENS`Cap output from MCP servers (default varies; set e.g., `50000`)
    `CLAUDE_CODE_NO_FLICKER=1`Enable alt-screen rendering to eliminate terminal flicker

    Cost & Performance Tips

  • Use --max-turns in print mode to prevent runaway loops. Start with 5-10 for most tasks.
  • Use --max-budget-usd for cost caps. Note: minimum ~$0.05 for system prompt cache creation.
  • Use --effort low for simple tasks (faster, cheaper). high or max for complex reasoning.
  • Use --bare for CI/scripting to skip plugin/hook discovery overhead.
  • Use --allowedTools to restrict to only what's needed (e.g., Read only for reviews).
  • Use /compact in interactive sessions when context gets large.
  • Pipe input instead of having Claude read files when you just need analysis of known content.
  • Use --model haiku for simple tasks (cheaper) and --model opus for complex multi-step work.
  • Use --fallback-model haiku in print mode to gracefully handle model overload.
  • Start new sessions for distinct tasks — sessions last 5 hours; fresh context is more efficient.
  • Use --no-session-persistence in CI to avoid accumulating saved sessions on disk.
  • Pitfalls & Gotchas

  • Interactive mode REQUIRES tmux — Claude Code is a full TUI app. Using pty=true alone in Hermes terminal works but tmux gives you capture-pane for monitoring and send-keys for input, which is essential for orchestration.
  • --dangerously-skip-permissions dialog defaults to "No, exit" — you must send Down then Enter to accept. Print mode (-p) skips this entirely.
  • --max-budget-usd minimum is ~$0.05 — system prompt cache creation alone costs this much. Setting lower will error immediately.
  • --max-turns is print-mode only — ignored in interactive sessions.
  • Claude may use python instead of python3 — on systems without a python symlink, Claude's bash commands will fail on first try but it self-corrects.
  • Session resumption requires same directory--continue finds the most recent session for the current working directory.
  • --json-schema needs enough --max-turns — Claude must read files before producing structured output, which takes multiple turns.
  • Trust dialog only appears once per directory — first-time only, then cached.
  • Background tmux sessions persist — always clean up with tmux kill-session -t when done.
  • Slash commands (like /commit) only work in interactive mode — in -p mode, describe the task in natural language instead.
  • --bare skips OAuth — requires ANTHROPIC_API_KEY env var or an apiKeyHelper in settings.
  • Context degradation is real — AI output quality measurably degrades above 70% context window usage. Monitor with /context and proactively /compact.
  • Rules for Hermes Agents

  • Prefer print mode (-p) for single tasks — cleaner, no dialog handling, structured output
  • Use tmux for multi-turn interactive work — the only reliable way to orchestrate the TUI
  • Always set workdir — keep Claude focused on the right project directory
  • Set --max-turns in print mode — prevents infinite loops and runaway costs
  • Monitor tmux sessions — use tmux capture-pane -t -p -S -50 to check progress
  • Look for the prompt — indicates Claude is waiting for input (done or asking a question)
  • Clean up tmux sessions — kill them when done to avoid resource leaks
  • Report results to user — after completion, summarize what Claude did and what changed
  • Don't kill slow sessions — Claude may be doing multi-step work; check progress instead
  • Use --allowedTools — restrict capabilities to what the task actually needs
  • Claude Code 终端编程完全指南

    2026-05-22 · 使用手册

    Claude Code 是 Anthropic 官方推出的终端编程工具,基于 Claude 3.5 Sonnet 模型,支持直接在命令行中与 AI 协作完成代码编写、调试、重构和解释等任务。

    核心能力

    • 智能代码生成:通过自然语言描述需求,自动生成完整代码文件
    • 代码审查与优化:分析代码逻辑,提供改进建议和性能优化方案
    • 多轮对话迭代:支持持续对话,可完成从设计到实现的完整流程
    • 文件批量处理:支持一次处理多个文件,适合大型项目重构
    • 安全沙箱执行:所有代码操作在隔离环境中执行

    安装方法

    npm install -g @anthropic-ai/claude-code
    npx claude-code

    基本使用

    claude-code
    # 解释代码
    "请解释 src/utils/auth.js 的工作原理"
    # 重构代码
    "将这个函数重构为 TypeScript,并添加类型注解"
    # 写测试
    "为这个模块生成 Jest 单元测试"

    进阶技巧

    • 使用 @ 引用本地文件:@src/main.ts 请分析这个模块
    • 使用 /approval 查看所有待执行的写操作
    • 使用 /model 切换不同 Claude 模型
    • 设置 CLAUDE_API_KEY 环境变量使用自有 API Key

    适用场景

    • 快速原型开发:用自然语言描述即可生成功能代码
    • 遗留代码维护:自动分析并重构老旧代码
    • 代码评审:辅助进行代码审查和 Bug 定位
    • 学习新技术:通过对话方式快速理解陌生代码库

    Claude Code 是现代 AI 原生开发工具的代表,让开发者从繁琐的重复编码中解放出来,专注于更具创造性的工作。

    评论区

    发表评论

    
    `CLAUDE_CODE_SUBPROCESS_ENV_SCRUB`Strip credentials from sub-processes for security