Struct rustc_mir_dataflow::graphviz::Formatter
source · pub struct Formatter<'a, 'tcx, A>where
A: Analysis<'tcx>,{
body: &'a Body<'tcx>,
results: &'a Results<'tcx, A>,
style: OutputStyle,
}
Fields§
§body: &'a Body<'tcx>
§results: &'a Results<'tcx, A>
§style: OutputStyle
Implementations§
Trait Implementations§
source§impl<'a, 'tcx, A> GraphWalk<'a> for Formatter<'a, 'tcx, A>where
A: Analysis<'tcx>,
impl<'a, 'tcx, A> GraphWalk<'a> for Formatter<'a, 'tcx, A>where
A: Analysis<'tcx>,
source§impl<'tcx, A> Labeller<'_> for Formatter<'_, 'tcx, A>where
A: Analysis<'tcx>,
A::Domain: DebugWithContext<A>,
impl<'tcx, A> Labeller<'_> for Formatter<'_, 'tcx, A>where
A: Analysis<'tcx>,
A::Domain: DebugWithContext<A>,
type Node = BasicBlock
type Edge = CfgEdge
source§fn node_id(&self, n: &Self::Node) -> Id<'_>
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. Read moresource§fn node_label(&self, block: &Self::Node) -> LabelText<'_>
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
. Read moresource§fn node_shape(&self, _n: &Self::Node) -> Option<LabelText<'_>>
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. Read moresource§fn edge_label(&self, e: &Self::Edge) -> LabelText<'_>
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. Read moresource§fn node_style(&'a self, _n: &Self::Node) -> Style
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
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<'a, 'tcx, A> !RefUnwindSafe for Formatter<'a, 'tcx, A>
impl<'a, 'tcx, A> !Send for Formatter<'a, 'tcx, A>
impl<'a, 'tcx, A> !Sync for Formatter<'a, 'tcx, A>
impl<'a, 'tcx, A> Unpin for Formatter<'a, 'tcx, A>where
'tcx: 'a,
impl<'a, 'tcx, A> !UnwindSafe for Formatter<'a, 'tcx, A>
Blanket Implementations§
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: 24 bytes