pub enum Error {
Show 14 variants
TooBig {
given: u64,
max: u64,
},
BufferTooSmall {
given: u64,
min: u64,
},
Empty,
Header,
HeaderMismatch {
expected_len: u64,
got_len: u64,
},
Literal {
len: u64,
src_len: u64,
dst_len: u64,
},
CopyRead {
len: u64,
src_len: u64,
},
CopyWrite {
len: u64,
dst_len: u64,
},
Offset {
offset: u64,
dst_pos: u64,
},
StreamHeader {
byte: u8,
},
StreamHeaderMismatch {
bytes: Vec<u8>,
},
UnsupportedChunkType {
byte: u8,
},
UnsupportedChunkLength {
len: u64,
header: bool,
},
Checksum {
expected: u32,
got: u32,
},
}
Expand description
Error describes all the possible errors that may occur during Snappy compression or decompression.
Note that it’s unlikely that you’ll need to care about the specific error
reported since all of them indicate a corrupt Snappy data or a limitation
that cannot be worked around. Therefore,
From<snap::Error> for std::io::Error
is provided so that any Snappy
errors will be converted to a std::io::Error
automatically when using
try!
.
Variants
TooBig
This error occurs when the given input is too big. This can happen during compression or decompression.
BufferTooSmall
This error occurs when the given buffer is too small to contain the maximum possible compressed bytes or the total number of decompressed bytes.
Empty
This error occurs when trying to decompress a zero length buffer.
Header
This error occurs when an invalid header is found during decompression.
HeaderMismatch
Fields
expected_len: u64
The total number of decompressed bytes expected (i.e., the header value).
got_len: u64
The total number of actual decompressed bytes.
This error occurs when there is a mismatch between the number of decompressed bytes reported in the header and the number of actual decompressed bytes. In this error case, the number of actual decompressed bytes is always less than the number reported in the header.
Literal
Fields
len: u64
The expected length of the literal.
src_len: u64
The number of remaining bytes in the compressed bytes.
dst_len: u64
The number of remaining slots in the decompression buffer.
This error occurs during decompression when there was a problem reading a literal.
CopyRead
Fields
len: u64
The expected length of the copy (as encoded in the compressed bytes).
src_len: u64
The number of remaining bytes in the compressed bytes.
This error occurs during decompression when there was a problem reading a copy.
CopyWrite
Fields
len: u64
The length of the copy (i.e., the total number of bytes to be produced by this copy in the decompression buffer).
dst_len: u64
The number of remaining bytes in the decompression buffer.
This error occurs during decompression when there was a problem writing a copy to the decompression buffer.
Offset
Fields
offset: u64
The offset that was read.
dst_pos: u64
The current position in the decompression buffer. If the offset is non-zero, then the offset must be greater than this position.
This error occurs during decompression when an invalid copy offset is found. An offset is invalid if it is zero or if it is out of bounds.
StreamHeader
Fields
byte: u8
The chunk type byte that was read.
This error occurs when a stream header chunk type was expected but got a different chunk type. This error only occurs when reading a Snappy frame formatted stream.
StreamHeaderMismatch
This error occurs when the magic stream headers bytes do not match what is expected. This error only occurs when reading a Snappy frame formatted stream.
UnsupportedChunkType
Fields
byte: u8
The chunk type byte that was read.
This error occurs when an unsupported chunk type is seen. This error only occurs when reading a Snappy frame formatted stream.
UnsupportedChunkLength
Fields
len: u64
The length of the chunk encountered.
header: bool
True when this error occured while reading the stream header.
This error occurs when trying to read a chunk with an unexpected or incorrect length when reading a Snappy frame formatted stream. This error only occurs when reading a Snappy frame formatted stream.
Checksum
This error occurs when a checksum validity check fails. This error only occurs when reading a Snappy frame formatted stream.
Trait Implementations
sourceimpl Error for Error
impl Error for Error
1.30.0 · sourcefn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
The lower-level source of this error, if any. Read more
sourcefn backtrace(&self) -> Option<&Backtrace>
fn backtrace(&self) -> Option<&Backtrace>
backtrace
)Returns a stack backtrace, if available, of where this error occurred. Read more
1.0.0 · sourcefn description(&self) -> &str
fn description(&self) -> &str
use the Display impl or to_string()
impl Eq for Error
Auto Trait Implementations
impl RefUnwindSafe for Error
impl Send for Error
impl Sync for Error
impl Unpin for Error
impl UnwindSafe for Error
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more