Builder

Struct Builder 

Source
pub struct Builder<W = Vec<u8>> { /* private fields */ }
Expand description

A builder for JSON values.

The builder accumulates JSON tokens and any associated payload into an internal byte buffer. Use the add_* methods to push values (or begin_*/end_* to create containers). When finished, call finish to obtain the serialized value.

Implementations§

Source§

impl Builder<Vec<u8>>

Source

pub fn new() -> Self

Creates a new Builder.

Source

pub fn with_capacity(capacity: usize) -> Self

Creates a new Builder with capacity.

Source§

impl<'a> Builder<&'a mut Vec<u8>>

Source

pub fn new(buffer: &'a mut Vec<u8>) -> Self

Creates a new Builder.

Source§

impl<W: AsMut<Vec<u8>>> Builder<W>

Source

pub fn add_null(&mut self)

Adds a null value to the builder.

Source

pub fn add_bool(&mut self, v: bool)

Adds a boolean value to the builder.

Source

pub fn add_u64(&mut self, v: u64)

Adds an u64 value to the builder.

Source

pub fn add_i64(&mut self, v: i64)

Adds an i64 value to the builder.

Source

pub fn add_f64(&mut self, v: f64)

Adds an f64 value to the builder.

Source

pub fn add_string(&mut self, v: &str)

Adds a string value to the builder.

Source

pub fn display(&mut self, v: impl Display)

Adds a string value that displays the given value to the builder.

Source

pub fn begin_array(&mut self)

Begins an array.

The caller then needs to push the elements and call end_array to finish the array.

Source

pub fn end_array(&mut self)

Ends an array.

Source

pub fn begin_object(&mut self)

Begins an object.

The caller then needs to push the keys and values in the following order:

key-1, value-1, key-2, value-2 ...

where each key must be a string.

Keys are allowed to be duplicated, but the last value will be used.

Finally end_object must be called to finish the object.

Source

pub fn end_object(&mut self)

Ends an object.

§Panics

Panics if:

  • there is an odd number of entries pushed since the paired begin_object.
  • any key is not a string.
Source

pub fn add_value(&mut self, value: ValueRef<'_>)

Adds a JSON value to the builder.

Source

pub fn pop(&mut self)

Pops the last value.

Source

pub fn rollback_to(&mut self, checkpoint: &Checkpoint)

Roll back the builder state to the given checkpoint.

This restores the internal buffer and stacks to the sizes recorded in checkpoint, effectively removing any data added after the checkpoint was created.

Only data added after the checkpoint will be removed. If the builder has already popped more items than recorded in the checkpoint, or if the checkpoint does not originate from this builder, the rollback may panic or leave the builder in an inconsistent state.

The following sequence is invalid and may panic for future manipulations.

let mut builder = jsonbb::Builder::<Vec<u8>>::new();
builder.begin_array();
builder.add_u64(1);
let checkpoint = builder.checkpoint();
builder.pop();
builder.add_u64(2);
builder.rollback_to(&checkpoint);
Source§

impl<W: AsRef<[u8]>> Builder<W>

Source

pub fn checkpoint(&self) -> Checkpoint

Creates a checkpoint of the current state.

Source§

impl Builder<Vec<u8>>

Source

pub fn capacity(&self) -> usize

Returns the capacity of the internal buffer, in bytes.

Source

pub fn finish(self) -> Value

Finishes building.

Source§

impl Builder<&mut Vec<u8>>

Source

pub fn finish(self)

Finishes building.

Trait Implementations§

Source§

impl<W: Clone> Clone for Builder<W>

Source§

fn clone(&self) -> Self

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<W> Debug for Builder<W>

Source§

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

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

impl Default for Builder<Vec<u8>>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<'de, W: AsMut<Vec<u8>>> DeserializeSeed<'de> for &mut Builder<W>

Source§

type Value = ()

The type produced by using this seed.
Source§

fn deserialize<D>(self, deserializer: D) -> Result<Self::Value, D::Error>
where D: Deserializer<'de>,

Equivalent to the more common Deserialize::deserialize method, except with some initial piece of data (the seed) passed in.
Source§

impl<W: AsMut<Vec<u8>>> SerializeMap for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_key<T>(&mut self, key: &T) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a map key. Read more
Source§

fn serialize_value<T>(&mut self, value: &T) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a map value. Read more
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a map.
Source§

fn serialize_entry<K, V>( &mut self, key: &K, value: &V, ) -> Result<(), Self::Error>
where K: Serialize + ?Sized, V: Serialize + ?Sized,

Serialize a map entry consisting of a key and a value. Read more
Source§

impl<W: AsMut<Vec<u8>>> SerializeSeq for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_element<T>(&mut self, value: &T) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a sequence element.
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a sequence.
Source§

impl<W: AsMut<Vec<u8>>> SerializeStruct for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_field<T>( &mut self, key: &'static str, value: &T, ) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a struct field.
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a struct.
Source§

fn skip_field(&mut self, key: &'static str) -> Result<(), Self::Error>

Indicate that a struct field has been skipped. Read more
Source§

impl<W: AsMut<Vec<u8>>> SerializeStructVariant for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_field<T>( &mut self, key: &'static str, value: &T, ) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a struct variant field.
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a struct variant.
Source§

fn skip_field(&mut self, key: &'static str) -> Result<(), Self::Error>

Indicate that a struct variant field has been skipped. Read more
Source§

impl<W: AsMut<Vec<u8>>> SerializeTuple for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_element<T>(&mut self, value: &T) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a tuple element.
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a tuple.
Source§

impl<W: AsMut<Vec<u8>>> SerializeTupleStruct for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_field<T>(&mut self, value: &T) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a tuple struct field.
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a tuple struct.
Source§

impl<W: AsMut<Vec<u8>>> SerializeTupleVariant for &mut Builder<W>

Source§

type Ok = ()

Must match the Ok type of our Serializer.
Source§

type Error = Error

Must match the Error type of our Serializer.
Source§

fn serialize_field<T>(&mut self, value: &T) -> Result<(), Self::Error>
where T: ?Sized + Serialize,

Serialize a tuple variant field.
Source§

fn end(self) -> Result<(), Self::Error>

Finish serializing a tuple variant.
Source§

impl<W: AsMut<Vec<u8>>> Serializer for &mut Builder<W>

Jsonbb is a data format.

Source§

type Ok = ()

The output type produced by this Serializer during successful serialization. Most serializers that produce text or binary output should set Ok = () and serialize into an io::Write or buffer contained within the Serializer instance. Serializers that build in-memory data structures may be simplified by using Ok to propagate the data structure around.
Source§

type Error = Error

The error type when some error occurs during serialization.
Source§

type SerializeSeq = &mut Builder<W>

Type returned from serialize_seq for serializing the content of the sequence.
Source§

type SerializeTuple = &mut Builder<W>

Type returned from serialize_tuple for serializing the content of the tuple.
Source§

type SerializeTupleStruct = &mut Builder<W>

Type returned from serialize_tuple_struct for serializing the content of the tuple struct.
Source§

type SerializeTupleVariant = &mut Builder<W>

Type returned from serialize_tuple_variant for serializing the content of the tuple variant.
Source§

type SerializeMap = &mut Builder<W>

Type returned from serialize_map for serializing the content of the map.
Source§

type SerializeStruct = &mut Builder<W>

Type returned from serialize_struct for serializing the content of the struct.
Source§

type SerializeStructVariant = &mut Builder<W>

Type returned from serialize_struct_variant for serializing the content of the struct variant.
Source§

fn serialize_bool(self, v: bool) -> Result<Self::Ok, Self::Error>

Serialize a bool value. Read more
Source§

fn serialize_i8(self, v: i8) -> Result<Self::Ok, Self::Error>

Serialize an i8 value. Read more
Source§

fn serialize_i16(self, v: i16) -> Result<Self::Ok, Self::Error>

Serialize an i16 value. Read more
Source§

fn serialize_i32(self, v: i32) -> Result<Self::Ok, Self::Error>

Serialize an i32 value. Read more
Source§

fn serialize_i64(self, v: i64) -> Result<Self::Ok, Self::Error>

Serialize an i64 value. Read more
Source§

fn serialize_i128(self, v: i128) -> Result<Self::Ok, Self::Error>

Serialize an i128 value. Read more
Source§

fn serialize_u8(self, v: u8) -> Result<Self::Ok, Self::Error>

Serialize a u8 value. Read more
Source§

fn serialize_u16(self, v: u16) -> Result<Self::Ok, Self::Error>

Serialize a u16 value. Read more
Source§

fn serialize_u32(self, v: u32) -> Result<Self::Ok, Self::Error>

Serialize a u32 value. Read more
Source§

fn serialize_u64(self, v: u64) -> Result<Self::Ok, Self::Error>

Serialize a u64 value. Read more
Source§

fn serialize_u128(self, v: u128) -> Result<Self::Ok, Self::Error>

Serialize a u128 value. Read more
Source§

fn serialize_f32(self, v: f32) -> Result<Self::Ok, Self::Error>

Serialize an f32 value. Read more
Source§

fn serialize_f64(self, v: f64) -> Result<Self::Ok, Self::Error>

Serialize an f64 value. Read more
Source§

fn serialize_char(self, v: char) -> Result<Self::Ok, Self::Error>

Serialize a character. Read more
Source§

fn serialize_str(self, v: &str) -> Result<Self::Ok, Self::Error>

Serialize a &str. Read more
Source§

fn serialize_bytes(self, v: &[u8]) -> Result<Self::Ok, Self::Error>

Serialize a chunk of raw byte data. Read more
Source§

fn serialize_none(self) -> Result<Self::Ok, Self::Error>

Serialize a None value. Read more
Source§

fn serialize_some<T>(self, value: &T) -> Result<Self::Ok, Self::Error>
where T: Serialize + ?Sized,

Serialize a Some(T) value. Read more
Source§

fn serialize_unit(self) -> Result<Self::Ok, Self::Error>

Serialize a () value. Read more
Source§

fn serialize_unit_struct( self, _name: &'static str, ) -> Result<Self::Ok, Self::Error>

Serialize a unit struct like struct Unit or PhantomData<T>. Read more
Source§

fn serialize_unit_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, ) -> Result<Self::Ok, Self::Error>

Serialize a unit variant like E::A in enum E { A, B }. Read more
Source§

fn serialize_newtype_struct<T>( self, _name: &'static str, value: &T, ) -> Result<Self::Ok, Self::Error>
where T: Serialize + ?Sized,

Serialize a newtype struct like struct Millimeters(u8). Read more
Source§

fn serialize_newtype_variant<T>( self, _name: &'static str, _variant_index: u32, variant: &'static str, value: &T, ) -> Result<Self::Ok, Self::Error>
where T: Serialize + ?Sized,

Serialize a newtype variant like E::N in enum E { N(u8) }. Read more
Source§

fn serialize_seq( self, _len: Option<usize>, ) -> Result<Self::SerializeSeq, Self::Error>

Begin to serialize a variably sized sequence. This call must be followed by zero or more calls to serialize_element, then a call to end. Read more
Source§

fn serialize_tuple( self, len: usize, ) -> Result<Self::SerializeTuple, Self::Error>

Begin to serialize a statically sized sequence whose length will be known at deserialization time without looking at the serialized data. This call must be followed by zero or more calls to serialize_element, then a call to end. Read more
Source§

fn serialize_tuple_struct( self, _name: &'static str, len: usize, ) -> Result<Self::SerializeTupleStruct, Self::Error>

Begin to serialize a tuple struct like struct Rgb(u8, u8, u8). This call must be followed by zero or more calls to serialize_field, then a call to end. Read more
Source§

fn serialize_tuple_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeTupleVariant, Self::Error>

Begin to serialize a tuple variant like E::T in enum E { T(u8, u8) }. This call must be followed by zero or more calls to serialize_field, then a call to end. Read more
Source§

fn serialize_map( self, _len: Option<usize>, ) -> Result<Self::SerializeMap, Self::Error>

Begin to serialize a map. This call must be followed by zero or more calls to serialize_key and serialize_value, then a call to end. Read more
Source§

fn serialize_struct( self, _name: &'static str, len: usize, ) -> Result<Self::SerializeStruct, Self::Error>

Begin to serialize a struct like struct Rgb { r: u8, g: u8, b: u8 }. This call must be followed by zero or more calls to serialize_field, then a call to end. Read more
Source§

fn serialize_struct_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeStructVariant, Self::Error>

Begin to serialize a struct variant like E::S in enum E { S { r: u8, g: u8, b: u8 } }. This call must be followed by zero or more calls to serialize_field, then a call to end. Read more
Source§

fn collect_str<T>(self, value: &T) -> Result<Self::Ok, Self::Error>
where T: ?Sized + Display,

Serialize a string produced by an implementation of Display. Read more
Source§

fn collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error>

Collect an iterator as a sequence. Read more
Source§

fn collect_map<K, V, I>(self, iter: I) -> Result<Self::Ok, Self::Error>
where K: Serialize, V: Serialize, I: IntoIterator<Item = (K, V)>,

Collect an iterator as a map. Read more
Source§

fn is_human_readable(&self) -> bool

Determine whether Serialize implementations should serialize in human-readable form. Read more

Auto Trait Implementations§

§

impl<W> Freeze for Builder<W>
where W: Freeze,

§

impl<W> RefUnwindSafe for Builder<W>
where W: RefUnwindSafe,

§

impl<W> Send for Builder<W>
where W: Send,

§

impl<W> Sync for Builder<W>
where W: Sync,

§

impl<W> Unpin for Builder<W>
where W: Unpin,

§

impl<W> UnwindSafe for Builder<W>
where W: 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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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.