对话记录清理(提供商修正)
本文档描述了在运行前(构建模型上下文时)应用于对话记录的提供商特定修正。这些是内存中的调整,用于满足提供商的严格要求。它们不会重写磁盘上存储的 JSONL 对话记录。 涵盖范围包括: 工具调用 id 清理 工具结果配对修复 轮次验证 / 排序 思考签名清理 图片负载清理 如需了解对话记录存储细节,请参阅: /reference/session-management-compaction 运行位置 所有对话记录清理逻辑集中在嵌入式运行器中: 策略选择:src/agents/transcript-policy.ts 清理/修复应用:src/agents/pi-embedded-runner/google.ts 中的 sanitizeSessionHistory 策略根据 provider、modelApi 和 modelId 来决定应用哪些规则。 全局规则:图片清理 图片负载始终会被清理,以防止因大小限制导致提供商端拒绝(对超大 base64 图片进行缩放/重新压缩)。 实现: src/agents/pi-embedded-helpers/images.ts 中的 sanitizeSessionMessagesImages src/agents/tool-images.ts 中的 sanitizeContentBlocksImages 提供商矩阵(当前行为) OpenAI / OpenAI Codex 仅图片清理。 切换到 OpenAI Responses/Codex 模型时,丢弃孤立的推理签名(没有后续内容块的独立推理项)。 不进行工具调用 id 清理。 不进行工具结果配对修复。 不进行轮次验证或重新排序。 不生成合成工具结果。 不剥离思考签名。 Google (Generative AI / Gemini CLI / Antigravity) 工具调用 id 清理:严格字母数字。 工具结果配对修复和合成工具结果。 轮次验证(Gemini 风格的轮次交替)。 Google 轮次排序修正(如果历史记录以助手开头,则在前面添加一个小型用户引导消息)。 Antigravity Claude:规范化思考签名;丢弃未签名的思考块。 Anthropic / Minimax(Anthropic 兼容) ...