refactor(http): combine reserve_read_buf into read_from_io
This commit is contained in:
		| @@ -68,7 +68,6 @@ impl<T: AsyncRead + AsyncWrite> Buffered<T> { | ||||
|                     } | ||||
|                 }, | ||||
|             } | ||||
|             self.reserve_read_buf(); | ||||
|             match self.read_from_io() { | ||||
|                 Ok(0) => { | ||||
|                     trace!("parse eof"); | ||||
| @@ -88,8 +87,17 @@ impl<T: AsyncRead + AsyncWrite> Buffered<T> { | ||||
|  | ||||
|     fn read_from_io(&mut self) -> io::Result<usize> { | ||||
|         use bytes::BufMut; | ||||
|         // TODO: Investigate if we still need these unsafe blocks | ||||
|         if self.read_buf.remaining_mut() < INIT_BUFFER_SIZE { | ||||
|             self.read_buf.reserve(INIT_BUFFER_SIZE); | ||||
|             unsafe { // Zero out unused memory | ||||
|                 let buf = self.read_buf.bytes_mut(); | ||||
|                 let len = buf.len(); | ||||
|                 ptr::write_bytes(buf.as_mut_ptr(), 0, len); | ||||
|             } | ||||
|         } | ||||
|         self.read_blocked = false; | ||||
|         unsafe { | ||||
|         unsafe { // Can we use AsyncRead::read_buf instead? | ||||
|             let n = match self.io.read(self.read_buf.bytes_mut()) { | ||||
|                 Ok(n) => n, | ||||
|                 Err(e) => { | ||||
| @@ -104,19 +112,6 @@ impl<T: AsyncRead + AsyncWrite> Buffered<T> { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     fn reserve_read_buf(&mut self) { | ||||
|         use bytes::BufMut; | ||||
|         if self.read_buf.remaining_mut() >= INIT_BUFFER_SIZE { | ||||
|             return | ||||
|         } | ||||
|         self.read_buf.reserve(INIT_BUFFER_SIZE); | ||||
|         unsafe { | ||||
|             let buf = self.read_buf.bytes_mut(); | ||||
|             let len = buf.len(); | ||||
|             ptr::write_bytes(buf.as_mut_ptr(), 0, len); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     pub fn buffer<B: AsRef<[u8]>>(&mut self, buf: B) -> usize { | ||||
|         self.write_buf.buffer(buf.as_ref()) | ||||
|     } | ||||
| @@ -163,7 +158,6 @@ impl<T: AsyncRead + AsyncWrite> MemRead for Buffered<T> { | ||||
|             trace!("Buffered.read_mem read_buf is not empty, slicing {}", n); | ||||
|             Ok(self.read_buf.split_to(n).freeze()) | ||||
|         } else { | ||||
|             self.reserve_read_buf(); | ||||
|             let n = try!(self.read_from_io()); | ||||
|             Ok(self.read_buf.split_to(::std::cmp::min(len, n)).freeze()) | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user