Skip to content

Commit

Permalink
fix: handle unexpected EOF in PeekReader in case zero bytes has read
Browse files Browse the repository at this point in the history
  • Loading branch information
kusstas committed Dec 22, 2024
1 parent f801bea commit 93a7cb7
Showing 1 changed file with 9 additions and 1 deletion.
10 changes: 9 additions & 1 deletion mavlink-core/src/peek_reader.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ use crate::embedded::Read;
#[cfg(feature = "std")]
use std::io::Read;

use crate::error::MessageReadError;
use crate::{bytes, error::MessageReadError};

/// A buffered/peekable reader
///
Expand Down Expand Up @@ -134,6 +134,14 @@ impl<R: Read, const BUFFER_SIZE: usize> PeekReader<R, BUFFER_SIZE> {
// read needed bytes from reader
let bytes_read = self.reader.read(&mut buf[..bytes_to_read])?;

if bytes_read == 0 {
// EOF
return Err(MessageReadError::Io(std::io::Error::new(
std::io::ErrorKind::UnexpectedEof,
"Unexpected EOF",
)));
}

// if some bytes were read, add them to the buffer

if self.buffer.len() - self.top < bytes_read {
Expand Down

0 comments on commit 93a7cb7

Please sign in to comment.