fix(hindsight-openclaw): skip synthetic tool_result user messages in sliceLastTurnsByUserBoundary#2307
Open
kumaxs wants to merge 3 commits into
Open
Conversation
added 3 commits
June 19, 2026 15:50
…Boundary OpenClaw normalizes tool_result blocks into role:"user" messages with a tool_result content block. The sliceLastTurnsByUserBoundary function used to count every role:"user" message as a turn boundary, causing synthetic tool_result messages to fill the retention window and exclude actual user input from retained transcripts. This change adds a hasRealTextContent guard that skips user messages containing only tool_result blocks, ensuring only genuine user text is counted as turn boundaries for both retain and recall window slicing. Fixes: retained transcripts missing user input when tool calls are present
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Problem
OpenClaw normalizes
tool_resultblocks intorole:"user"messages with atool_resultcontent block. ThesliceLastTurnsByUserBoundaryfunction counts everyrole:"user"message as a turn boundary when slicing the retention/recall window, causing synthetictool_resultmessages to fill the window and exclude actual user text input from retained transcripts.Fix
Added a
hasRealTextContentguard tosliceLastTurnsByUserBoundary. Only user messages containing at least one non-emptytype:"text"block are counted as turn boundaries. Synthetictool_resultmessages are skipped.Testing