Trait tract_pulse::internal::fmt::Binary 1.0.0[−][src]
Expand description
b formatting.
The Binary trait should format its output as a number in binary.
For primitive signed integers (i8 to i128, and isize),
negative values are formatted as the two’s complement representation.
The alternate flag, #, adds a 0b 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 '101010' in binary assert_eq!(format!("{:b}", x), "101010"); assert_eq!(format!("{:#b}", x), "0b101010"); assert_eq!(format!("{:b}", -16), "11111111111111111111111111110000");
Implementing Binary on a type:
use std::fmt; struct Length(i32); impl fmt::Binary for Length { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { let val = self.0; fmt::Binary::fmt(&val, f) // delegate to i32's implementation } } let l = Length(107); assert_eq!(format!("l as binary is: {:b}", l), "l as binary is: 1101011"); assert_eq!( format!("l as binary is: {:#032b}", l), "l as binary is: 0b000000000000000000000001101011" );
Required methods
Implementations on Foreign Types
impl<O, V> Binary for BitArray<O, V> where
O: BitOrder,
V: BitView,
impl<O, V> Binary for BitArray<O, V> where
O: BitOrder,
V: BitView, impl<O, T> Binary for BitSlice<O, T> where
O: BitOrder,
T: BitStore,
impl<O, T> Binary 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:
Binaryrenders each bit individually as0or1,Octalrenders clusters of three bits as the numbers0through7,- and
UpperHexandLowerHexrender clusters of four bits as the numbers0through9andAthroughF.
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.
impl<'_, T> Binary for Domain<'_, T> where
T: BitStore,
impl<'_, T> Binary for Domain<'_, T> where
T: BitStore, impl<R> Binary for BitSel<R> where
R: BitRegister,
impl<R> Binary for BitSel<R> where
R: BitRegister, impl<R> Binary for BitMask<R> where
R: BitRegister,
impl<R> Binary for BitMask<R> where
R: BitRegister, impl<R> Binary for BitIdx<R> where
R: BitRegister,
impl<R> Binary for BitIdx<R> where
R: BitRegister, impl<O, T> Binary for BitBox<O, T> where
O: BitOrder,
T: BitStore,
impl<O, T> Binary for BitBox<O, T> where
O: BitOrder,
T: BitStore, impl<O, T> Binary for BitVec<O, T> where
O: BitOrder,
T: BitStore,
impl<O, T> Binary for BitVec<O, T> where
O: BitOrder,
T: BitStore, Implementors
impl Binary for NonZeroI161.34.0[src]
impl Binary for NonZeroI161.34.0[src]impl Binary for NonZeroI321.34.0[src]
impl Binary for NonZeroI321.34.0[src]impl Binary for NonZeroI641.34.0[src]
impl Binary for NonZeroI641.34.0[src]impl Binary for NonZeroI1281.34.0[src]
impl Binary for NonZeroI1281.34.0[src]impl Binary for NonZeroIsize1.34.0[src]
impl Binary for NonZeroIsize1.34.0[src]impl Binary for NonZeroU161.28.0[src]
impl Binary for NonZeroU161.28.0[src]impl Binary for NonZeroU321.28.0[src]
impl Binary for NonZeroU321.28.0[src]impl Binary for NonZeroU641.28.0[src]
impl Binary for NonZeroU641.28.0[src]impl Binary for NonZeroU1281.28.0[src]
impl Binary for NonZeroU1281.28.0[src]impl Binary for NonZeroUsize1.28.0[src]
impl Binary for NonZeroUsize1.28.0[src]impl<'a, A, S, D> Binary for ArrayBase<S, D> where
S: Data<Elem = A>,
D: Dimension,
A: Binary, [src]
impl<'a, A, S, D> Binary for ArrayBase<S, D> where
S: Data<Elem = A>,
D: Dimension,
A: Binary, [src]Format the array using Binary and apply the formatting parameters used
to each element.
The array is shown in multiline style.