sig
module type S =
sig
module Id : Identifiable.S
type directed_graph = Id.Set.t Id.Map.t
type component = Has_loop of Id.t list | No_loop of Id.t
val connected_components_sorted_from_roots_to_leaf :
Strongly_connected_components.S.directed_graph ->
Strongly_connected_components.S.component array
val component_graph :
Strongly_connected_components.S.directed_graph ->
(Strongly_connected_components.S.component * int list) array
end
module Make :
(Id : Identifiable.S) ->
sig
type directed_graph = Id.Set.t Id.Map.t
type component = Has_loop of Id.t list | No_loop of Id.t
val connected_components_sorted_from_roots_to_leaf :
directed_graph -> component array
val component_graph : directed_graph -> (component * int list) array
end
end