Struct netstack3_ip::socket::SocketHopLimits

source ·
pub struct SocketHopLimits<I: Ip> {
    pub unicast: Option<NonZeroU8>,
    pub multicast: Option<NonZeroU8>,
    pub version: IpVersionMarker<I>,
}
Expand description

The configurable hop limits for a socket.

Fields§

§unicast: Option<NonZeroU8>

Unicast hop limit.

§multicast: Option<NonZeroU8>

Multicast hop limit.

§version: IpVersionMarker<I>

An unused marker type signifying the IP version for which these hop limits are valid. Including this helps prevent using the wrong hop limits when operating on dualstack sockets.

Implementations§

source§

impl<I: Ip> SocketHopLimits<I>

source

pub fn set_unicast(value: Option<NonZeroU8>) -> impl FnOnce(&mut Self)

Returns a function that updates the unicast hop limit.

source

pub fn set_multicast(value: Option<NonZeroU8>) -> impl FnOnce(&mut Self)

Returns a function that updates the multicast hop limit.

source

pub fn get_limits_with_defaults(&self, defaults: &HopLimits) -> HopLimits

Returns the hop limits, or the provided defaults if unset.

source

pub fn hop_limit_for_dst( &self, destination: &SpecifiedAddr<I::Addr>, ) -> Option<NonZeroU8>

Returns the appropriate hop limit to use for the given destination addr.

Trait Implementations§

source§

impl<I: Clone + Ip> Clone for SocketHopLimits<I>

source§

fn clone(&self) -> SocketHopLimits<I>

Returns a copy 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<I: Debug + Ip> Debug for SocketHopLimits<I>

source§

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

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

impl<I: Default + Ip> Default for SocketHopLimits<I>

source§

fn default() -> SocketHopLimits<I>

Returns the “default value” for a type. Read more
source§

impl<I: PartialEq + Ip> PartialEq for SocketHopLimits<I>

source§

fn eq(&self, other: &SocketHopLimits<I>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<I: Copy + Ip> Copy for SocketHopLimits<I>

source§

impl<I: Eq + Ip> Eq for SocketHopLimits<I>

source§

impl<I: Ip> StructuralPartialEq for SocketHopLimits<I>

Auto Trait Implementations§

§

impl<I> Freeze for SocketHopLimits<I>

§

impl<I> RefUnwindSafe for SocketHopLimits<I>
where I: RefUnwindSafe,

§

impl<I> Send for SocketHopLimits<I>

§

impl<I> Sync for SocketHopLimits<I>

§

impl<I> Unpin for SocketHopLimits<I>
where I: Unpin,

§

impl<I> UnwindSafe for SocketHopLimits<I>
where I: UnwindSafe,

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<O, BC> BuildableCoreContext<BC> for O
where O: Default,

§

type Builder = ()

The builder type that can build this core context.
source§

fn build(_bindings_ctx: &mut BC, _: ()) -> O

Consumes this builder and returns the context.
source§

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

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

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

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

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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<CC, BC, Meta> RecvFrameContext<Meta, BC> for CC
where Meta: ReceivableFrameMeta<CC, BC>,

source§

fn receive_frame<B>(&mut self, bindings_ctx: &mut BC, metadata: Meta, frame: B)
where B: BufferMut + Debug,

Receive a frame. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<CC, BC, Meta> SendFrameContext<BC, Meta> for CC
where Meta: SendableFrameMeta<CC, BC>,

source§

fn send_frame<S>( &mut self, bindings_ctx: &mut BC, metadata: Meta, frame: S, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>
where S: Serializer, <S as Serializer>::Buffer: BufferMut,

Send a frame. Read more
source§

impl<Id, CC, BC> TimerHandler<BC, Id> for CC
where BC: TimerBindingsTypes, Id: HandleableTimer<CC, BC>,

source§

fn handle_timer( &mut self, bindings_ctx: &mut BC, dispatch: Id, timer: <BC as TimerBindingsTypes>::UniqueTimerId, )

Handle a timer firing. Read more
source§

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

§

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

impl<L, T> UnlockedAccess<L> for T
where L: UnlockedAccessMarkerFor<T>,

§

type Data = <L as UnlockedAccessMarkerFor<T>>::Data

The type of state being accessed.
§

type Guard<'l> = &'l <L as UnlockedAccessMarkerFor<T>>::Data where T: 'l

A guard providing read access to the data.
§

fn access(&self) -> <T as UnlockedAccess<L>>::Guard<'_>

How to access the state.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<B, A> LockBefore<B> for A
where B: LockAfter<A>,