use io::{self, Result}; use core::slice; use byteorder::ByteOrder; /// Extends `Read` with methods for reading numbers. (For `std::io`.) /// /// Most of the methods defined here have an unconstrained type parameter that /// must be explicitly instantiated. Typically, it is instantiated with either /// the `BigEndian` or `LittleEndian` types defined in this crate. /// /// # Examples /// /// Read unsigned 16 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![2, 5, 3, 0]); /// assert_eq!(517, rdr.read_u16::().unwrap()); /// assert_eq!(768, rdr.read_u16::().unwrap()); /// ``` pub trait ReadBytesExt: io::Read { /// Reads an unsigned 8 bit integer from the underlying reader. /// /// Note that since this reads a single byte, no byte order conversions /// are used. It is included for completeness. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read unsigned 8 bit integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![2, 5]); /// assert_eq!(2, rdr.read_u8().unwrap()); /// assert_eq!(5, rdr.read_u8().unwrap()); /// ``` #[inline] fn read_u8(&mut self) -> Result { let mut buf = [0; 1]; try!(self.read_exact(&mut buf)); Ok(buf[0]) } /// Reads a signed 8 bit integer from the underlying reader. /// /// Note that since this reads a single byte, no byte order conversions /// are used. It is included for completeness. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read unsigned 8 bit integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x02, 0xfb]); /// assert_eq!(2, rdr.read_i8().unwrap()); /// assert_eq!(-5, rdr.read_i8().unwrap()); /// ``` #[inline] fn read_i8(&mut self) -> Result { let mut buf = [0; 1]; try!(self.read_exact(&mut buf)); Ok(buf[0] as i8) } /// Reads an unsigned 16 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read unsigned 16 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![2, 5, 3, 0]); /// assert_eq!(517, rdr.read_u16::().unwrap()); /// assert_eq!(768, rdr.read_u16::().unwrap()); /// ``` #[inline] fn read_u16(&mut self) -> Result { let mut buf = [0; 2]; try!(self.read_exact(&mut buf)); Ok(T::read_u16(&buf)) } /// Reads a signed 16 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read signed 16 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x00, 0xc1, 0xff, 0x7c]); /// assert_eq!(193, rdr.read_i16::().unwrap()); /// assert_eq!(-132, rdr.read_i16::().unwrap()); /// ``` #[inline] fn read_i16(&mut self) -> Result { let mut buf = [0; 2]; try!(self.read_exact(&mut buf)); Ok(T::read_i16(&buf)) } /// Reads an unsigned 24 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read unsigned 24 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x00, 0x01, 0x0b]); /// assert_eq!(267, rdr.read_u24::().unwrap()); /// ``` #[inline] fn read_u24(&mut self) -> Result { let mut buf = [0; 3]; try!(self.read_exact(&mut buf)); Ok(T::read_u24(&buf)) } /// Reads a signed 24 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read signed 24 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0xff, 0x7a, 0x33]); /// assert_eq!(-34253, rdr.read_i24::().unwrap()); /// ``` #[inline] fn read_i24(&mut self) -> Result { let mut buf = [0; 3]; try!(self.read_exact(&mut buf)); Ok(T::read_i24(&buf)) } /// Reads an unsigned 32 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read unsigned 32 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x00, 0x00, 0x01, 0x0b]); /// assert_eq!(267, rdr.read_u32::().unwrap()); /// ``` #[inline] fn read_u32(&mut self) -> Result { let mut buf = [0; 4]; try!(self.read_exact(&mut buf)); Ok(T::read_u32(&buf)) } /// Reads a signed 32 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read signed 32 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0xff, 0xff, 0x7a, 0x33]); /// assert_eq!(-34253, rdr.read_i32::().unwrap()); /// ``` #[inline] fn read_i32(&mut self) -> Result { let mut buf = [0; 4]; try!(self.read_exact(&mut buf)); Ok(T::read_i32(&buf)) } /// Reads an unsigned 64 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read an unsigned 64 bit big-endian integer from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x00, 0x03, 0x43, 0x95, 0x4d, 0x60, 0x86, 0x83]); /// assert_eq!(918733457491587, rdr.read_u64::().unwrap()); /// ``` #[inline] fn read_u64(&mut self) -> Result { let mut buf = [0; 8]; try!(self.read_exact(&mut buf)); Ok(T::read_u64(&buf)) } /// Reads a signed 64 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a signed 64 bit big-endian integer from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x80, 0, 0, 0, 0, 0, 0, 0]); /// assert_eq!(i64::min_value(), rdr.read_i64::().unwrap()); /// ``` #[inline] fn read_i64(&mut self) -> Result { let mut buf = [0; 8]; try!(self.read_exact(&mut buf)); Ok(T::read_i64(&buf)) } /// Reads an unsigned 128 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read an unsigned 128 bit big-endian integer from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x00, 0x03, 0x43, 0x95, 0x4d, 0x60, 0x86, 0x83, /// 0x00, 0x03, 0x43, 0x95, 0x4d, 0x60, 0x86, 0x83 /// ]); /// assert_eq!(16947640962301618749969007319746179, rdr.read_u128::().unwrap()); /// ``` #[cfg(feature = "i128")] #[inline] fn read_u128(&mut self) -> Result { let mut buf = [0; 16]; try!(self.read_exact(&mut buf)); Ok(T::read_u128(&buf)) } /// Reads a signed 128 bit integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a signed 128 bit big-endian integer from a `Read`: /// /// ```rust /// #![feature(i128_type)] /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]); /// assert_eq!(i128::min_value(), rdr.read_i128::().unwrap()); /// ``` #[cfg(feature = "i128")] #[inline] fn read_i128(&mut self) -> Result { let mut buf = [0; 16]; try!(self.read_exact(&mut buf)); Ok(T::read_i128(&buf)) } /// Reads an unsigned n-bytes integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read an unsigned n-byte big-endian integer from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0x80, 0x74, 0xfa]); /// assert_eq!(8418554, rdr.read_uint::(3).unwrap()); #[inline] fn read_uint(&mut self, nbytes: usize) -> Result { let mut buf = [0; 8]; try!(self.read_exact(&mut buf[..nbytes])); Ok(T::read_uint(&buf[..nbytes], nbytes)) } /// Reads a signed n-bytes integer from the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read an unsigned n-byte big-endian integer from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0xc1, 0xff, 0x7c]); /// assert_eq!(-4063364, rdr.read_int::(3).unwrap()); #[inline] fn read_int(&mut self, nbytes: usize) -> Result { let mut buf = [0; 8]; try!(self.read_exact(&mut buf[..nbytes])); Ok(T::read_int(&buf[..nbytes], nbytes)) } /// Reads an unsigned n-bytes integer from the underlying reader. #[cfg(feature = "i128")] #[inline] fn read_uint128(&mut self, nbytes: usize) -> Result { let mut buf = [0; 16]; try!(self.read_exact(&mut buf[..nbytes])); Ok(T::read_uint128(&buf[..nbytes], nbytes)) } /// Reads a signed n-bytes integer from the underlying reader. #[cfg(feature = "i128")] #[inline] fn read_int128(&mut self, nbytes: usize) -> Result { let mut buf = [0; 16]; try!(self.read_exact(&mut buf[..nbytes])); Ok(T::read_int128(&buf[..nbytes], nbytes)) } /// Reads a IEEE754 single-precision (4 bytes) floating point number from /// the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a big-endian single-precision floating point number from a `Read`: /// /// ```rust /// use std::f32; /// use std::io::Cursor; /// /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x40, 0x49, 0x0f, 0xdb, /// ]); /// assert_eq!(f32::consts::PI, rdr.read_f32::().unwrap()); /// ``` #[inline] fn read_f32(&mut self) -> Result { let mut buf = [0; 4]; try!(self.read_exact(&mut buf)); Ok(T::read_f32(&buf)) } /// Reads a IEEE754 double-precision (8 bytes) floating point number from /// the underlying reader. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a big-endian double-precision floating point number from a `Read`: /// /// ```rust /// use std::f64; /// use std::io::Cursor; /// /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x40, 0x09, 0x21, 0xfb, 0x54, 0x44, 0x2d, 0x18, /// ]); /// assert_eq!(f64::consts::PI, rdr.read_f64::().unwrap()); /// ``` #[inline] fn read_f64(&mut self) -> Result { let mut buf = [0; 8]; try!(self.read_exact(&mut buf)); Ok(T::read_f64(&buf)) } /// Reads a sequence of unsigned 16 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of unsigned 16 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![2, 5, 3, 0]); /// let mut dst = [0; 2]; /// rdr.read_u16_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[inline] fn read_u16_into(&mut self, dst: &mut [u16]) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_u16(dst); Ok(()) } /// Reads a sequence of unsigned 32 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of unsigned 32 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0, 0, 2, 5, 0, 0, 3, 0]); /// let mut dst = [0; 2]; /// rdr.read_u32_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[inline] fn read_u32_into(&mut self, dst: &mut [u32]) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_u32(dst); Ok(()) } /// Reads a sequence of unsigned 64 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of unsigned 64 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0, 0, 0, 0, 0, 0, 2, 5, /// 0, 0, 0, 0, 0, 0, 3, 0, /// ]); /// let mut dst = [0; 2]; /// rdr.read_u64_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[inline] fn read_u64_into(&mut self, dst: &mut [u64]) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_u64(dst); Ok(()) } /// Reads a sequence of unsigned 128 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of unsigned 128 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 5, /// 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, /// ]); /// let mut dst = [0; 2]; /// rdr.read_u128_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[cfg(feature = "i128")] #[inline] fn read_u128_into( &mut self, dst: &mut [u128], ) -> Result<()> { { let mut buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_u128(dst); Ok(()) } /// Reads a sequence of signed 16 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of signed 16 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![2, 5, 3, 0]); /// let mut dst = [0; 2]; /// rdr.read_i16_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[inline] fn read_i16_into(&mut self, dst: &mut [i16]) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_i16(dst); Ok(()) } /// Reads a sequence of signed 32 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of signed 32 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![0, 0, 2, 5, 0, 0, 3, 0]); /// let mut dst = [0; 2]; /// rdr.read_i32_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[inline] fn read_i32_into(&mut self, dst: &mut [i32]) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_i32(dst); Ok(()) } /// Reads a sequence of signed 64 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of signed 64 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0, 0, 0, 0, 0, 0, 2, 5, /// 0, 0, 0, 0, 0, 0, 3, 0, /// ]); /// let mut dst = [0; 2]; /// rdr.read_i64_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[inline] fn read_i64_into(&mut self, dst: &mut [i64]) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_i64(dst); Ok(()) } /// Reads a sequence of signed 128 bit integers from the underlying /// reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of signed 128 bit big-endian integers from a `Read`: /// /// ```rust /// use std::io::Cursor; /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 5, /// 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, /// ]); /// let mut dst = [0; 2]; /// rdr.read_i128_into::(&mut dst).unwrap(); /// assert_eq!([517, 768], dst); /// ``` #[cfg(feature = "i128")] #[inline] fn read_i128_into( &mut self, dst: &mut [i128], ) -> Result<()> { { let mut buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_i128(dst); Ok(()) } /// Reads a sequence of IEEE754 single-precision (4 bytes) floating /// point numbers from the underlying reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of big-endian single-precision floating point number /// from a `Read`: /// /// ```rust /// use std::f32; /// use std::io::Cursor; /// /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x40, 0x49, 0x0f, 0xdb, /// 0x3f, 0x80, 0x00, 0x00, /// ]); /// let mut dst = [0.0; 2]; /// rdr.read_f32_into::(&mut dst).unwrap(); /// assert_eq!([f32::consts::PI, 1.0], dst); /// ``` #[inline] fn read_f32_into( &mut self, dst: &mut [f32], ) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_f32(dst); Ok(()) } /// **DEPRECATED**. /// /// This method is deprecated. Use `read_f32_into` instead. /// /// Reads a sequence of IEEE754 single-precision (4 bytes) floating /// point numbers from the underlying reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of big-endian single-precision floating point number /// from a `Read`: /// /// ```rust /// use std::f32; /// use std::io::Cursor; /// /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x40, 0x49, 0x0f, 0xdb, /// 0x3f, 0x80, 0x00, 0x00, /// ]); /// let mut dst = [0.0; 2]; /// rdr.read_f32_into_unchecked::(&mut dst).unwrap(); /// assert_eq!([f32::consts::PI, 1.0], dst); /// ``` #[inline] #[deprecated(since="1.2.0", note="please use `read_f32_into` instead")] fn read_f32_into_unchecked( &mut self, dst: &mut [f32], ) -> Result<()> { self.read_f32_into::(dst) } /// Reads a sequence of IEEE754 double-precision (8 bytes) floating /// point numbers from the underlying reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of big-endian single-precision floating point number /// from a `Read`: /// /// ```rust /// use std::f64; /// use std::io::Cursor; /// /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x40, 0x09, 0x21, 0xfb, 0x54, 0x44, 0x2d, 0x18, /// 0x3f, 0xF0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /// ]); /// let mut dst = [0.0; 2]; /// rdr.read_f64_into::(&mut dst).unwrap(); /// assert_eq!([f64::consts::PI, 1.0], dst); /// ``` #[inline] fn read_f64_into( &mut self, dst: &mut [f64], ) -> Result<()> { { let buf = unsafe { slice_to_u8_mut(dst) }; try!(self.read_exact(buf)); } T::from_slice_f64(dst); Ok(()) } /// **DEPRECATED**. /// /// This method is deprecated. Use `read_f64_into` instead. /// /// Reads a sequence of IEEE754 double-precision (8 bytes) floating /// point numbers from the underlying reader. /// /// The given buffer is either filled completely or an error is returned. /// If an error is returned, the contents of `dst` are unspecified. /// /// # Safety /// /// This method is unsafe because there are no guarantees made about the /// floating point values. In particular, this method does not check for /// signaling NaNs, which may result in undefined behavior. /// /// # Errors /// /// This method returns the same errors as [`Read::read_exact`]. /// /// [`Read::read_exact`]: https://doc.rust-lang.org/std/io/trait.Read.html#method.read_exact /// /// # Examples /// /// Read a sequence of big-endian single-precision floating point number /// from a `Read`: /// /// ```rust /// use std::f64; /// use std::io::Cursor; /// /// use byteorder::{BigEndian, ReadBytesExt}; /// /// let mut rdr = Cursor::new(vec![ /// 0x40, 0x09, 0x21, 0xfb, 0x54, 0x44, 0x2d, 0x18, /// 0x3f, 0xF0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /// ]); /// let mut dst = [0.0; 2]; /// rdr.read_f64_into_unchecked::(&mut dst).unwrap(); /// assert_eq!([f64::consts::PI, 1.0], dst); /// ``` #[inline] #[deprecated(since="1.2.0", note="please use `read_f64_into` instead")] fn read_f64_into_unchecked( &mut self, dst: &mut [f64], ) -> Result<()> { self.read_f64_into::(dst) } } /// All types that implement `Read` get methods defined in `ReadBytesExt` /// for free. impl ReadBytesExt for R {} /// Extends `Write` with methods for writing numbers. (For `std::io`.) /// /// Most of the methods defined here have an unconstrained type parameter that /// must be explicitly instantiated. Typically, it is instantiated with either /// the `BigEndian` or `LittleEndian` types defined in this crate. /// /// # Examples /// /// Write unsigned 16 bit big-endian integers to a `Write`: /// /// ```rust /// use byteorder::{BigEndian, WriteBytesExt}; /// /// let mut wtr = vec![]; /// wtr.write_u16::(517).unwrap(); /// wtr.write_u16::(768).unwrap(); /// assert_eq!(wtr, vec![2, 5, 3, 0]); /// ``` pub trait WriteBytesExt: io::Write { /// Writes an unsigned 8 bit integer to the underlying writer. /// /// Note that since this writes a single byte, no byte order conversions /// are used. It is included for completeness. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_u8(&mut self, n: u8) -> Result<()> { self.write_all(&[n]) } /// Writes a signed 8 bit integer to the underlying writer. /// /// Note that since this writes a single byte, no byte order conversions /// are used. It is included for completeness. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_i8(&mut self, n: i8) -> Result<()> { self.write_all(&[n as u8]) } /// Writes an unsigned 16 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_u16(&mut self, n: u16) -> Result<()> { let mut buf = [0; 2]; T::write_u16(&mut buf, n); self.write_all(&buf) } /// Writes a signed 16 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_i16(&mut self, n: i16) -> Result<()> { let mut buf = [0; 2]; T::write_i16(&mut buf, n); self.write_all(&buf) } /// Writes an unsigned 24 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_u24(&mut self, n: u32) -> Result<()> { let mut buf = [0; 3]; T::write_u24(&mut buf, n); self.write_all(&buf) } /// Writes a signed 24 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_i24(&mut self, n: i32) -> Result<()> { let mut buf = [0; 3]; T::write_i24(&mut buf, n); self.write_all(&buf) } /// Writes an unsigned 32 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_u32(&mut self, n: u32) -> Result<()> { let mut buf = [0; 4]; T::write_u32(&mut buf, n); self.write_all(&buf) } /// Writes a signed 32 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_i32(&mut self, n: i32) -> Result<()> { let mut buf = [0; 4]; T::write_i32(&mut buf, n); self.write_all(&buf) } /// Writes an unsigned 64 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_u64(&mut self, n: u64) -> Result<()> { let mut buf = [0; 8]; T::write_u64(&mut buf, n); self.write_all(&buf) } /// Writes a signed 64 bit integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_i64(&mut self, n: i64) -> Result<()> { let mut buf = [0; 8]; T::write_i64(&mut buf, n); self.write_all(&buf) } /// Writes an unsigned 128 bit integer to the underlying writer. #[cfg(feature = "i128")] #[inline] fn write_u128(&mut self, n: u128) -> Result<()> { let mut buf = [0; 16]; T::write_u128(&mut buf, n); self.write_all(&buf) } /// Writes a signed 128 bit integer to the underlying writer. #[cfg(feature = "i128")] #[inline] fn write_i128(&mut self, n: i128) -> Result<()> { let mut buf = [0; 16]; T::write_i128(&mut buf, n); self.write_all(&buf) } /// Writes an unsigned n-bytes integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all /// /// # Panics /// /// If the given integer is not representable in the given number of bytes, /// this method panics. If `nbytes > 8`, this method panics. #[inline] fn write_uint( &mut self, n: u64, nbytes: usize, ) -> Result<()> { let mut buf = [0; 8]; T::write_uint(&mut buf, n, nbytes); self.write_all(&buf[0..nbytes]) } /// Writes a signed n-bytes integer to the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all /// /// # Panics /// /// If the given integer is not representable in the given number of bytes, /// this method panics. If `nbytes > 8`, this method panics. #[inline] fn write_int( &mut self, n: i64, nbytes: usize, ) -> Result<()> { let mut buf = [0; 8]; T::write_int(&mut buf, n, nbytes); self.write_all(&buf[0..nbytes]) } /// Writes an unsigned n-bytes integer to the underlying writer. /// /// If the given integer is not representable in the given number of bytes, /// this method panics. If `nbytes > 16`, this method panics. #[cfg(feature = "i128")] #[inline] fn write_uint128( &mut self, n: u128, nbytes: usize, ) -> Result<()> { let mut buf = [0; 16]; T::write_uint128(&mut buf, n, nbytes); self.write_all(&buf[0..nbytes]) } /// Writes a signed n-bytes integer to the underlying writer. /// /// If the given integer is not representable in the given number of bytes, /// this method panics. If `nbytes > 16`, this method panics. #[cfg(feature = "i128")] #[inline] fn write_int128( &mut self, n: i128, nbytes: usize, ) -> Result<()> { let mut buf = [0; 16]; T::write_int128(&mut buf, n, nbytes); self.write_all(&buf[0..nbytes]) } /// Writes a IEEE754 single-precision (4 bytes) floating point number to /// the underlying writer. /// /// # Errors /// /// This method returns the same errors as [`Write::write_all`]. /// /// [`Write::write_all`]: https://doc.rust-lang.org/std/io/trait.Write.html#method.write_all #[inline] fn write_f32(&mut self, n: f32) -> Result<()> { let mut buf = [0; 4]; T::write_f32(&mut buf, n); self.write_all(&buf) } /// Writes a IEEE754 double-precision (8 bytes) floating point number to /// the underlying writer. #[inline] fn write_f64(&mut self, n: f64) -> Result<()> { let mut buf = [0; 8]; T::write_f64(&mut buf, n); self.write_all(&buf) } } /// All types that implement `Write` get methods defined in `WriteBytesExt` /// for free. impl WriteBytesExt for W {} /// Convert a slice of T (where T is plain old data) to its mutable binary /// representation. /// /// This function is wildly unsafe because it permits arbitrary modification of /// the binary representation of any `Copy` type. Use with care. unsafe fn slice_to_u8_mut(slice: &mut [T]) -> &mut [u8] { use core::mem::size_of; let len = size_of::() * slice.len(); slice::from_raw_parts_mut(slice.as_mut_ptr() as *mut u8, len) }