Trait tract_pulse::internal::fmt::LowerHex1.0.0[][src]

pub trait LowerHex {
    fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>;
}
Expand description

x formatting.

The LowerHex trait should format its output as a number in hexadecimal, with a through f in lower case.

For primitive signed integers (i8 to i128, and isize), negative values are formatted as the two’s complement representation.

The alternate flag, #, adds a 0x in front of the output.

For more information on formatters, see the module-level documentation.

Examples

Basic usage with i32:

let x = 42; // 42 is '2a' in hex

assert_eq!(format!("{:x}", x), "2a");
assert_eq!(format!("{:#x}", x), "0x2a");

assert_eq!(format!("{:x}", -16), "fffffff0");

Implementing LowerHex on a type:

use std::fmt;

struct Length(i32);

impl fmt::LowerHex for Length {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        let val = self.0;

        fmt::LowerHex::fmt(&val, f) // delegate to i32's implementation
    }
}

let l = Length(9);

assert_eq!(format!("l as hex is: {:x}", l), "l as hex is: 9");

assert_eq!(format!("l as hex is: {:#010x}", l), "l as hex is: 0x00000009");

Required methods

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

Expand description

Formats the value using the given formatter.

Implementations on Foreign Types

impl LowerHex for i128[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<'_, T> LowerHex for &'_ T where
    T: LowerHex + ?Sized
[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for isize[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for u32[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for i8[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<'_, T> LowerHex for &'_ mut T where
    T: LowerHex + ?Sized
[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for u64[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for i16[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for u8[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for i64[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for u128[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for i32[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for u16[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for usize[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<T> LowerHex for Complex<T> where
    T: LowerHex + Num + PartialOrd<T> + Clone
[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for bf16[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for f16[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<O, T> LowerHex for BitVec<O, T> where
    O: BitOrder,
    T: BitStore, 

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<O, T> LowerHex for BitSlice<O, T> where
    O: BitOrder,
    T: BitStore, 

Render the contents of a BitSlice in a numeric format.

These implementations render the bits of memory contained in a BitSlice as one of the three numeric bases that the Rust format system supports:

  • Binary renders each bit individually as 0 or 1,
  • Octal renders clusters of three bits as the numbers 0 through 7,
  • and UpperHex and LowerHex render clusters of four bits as the numbers 0 through 9 and A through F.

The formatters produce a “word” for each element T of memory. The chunked formats (octal and hexadecimal) operate somewhat peculiarly: they show the semantic value of the memory, as interpreted by the ordering parameter’s implementation rather than the raw value of memory you might observe with a debugger. In order to ease the process of expanding numbers back into bits, each digit is grouped to the right edge of the memory element. So, for example, the byte 0xFF would be rendered in as 0o377 rather than 0o773.

Rendered words are chunked by memory elements, rather than by as clean as possible a number of digits, in order to aid visualization of the slice’s place in memory.

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<'_, T> LowerHex for Domain<'_, T> where
    T: BitStore, 

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<O, T> LowerHex for BitBox<O, T> where
    O: BitOrder,
    T: BitStore, 

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<O, V> LowerHex for BitArray<O, V> where
    O: BitOrder,
    V: BitView, 

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtPointer<T> where
    T: Pointer + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtLowerExp<T> where
    T: LowerExp + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtOctal<T> where
    T: Octal + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtLowerHex<T> where
    T: LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtBinary<T> where
    T: Binary + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtUpperExp<T> where
    T: UpperExp + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtUpperHex<T> where
    T: UpperHex + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

impl<T> LowerHex for FmtDisplay<T> where
    T: Display + LowerHex

pub fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

Implementors

impl LowerHex for NonZeroI81.34.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroI161.34.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroI321.34.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroI641.34.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroI1281.34.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroIsize1.34.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroU81.28.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroU161.28.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroU321.28.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroU641.28.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroU1281.28.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl LowerHex for NonZeroUsize1.28.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<'a, A, S, D> LowerHex for ArrayBase<S, D> where
    S: Data<Elem = A>,
    D: Dimension,
    A: LowerHex
[src]

Format the array using LowerHex and apply the formatting parameters used to each element.

The array is shown in multiline style.

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<'a, I> LowerHex for Format<'a, I> where
    I: Iterator,
    <I as Iterator>::Item: LowerHex
[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

impl<T> LowerHex for Wrapping<T> where
    T: LowerHex
1.11.0[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]