pub struct AsyncFdReadyMutGuard<'a, T: AsRawFd> { /* private fields */ }
Expand description
Represents an IO-ready event detected on a particular file descriptor that
has not yet been acknowledged. This is a must_use
structure to help ensure
that you do not forget to explicitly clear (or not clear) the event.
This type exposes a mutable reference to the underlying IO object.
Implementations
sourceimpl<'a, Inner: AsRawFd> AsyncFdReadyMutGuard<'a, Inner>
impl<'a, Inner: AsRawFd> AsyncFdReadyMutGuard<'a, Inner>
sourcepub fn clear_ready(&mut self)
pub fn clear_ready(&mut self)
Indicates to tokio that the file descriptor is no longer ready. The internal readiness flag will be cleared, and tokio will wait for the next edge-triggered readiness notification from the OS.
It is critical that this function not be called unless your code actually observes that the file descriptor is not ready. Do not call it simply because, for example, a read succeeded; it should be called when a read is observed to block.
sourcepub fn retain_ready(&mut self)
pub fn retain_ready(&mut self)
This method should be invoked when you intentionally want to keep the ready flag asserted.
While this function is itself a no-op, it satisfies the #[must_use]
constraint on the AsyncFdReadyGuard
type.
sourcepub fn try_io<R>(
&mut self,
f: impl FnOnce(&mut AsyncFd<Inner>) -> Result<R>
) -> Result<Result<R>, TryIoError>
pub fn try_io<R>(
&mut self,
f: impl FnOnce(&mut AsyncFd<Inner>) -> Result<R>
) -> Result<Result<R>, TryIoError>
Performs the provided IO operation.
If f
returns a WouldBlock
error, the readiness state associated
with this file descriptor is cleared, and the method returns
Err(TryIoError::WouldBlock)
. You will typically need to poll the
AsyncFd
again when this happens.
This method helps ensure that the readiness state of the underlying file
descriptor remains in sync with the tokio-side readiness state, by
clearing the tokio-side state only when a WouldBlock
condition
occurs. It is the responsibility of the caller to ensure that f
returns WouldBlock
only if the file descriptor that originated this
AsyncFdReadyGuard
no longer expresses the readiness state that was queried to
create this AsyncFdReadyGuard
.
sourcepub fn get_mut(&mut self) -> &mut AsyncFd<Inner>
pub fn get_mut(&mut self) -> &mut AsyncFd<Inner>
Returns a mutable reference to the inner AsyncFd
.
sourcepub fn get_inner(&self) -> &Inner
pub fn get_inner(&self) -> &Inner
Returns a shared reference to the backing object of the inner AsyncFd
.
sourcepub fn get_inner_mut(&mut self) -> &mut Inner
pub fn get_inner_mut(&mut self) -> &mut Inner
Returns a mutable reference to the backing object of the inner AsyncFd
.
Trait Implementations
Auto Trait Implementations
impl<'a, T> !RefUnwindSafe for AsyncFdReadyMutGuard<'a, T>
impl<'a, T> Send for AsyncFdReadyMutGuard<'a, T> where
T: Send,
impl<'a, T> Sync for AsyncFdReadyMutGuard<'a, T> where
T: Sync,
impl<'a, T> Unpin for AsyncFdReadyMutGuard<'a, T>
impl<'a, T> !UnwindSafe for AsyncFdReadyMutGuard<'a, T>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more