use crate::buf::fixed::FixedBuf;
use crate::buf::BoundedBuf;
use crate::io::SharedFd;
use crate::runtime::driver::op::{self, Completable, Op};
use crate::BufResult;
use crate::runtime::CONTEXT;
use std::io;
pub(crate) struct WriteFixed<T> {
#[allow(dead_code)]
fd: SharedFd,
buf: T,
}
impl<T> Op<WriteFixed<T>>
where
T: BoundedBuf<Buf = FixedBuf>,
{
pub(crate) fn write_fixed_at(
fd: &SharedFd,
buf: T,
offset: u64,
) -> io::Result<Op<WriteFixed<T>>> {
use io_uring::{opcode, types};
CONTEXT.with(|x| {
x.handle().expect("Not in a runtime context").submit_op(
WriteFixed {
fd: fd.clone(),
buf,
},
|write_fixed| {
let ptr = write_fixed.buf.stable_ptr();
let len = write_fixed.buf.bytes_init();
let buf_index = write_fixed.buf.get_buf().buf_index();
opcode::WriteFixed::new(types::Fd(fd.raw_fd()), ptr, len as _, buf_index)
.offset(offset as _)
.build()
},
)
})
}
}
impl<T> Completable for WriteFixed<T> {
type Output = BufResult<usize, T>;
fn complete(self, cqe: op::CqeResult) -> Self::Output {
let res = cqe.result.map(|v| v as usize);
let buf = self.buf;
(res, buf)
}
}