From ea1f886e502bc826cd4e241d06ffd0ad26e95d00 Mon Sep 17 00:00:00 2001 From: nwin Date: Sat, 14 Mar 2015 13:39:39 +0100 Subject: [PATCH] Use generic trait implementations for Cursor when possible. --- src/libstd/io/cursor.rs | 74 ++++++++++++++--------------------------- 1 file changed, 25 insertions(+), 49 deletions(-) diff --git a/src/libstd/io/cursor.rs b/src/libstd/io/cursor.rs index 9590f0b7aa726..542b67adf2489 100644 --- a/src/libstd/io/cursor.rs +++ b/src/libstd/io/cursor.rs @@ -192,67 +192,43 @@ impl Cursor { pub fn set_position(&mut self, pos: u64) { self.pos = pos; } } -macro_rules! seek { - () => { - fn seek(&mut self, style: SeekFrom) -> io::Result { - let pos = match style { - SeekFrom::Start(n) => { self.pos = n; return Ok(n) } - SeekFrom::End(n) => self.inner.len() as i64 + n, - SeekFrom::Current(n) => self.pos as i64 + n, - }; - - if pos < 0 { - Err(Error::new(ErrorKind::InvalidInput, - "invalid seek to a negative position")) - } else { - self.pos = pos as u64; - Ok(self.pos) - } +#[stable(feature = "rust1", since = "1.0.0")] +impl io::Seek for Cursor where T: AsRef<[u8]> { + fn seek(&mut self, style: SeekFrom) -> io::Result { + let pos = match style { + SeekFrom::Start(n) => { self.pos = n; return Ok(n) } + SeekFrom::End(n) => self.inner.as_ref().len() as i64 + n, + SeekFrom::Current(n) => self.pos as i64 + n, + }; + + if pos < 0 { + Err(Error::new(ErrorKind::InvalidInput, + "invalid seek to a negative position")) + } else { + self.pos = pos as u64; + Ok(self.pos) } } } #[stable(feature = "rust1", since = "1.0.0")] -impl<'a> io::Seek for Cursor<&'a [u8]> { seek!(); } -#[stable(feature = "rust1", since = "1.0.0")] -impl<'a> io::Seek for Cursor<&'a mut [u8]> { seek!(); } -#[stable(feature = "rust1", since = "1.0.0")] -impl io::Seek for Cursor> { seek!(); } - -macro_rules! read { - () => { - fn read(&mut self, buf: &mut [u8]) -> io::Result { - let n = try!(Read::read(&mut try!(self.fill_buf()), buf)); - self.pos += n as u64; - Ok(n) - } +impl Read for Cursor where T: AsRef<[u8]> { + fn read(&mut self, buf: &mut [u8]) -> io::Result { + let n = try!(Read::read(&mut try!(self.fill_buf()), buf)); + self.pos += n as u64; + Ok(n) } } #[stable(feature = "rust1", since = "1.0.0")] -impl<'a> Read for Cursor<&'a [u8]> { read!(); } -#[stable(feature = "rust1", since = "1.0.0")] -impl<'a> Read for Cursor<&'a mut [u8]> { read!(); } -#[stable(feature = "rust1", since = "1.0.0")] -impl Read for Cursor> { read!(); } - -macro_rules! buffer { - () => { - fn fill_buf(&mut self) -> io::Result<&[u8]> { - let amt = cmp::min(self.pos, self.inner.len() as u64); - Ok(&self.inner[(amt as usize)..]) - } - fn consume(&mut self, amt: usize) { self.pos += amt as u64; } +impl BufRead for Cursor where T: AsRef<[u8]> { + fn fill_buf(&mut self) -> io::Result<&[u8]> { + let amt = cmp::min(self.pos, self.inner.as_ref().len() as u64); + Ok(&self.inner.as_ref()[(amt as usize)..]) } + fn consume(&mut self, amt: usize) { self.pos += amt as u64; } } -#[stable(feature = "rust1", since = "1.0.0")] -impl<'a> BufRead for Cursor<&'a [u8]> { buffer!(); } -#[stable(feature = "rust1", since = "1.0.0")] -impl<'a> BufRead for Cursor<&'a mut [u8]> { buffer!(); } -#[stable(feature = "rust1", since = "1.0.0")] -impl<'a> BufRead for Cursor> { buffer!(); } - #[stable(feature = "rust1", since = "1.0.0")] impl<'a> Write for Cursor<&'a mut [u8]> { fn write(&mut self, data: &[u8]) -> io::Result {