Skip to main content

StreamingPromptRequest

Struct StreamingPromptRequest 

Source
pub struct StreamingPromptRequest<M, P>
where M: CompletionModel, P: PromptHook<M> + 'static,
{ /* 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::MaxTurnsError if the agent decides to call tools back to back.

Implementations§

Source§

impl<M, P> StreamingPromptRequest<M, P>

Source

pub fn new( agent: Arc<Agent<M>>, prompt: impl Into<Message>, ) -> StreamingPromptRequest<M, ()>

Create a new StreamingPromptRequest with the given prompt and model. Note: This creates a request without an agent hook. Use from_agent to include the agent’s hook.

Source

pub fn from_agent<P2>( agent: &Agent<M, P2>, prompt: impl Into<Message>, ) -> StreamingPromptRequest<M, P2>
where P2: PromptHook<M>,

Create a new StreamingPromptRequest from an agent, cloning the agent’s data and default hook.

Source

pub fn multi_turn(self, turns: usize) -> Self

Set the maximum Turns 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::MaxTurnsError.

Source

pub fn with_history(self, history: Vec<Message>) -> Self

Add chat history to the prompt request.

When history is provided, the final FinalResponse will include the updated chat history (original messages + new user prompt + assistant response).

let mut stream = agent
    .stream_prompt("Hello")
    .with_history(vec![])
    .await;
// ... consume stream ...
// Access updated history from FinalResponse::history()
Source

pub fn with_hook<P2>(self, hook: P2) -> StreamingPromptRequest<M, P2>
where P2: PromptHook<M>,

Attach a per-request hook for tool call events. This overrides any default hook set on the agent.

Trait Implementations§

Source§

impl<M, P> IntoFuture for StreamingPromptRequest<M, P>
where M: CompletionModel + 'static, <M as CompletionModel>::StreamingResponse: WasmCompatSend, P: PromptHook<M> + 'static,

Source§

type Output = Pin<Box<dyn Stream<Item = Result<MultiTurnStreamItem<<M as CompletionModel>::StreamingResponse>, StreamingError>> + Send>>

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

type IntoFuture = Pin<Box<dyn Future<Output = <StreamingPromptRequest<M, P> as IntoFuture>::Output> + Send>>

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<M, P> Freeze for StreamingPromptRequest<M, P>
where P: Freeze,

§

impl<M, P> !RefUnwindSafe for StreamingPromptRequest<M, P>

§

impl<M, P> Send for StreamingPromptRequest<M, P>

§

impl<M, P> Sync for StreamingPromptRequest<M, P>

§

impl<M, P> Unpin for StreamingPromptRequest<M, P>
where P: Unpin,

§

impl<M, P> UnsafeUnpin for StreamingPromptRequest<M, P>
where P: UnsafeUnpin,

§

impl<M, P> !UnwindSafe for StreamingPromptRequest<M, P>

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

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
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<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> WasmCompatSend for T
where T: Send,

Source§

impl<T> WasmCompatSync for T
where T: Sync,