Struct rasn::error::DecodeError

source ·
pub struct DecodeError {
    pub kind: Box<DecodeErrorKind>,
    pub codec: Codec,
    pub backtrace: Backtrace,
}
Expand description

An error type for failed decoding for every decoder. Abstracts over the different generic and codec-specific errors.

kind field is used to determine the kind of error that occurred. codec field is used to determine the codec that failed. backtrace field is used to determine the backtrace of the error.

There is Kind::CodecSpecific variant which wraps the codec-specific errors as CodecEncodeError type.

§Example

use nom::Needed;
use rasn::codec::Codec;
use rasn::error::DecodeErrorKind;
use rasn::prelude::*;

#[derive(AsnType, Clone, Debug, Decode, Encode, PartialEq)]
#[rasn(delegate)]
struct MyString(pub VisibleString);

fn main() {
    // Hello, World! in decimal bytes with trailing zeros
    // Below sample requires that `backtraces` feature is enabled
    let hello_data = vec![
        13, 145, 151, 102, 205, 235, 16, 119, 223, 203, 102, 68, 32, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
        0,
    ];
    // Initially parse the first 2 bytes for Error demonstration purposes
    let mut total = 2;

    loop {
        let decoded = Codec::Uper.decode_from_binary::<MyString>(&hello_data[0..hello_data.len().min(total)]);
        match decoded {
            Ok(succ) => {
                println!("Successful decoding!");
                println!("Decoded string: {}", succ.0);
                break;
            }
            Err(e) => {
                // e is DecodeError, kind is boxed
                match *e.kind {
                    DecodeErrorKind::Incomplete { needed } => {
                        println!("Codec error source: {}", e.codec);
                        println!("Error kind: {}", e.kind);
                        // Here you need to know, that VisibleString has width of 7 bits and UPER parses input
                        // as bits, if you want to build logic around it, and feed exactly the correct amount of data.
                        // Usually you might need to just provide one byte at time instead when something is missing, since
                        // inner logic might not be known to you, and data structures can get complex.
                        total += match needed {
                            Needed::Size(n) => {
                                let missing_bytes = n.get() / 7;
                                missing_bytes
                               
                            }
                            _ => {
                                #[cfg(feature = "backtraces")]
                                println!("Backtrace:\n{:?}", e.backtrace);
                                panic!("Unexpected error! {e:?}");
                            }
                        }
                    }
                    k => {
                        #[cfg(feature = "backtraces")]
                        println!("Backtrace:\n{:?}", e.backtrace);
                        panic!("Unexpected error! {k:?}");
                    }
                }
            }
        }
    }
}

The previous will produce something like following:

Codec error: UPER
Error kind: Need more BITS to continue: (Size(83)).
Successful decoding!
Decoded string: Hello, world!

Fields§

§kind: Box<DecodeErrorKind>§codec: Codec§backtrace: Backtrace

Implementations§

source§

impl DecodeError

source

pub fn alphabet_constraint_not_satisfied( reason: PermittedAlphabetError, codec: Codec ) -> Self

source

pub fn range_exceeds_platform_width( needed: u32, present: u32, codec: Codec ) -> Self

source

pub fn fixed_string_conversion_failed( tag: Tag, actual: usize, expected: usize, codec: Codec ) -> Self

source

pub fn incorrect_item_number_in_sequence( expected: usize, actual: usize, codec: Codec ) -> Self

source

pub fn integer_overflow(max_width: u32, codec: Codec) -> Self

source

pub fn integer_type_conversion_failed(msg: String, codec: Codec) -> Self

source

pub fn invalid_bit_string(bits: u8, codec: Codec) -> Self

source

pub fn missing_tag_class_or_value_in_sequence_or_set( class: Class, value: u32, codec: Codec ) -> Self

source

pub fn type_not_extensible(codec: Codec) -> Self

source

pub fn parser_fail(msg: String, codec: Codec) -> Self

source

pub fn required_extension_not_present(tag: Tag, codec: Codec) -> Self

source

pub fn extension_present_but_not_required(tag: Tag, codec: Codec) -> Self

source

pub fn enumeration_index_not_found( index: usize, extended_list: bool, codec: Codec ) -> Self

source

pub fn choice_index_exceeds_platform_width( needed: u32, present: u64, codec: Codec ) -> Self

source

pub fn choice_index_not_found( index: usize, variants: Variants, codec: Codec ) -> Self

source

pub fn string_conversion_failed(tag: Tag, msg: String, codec: Codec) -> Self

source

pub fn unexpected_extra_data(length: usize, codec: Codec) -> Self

source

pub fn assert_length( expected: usize, actual: usize, codec: Codec ) -> Result<(), DecodeError>

source

pub fn map_nom_err<T: Debug>(error: Err<Error<T>>, codec: Codec) -> DecodeError

source

pub fn from_kind(kind: DecodeErrorKind, codec: Codec) -> Self

Trait Implementations§

source§

impl Debug for DecodeError

source§

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

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

impl Display for DecodeError

source§

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

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

impl Error for DecodeError

source§

fn custom<D: Display>(msg: D, codec: Codec) -> Self

Creates a new general error using msg when decoding ASN.1.
source§

fn incomplete(needed: Needed, codec: Codec) -> Self

Creates a new error about needing more data to finish parsing.
source§

fn exceeds_max_length(length: BigUint, codec: Codec) -> Self

Creates a new error about exceeding the maximum allowed data for a type.
source§

fn missing_field(name: &'static str, codec: Codec) -> Self

Creates a new error about a missing field.
source§

fn no_valid_choice(name: &'static str, codec: Codec) -> Self

Creates a new error about being unable to match any variant in a choice.
source§

fn field_error(name: &'static str, nested: DecodeError, codec: Codec) -> Self

Creates a new error about being unable to decode a field in a compound type, such as a set or sequence.
source§

fn duplicate_field(name: &'static str, codec: Codec) -> Self

Creates a new error about finding a duplicate field.
source§

fn unknown_field(index: usize, tag: Tag, codec: Codec) -> Self

Create a new error about unknown field.
source§

impl From<BerDecodeErrorKind> for DecodeError

source§

fn from(error: BerDecodeErrorKind) -> Self

Converts to this type from the input type.
source§

impl From<CodecDecodeError> for DecodeError

source§

fn from(error: CodecDecodeError) -> Self

Converts to this type from the input type.
source§

impl From<DerDecodeErrorKind> for DecodeError

source§

fn from(error: DerDecodeErrorKind) -> Self

Converts to this type from the input type.
source§

impl From<JerDecodeErrorKind> for DecodeError

source§

fn from(error: JerDecodeErrorKind) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

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
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, W> HasTypeWitness<W> for T
where W: MakeTypeWitness<Arg = T>, T: ?Sized,

§

const WITNESS: W = W::MAKE

A constant of the type witness
§

impl<T> Identity for T
where T: ?Sized,

§

type Type = T

The same type as Self, used to emulate type equality bounds (T == U) with associated type equality constraints (T: Identity<Type = U>).
§

const TYPE_EQ: TypeEq<T, <T as Identity>::Type> = TypeEq::NEW

Proof that Self is the same type as Self::Type, provides methods for casting between Self and Self::Type.
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.

§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.