multiversx_sc_codec/single/
top_de_input.rsuse crate::{
num_conv::{universal_decode_number, universal_decode_number_unchecked},
transmute::vec_into_boxed_slice,
DecodeError, DecodeErrorHandler, NestedDecodeInput, OwnedBytesNestedDecodeInput, TryStaticCast,
};
use alloc::{boxed::Box, vec::Vec};
pub trait TopDecodeInput: Sized {
type NestedBuffer: NestedDecodeInput;
fn byte_len(&self) -> usize;
fn into_boxed_slice_u8(self) -> Box<[u8]>;
#[deprecated(
since = "0.48.1",
note = "Please use method `into_max_size_buffer_align_right` instead."
)]
fn into_max_size_buffer<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<&[u8], H::HandledErr>
where
H: DecodeErrorHandler;
fn into_max_size_buffer_align_right<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<usize, H::HandledErr>
where
H: DecodeErrorHandler;
fn into_u64<H>(self, h: H) -> Result<u64, H::HandledErr>
where
H: DecodeErrorHandler,
{
let mut buffer = [0u8; 8];
let _ = self.into_max_size_buffer_align_right(&mut buffer, h)?;
Ok(u64::from_be_bytes(buffer))
}
fn into_i64<H>(self, h: H) -> Result<i64, H::HandledErr>
where
H: DecodeErrorHandler,
{
let mut buffer = [0u8; 8];
let len = self.into_max_size_buffer_align_right(&mut buffer, h)?;
Ok(universal_decode_number_unchecked(&buffer[8 - len..], true) as i64)
}
#[inline]
fn supports_specialized_type<T: TryStaticCast>() -> bool {
false
}
fn into_specialized<T, H>(self, h: H) -> Result<T, H::HandledErr>
where
T: TryStaticCast,
H: DecodeErrorHandler,
{
Err(h.handle_error(DecodeError::UNSUPPORTED_OPERATION))
}
fn into_nested_buffer(self) -> Self::NestedBuffer;
}
impl TopDecodeInput for Box<[u8]> {
type NestedBuffer = OwnedBytesNestedDecodeInput;
fn byte_len(&self) -> usize {
self.len()
}
fn into_boxed_slice_u8(self) -> Box<[u8]> {
self
}
#[allow(deprecated)]
fn into_max_size_buffer<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<&[u8], H::HandledErr>
where
H: DecodeErrorHandler,
{
(&*self).into_max_size_buffer(buffer, h)
}
fn into_max_size_buffer_align_right<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<usize, H::HandledErr>
where
H: DecodeErrorHandler,
{
(&*self).into_max_size_buffer_align_right(buffer, h)
}
fn into_nested_buffer(self) -> Self::NestedBuffer {
OwnedBytesNestedDecodeInput::new(self)
}
}
impl TopDecodeInput for Vec<u8> {
type NestedBuffer = OwnedBytesNestedDecodeInput;
fn byte_len(&self) -> usize {
self.len()
}
fn into_boxed_slice_u8(self) -> Box<[u8]> {
vec_into_boxed_slice(self)
}
#[allow(deprecated)]
fn into_max_size_buffer<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<&[u8], H::HandledErr>
where
H: DecodeErrorHandler,
{
self.as_slice().into_max_size_buffer(buffer, h)
}
fn into_max_size_buffer_align_right<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<usize, H::HandledErr>
where
H: DecodeErrorHandler,
{
self.as_slice().into_max_size_buffer_align_right(buffer, h)
}
fn into_nested_buffer(self) -> Self::NestedBuffer {
OwnedBytesNestedDecodeInput::new(self.into_boxed_slice())
}
}
impl<'a> TopDecodeInput for &'a [u8] {
type NestedBuffer = &'a [u8];
fn byte_len(&self) -> usize {
self.len()
}
fn into_boxed_slice_u8(self) -> Box<[u8]> {
Box::from(self)
}
fn into_max_size_buffer<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<&[u8], H::HandledErr>
where
H: DecodeErrorHandler,
{
let l = self.len();
if l > MAX_LEN {
return Err(h.handle_error(DecodeError::INPUT_TOO_LONG));
}
buffer[..l].copy_from_slice(self);
Ok(&buffer[..l])
}
fn into_max_size_buffer_align_right<H, const MAX_LEN: usize>(
self,
buffer: &mut [u8; MAX_LEN],
h: H,
) -> Result<usize, H::HandledErr>
where
H: DecodeErrorHandler,
{
let len = self.len();
if len > MAX_LEN {
return Err(h.handle_error(DecodeError::INPUT_TOO_LONG));
}
let target_start = MAX_LEN - len;
let byte_slice = &mut buffer[target_start..];
byte_slice.copy_from_slice(self);
Ok(len)
}
#[inline]
fn into_u64<H>(self, _h: H) -> Result<u64, H::HandledErr>
where
H: DecodeErrorHandler,
{
Ok(universal_decode_number(self, false))
}
#[inline]
fn into_i64<H>(self, _h: H) -> Result<i64, H::HandledErr>
where
H: DecodeErrorHandler,
{
Ok(universal_decode_number(self, true) as i64)
}
fn into_nested_buffer(self) -> Self::NestedBuffer {
self
}
}