sig
  val formatter : Format.formatter Pervasives.ref
  val pp : ('a, Format.formatter, unit) Pervasives.format -> 'a
  module StringSet :
    sig
      type elt = string
      type t
      val empty : t
      val is_empty : t -> bool
      val mem : elt -> t -> bool
      val add : elt -> t -> t
      val singleton : elt -> t
      val remove : elt -> t -> t
      val union : t -> t -> t
      val inter : t -> t -> t
      val diff : t -> t -> t
      val compare : t -> t -> int
      val equal : t -> t -> bool
      val subset : t -> t -> bool
      val iter : (elt -> unit) -> t -> unit
      val fold : (elt -> '-> 'a) -> t -> '-> 'a
      val for_all : (elt -> bool) -> t -> bool
      val exists : (elt -> bool) -> t -> bool
      val filter : (elt -> bool) -> t -> t
      val partition : (elt -> bool) -> t -> t * t
      val cardinal : t -> int
      val elements : t -> elt list
      val min_elt : t -> elt
      val max_elt : t -> elt
      val choose : t -> elt
      val split : elt -> t -> t * bool * t
      val find : elt -> t -> elt
    end
  module StringMap :
    sig
      type key = string
      type +'a t
      val empty : 'a t
      val is_empty : 'a t -> bool
      val mem : key -> 'a t -> bool
      val add : key -> '-> 'a t -> 'a t
      val singleton : key -> '-> 'a t
      val remove : key -> 'a t -> 'a t
      val merge :
        (key -> 'a option -> 'b option -> 'c option) -> 'a t -> 'b t -> 'c t
      val compare : ('-> '-> int) -> 'a t -> 'a t -> int
      val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
      val iter : (key -> '-> unit) -> 'a t -> unit
      val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b
      val for_all : (key -> '-> bool) -> 'a t -> bool
      val exists : (key -> '-> bool) -> 'a t -> bool
      val filter : (key -> '-> bool) -> 'a t -> 'a t
      val partition : (key -> '-> bool) -> 'a t -> 'a t * 'a t
      val cardinal : 'a t -> int
      val bindings : 'a t -> (key * 'a) list
      val min_binding : 'a t -> key * 'a
      val max_binding : 'a t -> key * 'a
      val choose : 'a t -> key * 'a
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
    end
  val identity : '-> 'a
  val ( |> ) : '-> ('-> 'b) -> 'b
  val ( |>> ) : '-> ('-> unit) -> 'a
  val ( >> ) : ('-> 'b) -> ('-> 'c) -> '-> 'c
  val ( >>= ) : 'a option -> ('-> 'b option) -> 'b option
  module List :
    sig
      val length : 'a list -> int
      val hd : 'a list -> 'a
      val tl : 'a list -> 'a list
      val nth : 'a list -> int -> 'a
      val rev : 'a list -> 'a list
      val append : 'a list -> 'a list -> 'a list
      val rev_append : 'a list -> 'a list -> 'a list
      val concat : 'a list list -> 'a list
      val flatten : 'a list list -> 'a list
      val iter : ('-> unit) -> 'a list -> unit
      val map : ('-> 'b) -> 'a list -> 'b list
      val rev_map : ('-> 'b) -> 'a list -> 'b list
      val fold_left : ('-> '-> 'a) -> '-> 'b list -> 'a
      val fold_right : ('-> '-> 'b) -> 'a list -> '-> 'b
      val iter2 : ('-> '-> unit) -> 'a list -> 'b list -> unit
      val map2 : ('-> '-> 'c) -> 'a list -> 'b list -> 'c list
      val rev_map2 : ('-> '-> 'c) -> 'a list -> 'b list -> 'c list
      val fold_left2 :
        ('-> '-> '-> 'a) -> '-> 'b list -> 'c list -> 'a
      val fold_right2 :
        ('-> '-> '-> 'c) -> 'a list -> 'b list -> '-> 'c
      val for_all : ('-> bool) -> 'a list -> bool
      val exists : ('-> bool) -> 'a list -> bool
      val for_all2 : ('-> '-> bool) -> 'a list -> 'b list -> bool
      val exists2 : ('-> '-> bool) -> 'a list -> 'b list -> bool
      val mem : '-> 'a list -> bool
      val memq : '-> 'a list -> bool
      val find : ('-> bool) -> 'a list -> 'a
      val filter : ('-> bool) -> 'a list -> 'a list
      val find_all : ('-> bool) -> 'a list -> 'a list
      val partition : ('-> bool) -> 'a list -> 'a list * 'a list
      val assoc : '-> ('a * 'b) list -> 'b
      val assq : '-> ('a * 'b) list -> 'b
      val mem_assoc : '-> ('a * 'b) list -> bool
      val mem_assq : '-> ('a * 'b) list -> bool
      val remove_assoc : '-> ('a * 'b) list -> ('a * 'b) list
      val remove_assq : '-> ('a * 'b) list -> ('a * 'b) list
      val split : ('a * 'b) list -> 'a list * 'b list
      val combine : 'a list -> 'b list -> ('a * 'b) list
      val sort : ('-> '-> int) -> 'a list -> 'a list
      val stable_sort : ('-> '-> int) -> 'a list -> 'a list
      val fast_sort : ('-> '-> int) -> 'a list -> 'a list
      val merge : ('-> '-> int) -> 'a list -> 'a list -> 'a list
      val last : 'a list -> 'a
      val fold : ('-> '-> 'b) -> 'a list -> '-> 'b
      val fold_cons : ('-> 'b) -> 'a list -> 'b list -> 'b list
      val fold_append : ('-> 'b list) -> 'a list -> 'b list -> 'b list
      val lifted_fold : ('-> '-> 'b option) -> 'a list -> '-> 'b option
      val reduce : ('-> 'b list -> 'b list) -> 'a list -> 'b list
      val reduce_append : ('-> 'b list) -> 'a list -> 'b list
      val filter_not : ('-> bool) -> 'a list -> 'a list
      val map_partial : ('-> 'b option) -> 'a list -> 'b list
      val map_option : ('-> 'b option) -> 'a list -> 'b list option
    end
  type component
  val component_is_field : Misc.component -> bool
  val component_of_string : string -> Misc.component
  val string_of_component : Misc.component -> string
  val string_of_field_component : Misc.component -> string
  val compare_component : Misc.component -> Misc.component -> int
  val compare_components : Misc.component list -> Misc.component list -> int
  val node_component : Misc.component
  val list_link_tag : Misc.component
  val list_data_tag : Misc.component
  val dl_Llink_tag : Misc.component
  val dl_Rlink_tag : Misc.component
  val tree_link_tags : Misc.component * Misc.component
  val tree_data_tag : Misc.component
  val is_value_field : Misc.component -> bool
  val is_lock_field : Misc.component -> bool
  val possible_link_fields : Misc.component list Pervasives.ref
  module CompSet :
    sig
      type elt = component
      type t
      val empty : t
      val is_empty : t -> bool
      val mem : elt -> t -> bool
      val add : elt -> t -> t
      val singleton : elt -> t
      val remove : elt -> t -> t
      val union : t -> t -> t
      val inter : t -> t -> t
      val diff : t -> t -> t
      val compare : t -> t -> int
      val equal : t -> t -> bool
      val subset : t -> t -> bool
      val iter : (elt -> unit) -> t -> unit
      val fold : (elt -> '-> 'a) -> t -> '-> 'a
      val for_all : (elt -> bool) -> t -> bool
      val exists : (elt -> bool) -> t -> bool
      val filter : (elt -> bool) -> t -> t
      val partition : (elt -> bool) -> t -> t * t
      val cardinal : t -> int
      val elements : t -> elt list
      val min_elt : t -> elt
      val max_elt : t -> elt
      val choose : t -> elt
      val split : elt -> t -> t * bool * t
      val find : elt -> t -> elt
    end
  type ('a, 'b) plist = PNil | PCons of 'a * 'b * ('a, 'b) Misc.plist
  module PList :
    sig
      val nil : ('a, 'b) Misc.plist
      val cons : '-> '-> ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist
      val rev_append :
        ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist
      val for_all : ('-> '-> bool) -> ('a, 'b) Misc.plist -> bool
      val exists : ('-> '-> bool) -> ('a, 'b) Misc.plist -> bool
      val fold : ('-> '-> '-> 'c) -> ('a, 'b) Misc.plist -> '-> 'c
      val fold_val : ('-> '-> 'c) -> ('a, 'b) Misc.plist -> '-> 'c
      val lifted_fold :
        ('-> '-> '-> 'c option) ->
        ('a, 'b) Misc.plist -> '-> 'c option
      val iter : ('-> '-> unit) -> ('a, 'b) Misc.plist -> unit
      val iter_val : ('-> unit) -> ('a, 'b) Misc.plist -> unit
      val length : ('a, 'b) Misc.plist -> int
      val filter :
        ('-> '-> bool) -> ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist
      val rev_partition :
        ('-> '-> bool) ->
        ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist * ('a, 'b) Misc.plist
      val map_val : ('-> 'b) -> ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist
      val mem_assq : '-> ('a, 'b) Misc.plist -> bool
      val assq : '-> ('a, 'b) Misc.plist -> 'b
      val try_assq : '-> ('a, 'b) Misc.plist -> 'b option
      val remove_assq : '-> ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist
      val findq : ('a, 'b) Misc.plist -> '-> '-> 'b
      val merge :
        ('-> '-> int) ->
        ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist -> ('a, 'b) Misc.plist
      val get_first :
        ('-> '-> 'c option) -> ('a, 'b) Misc.plist -> 'c option
      val combine : 'a list -> 'b list -> ('a, 'b) Misc.plist
      val common :
        ('-> '-> '-> '-> int) ->
        ('a, 'b) Misc.plist ->
        ('a, 'b) Misc.plist ->
        ('a, 'b) Misc.plist * ('a, 'b) Misc.plist * ('a, 'b) Misc.plist
    end
end
Imprint | Data protection