pub struct ListeningSocket { /* private fields */ }
Expand description

An utility representing a unix socket on which your compositor is listening for new clients

Implementations§

source§

impl ListeningSocket

source

pub fn bind<S: AsRef<OsStr>>(socket_name: S) -> Result<Self, BindError>

Attempt to bind a listening socket with given name

This method will acquire an associate lockfile. The socket will be created in the directory pointed to by the XDG_RUNTIME_DIR environment variable.

source

pub fn bind_auto( basename: &str, range: impl IntoIterator<Item = usize> ) -> Result<Self, BindError>

Attempt to bind a listening socket from a sequence of names

This method will repeatedly try to bind sockets in teh form {basename}-{n} for values of n yielded from the provided range and returns the first one that succeeds.

This method will acquire an associate lockfile. The socket will be created in the directory pointed to by the XDG_RUNTIME_DIR environment variable.

source

pub fn bind_absolute(socket_path: PathBuf) -> Result<Self, BindError>

Attempt to bind a listening socket with given name

The socket will be created at the specified path, and this method will acquire an associatet lockfile alongside it.

source

pub fn accept(&self) -> Result<Option<UnixStream>>

Try to accept a new connection to the listening socket

This method will never block, and return Ok(None) if no new connection is available.

source

pub fn socket_name(&self) -> Option<&OsStr>

Returns the name of the listening socket.

Will only be Some if that socket was created with bind or bind_auto.

Trait Implementations§

source§

impl AsFd for ListeningSocket

source§

fn as_fd(&self) -> BorrowedFd<'_>

Returns a file descriptor that may be polled for readiness.

This file descriptor may be polled using apis such as epoll and kqueue to be told when a client has found the socket and is trying to connect.

When the polling system reports the file descriptor is ready, you can use ListeningSocket::accept to get a stream to the new client.

source§

impl AsRawFd for ListeningSocket

source§

fn as_raw_fd(&self) -> RawFd

Returns a file descriptor that may be polled for readiness.

This file descriptor may be polled using apis such as epoll and kqueue to be told when a client has found the socket and is trying to connect.

When the polling system reports the file descriptor is ready, you can use ListeningSocket::accept to get a stream to the new client.

source§

impl Debug for ListeningSocket

source§

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

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

impl Drop for ListeningSocket

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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, 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.