PromptRequest

Struct PromptRequest 

Source
pub struct PromptRequest<'a, S: PromptType, M: CompletionModel> { /* private fields */ }
Expand description

A builder for creating prompt requests with customizable options. Uses generics to track which options have been set during the build process.

If you expect to continuously call tools, you will want to ensure you use the .multi_turn() argument to add more turns as by default, it is 0 (meaning only 1 tool round-trip). Otherwise, attempting to await (which will send the prompt request) can potentially return crate::completion::request::PromptError::MaxDepthError if the agent decides to call tools back to back.

Implementations§

Source§

impl<'a, M: CompletionModel> PromptRequest<'a, Standard, M>

Source

pub fn new(agent: &'a Agent<M>, prompt: impl Into<Message>) -> Self

Create a new PromptRequest with the given prompt and model

Source

pub fn extended_details(self) -> PromptRequest<'a, Extended, M>

Enable returning extended details for responses (includes aggregated token usage)

Note: This changes the type of the response from .send to return a PromptResponse struct instead of a simple String. This is useful for tracking token usage across multiple turns of conversation.

Source§

impl<'a, S: PromptType, M: CompletionModel> PromptRequest<'a, S, M>

Source

pub fn multi_turn(self, depth: usize) -> PromptRequest<'a, S, M>

Set the maximum depth for multi-turn conversations (ie, the maximum number of turns an LLM can have calling tools before writing a text response). If the maximum turn number is exceeded, it will return a crate::completion::request::PromptError::MaxDepthError.

Source

pub fn with_history( self, history: &'a mut Vec<Message>, ) -> PromptRequest<'a, S, M>

Add chat history to the prompt request

Trait Implementations§

Source§

impl<'a, M: CompletionModel> IntoFuture for PromptRequest<'a, Extended, M>

Source§

type Output = Result<PromptResponse, PromptError>

The output that the future will produce on completion.
Source§

type IntoFuture = Pin<Box<dyn Future<Output = <PromptRequest<'a, Extended, M> as IntoFuture>::Output> + Send + 'a>>

Which kind of future are we turning this into?
Source§

fn into_future(self) -> Self::IntoFuture

Creates a future from a value. Read more
Source§

impl<'a, M: CompletionModel> IntoFuture for PromptRequest<'a, Standard, M>

Due to: RFC 2515, we have to use a BoxFuture for the IntoFuture implementation. In the future, we should be able to use impl Future<...> directly via the associated type.

Source§

type Output = Result<String, PromptError>

The output that the future will produce on completion.
Source§

type IntoFuture = Pin<Box<dyn Future<Output = <PromptRequest<'a, Standard, M> as IntoFuture>::Output> + Send + 'a>>

Which kind of future are we turning this into?
Source§

fn into_future(self) -> Self::IntoFuture

Creates a future from a value. Read more

Auto Trait Implementations§

§

impl<'a, S, M> Freeze for PromptRequest<'a, S, M>

§

impl<'a, S, M> !RefUnwindSafe for PromptRequest<'a, S, M>

§

impl<'a, S, M> Send for PromptRequest<'a, S, M>
where S: Send,

§

impl<'a, S, M> Sync for PromptRequest<'a, S, M>
where S: Sync,

§

impl<'a, S, M> Unpin for PromptRequest<'a, S, M>
where S: Unpin,

§

impl<'a, S, M> !UnwindSafe for PromptRequest<'a, S, M>

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

impl<T> ErasedDestructor for T
where T: 'static,