diff --git a/README.ja.md b/README.ja.md index a109035..94f4ad2 100644 --- a/README.ja.md +++ b/README.ja.md @@ -868,7 +868,7 @@ Oh My OpenCode は以下の場所からフックを読み込んで実行しま } ``` -利用可能なフック:`todo-continuation-enforcer`, `context-window-monitor`, `session-recovery`, `session-notification`, `comment-checker`, `grep-output-truncator`, `tool-output-truncator`, `directory-agents-injector`, `directory-readme-injector`, `empty-task-response-detector`, `think-mode`, `anthropic-auto-compact`, `rules-injector`, `background-notification`, `auto-update-checker`, `startup-toast`, `keyword-detector`, `agent-usage-reminder`, `non-interactive-env`, `interactive-bash-session`, `empty-message-sanitizer`, `preemptive-compaction`, `compaction-context-injector`, `thinking-block-validator`, `claude-code-hooks` +利用可能なフック:`todo-continuation-enforcer`, `context-window-monitor`, `session-recovery`, `session-notification`, `comment-checker`, `grep-output-truncator`, `tool-output-truncator`, `directory-agents-injector`, `directory-readme-injector`, `empty-task-response-detector`, `think-mode`, `anthropic-context-window-limit-recovery`, `rules-injector`, `background-notification`, `auto-update-checker`, `startup-toast`, `keyword-detector`, `agent-usage-reminder`, `non-interactive-env`, `interactive-bash-session`, `empty-message-sanitizer`, `preemptive-compaction`, `compaction-context-injector`, `thinking-block-validator`, `claude-code-hooks` **`auto-update-checker`と`startup-toast`について**: `startup-toast` フックは `auto-update-checker` のサブ機能です。アップデートチェックは有効なまま起動トースト通知のみを無効化するには、`disabled_hooks` に `"startup-toast"` を追加してください。すべてのアップデートチェック機能(トーストを含む)を無効化するには、`"auto-update-checker"` を追加してください。 diff --git a/README.ko.md b/README.ko.md index 125bb5e..ea5556b 100644 --- a/README.ko.md +++ b/README.ko.md @@ -865,7 +865,7 @@ Schema 자동 완성이 지원됩니다: } ``` -사용 가능한 훅: `todo-continuation-enforcer`, `context-window-monitor`, `session-recovery`, `session-notification`, `comment-checker`, `grep-output-truncator`, `tool-output-truncator`, `directory-agents-injector`, `directory-readme-injector`, `empty-task-response-detector`, `think-mode`, `anthropic-auto-compact`, `rules-injector`, `background-notification`, `auto-update-checker`, `startup-toast`, `keyword-detector`, `agent-usage-reminder`, `non-interactive-env`, `interactive-bash-session`, `empty-message-sanitizer`, `preemptive-compaction`, `compaction-context-injector`, `thinking-block-validator`, `claude-code-hooks` +사용 가능한 훅: `todo-continuation-enforcer`, `context-window-monitor`, `session-recovery`, `session-notification`, `comment-checker`, `grep-output-truncator`, `tool-output-truncator`, `directory-agents-injector`, `directory-readme-injector`, `empty-task-response-detector`, `think-mode`, `anthropic-context-window-limit-recovery`, `rules-injector`, `background-notification`, `auto-update-checker`, `startup-toast`, `keyword-detector`, `agent-usage-reminder`, `non-interactive-env`, `interactive-bash-session`, `empty-message-sanitizer`, `preemptive-compaction`, `compaction-context-injector`, `thinking-block-validator`, `claude-code-hooks` **`auto-update-checker`와 `startup-toast`에 대한 참고사항**: `startup-toast` 훅은 `auto-update-checker`의 하위 기능입니다. 업데이트 확인은 유지하면서 시작 토스트 알림만 비활성화하려면 `disabled_hooks`에 `"startup-toast"`를 추가하세요. 모든 업데이트 확인 기능(토스트 포함)을 비활성화하려면 `"auto-update-checker"`를 추가하세요. diff --git a/README.md b/README.md index 414097a..901cb8d 100644 --- a/README.md +++ b/README.md @@ -904,7 +904,7 @@ Disable specific built-in hooks via `disabled_hooks` in `~/.config/opencode/oh-m } ``` -Available hooks: `todo-continuation-enforcer`, `context-window-monitor`, `session-recovery`, `session-notification`, `comment-checker`, `grep-output-truncator`, `tool-output-truncator`, `directory-agents-injector`, `directory-readme-injector`, `empty-task-response-detector`, `think-mode`, `anthropic-auto-compact`, `rules-injector`, `background-notification`, `auto-update-checker`, `startup-toast`, `keyword-detector`, `agent-usage-reminder`, `non-interactive-env`, `interactive-bash-session`, `empty-message-sanitizer`, `preemptive-compaction`, `compaction-context-injector`, `thinking-block-validator`, `claude-code-hooks` +Available hooks: `todo-continuation-enforcer`, `context-window-monitor`, `session-recovery`, `session-notification`, `comment-checker`, `grep-output-truncator`, `tool-output-truncator`, `directory-agents-injector`, `directory-readme-injector`, `empty-task-response-detector`, `think-mode`, `anthropic-context-window-limit-recovery`, `rules-injector`, `background-notification`, `auto-update-checker`, `startup-toast`, `keyword-detector`, `agent-usage-reminder`, `non-interactive-env`, `interactive-bash-session`, `empty-message-sanitizer`, `preemptive-compaction`, `compaction-context-injector`, `thinking-block-validator`, `claude-code-hooks` **Note on `auto-update-checker` and `startup-toast`**: The `startup-toast` hook is a sub-feature of `auto-update-checker`. To disable only the startup toast notification while keeping update checking enabled, add `"startup-toast"` to `disabled_hooks`. To disable all update checking features (including the toast), add `"auto-update-checker"` to `disabled_hooks`. diff --git a/README.zh-cn.md b/README.zh-cn.md index 1ab23b4..a5034b5 100644 --- a/README.zh-cn.md +++ b/README.zh-cn.md @@ -872,7 +872,7 @@ Sisyphus Agent 也能自定义: } ``` -可关的 hook:`todo-continuation-enforcer`、`context-window-monitor`、`session-recovery`、`session-notification`、`comment-checker`、`grep-output-truncator`、`tool-output-truncator`、`directory-agents-injector`、`directory-readme-injector`、`empty-task-response-detector`、`think-mode`、`anthropic-auto-compact`、`rules-injector`、`background-notification`、`auto-update-checker`、`startup-toast`、`keyword-detector`、`agent-usage-reminder`、`non-interactive-env`、`interactive-bash-session`、`empty-message-sanitizer`、`preemptive-compaction`、`compaction-context-injector`、`thinking-block-validator`、`claude-code-hooks` +可关的 hook:`todo-continuation-enforcer`、`context-window-monitor`、`session-recovery`、`session-notification`、`comment-checker`、`grep-output-truncator`、`tool-output-truncator`、`directory-agents-injector`、`directory-readme-injector`、`empty-task-response-detector`、`think-mode`、`anthropic-context-window-limit-recovery`、`rules-injector`、`background-notification`、`auto-update-checker`、`startup-toast`、`keyword-detector`、`agent-usage-reminder`、`non-interactive-env`、`interactive-bash-session`、`empty-message-sanitizer`、`preemptive-compaction`、`compaction-context-injector`、`thinking-block-validator`、`claude-code-hooks` **关于 `auto-update-checker` 和 `startup-toast`**: `startup-toast` hook 是 `auto-update-checker` 的子功能。若想保持更新检查但只禁用启动提示通知,在 `disabled_hooks` 中添加 `"startup-toast"`。若要禁用所有更新检查功能(包括提示),添加 `"auto-update-checker"`。 diff --git a/assets/oh-my-opencode.schema.json b/assets/oh-my-opencode.schema.json index e9df15a..1729b7c 100644 --- a/assets/oh-my-opencode.schema.json +++ b/assets/oh-my-opencode.schema.json @@ -50,7 +50,7 @@ "directory-readme-injector", "empty-task-response-detector", "think-mode", - "anthropic-auto-compact", + "anthropic-context-window-limit-recovery", "rules-injector", "background-notification", "auto-update-checker", diff --git a/src/config/schema.ts b/src/config/schema.ts index 888794a..aea9af7 100644 --- a/src/config/schema.ts +++ b/src/config/schema.ts @@ -54,7 +54,7 @@ export const HookNameSchema = z.enum([ "directory-readme-injector", "empty-task-response-detector", "think-mode", - "anthropic-auto-compact", + "anthropic-context-window-limit-recovery", "rules-injector", "background-notification", "auto-update-checker", diff --git a/src/hooks/AGENTS.md b/src/hooks/AGENTS.md index 77ae00f..b83da14 100644 --- a/src/hooks/AGENTS.md +++ b/src/hooks/AGENTS.md @@ -9,7 +9,7 @@ Lifecycle hooks that intercept/modify agent behavior. Inject context, enforce ru ``` hooks/ ├── agent-usage-reminder/ # Remind to use specialized agents -├── anthropic-auto-compact/ # Auto-compact Claude at token limit +├── anthropic-context-window-limit-recovery/ # Auto-compact Claude at token limit ├── auto-update-checker/ # Version update notifications ├── background-notification/ # OS notify on background task complete ├── claude-code-hooks/ # Claude Code settings.json integration @@ -40,7 +40,7 @@ hooks/ | Category | Hooks | Purpose | |----------|-------|---------| | Context Injection | directory-agents-injector, directory-readme-injector, rules-injector, compaction-context-injector | Auto-inject relevant context | -| Session Management | session-recovery, anthropic-auto-compact, preemptive-compaction, empty-message-sanitizer | Handle session lifecycle | +| Session Management | session-recovery, anthropic-context-window-limit-recovery, preemptive-compaction, empty-message-sanitizer | Handle session lifecycle | | Output Control | comment-checker, tool-output-truncator | Control agent output quality | | Notifications | session-notification, background-notification, auto-update-checker | OS/user notifications | | Behavior Enforcement | todo-continuation-enforcer, keyword-detector, think-mode, agent-usage-reminder | Enforce agent behavior | diff --git a/src/hooks/anthropic-auto-compact/executor.test.ts b/src/hooks/anthropic-context-window-limit-recovery/executor.test.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/executor.test.ts rename to src/hooks/anthropic-context-window-limit-recovery/executor.test.ts diff --git a/src/hooks/anthropic-auto-compact/executor.ts b/src/hooks/anthropic-context-window-limit-recovery/executor.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/executor.ts rename to src/hooks/anthropic-context-window-limit-recovery/executor.ts diff --git a/src/hooks/anthropic-auto-compact/index.ts b/src/hooks/anthropic-context-window-limit-recovery/index.ts similarity index 94% rename from src/hooks/anthropic-auto-compact/index.ts rename to src/hooks/anthropic-context-window-limit-recovery/index.ts index 8904920..5ed0c27 100644 --- a/src/hooks/anthropic-auto-compact/index.ts +++ b/src/hooks/anthropic-context-window-limit-recovery/index.ts @@ -5,11 +5,11 @@ import { parseAnthropicTokenLimitError } from "./parser" import { executeCompact, getLastAssistant } from "./executor" import { log } from "../../shared/logger" -export interface AnthropicAutoCompactOptions { +export interface AnthropicContextWindowLimitRecoveryOptions { experimental?: ExperimentalConfig } -function createAutoCompactState(): AutoCompactState { +function createRecoveryState(): AutoCompactState { return { pendingCompact: new Set(), errorDataBySession: new Map(), @@ -22,8 +22,8 @@ function createAutoCompactState(): AutoCompactState { } } -export function createAnthropicAutoCompactHook(ctx: PluginInput, options?: AnthropicAutoCompactOptions) { - const autoCompactState = createAutoCompactState() +export function createAnthropicContextWindowLimitRecoveryHook(ctx: PluginInput, options?: AnthropicContextWindowLimitRecoveryOptions) { + const autoCompactState = createRecoveryState() const experimental = options?.experimental const eventHandler = async ({ event }: { event: { type: string; properties?: unknown } }) => { diff --git a/src/hooks/anthropic-auto-compact/parser.ts b/src/hooks/anthropic-context-window-limit-recovery/parser.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/parser.ts rename to src/hooks/anthropic-context-window-limit-recovery/parser.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-deduplication.test.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-deduplication.test.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-deduplication.test.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-deduplication.test.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-deduplication.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-deduplication.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-deduplication.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-deduplication.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-executor.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-executor.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-executor.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-executor.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-purge-errors.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-purge-errors.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-purge-errors.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-purge-errors.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-storage.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-storage.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-storage.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-storage.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-supersede.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-supersede.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-supersede.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-supersede.ts diff --git a/src/hooks/anthropic-auto-compact/pruning-types.ts b/src/hooks/anthropic-context-window-limit-recovery/pruning-types.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/pruning-types.ts rename to src/hooks/anthropic-context-window-limit-recovery/pruning-types.ts diff --git a/src/hooks/anthropic-auto-compact/storage.ts b/src/hooks/anthropic-context-window-limit-recovery/storage.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/storage.ts rename to src/hooks/anthropic-context-window-limit-recovery/storage.ts diff --git a/src/hooks/anthropic-auto-compact/types.ts b/src/hooks/anthropic-context-window-limit-recovery/types.ts similarity index 100% rename from src/hooks/anthropic-auto-compact/types.ts rename to src/hooks/anthropic-context-window-limit-recovery/types.ts diff --git a/src/hooks/index.ts b/src/hooks/index.ts index a409813..7428018 100644 --- a/src/hooks/index.ts +++ b/src/hooks/index.ts @@ -7,7 +7,7 @@ export { createToolOutputTruncatorHook } from "./tool-output-truncator"; export { createDirectoryAgentsInjectorHook } from "./directory-agents-injector"; export { createDirectoryReadmeInjectorHook } from "./directory-readme-injector"; export { createEmptyTaskResponseDetectorHook } from "./empty-task-response-detector"; -export { createAnthropicAutoCompactHook, type AnthropicAutoCompactOptions } from "./anthropic-auto-compact"; +export { createAnthropicContextWindowLimitRecoveryHook, type AnthropicContextWindowLimitRecoveryOptions } from "./anthropic-context-window-limit-recovery"; export { createPreemptiveCompactionHook, type PreemptiveCompactionOptions, type SummarizeContext, type BeforeSummarizeCallback } from "./preemptive-compaction"; export { createCompactionContextInjector } from "./compaction-context-injector"; export { createThinkModeHook } from "./think-mode"; diff --git a/src/index.ts b/src/index.ts index f02721c..d7decfc 100644 --- a/src/index.ts +++ b/src/index.ts @@ -12,7 +12,7 @@ import { createEmptyTaskResponseDetectorHook, createThinkModeHook, createClaudeCodeHooksHook, - createAnthropicAutoCompactHook, + createAnthropicContextWindowLimitRecoveryHook, createPreemptiveCompactionHook, createCompactionContextInjector, createRulesInjectorHook, @@ -266,8 +266,8 @@ const OhMyOpenCodePlugin: Plugin = async (ctx) => { const claudeCodeHooks = createClaudeCodeHooksHook(ctx, { disabledHooks: (pluginConfig.claude_code?.hooks ?? true) ? undefined : true, }); - const anthropicAutoCompact = isHookEnabled("anthropic-auto-compact") - ? createAnthropicAutoCompactHook(ctx, { experimental: pluginConfig.experimental }) + const anthropicContextWindowLimitRecovery = isHookEnabled("anthropic-context-window-limit-recovery") + ? createAnthropicContextWindowLimitRecoveryHook(ctx, { experimental: pluginConfig.experimental }) : null; const compactionContextInjector = createCompactionContextInjector(); const preemptiveCompaction = createPreemptiveCompactionHook(ctx, { @@ -566,7 +566,7 @@ const OhMyOpenCodePlugin: Plugin = async (ctx) => { await directoryReadmeInjector?.event(input); await rulesInjector?.event(input); await thinkMode?.event(input); - await anthropicAutoCompact?.event(input); + await anthropicContextWindowLimitRecovery?.event(input); await preemptiveCompaction?.event(input); await agentUsageReminder?.event(input); await interactiveBashSession?.event(input);