Skip to main content

TurnOutcome

Enum TurnOutcome 

Source
pub enum TurnOutcome {
    NeedsMoreTurns {
        turn: usize,
        turn_usage: TokenUsage,
        total_usage: TokenUsage,
        summary: TurnSummary,
    },
    Done {
        total_turns: u32,
        total_usage: TokenUsage,
        summary: TurnSummary,
    },
    AwaitingConfirmation {
        tool_call_id: String,
        tool_name: String,
        display_name: String,
        input: Value,
        description: String,
        continuation: Box<ContinuationEnvelope>,
        summary: TurnSummary,
    },
    Refusal {
        total_turns: u32,
        total_usage: TokenUsage,
        summary: TurnSummary,
    },
    Cancelled {
        total_turns: u32,
        total_usage: TokenUsage,
        summary: TurnSummary,
    },
    Error(AgentError),
    PendingToolCalls {
        turn: usize,
        turn_usage: TokenUsage,
        total_usage: TokenUsage,
        tool_calls: Vec<PendingToolCallInfo>,
        continuation: Box<ContinuationEnvelope>,
        summary: TurnSummary,
    },
}
Expand description

Outcome of running a single turn.

This is returned by run_turn to indicate what happened and what to do next.

§Server-facing contract

Every terminal variant (everything except TurnOutcome::Error) carries a TurnSummary with the provider/model/stop-reason/response-id/usage provenance that later server phases need to durably persist. Matching by field name continues to work because the legacy variant fields are preserved alongside the new summary field.

Variants§

§

NeedsMoreTurns

Turn completed successfully, but more turns are needed.

Tools were executed and their results are stored in the message history. Call run_turn again with AgentInput::Continue to proceed.

Fields

§turn: usize

The turn number that just completed

§turn_usage: TokenUsage

Token usage for this turn

§total_usage: TokenUsage

Cumulative token usage so far

§summary: TurnSummary

Structured server-facing outcome metadata.

§

Done

Agent completed successfully (no more tool calls).

Fields

§total_turns: u32

Total turns executed

§total_usage: TokenUsage

Cumulative token usage

§summary: TurnSummary

Structured server-facing outcome metadata.

§

AwaitingConfirmation

A tool requires user confirmation.

Present this to the user and call run_turn with AgentInput::Resume to continue.

Fields

§tool_call_id: String

ID of the pending tool call (from LLM)

§tool_name: String

Tool name string (for LLM protocol)

§display_name: String

Human-readable display name

§input: Value

Tool input parameters

§description: String

Description of what confirmation is needed

§continuation: Box<ContinuationEnvelope>

Versioned continuation envelope for resuming.

§summary: TurnSummary

Structured server-facing outcome metadata.

§

Refusal

Model refused the request (safety/policy).

Fields

§total_turns: u32

Total turns executed

§total_usage: TokenUsage

Cumulative token usage

§summary: TurnSummary

Structured server-facing outcome metadata.

§

Cancelled

The turn was cancelled via a cancellation token.

Fields

§total_turns: u32

Total turns executed before cancellation

§total_usage: TokenUsage

Cumulative token usage

§summary: TurnSummary

Structured server-facing outcome metadata.

§

Error(AgentError)

An error occurred.

No TurnSummary is attached because the error may have occurred before the turn produced any durable LLM provenance.

§

PendingToolCalls

Tool calls are ready for external execution.

Only returned when ToolRuntime::External is set in TurnOptions. The caller is responsible for executing the tool calls and resuming with AgentInput::SubmitToolResults, providing one ExternalToolResult for each pending tool call.

The continuation must be passed back unmodified — it carries the turn identity, token usage, and agent state needed to validate and apply the results.

Fields

§turn: usize

The turn number that produced these tool calls

§turn_usage: TokenUsage

Token usage for this turn’s LLM call

§total_usage: TokenUsage

Cumulative token usage so far

§tool_calls: Vec<PendingToolCallInfo>

Tool calls to execute externally

§continuation: Box<ContinuationEnvelope>

Versioned continuation envelope for resuming after external tool execution.

§summary: TurnSummary

Structured server-facing outcome metadata.

Implementations§

Source§

impl TurnOutcome

Source

pub const fn summary(&self) -> Option<&TurnSummary>

Returns the attached TurnSummary, if the variant carries one.

Present on every variant except TurnOutcome::Error.

Trait Implementations§

Source§

impl Debug for TurnOutcome

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more

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> FutureExt for T

Source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
Source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,