// Copyright 2016 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. use super::indexed_vec::Idx; pub mod dominators; pub mod iterate; mod reference; #[cfg(test)] mod test; pub trait ControlFlowGraph where Self: for<'graph> GraphPredecessors<'graph, Item=::Node>, Self: for<'graph> GraphSuccessors<'graph, Item=::Node> { type Node: Idx; fn num_nodes(&self) -> usize; fn start_node(&self) -> Self::Node; fn predecessors<'graph>(&'graph self, node: Self::Node) -> >::Iter; fn successors<'graph>(&'graph self, node: Self::Node) -> >::Iter; } pub trait GraphPredecessors<'graph> { type Item; type Iter: Iterator; } pub trait GraphSuccessors<'graph> { type Item; type Iter: Iterator; }