Struct netstack3_base::socket::SocketIpAddr

source ·
pub struct SocketIpAddr<A: IpAddress>(/* private fields */);
Expand description

An IP address that witnesses all required properties of a socket address.

Requires SpecifiedAddr because most contexts do not permit unspecified addresses; those that do can hold a Option<SocketIpAddr>.

Requires NonMappedAddr because mapped addresses (i.e. ipv4-mapped-ipv6 addresses) are converted from their original IP version to their target IP version when entering the stack.

Implementations§

source§

impl<A: IpAddress> SocketIpAddr<A>

source

pub fn new(addr: A) -> Option<SocketIpAddr<A>>

Constructs a SocketIpAddr if the address is compliant, else None.

source

pub fn new_from_witness(addr: NonMappedAddr<SpecifiedAddr<A>>) -> Self

Constructs a SocketIpAddr from the inner witness.

source

pub const unsafe fn new_unchecked(addr: A) -> SocketIpAddr<A>

Constructs a SocketIpAddr without verify the address’s properties.

§Safety

Callers must ensure that the addr is both a SpecifiedAddr and a NonMappedAddr.

source

pub const unsafe fn new_from_specified_unchecked( addr: SpecifiedAddr<A>, ) -> SocketIpAddr<A>

Like SocketIpAddr::new_unchecked, but the address is specified.

§Safety

Callers must ensure that the addr is a NonMappedAddr.

source

pub fn addr(self) -> A

Returns the inner address, dropping all witnesses.

source

pub fn into_inner(self) -> NonMappedAddr<SpecifiedAddr<A>>

Returns the inner address, including all witness types.

source

pub fn new_from_multicast(addr: MulticastAddr<A>) -> SocketIpAddr<A>

Constructs a SocketIpAddr from the given multicast address.

source§

impl SocketIpAddr<Ipv4Addr>

source

pub fn new_ipv4_specified(addr: SpecifiedAddr<Ipv4Addr>) -> Self

Constructs a SocketIpAddr from a given specified IPv4 address.

source§

impl SocketIpAddr<Ipv6Addr>

source

pub fn new_from_ipv6_non_mapped_unicast( addr: NonMappedAddr<UnicastAddr<Ipv6Addr>>, ) -> Self

Constructs a SocketIpAddr from the given [Ipv6DeviceAddr].

source

pub fn new_from_ipv6_source(addr: Ipv6SourceAddr) -> Option<Self>

Optionally constructs a SocketIpAddr from the given Ipv6SourceAddr, returning None if the given addr is Unspecified.

Trait Implementations§

source§

impl<A: IpAddress> AsRef<SpecifiedAddr<A>> for SocketIpAddr<A>

source§

fn as_ref(&self) -> &SpecifiedAddr<A>

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<A: Clone + IpAddress> Clone for SocketIpAddr<A>

source§

fn clone(&self) -> SocketIpAddr<A>

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<A: IpAddress> Debug for SocketIpAddr<A>

source§

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

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

impl<A: IpAddress> Display for SocketIpAddr<A>

source§

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

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

impl<A: IpAddress> From<IpDeviceAddr<A>> for SocketIpAddr<A>

source§

fn from(addr: IpDeviceAddr<A>) -> Self

Converts to this type from the input type.
source§

impl<A: IpAddress> From<SocketIpAddr<A>> for SpecifiedAddr<A>

source§

fn from(addr: SocketIpAddr<A>) -> Self

Converts to this type from the input type.
source§

impl<A: IpAddress, IpType: Ip> GenericOverIp<IpType> for SocketIpAddr<A>
where IpType::Addr: IpAddress,

§

type Type = SocketIpAddr<<IpType as Ip>::Addr>

The type of Self when its IP-generic parameter is replaced with the type NewIp.
source§

impl<A: Hash + IpAddress> Hash for SocketIpAddr<A>

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<A: PartialEq + IpAddress> PartialEq for SocketIpAddr<A>

source§

fn eq(&self, other: &SocketIpAddr<A>) -> 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<A: IpAddress> ScopeableAddress for SocketIpAddr<A>

Allows SocketIpAddr to be used inside of a ZonedAddr.

§

type Scope = <A as ScopeableAddress>::Scope

The type of all non-global scopes.
source§

fn scope(&self) -> Self::Scope

The scope of this address. Read more
source§

impl<A: IpAddress> TryFrom<SpecifiedAddr<A>> for SocketIpAddr<A>

§

type Error = AddrIsMappedError

The type returned in the event of a conversion error.
source§

fn try_from(addr: SpecifiedAddr<A>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<A: Copy + IpAddress> Copy for SocketIpAddr<A>

source§

impl<A: Eq + IpAddress> Eq for SocketIpAddr<A>

source§

impl<A: IpAddress> StructuralPartialEq for SocketIpAddr<A>

Auto Trait Implementations§

§

impl<A> Freeze for SocketIpAddr<A>
where A: Freeze,

§

impl<A> RefUnwindSafe for SocketIpAddr<A>
where A: RefUnwindSafe,

§

impl<A> Send for SocketIpAddr<A>

§

impl<A> Sync for SocketIpAddr<A>

§

impl<A> Unpin for SocketIpAddr<A>
where A: Unpin,

§

impl<A> UnwindSafe for SocketIpAddr<A>
where A: 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<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<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> ToString for T
where T: Display + ?Sized,

source§

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

§

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