1.0.0[][src]Trait nom::lib::std::fmt::Octal

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

o formatting.

The Octal trait should format its output as a number in base-8.

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

The alternate flag, #, adds a 0o 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 '52' in octal

assert_eq!(format!("{:o}", x), "52");
assert_eq!(format!("{:#o}", x), "0o52");

assert_eq!(format!("{:o}", -16), "37777777760");

Implementing Octal on a type:

use std::fmt;

struct Length(i32);

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

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

let l = Length(9);

assert_eq!(format!("l as octal is: {:o}", l), "l as octal is: 11");

assert_eq!(format!("l as octal is: {:#06o}", l), "l as octal is: 0o0011");

Required methods

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

Formats the value using the given formatter.

Loading content...

Implementations on Foreign Types

impl Octal for isize[src]

impl Octal for u8[src]

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

impl Octal for NonZeroUsize[src]

impl Octal for NonZeroU32[src]

impl Octal for NonZeroI16[src]

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

impl Octal for NonZeroIsize[src]

impl Octal for NonZeroU8[src]

impl Octal for NonZeroI32[src]

impl Octal for i16[src]

impl Octal for NonZeroU16[src]

impl Octal for u32[src]

impl Octal for NonZeroU64[src]

impl Octal for u16[src]

impl Octal for i128[src]

impl Octal for u64[src]

impl Octal for NonZeroU128[src]

impl Octal for u128[src]

impl Octal for usize[src]

impl Octal for i32[src]

impl Octal for NonZeroI8[src]

impl Octal for NonZeroI128[src]

impl Octal for i64[src]

impl<T> Octal for Wrapping<T> where
    T: Octal
[src]

impl Octal for NonZeroI64[src]

impl Octal for i8[src]

impl<O, T> Octal for BitVec<O, T> where
    O: BitOrder,
    T: BitStore
[src]

impl<O, T> Octal for BitBox<O, T> where
    O: BitOrder,
    T: BitStore
[src]

impl<O, T> Octal for BitSlice<O, T> where
    O: BitOrder,
    T: BitStore
[src]

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.

impl<O, V> Octal for BitArray<O, V> where
    O: BitOrder,
    V: BitView
[src]

impl<'_, T> Octal for Domain<'_, T> where
    T: BitStore
[src]

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

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

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

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

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

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

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

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

Loading content...

Implementors

Loading content...