Merge pull request #2597 from code-yeongyu/fix/todo-compaction-only-guard

fix(todo-continuation-enforcer): skip continuation when only compaction messages exist
This commit is contained in:
acamq
2026-03-15 20:20:20 -06:00
committed by GitHub
3 changed files with 21 additions and 8 deletions

View File

@@ -144,8 +144,11 @@ export async function handleSessionIdle(args: {
}
let resolvedInfo: ResolvedMessageInfo | undefined
let encounteredCompaction = false
try {
resolvedInfo = await resolveLatestMessageInfo(ctx, sessionID)
const messageInfoResult = await resolveLatestMessageInfo(ctx, sessionID)
resolvedInfo = messageInfoResult.resolvedInfo
encounteredCompaction = messageInfoResult.encounteredCompaction
} catch (error) {
log(`[${HOOK_NAME}] Failed to fetch messages for agent check`, { sessionID, error: String(error) })
}
@@ -164,7 +167,7 @@ export async function handleSessionIdle(args: {
log(`[${HOOK_NAME}] Skipped: agent in skipAgents list`, { sessionID, agent: resolvedAgentName })
return
}
if (compactionGuardActive && !resolvedInfo?.agent) {
if ((compactionGuardActive || encounteredCompaction) && !resolvedInfo?.agent) {
log(`[${HOOK_NAME}] Skipped: compaction occurred but no agent info resolved`, { sessionID })
return
}

View File

@@ -2,30 +2,35 @@ import type { PluginInput } from "@opencode-ai/plugin"
import { normalizeSDKResponse } from "../../shared"
import type { MessageInfo, ResolvedMessageInfo } from "./types"
import type { MessageInfo, ResolveLatestMessageInfoResult } from "./types"
export async function resolveLatestMessageInfo(
ctx: PluginInput,
sessionID: string
): Promise<ResolvedMessageInfo | undefined> {
): Promise<ResolveLatestMessageInfoResult> {
const messagesResp = await ctx.client.session.messages({
path: { id: sessionID },
})
const messages = normalizeSDKResponse(messagesResp, [] as Array<{ info?: MessageInfo }>)
let encounteredCompaction = false
for (let i = messages.length - 1; i >= 0; i--) {
const info = messages[i].info
if (info?.agent === "compaction") {
encounteredCompaction = true
continue
}
if (info?.agent || info?.model || (info?.modelID && info?.providerID)) {
return {
agent: info.agent,
model: info.model ?? (info.providerID && info.modelID ? { providerID: info.providerID, modelID: info.modelID } : undefined),
tools: info.tools,
resolvedInfo: {
agent: info.agent,
model: info.model ?? (info.providerID && info.modelID ? { providerID: info.providerID, modelID: info.modelID } : undefined),
tools: info.tools,
},
encounteredCompaction,
}
}
}
return undefined
return { resolvedInfo: undefined, encounteredCompaction }
}

View File

@@ -54,3 +54,8 @@ export interface ResolvedMessageInfo {
model?: { providerID: string; modelID: string }
tools?: Record<string, ToolPermission>
}
export interface ResolveLatestMessageInfoResult {
resolvedInfo?: ResolvedMessageInfo
encounteredCompaction: boolean
}