diff options
| -rw-r--r-- | CHANGELOG | 2 | ||||
| -rw-r--r-- | Cargo.toml | 2 | ||||
| -rw-r--r-- | src/reader.rs | 7 | ||||
| -rw-r--r-- | tests/lib.rs | 2 | ||||
| -rw-r--r-- | tests/reader.rs | 24 | 
5 files changed, 34 insertions, 3 deletions
| @@ -2,6 +2,8 @@  added `Reader` impls for `U8Reader` on `u16` addresses +fix incorrect `Reader` impls of `offset` and `total_offset` on non-`u8` words +  ## 0.2.2  added `ReaderBuilder` trait and impls for `U8Reader` on various address and word types. @@ -7,7 +7,7 @@ keywords = ["disassembly", "disassembler"]  license = "0BSD"  name = "yaxpeax-arch"  repository = "https://git.iximeow.net/yaxpeax-arch/" -version = "0.2.3" +version = "0.2.4"  [dependencies]  "num-traits" = { version = "0.2", default-features = false } diff --git a/src/reader.rs b/src/reader.rs index db72b79..acb0146 100644 --- a/src/reader.rs +++ b/src/reader.rs @@ -6,6 +6,7 @@ impl From<ReadError> for StandardDecodeError {      }  } +#[derive(Debug, PartialEq, Eq, Copy, Clone)]  pub enum ReadError {      ExhaustedInput,      IOError(&'static str), @@ -167,11 +168,13 @@ macro_rules! u8reader_reader_impl {              }              #[inline]              fn offset(&mut self) -> $addr_size { -                (self.data as usize - self.mark as usize) as $addr_size +                (self.data as usize - self.mark as usize) as $addr_size / +                    (core::mem::size_of::<$word>() as $addr_size)              }              #[inline]              fn total_offset(&mut self) -> $addr_size { -                (self.data as usize - self.start as usize) as $addr_size +                (self.data as usize - self.start as usize) as $addr_size / +                    (core::mem::size_of::<$word>() as $addr_size)              }          } diff --git a/tests/lib.rs b/tests/lib.rs index 9add6e3..1d5e964 100644 --- a/tests/lib.rs +++ b/tests/lib.rs @@ -1,5 +1,7 @@  use yaxpeax_arch::AddressBase; +mod reader; +  #[test]  fn test_u16() {      for l in 0..100 { diff --git a/tests/reader.rs b/tests/reader.rs new file mode 100644 index 0000000..d5d5440 --- /dev/null +++ b/tests/reader.rs @@ -0,0 +1,24 @@ +use yaxpeax_arch::{Reader, U8Reader, U16le, U32le}; + +#[test] +fn reader_offset_is_words_not_bytes() { +    fn test_u16<T: Reader<u64, U16le>>(reader: &mut T) { +        reader.mark(); +        assert_eq!(reader.offset(), 0); +        reader.next().unwrap(); +        assert_eq!(reader.offset(), 1); +        reader.mark(); +        reader.next().unwrap(); +        assert_eq!(reader.offset(), 1); +        assert_eq!(reader.total_offset(), 2); +    } +    fn test_u32<T: Reader<u64, U32le>>(reader: &mut T) { +        reader.mark(); +        assert_eq!(reader.offset(), 0); +        reader.next().unwrap(); +        assert_eq!(reader.offset(), 1); +    } + +    test_u16(&mut U8Reader::new(&[0x01, 0x02, 0x03, 0x04])); +    test_u32(&mut U8Reader::new(&[0x01, 0x02, 0x03, 0x04])); +} | 
