hooks

Compare original and translation side by side

🇺🇸

Original

English
🇨🇳

Translation

Chinese

Hook Development Rules

Hook开发规则

When working with files in
.claude/hooks/
:
在处理
.claude/hooks/
中的文件时:

Pattern

模式

Shell wrapper (.sh) → TypeScript (.ts) via
npx tsx
Shell包装器(.sh)→ 通过
npx tsx
调用TypeScript(.ts)

Shell Wrapper Template

Shell包装器模板

bash
#!/bin/bash
set -e
cd "$CLAUDE_PROJECT_DIR/.claude/hooks"
cat | npx tsx <handler>.ts
bash
#!/bin/bash
set -e
cd "$CLAUDE_PROJECT_DIR/.claude/hooks"
cat | npx tsx <handler>.ts

TypeScript Handler Pattern

TypeScript处理器模式

typescript
interface HookInput {
  // Event-specific fields
}

async function main() {
  const input: HookInput = JSON.parse(await readStdin());

  // Process input

  const output = {
    result: 'continue',  // or 'block'
    message: 'Optional system reminder'
  };

  console.log(JSON.stringify(output));
}
typescript
interface HookInput {
  // 事件专属字段
}

async function main() {
  const input: HookInput = JSON.parse(await readStdin());

  // 处理输入

  const output = {
    result: 'continue',  // 或 'block'
    message: '可选系统提醒'
  };

  console.log(JSON.stringify(output));
}

Hook Events

Hook事件

  • PreToolUse - Before tool execution (can block)
  • PostToolUse - After tool execution
  • UserPromptSubmit - Before processing user prompt
  • PreCompact - Before context compaction
  • SessionStart - On session start/resume/compact
  • Stop - When agent finishes
  • PreToolUse - 工具执行前(可阻止)
  • PostToolUse - 工具执行后
  • UserPromptSubmit - 处理用户提示前
  • PreCompact - 上下文压缩前
  • SessionStart - 会话启动/恢复/压缩时
  • Stop - Agent结束时

Testing

测试

Test hooks manually:
bash
echo '{"type": "resume"}' | .claude/hooks/session-start-continuity.sh
手动测试Hook:
bash
echo '{"type": "resume"}' | .claude/hooks/session-start-continuity.sh

Registration

注册

Add hooks to
.claude/settings.json
:
json
{
  "hooks": {
    "EventName": [{
      "matcher": ["pattern"],  // Optional
      "hooks": [{
        "type": "command",
        "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/hook.sh"
      }]
    }]
  }
}
.claude/settings.json
中添加Hook:
json
{
  "hooks": {
    "EventName": [{
      "matcher": ["pattern"],  // 可选
      "hooks": [{
        "type": "command",
        "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/hook.sh"
      }]
    }]
  }
}