| //! Helper functions and structures for debugging purpose |
| |
| use nom::combinator::{map, peek, rest}; |
| use nom::HexDisplay; |
| use nom::IResult; |
| use std::fmt; |
| |
| /// Dump the remaining bytes to stderr, formatted as hex |
| pub fn dbg_dmp_rest(i: &[u8]) -> IResult<&[u8], ()> { |
| map(peek(rest), |r: &[u8]| eprintln!("\n{}\n", r.to_hex(16)))(i) |
| } |
| |
| /// Wrapper for printing value as u8 hex data |
| pub struct HexU8(pub u8); |
| |
| impl fmt::Debug for HexU8 { |
| fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result { |
| write!(fmt, "0x{:02x}", self.0) |
| } |
| } |
| |
| /// Wrapper for printing value as u16 hex data |
| pub struct HexU16(pub u16); |
| |
| impl fmt::Debug for HexU16 { |
| fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result { |
| write!(fmt, "0x{:04x}", self.0) |
| } |
| } |
| |
| /// Wrapper for printing slice as hex data |
| pub struct HexSlice<'a>(pub &'a [u8]); |
| |
| impl<'a> fmt::Debug for HexSlice<'a> { |
| fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result { |
| let s: Vec<_> = self.0.iter().map(|&i| format!("{:02x}", i)).collect(); |
| write!(fmt, "[{}]", s.join(" ")) |
| } |
| } |
| |
| #[cfg(test)] |
| mod tests { |
| use crate::debug; |
| |
| #[test] |
| fn debug_print_hexu8() { |
| assert_eq!(format!("{:?}", debug::HexU8(18)), "0x12"); |
| } |
| |
| #[test] |
| fn debug_print_hexu16() { |
| assert_eq!(format!("{:?}", debug::HexU16(32769)), "0x8001"); |
| } |
| |
| #[test] |
| fn debug_print_hexslice() { |
| assert_eq!( |
| format!("{:?}", debug::HexSlice(&[15, 16, 17, 18, 19, 20])), |
| "[0f 10 11 12 13 14]" |
| ); |
| } |
| } |