diff options
| author | Alejandro Soto <alejandro@34project.org> | 2022-01-05 02:52:04 -0600 |
|---|---|---|
| committer | Alejandro Soto <alejandro@34project.org> | 2022-01-05 02:52:04 -0600 |
| commit | 75cced9d4c101ec2f9f04ed95621ff3a3f750eae (patch) | |
| tree | a8ff3fa46a75b18ee3c1133aa6fc0857132d6115 /src/ops/rw.rs | |
| parent | ff17b04143dde5157808be5bcf1cbf8a942db4c4 (diff) | |
Refactor impls of Reply as individual traits
Diffstat (limited to '')
| -rw-r--r-- | src/ops/rw.rs | 46 |
1 files changed, 17 insertions, 29 deletions
diff --git a/src/ops/rw.rs b/src/ops/rw.rs index b1c184b..8206c7c 100644 --- a/src/ops/rw.rs +++ b/src/ops/rw.rs @@ -1,6 +1,9 @@ -use super::FromRequest; -use crate::{private_trait::Sealed, proto, util::OutputChain, Done, Operation, Reply, Request}; -use std::{ffi::OsStr, os::unix::ffi::OsStrExt}; +use super::{ + traits::{ReplyGather, ReplyOk}, + FromRequest, +}; + +use crate::{private_trait::Sealed, proto, Done, Operation, Reply, Request}; pub enum Readlink {} pub enum Read {} @@ -11,6 +14,10 @@ pub struct WriteState { size: u32, } +pub trait ReplyAll<'o>: Operation<'o> { + fn all(reply: Reply<'o, Self>) -> Done<'o>; +} + impl Sealed for Readlink {} impl Sealed for Read {} impl Sealed for Write {} @@ -36,18 +43,7 @@ impl<'o> Operation<'o> for Flush { type ReplyTail = (); } -impl<'o> Reply<'o, Readlink> { - /// This inode corresponds to a symbolic link pointing to the given target path. - pub fn target<T: AsRef<OsStr>>(self, target: T) -> Done<'o> { - self.chain(OutputChain::tail(&[target.as_ref().as_bytes()])) - } - - /// Same as [`Reply::target()`], except that the target path is taken from disjoint - /// slices. This involves no additional allocation. - pub fn gather_target(self, target: &[&[u8]]) -> Done<'o> { - self.chain(OutputChain::tail(target)) - } -} +impl<'o> ReplyGather<'o> for Readlink {} impl<'o> Request<'o, Read> { pub fn handle(&self) -> u64 { @@ -63,11 +59,7 @@ impl<'o> Request<'o, Read> { } } -impl<'o> Reply<'o, Read> { - pub fn slice(self, data: &[u8]) -> Done<'o> { - self.chain(OutputChain::tail(&[data])) - } -} +impl<'o> ReplyGather<'o> for Read {} impl<'o> Request<'o, Write> { pub fn handle(&self) -> u64 { @@ -83,10 +75,10 @@ impl<'o> Request<'o, Write> { } } -impl<'o> Reply<'o, Write> { - pub fn all(self) -> Done<'o> { - let size = self.tail.size; - self.single(&proto::WriteOut { +impl<'o> ReplyAll<'o> for Write { + fn all(reply: Reply<'o, Self>) -> Done<'o> { + let size = reply.tail.size; + reply.single(&proto::WriteOut { size, padding: Default::default(), }) @@ -99,11 +91,7 @@ impl<'o> Request<'o, Flush> { } } -impl<'o> Reply<'o, Flush> { - pub fn ok(self) -> Done<'o> { - self.empty() - } -} +impl<'o> ReplyOk<'o> for Flush {} impl<'o> FromRequest<'o, Write> for WriteState { fn from_request(request: &Request<'o, Write>) -> Self { |
