Struct TrySegmentError

Source
pub struct TrySegmentError { /* private fields */ }
Expand description

An error that occurs when trying to create a segment with an invalid range.

This error indicates that the requested range extends beyond the buffer’s boundaries or is otherwise invalid (e.g., start > end). The original buffer remains unchanged.

§Examples

let data = b"Hello";
let buf = &data[..];

// Range extends beyond buffer
match buf.try_segment(2..10) {
    Err(e) => {
        assert_eq!(e.start(), 2);
        assert_eq!(e.end(), 10);
        assert_eq!(e.available(), 5);
    }
    _ => panic!("Expected error"),
}

// Invalid range (start > end)
assert!(buf.try_segment(4..2).is_err());

Implementations§

Source§

impl TrySegmentError

Source

pub const fn new(start: usize, end: usize, available: usize) -> Self

Creates a new TrySegmentError.

§Panics

In debug builds, panics if the range is valid (would not be an error) or the available bytes are less than the requested range.

Source

pub const fn start(&self) -> usize

Returns the start index of the requested range.

Source

pub const fn end(&self) -> usize

Returns the end index of the requested range (exclusive).

Source

pub const fn available(&self) -> usize

Returns the total number of bytes available in the buffer.

Source

pub const fn requested(&self) -> usize

Returns the length of the requested range.

Returns 0 if start > end (invalid range).

Source

pub const fn is_inverted(&self) -> bool

Returns whether the range itself is invalid (start > end).

Source

pub const fn overflow(&self) -> usize

Returns how many bytes the range extends beyond the buffer.

Returns 0 if the range doesn’t extend beyond the buffer (e.g., when the error is due to start > end).

Trait Implementations§

Source§

impl Clone for TrySegmentError

Source§

fn clone(&self) -> TrySegmentError

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for TrySegmentError

Source§

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

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

impl Display for TrySegmentError

Source§

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

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

impl Error for TrySegmentError

1.30.0 · Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<TrySegmentError> for Error

Source§

fn from(e: TrySegmentError) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for TrySegmentError

Source§

fn eq(&self, other: &TrySegmentError) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for TrySegmentError

Source§

impl Eq for TrySegmentError

Source§

impl StructuralPartialEq for TrySegmentError

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
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

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

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

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

Source§

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

Source§

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.