Trait cairo_vm::with_std::fmt::Pointer

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

p formatting.

The Pointer trait should format its output as a memory location. This is commonly presented as hexadecimal.

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

§Examples

Basic usage with &i32:

let x = &42;

let address = format!("{x:p}"); // this produces something like '0x7f06092ac6d0'

Implementing Pointer on a type:

use std::fmt;

struct Length(i32);

impl fmt::Pointer for Length {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        // use `as` to convert to a `*const T`, which implements Pointer, which we can use

        let ptr = self as *const Self;
        fmt::Pointer::fmt(&ptr, f)
    }
}

let l = Length(42);

println!("l is in memory here: {l:p}");

let l_ptr = format!("{l:018p}");
assert_eq!(l_ptr.len(), 18);
assert_eq!(&l_ptr[..2], "0x");

Required Methods§

1.0.0 · source

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

Formats the value using the given formatter.

§Errors

This function should return Err if, and only if, the provided Formatter returns Err. String formatting is considered an infallible operation; this function only returns a Result because writing to the underlying stream might fail and it must provide a way to propagate the fact that an error has occurred back up the stack.

Implementors§

1.4.0 · source§

impl<F> Pointer for F
where F: FnPtr,

source§

impl<M, T> Pointer for Address<M, T>
where M: Mutability, T: ?Sized,

source§

impl<M, T, O> Pointer for BitRef<'_, M, T, O>
where M: Mutability, T: BitStore, O: BitOrder,

source§

impl<M, T, O> Pointer for BitPtr<M, T, O>
where M: Mutability, T: BitStore, O: BitOrder,

1.33.0 · source§

impl<Ptr> Pointer for Pin<Ptr>
where Ptr: Pointer,

1.0.0 · source§

impl<T> Pointer for *const T
where T: ?Sized,

1.0.0 · source§

impl<T> Pointer for *mut T
where T: ?Sized,

1.0.0 · source§

impl<T> Pointer for &T
where T: ?Sized,

1.0.0 · source§

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

1.25.0 · source§

impl<T> Pointer for NonNull<T>
where T: ?Sized,

1.24.0 · source§

impl<T> Pointer for AtomicPtr<T>

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

1.0.0 · source§

impl<T, A> Pointer for cairo_vm::stdlib::prelude::Box<T, A>
where A: Allocator, T: ?Sized,

1.0.0 · source§

impl<T, A> Pointer for Rc<T, A>
where A: Allocator, T: ?Sized,

1.0.0 · source§

impl<T, A> Pointer for Arc<T, A>
where A: Allocator, T: ?Sized,

source§

impl<T, A> Pointer for allocator_api2::stable::boxed::Box<T, A>
where A: Allocator, T: ?Sized,

source§

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

source§

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

source§

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