CFG

Struct CFG 

Source
pub struct CFG<B> {
    pub root: NodeIndex,
    pub graph: Graph<Block<B>, Edge, Directed>,
}

Fields§

§root: NodeIndex§graph: Graph<Block<B>, Edge, Directed>

Implementations§

Source§

impl<B: BV> CFG<B>

Source

pub fn new(instrs: &[LabeledInstr<B>]) -> Self

Construct a control flow graph from a slice of labeled instructions. Note that the set of labels should be pruned with super::prune_labels, otherwise the control flow graph will end up containing redundant blocks.

Source

pub fn all_vars_typed(&self, ret_ty: &Ty<Name>) -> HashMap<Name, Ty<Name>>

Returns a HashMap of all variables declared in a CFG. Also includes the special RETURN variable which is used to signal the return value of a function, hence why the return type of the function is also passed as an argument.

Source

pub fn ssa(&mut self)

Put the CFG into single static assignment (SSA) form.

Source

pub fn dot(&self, output: &mut dyn Write, symtab: &Symtab<'_>) -> Result<()>

Generate a dot file of the CFG. For debugging.

Auto Trait Implementations§

§

impl<B> Freeze for CFG<B>

§

impl<B> RefUnwindSafe for CFG<B>

§

impl<B> Send for CFG<B>

§

impl<B> Sync for CFG<B>

§

impl<B> Unpin for CFG<B>

§

impl<B> UnwindSafe for CFG<B>

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> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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>,

Source§

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.