rustc_data_structures/graph/
reference.rsuse super::*;
impl<'graph, G: DirectedGraph> DirectedGraph for &'graph G {
    type Node = G::Node;
    fn num_nodes(&self) -> usize {
        (**self).num_nodes()
    }
}
impl<'graph, G: StartNode> StartNode for &'graph G {
    fn start_node(&self) -> Self::Node {
        (**self).start_node()
    }
}
impl<'graph, G: Successors> Successors for &'graph G {
    fn successors(&self, node: Self::Node) -> impl Iterator<Item = Self::Node> {
        (**self).successors(node)
    }
}
impl<'graph, G: Predecessors> Predecessors for &'graph G {
    fn predecessors(&self, node: Self::Node) -> impl Iterator<Item = Self::Node> {
        (**self).predecessors(node)
    }
}