#[cfg(feature = "alloc")]
mod alloc;
mod packed;
pub use self::packed::Packed;
use crate::de::{Decode, Decoder, SequenceDecoder};
use crate::en::{Encode, Encoder, SequenceEncoder};
use crate::mode::Mode;
use crate::Context;
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[repr(transparent)]
pub struct Sequence<T>(pub T);
impl<T> Sequence<T> {
pub const fn new(value: T) -> Self {
Self(value)
}
}
impl<M, T> Encode<M> for Sequence<&'_ [T]>
where
M: Mode,
T: Encode<M>,
{
#[inline]
fn encode<C, E>(&self, cx: &mut C, encoder: E) -> Result<E::Ok, C::Error>
where
C: Context<Input = E::Error>,
E: Encoder,
{
let mut seq = encoder.encode_sequence(cx, self.0.len())?;
for (index, value) in self.0.iter().enumerate() {
cx.enter_sequence_index(index);
let encoder = seq.next(cx)?;
T::encode(value, cx, encoder)?;
cx.leave_sequence_index();
}
seq.end(cx)
}
}
impl<M> Encode<M> for Sequence<()>
where
M: Mode,
{
#[inline]
fn encode<C, E>(&self, cx: &mut C, encoder: E) -> Result<E::Ok, C::Error>
where
C: Context<Input = E::Error>,
E: Encoder,
{
encoder.encode_sequence(cx, 0)?.end(cx)
}
}
impl<'de, M> Decode<'de, M> for Sequence<()>
where
M: Mode,
{
fn decode<C, D>(cx: &mut C, decoder: D) -> Result<Self, C::Error>
where
C: Context<Input = D::Error>,
D: Decoder<'de>,
{
let seq = decoder.decode_sequence(cx)?;
seq.end(cx)?;
Ok(Self(()))
}
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[repr(transparent)]
pub struct Bytes<T>(pub T);
impl<const N: usize, M> Encode<M> for Bytes<[u8; N]>
where
M: Mode,
{
#[inline]
fn encode<C, E>(&self, cx: &mut C, encoder: E) -> Result<E::Ok, C::Error>
where
C: Context<Input = E::Error>,
E: Encoder,
{
encoder.encode_array(cx, self.0)
}
}
impl<'de, M, const N: usize> Decode<'de, M> for Bytes<[u8; N]>
where
M: Mode,
{
#[inline]
fn decode<C, D>(cx: &mut C, decoder: D) -> Result<Self, C::Error>
where
C: Context<Input = D::Error>,
D: Decoder<'de>,
{
decoder.decode_array(cx).map(Self)
}
}