mod encoder;
mod error;
use crate::flat::filler::Filler;
#[cfg(feature = "num-bigint")]
use num_bigint::BigInt;
pub use encoder::Encoder;
pub use error::Error;
pub trait Encode {
fn encode(&self, e: &mut Encoder) -> Result<(), Error>;
}
impl Encode for bool {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.bool(*self);
Ok(())
}
}
impl Encode for u8 {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.u8(*self)?;
Ok(())
}
}
#[cfg(feature = "num-bigint")]
impl Encode for BigInt {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.big_integer(self.clone());
Ok(())
}
}
impl Encode for isize {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.integer(*self);
Ok(())
}
}
impl Encode for usize {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.word(*self);
Ok(())
}
}
impl Encode for char {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.char(*self);
Ok(())
}
}
impl Encode for &str {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.utf8(self)?;
Ok(())
}
}
impl Encode for String {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.utf8(self)?;
Ok(())
}
}
impl Encode for Vec<u8> {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.bytes(self)?;
Ok(())
}
}
impl Encode for &[u8] {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.bytes(self)?;
Ok(())
}
}
impl<T: Encode> Encode for Box<T> {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
self.as_ref().encode(e)?;
Ok(())
}
}
impl Encode for Filler {
fn encode(&self, e: &mut Encoder) -> Result<(), Error> {
e.filler();
Ok(())
}
}