sig
  module M :
    sig
      type key = NodeKf.t
      type 'a t = 'Map.Make(NodeKf).t
      val empty : 'a t
      val is_empty : 'a t -> bool
      val add : key -> '-> 'a t -> 'a t
      val find : key -> 'a t -> 'a
      val remove : key -> 'a t -> 'a t
      val mem : key -> 'a t -> bool
      val iter : (key -> '-> unit) -> 'a t -> unit
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
      val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
      val compare : ('-> '-> int) -> 'a t -> 'a t -> int
      val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
    end
  type fwd_kind = Impact | Security
  type kind =
      Direct
    | Indirect_Backward
    | Forward of Components.Component.fwd_kind
  type value = {
    pdg : Db.Pdg.t;
    mutable callstack_length : int;
    mutable direct : bool;
    mutable indirect_backward : bool;
    mutable forward : bool;
  }
  type t = Components.Component.value Components.Component.M.t
  val is_direct : Components.Component.value -> bool
  val is_indirect_backward : Components.Component.value -> bool
  val is_forward : Components.Component.value -> bool
  val check_and_add :
    bool ->
    Components.Component.M.key ->
    Components.Component.kind ->
    Db.Pdg.t ->
    int ->
    Components.Component.value Components.Component.M.t ->
    bool * Components.Component.value Components.Component.M.t
  val one_step_related_nodes :
    Components.Component.kind ->
    Db.Pdg.t -> Db.Pdg.t_node -> Db.Pdg.t_node list
  val search_input :
    Components.Component.kind ->
    Kernel_function.t -> 'a list Lazy.t -> 'a list
  val add_from_deep :
    Db_types.kernel_function ->
    Components.Todolist.t -> Db.Pdg.t_node -> Components.Todolist.t
  val forward_caller :
    Db_types.kernel_function ->
    Db.Pdg.t_node -> Components.Todolist.t -> Components.Todolist.t
  val related_nodes_of_nodes :
    Components.Component.kind ->
    Components.Component.value Components.Component.M.t ->
    Components.Todolist.t ->
    Components.Component.value Components.Component.M.t
  val initial_nodes :
    Db_types.kernel_function ->
    Cil_types.stmt -> Components.Todolist.todo list
  val direct :
    Db_types.kernel_function ->
    Cil_types.stmt -> Components.Component.value Components.Component.M.t
  val backward :
    Db_types.kernel_function ->
    Cil_types.stmt -> Components.Component.value Components.Component.M.t
  val whole :
    Db_types.kernel_function ->
    Cil_types.stmt -> Components.Component.value Components.Component.M.t
  val forward :
    Components.Component.fwd_kind ->
    Db_types.kernel_function ->
    Cil_types.stmt -> Cil_datatype.Stmt.Set.elt list
  val get_component :
    Components.Component.kind ->
    Cil_types.stmt -> Cil_datatype.Stmt.Set.elt list
  val iter :
    bool ->
    (Components.Component.M.key -> unit) ->
    Db_types.kernel_function -> Cil_types.stmt -> unit
end