fix: detect empty text parts in messages with tool calls during session recovery

This commit is contained in:
ewjin
2026-03-27 11:04:42 +09:00
parent 1c9f4148d0
commit b1735d4004
2 changed files with 11 additions and 5 deletions

View File

@@ -1,6 +1,7 @@
import {
findEmptyMessages,
findEmptyMessageByIndex,
findMessagesWithEmptyTextParts,
injectTextPart,
replaceEmptyTextParts,
} from "../session-recovery/storage"
@@ -79,7 +80,9 @@ export async function fixEmptyMessages(params: {
if (!fixed) {
const emptyMessageIds = findEmptyMessages(params.sessionID)
if (emptyMessageIds.length === 0) {
const emptyTextPartIds = findMessagesWithEmptyTextParts(params.sessionID)
const allIds = [...new Set([...emptyMessageIds, ...emptyTextPartIds])]
if (allIds.length === 0) {
await params.client.tui
.showToast({
body: {
@@ -93,7 +96,7 @@ export async function fixEmptyMessages(params: {
return false
}
for (const messageID of emptyMessageIds) {
for (const messageID of allIds) {
const replaced = replaceEmptyTextParts(messageID, PLACEHOLDER_TEXT)
if (replaced) {
fixed = true

View File

@@ -4,6 +4,7 @@ import { normalizeSDKResponse } from "../../shared"
import { isSqliteBackend } from "../../shared/opencode-storage-detection"
import {
findEmptyMessages,
findMessagesWithEmptyTextParts,
injectTextPart,
replaceEmptyTextParts,
} from "../session-recovery/storage"
@@ -114,12 +115,14 @@ export async function sanitizeEmptyMessagesBeforeSummarize(
}
const emptyMessageIds = findEmptyMessages(sessionID)
if (emptyMessageIds.length === 0) {
const emptyTextPartIds = findMessagesWithEmptyTextParts(sessionID)
const allIds = [...new Set([...emptyMessageIds, ...emptyTextPartIds])]
if (allIds.length === 0) {
return 0
}
let fixedCount = 0
for (const messageID of emptyMessageIds) {
for (const messageID of allIds) {
const replaced = replaceEmptyTextParts(messageID, PLACEHOLDER_TEXT)
if (replaced) {
fixedCount++
@@ -135,7 +138,7 @@ export async function sanitizeEmptyMessagesBeforeSummarize(
log("[auto-compact] pre-summarize sanitization fixed empty messages", {
sessionID,
fixedCount,
totalEmpty: emptyMessageIds.length,
totalEmpty: allIds.length,
})
}