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

X formatting.

The UpperHex trait should format its output as a number in hexadecimal, with A through F in upper 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 UpperHex on a type:

use std::fmt;

struct Length(i32);

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

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

let l = Length(i32::MAX);

assert_eq!(format!("l as hex is: {l:X}"), "l as hex is: 7FFFFFFF");

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

Required Methods§

source

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

Formats the value using the given formatter.

Implementors§

source§

impl UpperHex for i8

source§

impl UpperHex for i16

source§

impl UpperHex for i32

source§

impl UpperHex for i64

source§

impl UpperHex for i128

source§

impl UpperHex for isize

source§

impl UpperHex for u8

source§

impl UpperHex for u16

source§

impl UpperHex for u32

source§

impl UpperHex for u64

source§

impl UpperHex for u128

source§

impl UpperHex for usize

source§

impl UpperHex for AccessRights

source§

impl UpperHex for U128

source§

impl UpperHex for U256

source§

impl UpperHex for U512

source§

impl UpperHex for BigInt

source§

impl UpperHex for BigUint

source§

impl<O, T> UpperHex 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.

source§

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

source§

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

source§

impl<T> UpperHex for &T
where T: UpperHex + ?Sized,

source§

impl<T> UpperHex for &mut T
where T: UpperHex + ?Sized,

1.28.0 · source§

impl<T> UpperHex for NonZero<T>

1.74.0 · source§

impl<T> UpperHex for Saturating<T>
where T: UpperHex,

1.11.0 · source§

impl<T> UpperHex for Wrapping<T>
where T: UpperHex,

source§

impl<T> UpperHex for GenericArray<u8, T>
where T: ArrayLength<u8> + Add, <T as Add>::Output: ArrayLength<u8>,

source§

impl<T> UpperHex for HexFmt<T>
where T: AsRef<[u8]>,

source§

impl<T> UpperHex for HexList<T>
where T: Clone + IntoIterator, <T as IntoIterator>::Item: AsRef<[u8]>,

source§

impl<T> UpperHex for Complex<T>
where T: UpperHex + Num + PartialOrd + Clone,

source§

impl<T> UpperHex for Ratio<T>
where T: UpperHex + Clone + Integer,

source§

impl<T> UpperHex for FmtBinary<T>
where T: Binary + UpperHex,

source§

impl<T> UpperHex for FmtDisplay<T>
where T: Display + UpperHex,

source§

impl<T> UpperHex for FmtLowerExp<T>
where T: LowerExp + UpperHex,

source§

impl<T> UpperHex for FmtLowerHex<T>
where T: LowerHex + UpperHex,

source§

impl<T> UpperHex for FmtOctal<T>
where T: Octal + UpperHex,

source§

impl<T> UpperHex for FmtPointer<T>
where T: Pointer + UpperHex,

source§

impl<T> UpperHex for FmtUpperExp<T>
where T: UpperExp + UpperHex,

source§

impl<T> UpperHex for FmtUpperHex<T>
where T: UpperHex,