Skip to content

Commit

Permalink
Use set-len when reading into buffer
Browse files Browse the repository at this point in the history
  • Loading branch information
alexheretic committed Dec 17, 2024
1 parent ff7325f commit 8a0faba
Showing 1 changed file with 19 additions and 15 deletions.
34 changes: 19 additions & 15 deletions src/protocol/frame/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ use crate::{
};
use bytes::BytesMut;
use log::*;
use std::io::{Cursor, Error as IoError, ErrorKind as IoErrorKind, Read, Write};
use std::io::{self, Cursor, Error as IoError, ErrorKind as IoErrorKind, Read, Write};

/// Read buffer size used for `FrameSocket`.
const READ_BUF_LEN: usize = 128 * 1024;
Expand Down Expand Up @@ -154,14 +154,11 @@ impl FrameCodec {
}

/// Read a frame from the provided stream.
pub(super) fn read_frame<Stream>(
pub(super) fn read_frame(
&mut self,
stream: &mut Stream,
stream: &mut impl Read,
max_size: Option<usize>,
) -> Result<Option<Frame>>
where
Stream: Read,
{
) -> Result<Option<Frame>> {
let max_size = max_size.unwrap_or_else(usize::max_value);

let payload = loop {
Expand Down Expand Up @@ -192,14 +189,8 @@ impl FrameCodec {
}

// Not enough data in buffer.
let reserve_len = self.header.as_ref().map(|(_, l)| *l as usize).unwrap_or(6);
self.in_buffer.reserve(reserve_len);
let mut buf = self.in_buffer.split_off(self.in_buffer.len());
buf.resize(reserve_len.max(buf.capacity()), 0);
let size = stream.read(&mut buf)?;
buf.truncate(size);
self.in_buffer.unsplit(buf);
if size == 0 {
self.in_buffer.reserve(self.header.as_ref().map(|(_, l)| *l as usize).unwrap_or(6));
if self.read_in(stream)? == 0 {
trace!("no frame received");
return Ok(None);
}
Expand All @@ -212,6 +203,19 @@ impl FrameCodec {
Ok(Some(frame))
}

/// Read into available `in_buffer` capacity.
fn read_in(&mut self, stream: &mut impl Read) -> io::Result<usize> {
let len = self.in_buffer.len();
debug_assert!(self.in_buffer.capacity() > len);
// SAFETY: truncated after read so uninit bytes are never read
unsafe {
self.in_buffer.set_len(self.in_buffer.capacity());
}
let size = stream.read(&mut self.in_buffer[len..]);
self.in_buffer.truncate(len + size.as_ref().copied().unwrap_or(0));
size
}

/// Writes a frame into the `out_buffer`.
/// If the out buffer size is over the `out_buffer_write_len` will also write
/// the out buffer into the provided `stream`.
Expand Down

0 comments on commit 8a0faba

Please sign in to comment.