Skip to main content

AgentError

Enum AgentError 

Source
pub enum AgentError {
    ProcessFailed {
        exit_code: i32,
        stderr: String,
    },
    SchemaValidation {
        expected: String,
        got: String,
        debug_messages: Vec<DebugMessage>,
        partial_usage: Box<PartialUsage>,
        raw_response: Option<String>,
    },
    PromptTooLarge {
        chars: usize,
        estimated_tokens: usize,
        model_limit: usize,
    },
    Timeout {
        limit: Duration,
    },
}
Expand description

Error specific to agent (AI provider) invocations.

Returned by AgentProvider::invoke and automatically wrapped into OperationError::Agent when propagated with ?.

Variants§

§

ProcessFailed

The agent process exited with a non-zero status code.

Fields

§exit_code: i32

Process exit code, or -1 if spawning failed.

§stderr: String

Captured stderr.

§

SchemaValidation

The agent output did not match the expected schema.

Fields

§expected: String

What was expected (e.g. "structured_output field").

§got: String

What was actually received.

§debug_messages: Vec<DebugMessage>

Verbose conversation trace captured before the validation failure.

Populated when the agent ran in verbose (stream-json) mode so that callers can persist the debug trail even on error paths.

§partial_usage: Box<PartialUsage>

Partial usage data from the CLI response, available even though structured output extraction failed. Boxed to keep AgentError small on the stack.

§raw_response: Option<String>

Raw text response from the agent, truncated to ~4000 bytes.

When structured output extraction fails, the model may still have produced useful text in the result field. This captures it so callers can persist it for debugging (e.g. in the step output).

§

PromptTooLarge

The prompt exceeds the model’s context window.

Returned before spawning the process when the estimated token count exceeds the model’s known limit.

  • chars - number of characters in the combined prompt (system + user).
  • estimated_tokens - approximate token count (chars / 4).
  • model_limit - the model’s context window in tokens.

Fields

§chars: usize

Number of characters in the prompt.

§estimated_tokens: usize

Estimated token count (chars / 4 heuristic).

§model_limit: usize

Model’s context window in tokens.

§

Timeout

The agent did not complete within the configured timeout.

Fields

§limit: Duration

The Duration that was exceeded.

Trait Implementations§

Source§

impl Debug for AgentError

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Display for AgentError

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Error for AgentError

1.30.0 · Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<AgentError> for OperationError

Source§

fn from(source: AgentError) -> Self

Converts to this type from the input type.

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> 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T> ToStringFallible for T
where T: Display,

Source§

fn try_to_string(&self) -> Result<String, TryReserveError>

ToString::to_string, but without panic on OOM.

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