Struct cap_std::net::UdpSocket

source ·
pub struct UdpSocket { /* private fields */ }
Available on non-WASI only.
Expand description

A UDP socket.

This corresponds to std::net::UdpSocket.

This UdpSocket has no bind, connect, or send_to methods. To create a UdpSocket bound to an address or to send a message to an address, first obtain a Pool permitting the address, and then call Pool::bind_udp_socket, or Pool::connect_udp_socket, or Pool::send_to_udp_socket_addr.

Implementations§

source§

impl UdpSocket

source

pub fn from_std(std: UdpSocket) -> Self

Constructs a new instance of Self from the given std::net::UdpSocket.

This grants access the resources the std::net::UdpSocket instance already has access to.

source

pub fn recv_from(&self, buf: &mut [u8]) -> Result<(usize, SocketAddr)>

Receives a single datagram message on the socket.

This corresponds to std::net::UdpSocket::recv_from.

source

pub fn peek_from(&self, buf: &mut [u8]) -> Result<(usize, SocketAddr)>

Receives a single datagram message on the socket, without removing it from the queue.

This corresponds to std::net::UdpSocket::peek_from.

source

pub fn peer_addr(&self) -> Result<SocketAddr>

Returns the socket address of the remote peer this socket was connected to.

This corresponds to std::net::UdpSocket::peer_addr.

source

pub fn local_addr(&self) -> Result<SocketAddr>

Returns the socket address that this socket was created from.

This corresponds to std::net::UdpSocket::local_addr.

source

pub fn try_clone(&self) -> Result<Self>

Creates a new independently owned handle to the underlying socket.

This corresponds to std::net::UdpSocket::try_clone.

source

pub fn set_read_timeout(&self, dur: Option<Duration>) -> Result<()>

Sets the read timeout to the timeout specified.

This corresponds to std::net::UdpSocket::set_read_timeout.

source

pub fn set_write_timeout(&self, dur: Option<Duration>) -> Result<()>

Sets the write timeout to the timeout specified.

This corresponds to std::net::UdpSocket::set_write_timeout.

source

pub fn read_timeout(&self) -> Result<Option<Duration>>

Returns the read timeout of this socket.

This corresponds to std::net::UdpSocket::read_timeout.

source

pub fn write_timeout(&self) -> Result<Option<Duration>>

Returns the write timeout of this socket.

This corresponds to std::net::UdpSocket::write_timeout.

source

pub fn set_broadcast(&self, broadcast: bool) -> Result<()>

Sets the value of the SO_BROADCAST option for this socket.

This corresponds to std::net::UdpSocket::set_broadcast.

source

pub fn broadcast(&self) -> Result<bool>

Gets the value of the SO_BROADCAST option for this socket.

This corresponds to std::net::UdpSocket::broadcast.

source

pub fn set_multicast_loop_v4(&self, multicast_loop_v4: bool) -> Result<()>

Sets the value of the IP_MULTICAST_LOOP option for this socket.

This corresponds to std::net::UdpSocket::set_multicast_loop_v4.

source

pub fn multicast_loop_v4(&self) -> Result<bool>

Gets the value of the IP_MULTICAST_LOOP option for this socket.

This corresponds to std::net::UdpSocket::multicast_loop_v4.

source

pub fn set_multicast_ttl_v4(&self, multicast_ttl_v4: u32) -> Result<()>

Sets the value of the IP_MULTICAST_TTL option for this socket.

This corresponds to std::net::UdpSocket::set_multicast_ttl_v4.

source

pub fn multicast_ttl_v4(&self) -> Result<u32>

Gets the value of the IP_MULTICAST_TTL option for this socket.

This corresponds to std::net::UdpSocket::multicast_ttl_v4.

source

pub fn set_multicast_loop_v6(&self, multicast_loop_v6: bool) -> Result<()>

Sets the value of the IPV6_MULTICAST_LOOP option for this socket.

This corresponds to std::net::UdpSocket::set_multicast_loop_v6.

source

pub fn multicast_loop_v6(&self) -> Result<bool>

Gets the value of the IPV6_MULTICAST_LOOP option for this socket.

This corresponds to std::net::UdpSocket::multicast_loop_v6.

source

pub fn set_ttl(&self, ttl: u32) -> Result<()>

Sets the value for the IP_TTL option on this socket.

This corresponds to std::net::UdpSocket::set_ttl.

source

pub fn ttl(&self) -> Result<u32>

Gets the value of the IP_TTL option for this socket.

This corresponds to std::net::UdpSocket::ttl.

source

pub fn join_multicast_v4( &self, multiaddr: &Ipv4Addr, interface: &Ipv4Addr ) -> Result<()>

Executes an operation of the IP_ADD_MEMBERSHIP type.

This corresponds to std::net::UdpSocket::join_multicast_v4.

source

pub fn join_multicast_v6( &self, multiaddr: &Ipv6Addr, interface: u32 ) -> Result<()>

Executes an operation of the IPV6_ADD_MEMBERSHIP type.

This corresponds to std::net::UdpSocket::join_multicast_v6.

source

pub fn leave_multicast_v4( &self, multiaddr: &Ipv4Addr, interface: &Ipv4Addr ) -> Result<()>

Executes an operation of the IP_DROP_MEMBERSHIP type.

This corresponds to std::net::UdpSocket::leave_multicast_v4.

source

pub fn leave_multicast_v6( &self, multiaddr: &Ipv6Addr, interface: u32 ) -> Result<()>

Executes an operation of the IPV6_DROP_MEMBERSHIP type.

This corresponds to std::net::UdpSocket::leave_multicast_v6.

source

pub fn take_error(&self) -> Result<Option<Error>>

Gets the value of the SO_ERROR option on this socket.

