Skip to main content

JsonStreamBuffer

Struct JsonStreamBuffer 

Source
pub struct JsonStreamBuffer { /* private fields */ }
Expand description

Incremental JSON stream parser for buffering and parsing newline-delimited JSON.

Accumulates input chunks and attempts to parse complete JSON values. Handles cases where JSON objects span multiple lines or chunks.

§Buffer overflow protection

If the buffer exceeds max_buffer_size bytes, a CLIJSONDecodeError is returned and the buffer is cleared.

Implementations§

Source§

impl JsonStreamBuffer

Source

pub fn new(max_buffer_size: usize) -> Self

Creates a new JsonStreamBuffer with the given maximum buffer size.

§Example
use claude_code::JsonStreamBuffer;

let _buffer = JsonStreamBuffer::new(1024 * 1024);
Source

pub fn push_chunk( &mut self, chunk: &str, ) -> Result<Vec<Value>, CLIJSONDecodeError>

Pushes a chunk of data into the buffer and returns any complete JSON values.

The chunk is split by newlines, and each line is appended to the internal buffer. After each line, the buffer is tested for valid JSON. If it parses successfully, the value is collected and the buffer is cleared for the next message.

§Returns

A Vec<Value> of all complete JSON values parsed from this chunk.

§Errors

Returns CLIJSONDecodeError if the buffer exceeds the maximum size.

§Example
use claude_code::JsonStreamBuffer;

let mut buffer = JsonStreamBuffer::new(1024);
let parsed = buffer.push_chunk("{\"type\":\"system\"}\n").unwrap();
assert_eq!(parsed.len(), 1);

Trait Implementations§

Source§

impl Clone for JsonStreamBuffer

Source§

fn clone(&self) -> JsonStreamBuffer

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 Debug for JsonStreamBuffer

Source§

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

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