nix::sys::socket

Struct UnixAddr

source
#[repr(C)]
pub struct UnixAddr { /* private fields */ }
Expand description

A wrapper around sockaddr_un.

Implementations§

source§

impl UnixAddr

source

pub fn new<P: ?Sized + NixPath>(path: &P) -> Result<UnixAddr>

Create a new sockaddr_un representing a filesystem path.

source

pub fn new_abstract(path: &[u8]) -> Result<UnixAddr>

Create a new sockaddr_un representing an address in the “abstract namespace”.

The leading nul byte for the abstract namespace is automatically added; thus the input path is expected to be the bare name, not NUL-prefixed. This is a Linux-specific extension, primarily used to allow chrooted processes to communicate with processes having a different filesystem view.

source

pub fn new_unnamed() -> UnixAddr

Create a new sockaddr_un representing an “unnamed” unix socket address.

source

pub fn path(&self) -> Option<&Path>

If this address represents a filesystem path, return that path.

source

pub fn as_abstract(&self) -> Option<&[u8]>

If this address represents an abstract socket, return its name.

For abstract sockets only the bare name is returned, without the leading NUL byte. None is returned for unnamed or path-backed sockets.

source

pub fn is_unnamed(&self) -> bool

Check if this address is an “unnamed” unix socket address.

source

pub fn path_len(&self) -> usize

Returns the addrlen of this socket - offsetof(struct sockaddr_un, sun_path)

source

pub fn as_ptr(&self) -> *const sockaddr_un

Returns a pointer to the raw sockaddr_un struct

source

pub fn as_mut_ptr(&mut self) -> *mut sockaddr_un

Returns a mutable pointer to the raw sockaddr_un struct

Trait Implementations§

source§

impl AsRef<sockaddr_un> for UnixAddr

source§

fn as_ref(&self) -> &sockaddr_un

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

impl Clone for UnixAddr

source§

fn clone(&self) -> UnixAddr

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 Debug for UnixAddr

source§

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

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

impl Display for UnixAddr

source§

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

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

impl Hash for UnixAddr

source§

fn hash<H: Hasher>(&self, s: &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 PartialEq for UnixAddr

source§

fn eq(&self, other: &UnixAddr) -> 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 SockaddrLike for UnixAddr

source§

fn len(&self) -> socklen_t

Return the length of valid data in the sockaddr structure. Read more
source§

unsafe fn from_raw( addr: *const sockaddr, len: Option<socklen_t>, ) -> Option<Self>
where Self: Sized,

Unsafe constructor from a variable length source Read more
source§

fn size() -> socklen_t
where Self: Sized,

Return the available space in the structure
source§

fn as_ptr(&self) -> *const sockaddr

Returns a raw pointer to the inner structure. Useful for FFI.
source§

fn family(&self) -> Option<AddressFamily>

Return the address family of this socket Read more
source§

impl Copy for UnixAddr

source§

impl Eq for UnixAddr

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

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

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.