This corresponds to std::net::UdpSocket::take_error.

source

pub fn send(&self, buf: &[u8]) -> Result<usize>

Sends data on the socket to the remote address to which it is connected.

This corresponds to std::net::UdpSocket::send.

source

pub fn recv(&self, buf: &mut [u8]) -> Result<usize>

Receives a single datagram message on the socket from the remote address to which it is connected.

This corresponds to std::net::UdpSocket::recv.

source

pub fn peek(&self, buf: &mut [u8]) -> Result<usize>

Receives single datagram on the socket from the remote address to which it is connected, without removing the message from input queue.

This corresponds to std::net::UdpSocket::peek.

source

pub fn set_nonblocking(&self, nonblocking: bool) -> Result<()>

Moves this UDP socket into or out of nonblocking mode.

This corresponds to std::net::UdpSocket::set_nonblocking.

Trait Implementations§

source§

impl AsHandleOrSocket for UdpSocket

Available on Windows only.
source§

impl AsRawHandleOrSocket for UdpSocket

Available on Windows only.
source§

impl AsRawSocket for UdpSocket

Available on Windows only.
source§

fn as_raw_socket(&self) -> RawSocket

Extracts the raw socket. Read more
source§

impl AsSocket for UdpSocket

Available on Windows only.
source§

fn as_socket(&self) -> BorrowedSocket<'_>

Borrows the socket.
source§

impl Debug for UdpSocket

source§

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

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

impl From<OwnedSocket> for UdpSocket

Available on Windows only.
source§

fn from(socket: OwnedSocket) -> Self

Converts to this type from the input type.
source§

impl From<UdpSocket> for OwnedHandleOrSocket

Available on Windows only.
source§

fn from(socket: UdpSocket) -> Self

Converts to this type from the input type.
source§

impl From<UdpSocket> for OwnedSocket

Available on Windows only.
source§

fn from(socket: UdpSocket) -> OwnedSocket

Converts to this type from the input type.
source§

impl FromRawSocket for UdpSocket

Available on Windows only.
source§

unsafe fn from_raw_socket(socket: RawSocket) -> Self

Constructs a new I/O object from the specified raw socket. Read more
source§

impl IntoRawHandleOrSocket for UdpSocket

Available on Windows only.
source§

impl IntoRawSocket for UdpSocket

Available on Windows only.
source§

fn into_raw_socket(self) -> RawSocket

Consumes this object, returning the raw underlying socket. Read more
source§

impl SocketlikeViewType for UdpSocket

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> AsGrip for Twhere T: AsHandleOrSocket,

source§

fn as_grip(&self) -> BorrowedHandleOrSocket<'_>

Extracts the grip.
source§

impl<T> AsRawGrip for Twhere T: AsRawHandleOrSocket,

source§

fn as_raw_grip(&self) -> RawHandleOrSocket

Extracts the raw grip.
source§

impl<T> AsRawSocketlike for Twhere T: AsRawSocket,

source§

fn as_raw_socketlike(&self) -> u32

Returns the raw value.
source§

impl<T> AsSocketlike for Twhere T: AsSocket,

source§

fn as_socketlike(&self) -> BorrowedSocket<'_>

Borrows the reference.
source§

fn as_socketlike_view<Target>(&self) -> SocketlikeView<'_, Target>where Target: SocketlikeViewType,

Return a borrowing view of a resource which dereferences to a &Target. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FromRawSocketlike for Twhere T: FromRawSocket,

source§

unsafe fn from_raw_socketlike(raw: u32) -> T

Constructs Self from the raw value.
source§

impl<T> FromSocket for Twhere T: From<OwnedSocket>,

source§

fn from_socket(owned_socket: OwnedSocket) -> T

👎Deprecated since 1.0.0: FromSocket::from_socket is replaced by From<OwnedSocket>::from
Constructs a new instance of Self from the given socket.
source§

fn from_into_socket<Owned>(into_owned: Owned) -> Selfwhere Owned: Into<OwnedSocket>, Self: Sized + From<OwnedSocket>,

Constructs a new instance of Self from the given socket converted from into_owned.
source§

impl<T> FromSocketlike for Twhere T: From<OwnedSocket>,

source§

fn from_socketlike(owned: OwnedSocket) -> T

Constructs a new instance of Self from the given socketlike object.
source§

fn from_into_socketlike<Owned>(owned: Owned) -> Twhere Owned: IntoSocketlike,

Constructs a new instance of Self from the given socketlike object converted from into_owned.
source§

impl<T, U> Into<U> for Twhere 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> IntoGrip for Twhere T: Into<OwnedHandleOrSocket>,

source§

fn into_grip(self) -> OwnedHandleOrSocket

Consume self and convert into an OwnedGrip.
source§

impl<T> IntoRawGrip for Twhere T: IntoRawHandleOrSocket,

source§

fn into_raw_grip(self) -> RawHandleOrSocket

Consume self and convert into an RawGrip.
source§

impl<T> IntoRawSocketlike for Twhere T: IntoRawSocket,

source§

fn into_raw_socketlike(self) -> u32

Returns the raw value.
source§

impl<T> IntoSocket for Twhere OwnedSocket: From<T>,

source§

fn into_socket(self) -> OwnedSocket

👎Deprecated since 1.0.0: IntoSocket is replaced by From<...> for OwnedSocket or Into<OwnedSocket>
Consumes this object, returning the underlying socket.
source§

impl<T> IntoSocketlike for Twhere T: Into<OwnedSocket>,

source§

fn into_socketlike(self) -> OwnedSocket

Consumes this object, returning the underlying socketlike object. Read more
source§

impl<T, U> TryFrom<U> for Twhere 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 Twhere 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.