nix::sys::aio

Struct AioWrite

Source
pub struct AioWrite<'a> { /* private fields */ }
Expand description

Asynchronously writes from a buffer to a file descriptor

§References

aio_write

§Examples

const WBUF: &[u8] = b"abcdef123456";
let mut f = tempfile().unwrap();
let mut aiow = Box::pin(
    AioWrite::new(
        f.as_raw_fd(),
        2,   //offset
        WBUF,
        0,   //priority
        SigevNotify::SigevNone
    )
);
aiow.as_mut().submit().unwrap();
while (aiow.as_mut().error() == Err(Errno::EINPROGRESS)) {
    thread::sleep(time::Duration::from_millis(10));
}
assert_eq!(aiow.as_mut().aio_return().unwrap(), WBUF.len());

Implementations§

Source§

impl<'a> AioWrite<'a>

Source

pub fn nbytes(&self) -> usize

Returns the requested length of the aio operation in bytes

This method returns the requested length of the operation. To get the number of bytes actually read or written by a completed operation, use aio_return instead.

Source

pub fn new( fd: RawFd, offs: off_t, buf: &'a [u8], prio: i32, sigev_notify: SigevNotify, ) -> Self

Construct a new AioWrite.

§Arguments
  • fd: File descriptor to write to
  • offs: File offset
  • buf: A memory buffer. It must outlive the AioWrite.
  • prio: If POSIX Prioritized IO is supported, then the operation will be prioritized at the process’s priority level minus prio
  • sigev_notify: Determines how you will be notified of event completion.
Source

pub fn offset(&self) -> off_t

Returns the file offset of the operation.

Trait Implementations§

Source§

impl<'a> Aio for AioWrite<'a>

Source§

type Output = usize

The return type of Aio::aio_return.
Source§

fn cancel(self: Pin<&mut Self>) -> Result<AioCancelStat>

Cancels an outstanding AIO request. Read more
Source§

fn error(self: Pin<&mut Self>) -> Result<()>

Retrieve error status of an asynchronous operation. Read more
Source§

fn fd(&self) -> RawFd

Returns the underlying file descriptor associated with the operation.
Source§

fn in_progress(&self) -> bool

Does this operation currently have any in-kernel state? Read more
Source§

fn priority(&self) -> i32

Returns the priority of the AioCb
Source§

fn set_sigev_notify(&mut self, sev: SigevNotify)

Update the notification settings for an existing AIO operation that has not yet been submitted.
Source§

fn sigevent(&self) -> SigEvent

Returns the SigEvent that will be used for notification.
Source§

fn aio_return(self: Pin<&mut Self>) -> Result<<Self as Aio>::Output>

Retrieve return status of an asynchronous operation. Read more
Source§

fn submit(self: Pin<&mut Self>) -> Result<()>

Actually start the I/O operation. Read more
Source§

impl<'a> AsMut<aiocb> for AioWrite<'a>

Source§

fn as_mut(&mut self) -> &mut aiocb

Converts this type into a mutable reference of the (usually inferred) input type.
Source§

impl<'a> AsRef<aiocb> for AioWrite<'a>

Source§

fn as_ref(&self) -> &aiocb

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

impl<'a> Debug for AioWrite<'a>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for AioWrite<'a>

§

impl<'a> RefUnwindSafe for AioWrite<'a>

§

impl<'a> Send for AioWrite<'a>

§

impl<'a> Sync for AioWrite<'a>

§

impl<'a> !Unpin for AioWrite<'a>

§

impl<'a> UnwindSafe for AioWrite<'a>

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

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.