Commit bc67c8d
fix(careful): hook 発火経路と output format を Claude Code 仕様に合わせる + 日本語化 + BSD sed 互換性
PR #24(step 28)の実機 integration テストで判明した問題を 4 件修正:
1. hook command path:`${CLAUDE_SKILL_DIR}` は Claude Code 公式 env var ではなく gstack 独自拡張だった(Claude Code は提供しない)。Claude Code 公式 `$CLAUDE_PROJECT_DIR` ベースの絶対 path に置換 → `$CLAUDE_PROJECT_DIR/.claude/skills/careful/bin/check-careful.sh`。これにより hook がそもそも script を見つけられない問題(`bash: /bin/check-careful.sh: No such file or directory`)を解消
2. hook output JSON format:gstack の `{"permissionDecision":"ask","message":"..."}` は旧 format。現行 Claude Code は `hookSpecificOutput` で wrap した format を要求 → `{"hookSpecificOutput":{"hookEventName":"PreToolUse","permissionDecision":"ask","permissionDecisionReason":"..."}}`。これにより hook は呼ばれるが警告が UI に表示されない問題を解消
3. WARN メッセージ 8 種を日本語化:「Destructive: ...」→「危険: ...」(uzustack の言語感に整合、SKILL.md.tmpl は日本語、statusMessage も日本語、warning だけ英語は不整合)
4. BSD sed 互換性:sed regex の `\s+` を `[[:space:]]+` に置換。macOS の BSD sed は `\s` 未対応で safe exception の RM_ARGS strip が失敗、結果として `rm -rf node_modules` が安全例外として通らなかった。POSIX の `[[:space:]]+` に置換して macOS / Linux 両対応に
これらの finding は Phase 4(freeze + investigate hook 復活)翻訳でも再利用される設計知見として [[未決-16 hook 機構の発動経路の検証]] に記録予定。
実機検証済み(Mode A、uzustack repo 内 Claude Code):
- destructive コマンド → `[careful] 危険: 再帰削除 (rm -r)。ファイルを永続的に削除します。` 警告発火
- 安全例外(`./fake_dir/node_modules`) → `{}` 返却で標準 prompt
- git reset --hard → `[careful] 危険: git reset --hard は未コミットの変更をすべて破棄します。` 警告
- 非 destructive → `{}` 返却
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent 39fdec6 commit bc67c8d
3 files changed
Lines changed: 13 additions & 13 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
25 | | - | |
| 25 | + | |
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
25 | | - | |
| 25 | + | |
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
4 | | - | |
| 4 | + | |
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
31 | | - | |
| 31 | + | |
32 | 32 | | |
33 | 33 | | |
34 | 34 | | |
| |||
53 | 53 | | |
54 | 54 | | |
55 | 55 | | |
56 | | - | |
| 56 | + | |
57 | 57 | | |
58 | 58 | | |
59 | 59 | | |
60 | 60 | | |
61 | 61 | | |
62 | | - | |
| 62 | + | |
63 | 63 | | |
64 | 64 | | |
65 | 65 | | |
66 | 66 | | |
67 | 67 | | |
68 | | - | |
| 68 | + | |
69 | 69 | | |
70 | 70 | | |
71 | 71 | | |
72 | 72 | | |
73 | 73 | | |
74 | | - | |
| 74 | + | |
75 | 75 | | |
76 | 76 | | |
77 | 77 | | |
78 | 78 | | |
79 | 79 | | |
80 | | - | |
| 80 | + | |
81 | 81 | | |
82 | 82 | | |
83 | 83 | | |
84 | 84 | | |
85 | 85 | | |
86 | | - | |
| 86 | + | |
87 | 87 | | |
88 | 88 | | |
89 | 89 | | |
90 | 90 | | |
91 | 91 | | |
92 | | - | |
| 92 | + | |
93 | 93 | | |
94 | 94 | | |
95 | 95 | | |
96 | 96 | | |
97 | 97 | | |
98 | | - | |
| 98 | + | |
99 | 99 | | |
100 | 100 | | |
101 | 101 | | |
102 | 102 | | |
103 | 103 | | |
104 | 104 | | |
105 | | - | |
| 105 | + | |
106 | 106 | | |
107 | 107 | | |
108 | 108 | | |
0 commit comments