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

Fields§

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

Implementations§

source§

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

source

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

source

pub(crate) fn into_results(self) -> Results<'tcx, A>

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<'mir, 'tcx, A> !RefUnwindSafe for Formatter<'mir, 'tcx, A>

§

impl<'mir, 'tcx, A> Send for Formatter<'mir, 'tcx, A>
where A: Send, <A as AnalysisDomain<'tcx>>::Domain: Send,

§

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

§

impl<'mir, 'tcx, A> Unpin for Formatter<'mir, 'tcx, A>
where A: Unpin, <A as AnalysisDomain<'tcx>>::Domain: Unpin,

§

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

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where 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 T
where 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 T
where 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 T
where 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: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.