Skip to content

Commit

Permalink
Rename Take::limit_ field to limit
Browse files Browse the repository at this point in the history
This workaround is no longer needed.
  • Loading branch information
taiki-e committed May 10, 2021
1 parent 61dae0d commit aa39d14
Showing 1 changed file with 11 additions and 12 deletions.
23 changes: 11 additions & 12 deletions futures-util/src/io/take.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,13 @@ pin_project! {
pub struct Take<R> {
#[pin]
inner: R,
// Add '_' to avoid conflicts with `limit` method.
limit_: u64,
limit: u64,
}
}

impl<R: AsyncRead> Take<R> {
pub(super) fn new(inner: R, limit: u64) -> Self {
Self { inner, limit_: limit }
Self { inner, limit }
}

/// Returns the remaining number of bytes that can be
Expand All @@ -48,7 +47,7 @@ impl<R: AsyncRead> Take<R> {
/// # Ok::<(), Box<dyn std::error::Error>>(()) }).unwrap();
/// ```
pub fn limit(&self) -> u64 {
self.limit_
self.limit
}

/// Sets the number of bytes that can be read before this instance will
Expand Down Expand Up @@ -78,7 +77,7 @@ impl<R: AsyncRead> Take<R> {
/// # Ok::<(), Box<dyn std::error::Error>>(()) }).unwrap();
/// ```
pub fn set_limit(&mut self, limit: u64) {
self.limit_ = limit
self.limit = limit
}

delegate_access_inner!(inner, R, ());
Expand All @@ -92,13 +91,13 @@ impl<R: AsyncRead> AsyncRead for Take<R> {
) -> Poll<Result<usize, io::Error>> {
let this = self.project();

if *this.limit_ == 0 {
if *this.limit == 0 {
return Poll::Ready(Ok(0));
}

let max = cmp::min(buf.len() as u64, *this.limit_) as usize;
let max = cmp::min(buf.len() as u64, *this.limit) as usize;
let n = ready!(this.inner.poll_read(cx, &mut buf[..max]))?;
*this.limit_ -= n as u64;
*this.limit -= n as u64;
Poll::Ready(Ok(n))
}

Expand All @@ -113,21 +112,21 @@ impl<R: AsyncBufRead> AsyncBufRead for Take<R> {
let this = self.project();

// Don't call into inner reader at all at EOF because it may still block
if *this.limit_ == 0 {
if *this.limit == 0 {
return Poll::Ready(Ok(&[]));
}

let buf = ready!(this.inner.poll_fill_buf(cx)?);
let cap = cmp::min(buf.len() as u64, *this.limit_) as usize;
let cap = cmp::min(buf.len() as u64, *this.limit) as usize;
Poll::Ready(Ok(&buf[..cap]))
}

fn consume(self: Pin<&mut Self>, amt: usize) {
let this = self.project();

// Don't let callers reset the limit by passing an overlarge value
let amt = cmp::min(amt as u64, *this.limit_) as usize;
*this.limit_ -= amt as u64;
let amt = cmp::min(amt as u64, *this.limit) as usize;
*this.limit -= amt as u64;
this.inner.consume(amt);
}
}

0 comments on commit aa39d14

Please sign in to comment.