2
0
Fork 1
mirror of https://github.com/async-rs/async-std.git synced 2025-10-20 17:16:35 +00:00

When read returns EOF, ensure future reads still check the file for EOF

Go back to the idle mode when returning EOF, so that the next read will
make another attempt to read from the file in case the file grew.
This commit is contained in:
Josh Triplett 2022-06-30 02:00:09 -07:00
parent 955fa65a64
commit 64b7791ee5

View file

@ -670,14 +670,19 @@ impl LockGuard<State> {
match self.mode { match self.mode {
Mode::Idle => {} Mode::Idle => {}
Mode::Reading(0) if self.cache.is_empty() => {
// If the cache is empty in reading mode, the last operation didn't read any bytes,
// which indicates that it reached the end of the file. In this case we need to
// reset the mode to idle so that next time we try to read again, since the file
// may grow after the first EOF.
self.mode = Mode::Idle;
return Poll::Ready(Ok(0));
}
Mode::Reading(start) => { Mode::Reading(start) => {
// How many bytes in the cache are available for reading. // How many bytes in the cache are available for reading.
let available = self.cache.len() - start; let available = self.cache.len() - start;
// If there is cached unconsumed data or if the cache is empty, we can read from if available > 0 {
// it. Empty cache in reading mode indicates that the last operation didn't read
// any bytes, i.e. it reached the end of the file.
if available > 0 || self.cache.is_empty() {
// Copy data from the cache into the buffer. // Copy data from the cache into the buffer.
let n = cmp::min(available, buf.len()); let n = cmp::min(available, buf.len());
buf[..n].copy_from_slice(&self.cache[start..(start + n)]); buf[..n].copy_from_slice(&self.cache[start..(start + n)]);