- Split 25+ index.ts files into hook.ts + extracted modules - Rename all catch-all utils.ts/helpers.ts to domain-specific names - Split src/tools/lsp/ into ~15 focused modules - Split src/tools/delegate-task/ into ~18 focused modules - Separate shared types from implementation - 155 files changed, 60+ new files created - All typecheck clean, 61 tests pass
39 lines
1.1 KiB
TypeScript
39 lines
1.1 KiB
TypeScript
const TARGET_TOOLS = ["task", "Task", "task_tool", "call_omo_agent"]
|
|
|
|
const SESSION_ID_PATTERNS = [
|
|
/Session ID: (ses_[a-zA-Z0-9_-]+)/,
|
|
/session_id: (ses_[a-zA-Z0-9_-]+)/,
|
|
/<task_metadata>\s*session_id: (ses_[a-zA-Z0-9_-]+)/,
|
|
/sessionId: (ses_[a-zA-Z0-9_-]+)/,
|
|
]
|
|
|
|
function extractSessionId(output: string): string | null {
|
|
for (const pattern of SESSION_ID_PATTERNS) {
|
|
const match = output.match(pattern)
|
|
if (match) return match[1] ?? null
|
|
}
|
|
return null
|
|
}
|
|
|
|
export function createTaskResumeInfoHook() {
|
|
const toolExecuteAfter = async (
|
|
input: { tool: string; sessionID: string; callID: string },
|
|
output: { title: string; output: string; metadata: unknown }
|
|
) => {
|
|
if (!TARGET_TOOLS.includes(input.tool)) return
|
|
if (output.output.startsWith("Error:") || output.output.startsWith("Failed")) return
|
|
if (output.output.includes("\nto continue:")) return
|
|
|
|
const sessionId = extractSessionId(output.output)
|
|
if (!sessionId) return
|
|
|
|
output.output =
|
|
output.output.trimEnd() +
|
|
`\n\nto continue: task(session_id="${sessionId}", prompt="...")`
|
|
}
|
|
|
|
return {
|
|
"tool.execute.after": toolExecuteAfter,
|
|
}
|
|
}
|