sig
  module S : sig val true_str : string val false_str : string end
  module PP :
    sig
      module B :
        sig
          type t = bool
          val to_string : bool -> string
          val pretty : Format.formatter -> bool -> unit
          val hash : '-> int
          val compare : '-> '-> int
          module Datatype :
            sig
              type t = bool
              val rehash : t -> t
              val descr : Unmarshal.t
              val copy : t -> t
              val name : string
              val register_comparable :
                ?compare:(t -> t -> int) ->
                ?equal:(t -> t -> bool) ->
                ?hash:(t -> int) -> ?physical_hash:(t -> int) -> unit -> unit
              val is_comparable_set : unit -> bool
              val hash : t -> int
              val physical_hash : t -> int
              val equal : t -> t -> bool
              val compare : t -> t -> int
              val contain_project : (Project.project -> t -> bool) option ref
            end
        end
      type l = B.t
      type tt = Boolean(Base.S).tt = private Top | Bottom | Value of l
      exception Error_Top
      exception Error_Bottom
      type t = tt
      type widen_hint = Abstract_interp.Make_Lattice_Base(B).widen_hint
      val equal : t -> t -> bool
      val join : t -> t -> t
      val link : t -> t -> t
      val meet : t -> t -> t
      val narrow : t -> t -> t
      val bottom : t
      val top : t
      val is_included : t -> t -> bool
      val is_included_exn : t -> t -> unit
      val intersects : t -> t -> bool
      val pretty : Format.formatter -> t -> unit
      val widen : widen_hint -> t -> t -> t
      val cardinal_zero_or_one : t -> bool
      val cardinal_less_than : t -> int -> int
      val tag : t -> int
      module Datatype :
        sig
          type t = t
          val rehash : t -> t
          val descr : Unmarshal.t
          val copy : t -> t
          val name : string
          val register_comparable :
            ?compare:(t -> t -> int) ->
            ?equal:(t -> t -> bool) ->
            ?hash:(t -> int) -> ?physical_hash:(t -> int) -> unit -> unit
          val is_comparable_set : unit -> bool
          val hash : t -> int
          val physical_hash : t -> int
          val equal : t -> t -> bool
          val compare : t -> t -> int
          val contain_project : (Project.project -> t -> bool) option ref
        end
      val project : t -> l
      val inject : l -> t
    end
  module CA :
    sig
      module B :
        sig
          type t = bool
          val to_string : bool -> string
          val pretty : Format.formatter -> bool -> unit
          val hash : '-> int
          val compare : '-> '-> int
          module Datatype :
            sig
              type t = bool
              val rehash : t -> t
              val descr : Unmarshal.t
              val copy : t -> t
              val name : string
              val register_comparable :
                ?compare:(t -> t -> int) ->
                ?equal:(t -> t -> bool) ->
                ?hash:(t -> int) -> ?physical_hash:(t -> int) -> unit -> unit
              val is_comparable_set : unit -> bool
              val hash : t -> int
              val physical_hash : t -> int
              val equal : t -> t -> bool
              val compare : t -> t -> int
              val contain_project : (Project.project -> t -> bool) option ref
            end
        end
      type l = B.t
      type tt = Boolean(S).tt = private Top | Bottom | Value of l
      exception Error_Top
      exception Error_Bottom
      type t = tt
      type widen_hint = Abstract_interp.Make_Lattice_Base(B).widen_hint
      val equal : t -> t -> bool
      val join : t -> t -> t
      val link : t -> t -> t
      val meet : t -> t -> t
      val narrow : t -> t -> t
      val bottom : t
      val top : t
      val is_included : t -> t -> bool
      val is_included_exn : t -> t -> unit
      val intersects : t -> t -> bool
      val pretty : Format.formatter -> t -> unit
      val widen : widen_hint -> t -> t -> t
      val cardinal_zero_or_one : t -> bool
      val cardinal_less_than : t -> int -> int
      val tag : t -> int
      module Datatype :
        sig
          type t = t
          val rehash : t -> t
          val descr : Unmarshal.t
          val copy : t -> t
          val name : string
          val register_comparable :
            ?compare:(t -> t -> int) ->
            ?equal:(t -> t -> bool) ->
            ?hash:(t -> int) -> ?physical_hash:(t -> int) -> unit -> unit
          val is_comparable_set : unit -> bool
          val hash : t -> int
          val physical_hash : t -> int
          val equal : t -> t -> bool
          val compare : t -> t -> int
          val contain_project : (Project.project -> t -> bool) option ref
        end
      val project : t -> l
      val inject : l -> t
    end
  type t1 = PP.t
  type t2 = CA.t
  type tt = private Product of t1 * t2 | Bottom
  exception Error_Top
  exception Error_Bottom
  type t = tt
  type widen_hint
  val equal : t -> t -> bool
  val join : t -> t -> t
  val link : t -> t -> t
  val meet : t -> t -> t
  val narrow : t -> t -> t
  val bottom : t
  val top : t
  val is_included : t -> t -> bool
  val is_included_exn : t -> t -> unit
  val intersects : t -> t -> bool
  val pretty : Format.formatter -> t -> unit
  val widen : widen_hint -> t -> t -> t
  val cardinal_zero_or_one : t -> bool
  val cardinal_less_than : t -> int -> int
  val tag : t -> int
  module Datatype :
    sig
      type t = t
      val rehash : t -> t
      val descr : Unmarshal.t
      val copy : t -> t
      val name : string
      val register_comparable :
        ?compare:(t -> t -> int) ->
        ?equal:(t -> t -> bool) ->
        ?hash:(t -> int) -> ?physical_hash:(t -> int) -> unit -> unit
      val is_comparable_set : unit -> bool
      val hash : t -> int
      val physical_hash : t -> int
      val equal : t -> t -> bool
      val compare : t -> t -> int
      val contain_project : (Project.project -> t -> bool) option ref
    end
  val inject : t1 -> t2 -> t
  val fst : t -> t1
  val snd : t -> t2
  type annotation = string
  val use_ctrl_dependencies : bool
  val pub : Lattice.Medium.PP.t
  val priv : Lattice.Medium.PP.t
  val concr : Lattice.Medium.CA.t
  val abstr : Lattice.Medium.CA.t
  val possible_annotations : string list
  val annotations2state : t -> string list -> t
  val constant : t
  val variable : t
end