Skip to main content

ClaudeClient

Struct ClaudeClient 

Source
pub struct ClaudeClient<R: CommandRunner = DefaultRunner> { /* private fields */ }
Expand description

Claude Code CLI client.

Implementations§

Source§

impl ClaudeClient

Source

pub fn new(config: ClaudeConfig) -> Self

Creates a new client with the default DefaultRunner.

Source§

impl ClaudeClient

Source

pub async fn ask_stream( &self, prompt: &str, ) -> Result<Pin<Box<dyn Stream<Item = Result<StreamEvent, ClaudeError>> + Send>>, ClaudeError>

Available on crate feature stream only.

Sends a prompt and returns a stream of events.

Spawns the CLI with --output-format stream-json and streams events in real-time. The stream ends with a StreamEvent::Result on success.

For real-time token-level streaming, enable crate::ClaudeConfigBuilder::include_partial_messages. This produces StreamEvent::Text / StreamEvent::Thinking delta chunks. Without it, only complete StreamEvent::AssistantText / StreamEvent::AssistantThinking messages are emitted.

Use crate::ClaudeConfigBuilder::stream_idle_timeout to set an idle timeout. If no event arrives within the specified duration, the stream yields ClaudeError::Timeout and terminates.

Source§

impl<R: CommandRunner> ClaudeClient<R>

Source

pub fn with_runner(config: ClaudeConfig, runner: R) -> Self

Creates a new client with a custom CommandRunner for testing.

Source

pub async fn ask_structured<T: DeserializeOwned>( &self, prompt: &str, ) -> Result<T, ClaudeError>

Sends a prompt and deserializes the result into T.

Requires json_schema to be set on the config beforehand. Use generate_schema to auto-generate it (requires the structured feature).

Source

pub async fn ask(&self, prompt: &str) -> Result<ClaudeResponse, ClaudeError>

Sends a prompt and returns the response.

Source§

impl<R: CommandRunner + Clone> ClaudeClient<R>

Source

pub fn conversation(&self) -> Conversation<R>

Creates a new Conversation for multi-turn interaction.

The conversation manages session_id automatically, injecting --resume from the second turn onwards.

Callers must set crate::ClaudeConfigBuilder::no_session_persistence(false) for multi-turn to work.

Source

pub fn conversation_resume( &self, session_id: impl Into<String>, ) -> Conversation<R>

Creates a Conversation that resumes an existing session.

The first ask() / ask_stream() call will include --resume with the given session ID.

Trait Implementations§

Source§

impl<R: Clone + CommandRunner> Clone for ClaudeClient<R>

Source§

fn clone(&self) -> ClaudeClient<R>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<R: Debug + CommandRunner> Debug for ClaudeClient<R>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<R> Freeze for ClaudeClient<R>
where R: Freeze,

§

impl<R> RefUnwindSafe for ClaudeClient<R>
where R: RefUnwindSafe,

§

impl<R> Send for ClaudeClient<R>

§

impl<R> Sync for ClaudeClient<R>

§

impl<R> Unpin for ClaudeClient<R>
where R: Unpin,

§

impl<R> UnsafeUnpin for ClaudeClient<R>
where R: UnsafeUnpin,

§

impl<R> UnwindSafe for ClaudeClient<R>
where R: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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