[][src]Struct serde_cbor::Serializer

pub struct Serializer<W> { /* fields omitted */ }

A structure for serializing Rust values to CBOR.

Methods

impl<W> Serializer<W> where
    W: Write
[src]

pub fn new(writer: W) -> Self[src]

Creates a new CBOR serializer.

to_vec and to_writer should normally be used instead of this method.

pub fn packed_format(self) -> Self[src]

Choose concise/packed format for serializer.

In the packed format enum variant names and field names are replaced with numeric indizes to conserve space.

pub fn legacy_enums(self) -> Self[src]

Enable old enum format used by serde_cbor versions <= v0.9.

The legacy_enums option determines how enums are encoded.

This makes no difference when encoding and decoding enums using this crate, but it shows up when decoding to a Value or decoding in other languages.

Examples

Given the following enum

enum Enum {
    Unit,
    NewType(i32),
    Tuple(String, bool),
    Struct{ x: i32, y: i32 },
}

we will give the Value with the same encoding for each case using JSON notation.

Default encodings

  • Enum::Unit encodes as "Unit"
  • Enum::NewType(10) encodes as {"NewType": 10}
  • Enum::Tuple("x", true) encodes as {"Tuple": ["x", true]}

Legacy encodings

  • Enum::Unit encodes as "Unit"
  • Enum::NewType(10) encodes as ["NewType", 10]
  • Enum::Tuple("x", true) encodes as ["Tuple", "x", true]
  • Enum::Struct{ x: 5, y: -5 } encodes as ["Struct", {"x": 5, "y": -5}]

pub fn self_describe(&mut self) -> Result<()>[src]

Writes a CBOR self-describe tag to the stream.

Tagging allows a decoder to distinguish different file formats based on their content without further information.

pub fn into_inner(self) -> W[src]

Unwrap the Writer from the Serializer.

Trait Implementations

impl<W: Debug> Debug for Serializer<W>[src]

impl<'a, W> Serializer for &'a mut Serializer<W> where
    W: Write
[src]

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. Read more

type Error = Error

The error type when some error occurs during serialization.

type SerializeSeq = CollectionSerializer<'a, W>

Type returned from [serialize_seq] for serializing the content of the sequence. Read more

type SerializeTuple = &'a mut Serializer<W>

Type returned from [serialize_tuple] for serializing the content of the tuple. Read more

type SerializeTupleStruct = &'a mut Serializer<W>

Type returned from [serialize_tuple_struct] for serializing the content of the tuple struct. Read more

type SerializeTupleVariant = &'a mut Serializer<W>

Type returned from [serialize_tuple_variant] for serializing the content of the tuple variant. Read more

type SerializeMap = CollectionSerializer<'a, W>

Type returned from [serialize_map] for serializing the content of the map. Read more

type SerializeStruct = StructSerializer<'a, W>

Type returned from [serialize_struct] for serializing the content of the struct. Read more

type SerializeStructVariant = StructSerializer<'a, W>

Type returned from [serialize_struct_variant] for serializing the content of the struct variant. Read more

impl<'a, W> SerializeTuple for &'a mut Serializer<W> where
    W: Write
[src]

type Ok = ()

Must match the Ok type of our Serializer.

type Error = Error

Must match the Error type of our Serializer.

impl<'a, W> SerializeTupleVariant for &'a mut Serializer<W> where
    W: Write
[src]

type Ok = ()

Must match the Ok type of our Serializer.

type Error = Error

Must match the Error type of our Serializer.

impl<'a, W> SerializeTupleStruct for &'a mut Serializer<W> where
    W: Write
[src]

type Ok = ()

Must match the Ok type of our Serializer.

type Error = Error

Must match the Error type of our Serializer.

Auto Trait Implementations

impl<W> Send for Serializer<W> where
    W: Send

impl<W> Unpin for Serializer<W> where
    W: Unpin

impl<W> Sync for Serializer<W> where
    W: Sync

impl<W> UnwindSafe for Serializer<W> where
    W: UnwindSafe

impl<W> RefUnwindSafe for Serializer<W> where
    W: RefUnwindSafe

Blanket Implementations

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]