Skip to main content

StrategyCompactor

Struct StrategyCompactor 

Source
pub struct StrategyCompactor { /* private fields */ }
Expand description

A reusable Compactor that bundles a trigger closure with a CompactionStrategy (often a CompactionPipeline) and an optional CompactionBackend. Use this when your trigger logic is a simple predicate over the transcript; implement Compactor directly when you need richer state (token meters, atomics, etc.).

§Example

use agentkit_compaction::{
    CompactionPipeline, CompactionReason, DropReasoningStrategy,
    KeepRecentStrategy, StrategyCompactor,
};
use agentkit_core::ItemKind;

let compactor = StrategyCompactor::new(
    |transcript: &[_], _point| {
        (transcript.len() > 32).then_some(CompactionReason::TranscriptTooLong)
    },
    CompactionPipeline::new()
        .with_strategy(DropReasoningStrategy::new())
        .with_strategy(
            KeepRecentStrategy::new(24)
                .preserve_kind(ItemKind::System)
                .preserve_kind(ItemKind::Context),
        ),
);

Implementations§

Source§

impl StrategyCompactor

Source

pub fn new<T, S>(trigger: T, strategy: S) -> Self
where T: Fn(&[Item], MutationPoint) -> Option<CompactionReason> + Send + Sync + 'static, S: CompactionStrategy + 'static,

Create a new compactor from a trigger closure and a strategy.

The trigger receives the current transcript and MutationPoint and returns Some(reason) to fire compaction.

Source

pub fn builder() -> StrategyCompactorBuilder

Start a builder for StrategyCompactor.

Source

pub fn with_backend(self, backend: impl CompactionBackend + 'static) -> Self

Attach a CompactionBackend for strategies that require summarisation (e.g. SummarizeOlderStrategy).

Source

pub fn with_shared_backend(self, backend: Arc<dyn CompactionBackend>) -> Self

Reuse an existing Arc<dyn CompactionBackend> (e.g. one already shared elsewhere) without re-wrapping.

Source

pub fn with_metadata(self, metadata: MetadataMap) -> Self

Set metadata forwarded to every strategy invocation.

Trait Implementations§

Source§

impl Compactor for StrategyCompactor

Source§

fn should_compact( &self, transcript: &[Item], point: MutationPoint, ) -> Option<CompactionReason>

Decide whether to compact based on the current transcript and mutation point. Returning None is a no-op.
Source§

fn compact<'life0, 'life1, 'async_trait>( &'life0 self, transcript: &'life1 [Item], reason: CompactionReason, cancellation: Option<TurnCancellation>, ) -> Pin<Box<dyn Future<Output = Result<Vec<Item>, CompactionError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Produce the replacement transcript. Called only after should_compact returns Some. Implementations should respect cancellation.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more