sig
  module type T =
    sig
      val th : Th.t
      val map : (Term.t -> Term.t) -> Term.t -> Term.t
      val solve : Fact.Equal.t -> Fact.Equal.t list
      val disjunction : Fact.Equal.t -> Clause.t
    end
  module Make :
    functor (Sh : T->
      sig
        type e = Solution.Set.t
        val current : unit -> e
        val initialize : e -> unit
        val finalize : unit -> e
        val abstract : Term.t -> unit
        val merge : Fact.Equal.t -> unit
        val propagate : Fact.Equal.t -> unit
        val dismerge : Fact.Diseq.t -> unit
        val propagate_diseq : Fact.Diseq.t -> unit
        val branch : unit -> unit
        val normalize : unit -> unit
      end
end