struct SccConstraints<'a, 'tcx> {
    regioncx: &'a RegionInferenceContext<'tcx>,
    nodes_per_scc: IndexVec<ConstraintSccIndex, Vec<RegionVid>>,
}

Fields§

§regioncx: &'a RegionInferenceContext<'tcx>§nodes_per_scc: IndexVec<ConstraintSccIndex, Vec<RegionVid>>

Trait Implementations§

source§

impl<'a, 'this, 'tcx> GraphWalk<'this> for SccConstraints<'a, 'tcx>

§

type Node = ConstraintSccIndex

§

type Edge = (ConstraintSccIndex, ConstraintSccIndex)

source§

fn nodes(&'this self) -> Nodes<'this, ConstraintSccIndex>

Returns all the nodes in this graph.
source§

fn edges(&'this self) -> Edges<'this, (ConstraintSccIndex, ConstraintSccIndex)>

Returns all of the edges in this graph.
source§

fn source( &'this self, edge: &(ConstraintSccIndex, ConstraintSccIndex) ) -> ConstraintSccIndex

The source node for edge.
source§

fn target( &'this self, edge: &(ConstraintSccIndex, ConstraintSccIndex) ) -> ConstraintSccIndex

The target node for edge.
source§

impl<'a, 'this, 'tcx> Labeller<'this> for SccConstraints<'a, 'tcx>

§

type Node = ConstraintSccIndex

§

type Edge = (ConstraintSccIndex, ConstraintSccIndex)

source§

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

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

fn node_id(&'this self, n: &ConstraintSccIndex) -> Id<'this>

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_shape( &'this self, _node: &ConstraintSccIndex ) -> Option<LabelText<'this>>

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

fn node_label(&'this self, n: &ConstraintSccIndex) -> LabelText<'this>

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 edge_label(&'a self, _e: &Self::Edge) -> LabelText<'a>

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<'a, 'tcx> !RefUnwindSafe for SccConstraints<'a, 'tcx>

§

impl<'a, 'tcx> !Send for SccConstraints<'a, 'tcx>

§

impl<'a, 'tcx> !Sync for SccConstraints<'a, 'tcx>

§

impl<'a, 'tcx> Unpin for SccConstraints<'a, 'tcx>

§

impl<'a, 'tcx> !UnwindSafe for SccConstraints<'a, 'tcx>

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: 32 bytes