Skip to content

SlidingWindowConversationManager

Defined in: src/conversation-manager/sliding-window-conversation-manager.ts:43

Implements a sliding window strategy for managing conversation history.

This class handles the logic of maintaining a conversation window that preserves tool usage pairs and avoids invalid window states. When the message count exceeds the window size, it will either truncate large tool results or remove the oldest messages while ensuring tool use/result pairs remain valid.

As a Plugin, it registers callbacks for:

  • AfterInvocationEvent: Applies sliding window management after each invocation
  • AfterModelCallEvent: Reduces context on overflow errors and requests retry
new SlidingWindowConversationManager(config?): SlidingWindowConversationManager;

Defined in: src/conversation-manager/sliding-window-conversation-manager.ts:59

Initialize the sliding window conversation manager.

ParameterTypeDescription
config?SlidingWindowConversationManagerConfigConfiguration options for the sliding window manager.

SlidingWindowConversationManager

Plugin.constructor

get name(): string;

Defined in: src/conversation-manager/sliding-window-conversation-manager.ts:50

Unique identifier for this plugin.

string

Plugin.name

initAgent(agent): void;

Defined in: src/conversation-manager/sliding-window-conversation-manager.ts:74

Initialize the plugin by registering hooks with the agent.

Registers:

  • AfterInvocationEvent callback to apply sliding window management
  • AfterModelCallEvent callback to handle context overflow and request retry
ParameterTypeDescription
agentAgentDataThe agent to register hooks with

void

Plugin.initAgent


getTools(): Tool[];

Defined in: src/plugins/plugin.ts:82

Returns tools provided by this plugin for auto-registration. Override to provide plugin-specific tools.

Tool[]

Array of tools to register with the agent

Plugin.getTools