pub struct Formatter<'res, 'mir, 'tcx, A>where
    A: Analysis<'tcx>,{
    body: &'mir Body<'tcx>,
    results: RefCell<&'res mut Results<'tcx, A>>,
    style: OutputStyle,
    reachable: BitSet<BasicBlock>,
}

Fields§

§body: &'mir Body<'tcx>§results: RefCell<&'res mut Results<'tcx, A>>§style: OutputStyle§reachable: BitSet<BasicBlock>

Implementations§

source§

impl<'res, 'mir, 'tcx, A> Formatter<'res, 'mir, 'tcx, A>where A: Analysis<'tcx>,

source

pub fn new( body: &'mir Body<'tcx>, results: &'res mut Results<'tcx, A>, style: OutputStyle ) -> Self

Trait Implementations§

source§

impl<'mir, 'tcx, A> GraphWalk<'mir> for Formatter<'_, 'mir, 'tcx, A>where A: Analysis<'tcx>,

§

type Node = BasicBlock

§

type Edge = CfgEdge

source§

fn nodes(&self) -> Nodes<'_, Self::Node>

Returns all the nodes in this graph.
source§

fn edges(&self) -> Edges<'_, Self::Edge>

Returns all of the edges in this graph.
source§

fn source(&self, edge: &Self::Edge) -> Self::Node

The source node for edge.
source§

fn target(&self, edge: &Self::Edge) -> Self::Node

The target node for edge.
source§

impl<'tcx, A> Labeller<'_> for Formatter<'_, '_, 'tcx, A>where A: Analysis<'tcx>, A::Domain: DebugWithContext<A>,

§

type Node = BasicBlock

§

type Edge = CfgEdge

source§

fn graph_id(&self) -> Id<'_>

Must return a DOT compatible identifier naming the graph.
source§

fn node_id(&self, n: &Self::Node) -> Id<'_>

Maps n to a unique identifier with respect to self. The implementor is responsible for ensuring that the returned name is a valid DOT identifier.
source§

fn node_label(&self, block: &Self::Node) -> LabelText<'_>

Maps n to a label that will be used in the rendered output. The label need not be unique, and may be the empty string; the default is just the output from node_id.
source§

fn node_shape(&self, _n: &Self::Node) -> Option<LabelText<'_>>

Maps n to one of the graphviz shape names. If None is returned, no shape attribute is specified.
source§

fn edge_label(&self, e: &Self::Edge) -> LabelText<'_>

Maps e to a label that will be used in the rendered output. The label need not be unique, and may be the empty string; the default is in fact the empty string.
source§

fn node_style(&'a self, _n: &Self::Node) -> Style

Maps n to a style that will be used in the rendered output.
source§

fn edge_style(&'a self, _e: &Self::Edge) -> Style

Maps e to a style that will be used in the rendered output.

Auto Trait Implementations§

§

impl<'res, 'mir, 'tcx, A> !RefUnwindSafe for Formatter<'res, 'mir, 'tcx, A>

§

impl<'res, 'mir, 'tcx, A> !Send for Formatter<'res, 'mir, 'tcx, A>

§

impl<'res, 'mir, 'tcx, A> !Sync for Formatter<'res, 'mir, 'tcx, A>

§

impl<'res, 'mir, 'tcx, A> Unpin for Formatter<'res, 'mir, 'tcx, A>

§

impl<'res, 'mir, 'tcx, A> !UnwindSafe for Formatter<'res, 'mir, 'tcx, A>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 64 bytes