From 29604d52aee4f2dcad46e617ec21a00e24bb64f7 Mon Sep 17 00:00:00 2001 From: Alyssa Ross Date: Sun, 7 Jun 2020 04:34:52 +0000 Subject: msg_socket: implement MsgOnSocket for Result --- msg_socket/src/msg_on_socket.rs | 51 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) diff --git a/msg_socket/src/msg_on_socket.rs b/msg_socket/src/msg_on_socket.rs index 4149098..3dc59c0 100644 --- a/msg_socket/src/msg_on_socket.rs +++ b/msg_socket/src/msg_on_socket.rs @@ -196,6 +196,57 @@ impl MsgOnSocket for Option { } } +impl MsgOnSocket for Result { + fn uses_fd() -> bool { + O::uses_fd() || E::uses_fd() + } + + fn msg_size(&self) -> usize { + 1 + match self { + Ok(v) => v.msg_size(), + Err(e) => e.msg_size(), + } + } + + fn fd_count(&self) -> usize { + match self { + Ok(v) => v.fd_count(), + Err(e) => e.fd_count(), + } + } + + unsafe fn read_from_buffer(buffer: &[u8], fds: &[RawFd]) -> MsgResult<(Self, usize)> { + match buffer.get(0).ok_or(MsgError::WrongMsgBufferSize)? { + 0 => { + let (value, size) = O::read_from_buffer(&buffer[1..], &fds)?; + Ok((Ok(value), size)) + } + 1 => { + let (value, size) = E::read_from_buffer(&buffer[1..], &fds)?; + Ok((Err(value), size)) + } + _ => Err(MsgError::InvalidType), + } + } + + fn write_to_buffer(&self, buffer: &mut [u8], mut fds: &mut [RawFd]) -> MsgResult { + if buffer.is_empty() { + return Err(MsgError::WrongMsgBufferSize); + } + + match self { + Ok(value) => { + buffer[0] = 0; + Ok(value.write_to_buffer(&mut buffer[1..], &mut fds)?) + } + Err(error) => { + buffer[0] = 1; + Ok(error.write_to_buffer(&mut buffer[1..], &mut fds)?) + } + } + } +} + impl MsgOnSocket for Mutex { fn uses_fd() -> bool { T::uses_fd() -- cgit 1.4.1