sig
  exception Ocsigen_Internal_Error of string
  exception Input_is_too_large
  exception Ocsigen_Bad_Request
  exception Ocsigen_Request_too_long
  val ( >>= ) : 'Lwt.t -> ('-> 'Lwt.t) -> 'Lwt.t
  val ( >|= ) : 'Lwt.t -> ('-> 'b) -> 'Lwt.t
  val ( !! ) : 'Lazy.t -> 'a
  val ( |> ) : '-> ('-> 'b) -> 'b
  val ( @@ ) : ('-> 'b) -> '-> 'b
  external id : '-> 'a = "%identity"
  val comp : ('-> 'b) -> ('-> 'a) -> '-> 'b
  val curry : ('a * '-> 'c) -> '-> '-> 'c
  val uncurry : ('-> '-> 'c) -> 'a * '-> 'c
  module Tuple3 :
    sig
      val fst : 'a * 'b * '-> 'a
      val snd : 'a * 'b * '-> 'b
      val thd : 'a * 'b * '-> 'c
    end
  type poly = Ocsigen_lib_base.poly
  val to_poly : '-> poly
  val from_poly : poly -> 'a
  type yesnomaybe = Ocsigen_lib_base.yesnomaybe = Yes | No | Maybe
  type ('a, 'b) leftright =
    ('a, 'b) Ocsigen_lib_base.leftright =
      Left of 'a
    | Right of 'b
  val advert : string
  module Option :
    sig
      type 'a t = 'a option
      val map : ('-> 'b) -> 'a t -> 'b t
      val get : (unit -> 'a) -> 'a t -> 'a
      val get' : '-> 'a t -> 'a
      val iter : ('-> unit) -> 'a t -> unit
      val return : '-> 'a t
      val bind : 'a t -> ('-> 'b t) -> 'b t
      val to_list : 'a t -> 'a list
      module Lwt :
        sig
          val map : ('-> 'Lwt.t) -> 'a t -> 'b t Lwt.t
          val get : (unit -> 'Lwt.t) -> 'a t -> 'Lwt.t
          val get' : 'Lwt.t -> 'a t -> 'Lwt.t
          val iter : ('-> unit Lwt.t) -> 'a t -> unit Lwt.t
          val bind : 'a t -> ('-> 'b t Lwt.t) -> 'b t Lwt.t
        end
    end
  module List :
    sig
      type 'a t = 'a list = [] | (::) of 'a * 'a list
      val length : 'a list -> int
      val compare_lengths : 'a list -> 'b list -> int
      val compare_length_with : 'a list -> int -> int
      val cons : '-> 'a list -> 'a list
      val hd : 'a list -> 'a
      val tl : 'a list -> 'a list
      val nth : 'a list -> int -> 'a
      val nth_opt : 'a list -> int -> 'a option
      val rev : 'a list -> 'a list
      val init : int -> (int -> 'a) -> '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 equal : ('-> '-> bool) -> 'a list -> 'a list -> bool
      val compare : ('-> '-> int) -> 'a list -> 'a list -> int
      val iter : ('-> unit) -> 'a list -> unit
      val iteri : (int -> '-> unit) -> 'a list -> unit
      val map : ('-> 'b) -> 'a list -> 'b list
      val mapi : (int -> '-> 'b) -> 'a list -> 'b list
      val rev_map : ('-> 'b) -> 'a list -> 'b list
      val filter_map : ('-> 'b option) -> 'a list -> 'b list
      val concat_map : ('-> 'b list) -> 'a list -> 'b list
      val fold_left_map :
        ('-> '-> 'a * 'c) -> '-> 'b list -> 'a * 'c 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 find_opt : ('-> bool) -> 'a list -> 'a option
      val find_map : ('-> 'b option) -> 'a list -> 'b option
      val filter : ('-> bool) -> 'a list -> 'a list
      val find_all : ('-> bool) -> 'a list -> 'a list
      val filteri : (int -> '-> bool) -> 'a list -> 'a list
      val partition : ('-> bool) -> 'a list -> 'a list * 'a list
      val partition_map :
        ('-> ('b, 'c) Either.t) -> 'a list -> 'b list * 'c list
      val assoc : '-> ('a * 'b) list -> 'b
      val assoc_opt : '-> ('a * 'b) list -> 'b option
      val assq : '-> ('a * 'b) list -> 'b
      val assq_opt : '-> ('a * 'b) list -> 'b option
      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 sort_uniq : ('-> '-> int) -> 'a list -> 'a list
      val merge : ('-> '-> int) -> 'a list -> 'a list -> 'a list
      val to_seq : 'a list -> 'Seq.t
      val of_seq : 'Seq.t -> 'a list
      val map_filter : ('-> 'b option) -> 'a list -> 'b list
      val last : 'a list -> 'a
      val assoc_remove : '-> ('a * 'b) list -> 'b * ('a * 'b) list
      val remove_first_if_any : '-> 'a list -> 'a list
      val remove_first_if_any_q : '-> 'a list -> 'a list
      val remove_first : '-> 'a list -> 'a list
      val remove_first_q : '-> 'a list -> 'a list
      val remove_all : '-> 'a list -> 'a list
      val remove_all_q : '-> 'a list -> 'a list
      val remove_all_assoc : '-> ('a * 'b) list -> ('a * 'b) list
      val remove_all_assoc_q : '-> ('a * 'b) list -> ('a * 'b) list
      val is_prefix : 'a list -> 'a list -> bool
      val chop : int -> 'a list -> 'a list
      val split_at : int -> 'a list -> 'a list * 'a list
    end
  module Clist :
    sig
      type 'a t = 'Ocsigen_lib_base.Clist.t
      type 'a node = 'Ocsigen_lib_base.Clist.node
      val make : '-> 'a node
      val create : unit -> 'a t
      val insert : 'a t -> 'a node -> unit
      val remove : 'a node -> unit
      val value : 'a node -> 'a
      val in_list : 'a node -> bool
      val is_empty : 'a t -> bool
      val iter : ('-> unit) -> 'a t -> unit
      val fold_left : ('-> '-> 'a) -> '-> 'b t -> 'a
    end
  module Int :
    sig
      module Table :
        sig
          type key = int
          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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
          val max_binding : 'a t -> key * 'a
          val max_binding_opt : 'a t -> (key * 'a) option
          val choose : 'a t -> key * 'a
          val choose_opt : 'a t -> (key * 'a) option
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val find_opt : key -> 'a t -> 'a option
          val find_first : (key -> bool) -> 'a t -> key * 'a
          val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val find_last : (key -> bool) -> 'a t -> key * 'a
          val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val to_seq : 'a t -> (key * 'a) Seq.t
          val to_rev_seq : 'a t -> (key * 'a) Seq.t
          val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
          val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
          val of_seq : (key * 'a) Seq.t -> 'a t
        end
    end
  module String_base :
    sig
      type t = string
      val make : int -> char -> string
      val init : int -> (int -> char) -> string
      val empty : string
      val of_bytes : bytes -> string
      val to_bytes : string -> bytes
      external length : string -> int = "%string_length"
      external get : string -> int -> char = "%string_safe_get"
      val concat : string -> string list -> string
      val cat : string -> string -> string
      val equal : t -> t -> bool
      val compare : t -> t -> int
      val starts_with : prefix:string -> string -> bool
      val ends_with : suffix:string -> string -> bool
      val contains_from : string -> int -> char -> bool
      val rcontains_from : string -> int -> char -> bool
      val contains : string -> char -> bool
      val sub : string -> int -> int -> string
      val split_on_char : char -> string -> string list
      val map : (char -> char) -> string -> string
      val mapi : (int -> char -> char) -> string -> string
      val fold_left : ('-> char -> 'a) -> '-> string -> 'a
      val fold_right : (char -> '-> 'a) -> string -> '-> 'a
      val for_all : (char -> bool) -> string -> bool
      val exists : (char -> bool) -> string -> bool
      val trim : string -> string
      val escaped : string -> string
      val uppercase_ascii : string -> string
      val lowercase_ascii : string -> string
      val capitalize_ascii : string -> string
      val uncapitalize_ascii : string -> string
      val iter : (char -> unit) -> string -> unit
      val iteri : (int -> char -> unit) -> string -> unit
      val index_from : string -> int -> char -> int
      val index_from_opt : string -> int -> char -> int option
      val rindex_from : string -> int -> char -> int
      val rindex_from_opt : string -> int -> char -> int option
      val index : string -> char -> int
      val index_opt : string -> char -> int option
      val rindex : string -> char -> int
      val rindex_opt : string -> char -> int option
      val to_seq : t -> char Seq.t
      val to_seqi : t -> (int * char) Seq.t
      val of_seq : char Seq.t -> t
      external create : int -> bytes = "caml_create_string"
      external set : bytes -> int -> char -> unit = "%string_safe_set"
      val blit : string -> int -> bytes -> int -> int -> unit
      val copy : string -> string
      val fill : bytes -> int -> int -> char -> unit
      val uppercase : string -> string
      val lowercase : string -> string
      val capitalize : string -> string
      val uncapitalize : string -> string
      val get_uint8 : string -> int -> int
      val get_int8 : string -> int -> int
      val get_uint16_ne : string -> int -> int
      val get_uint16_be : string -> int -> int
      val get_uint16_le : string -> int -> int
      val get_int16_ne : string -> int -> int
      val get_int16_be : string -> int -> int
      val get_int16_le : string -> int -> int
      val get_int32_ne : string -> int -> int32
      val get_int32_be : string -> int -> int32
      val get_int32_le : string -> int -> int32
      val get_int64_ne : string -> int -> int64
      val get_int64_be : string -> int -> int64
      val get_int64_le : string -> int -> int64
      external unsafe_get : string -> int -> char = "%string_unsafe_get"
      external unsafe_set : bytes -> int -> char -> unit
        = "%string_unsafe_set"
      external unsafe_blit : string -> int -> bytes -> int -> int -> unit
        = "caml_blit_string" [@@noalloc]
      external unsafe_fill : bytes -> int -> int -> char -> unit
        = "caml_fill_string" [@@noalloc]
      val remove_spaces : string -> int -> int -> string
      val basic_sep : char -> string -> string * string
      val sep : char -> string -> string * string
      val split : ?multisep:bool -> char -> string -> string list
      val may_append : string -> sep:string -> string -> string
      val may_concat : string -> sep:string -> string -> string
      val first_diff : string -> string -> int -> int -> int
      module Table :
        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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
          val max_binding : 'a t -> key * 'a
          val max_binding_opt : 'a t -> (key * 'a) option
          val choose : 'a t -> key * 'a
          val choose_opt : 'a t -> (key * 'a) option
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val find_opt : key -> 'a t -> 'a option
          val find_first : (key -> bool) -> 'a t -> key * 'a
          val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val find_last : (key -> bool) -> 'a t -> key * 'a
          val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val to_seq : 'a t -> (key * 'a) Seq.t
          val to_rev_seq : 'a t -> (key * 'a) Seq.t
          val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
          val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
          val of_seq : (key * 'a) Seq.t -> 'a t
        end
      module Set :
        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 disjoint : t -> t -> bool
          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 map : (elt -> elt) -> t -> t
          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 filter_map : (elt -> elt option) -> t -> t
          val partition : (elt -> bool) -> t -> t * t
          val cardinal : t -> int
          val elements : t -> elt list
          val min_elt : t -> elt
          val min_elt_opt : t -> elt option
          val max_elt : t -> elt
          val max_elt_opt : t -> elt option
          val choose : t -> elt
          val choose_opt : t -> elt option
          val split : elt -> t -> t * bool * t
          val find : elt -> t -> elt
          val find_opt : elt -> t -> elt option
          val find_first : (elt -> bool) -> t -> elt
          val find_first_opt : (elt -> bool) -> t -> elt option
          val find_last : (elt -> bool) -> t -> elt
          val find_last_opt : (elt -> bool) -> t -> elt option
          val of_list : elt list -> t
          val to_seq_from : elt -> t -> elt Seq.t
          val to_seq : t -> elt Seq.t
          val to_rev_seq : t -> elt Seq.t
          val add_seq : elt Seq.t -> t -> t
          val of_seq : elt Seq.t -> t
        end
      module Map :
        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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
          val max_binding : 'a t -> key * 'a
          val max_binding_opt : 'a t -> (key * 'a) option
          val choose : 'a t -> key * 'a
          val choose_opt : 'a t -> (key * 'a) option
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val find_opt : key -> 'a t -> 'a option
          val find_first : (key -> bool) -> 'a t -> key * 'a
          val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val find_last : (key -> bool) -> 'a t -> key * 'a
          val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val to_seq : 'a t -> (key * 'a) Seq.t
          val to_rev_seq : 'a t -> (key * 'a) Seq.t
          val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
          val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
          val of_seq : (key * 'a) Seq.t -> 'a t
        end
    end
  module Url_base :
    sig
      type t = string
      type uri = string
      val make_absolute_url :
        https:bool -> host:string -> port:int -> uri -> t
      type path = string list
      val remove_dotdot : path -> path
      val remove_end_slash : string -> string
      val remove_internal_slash : path -> path
      val change_empty_list : path -> path
      val add_end_slash_if_missing : path -> path
      val remove_slash_at_end : path -> path
      val remove_slash_at_beginning : path -> path
      val is_prefix_skip_end_slash : string list -> string list -> bool
      val split_fragment : string -> string * string option
      val join_path : path -> string
      val split_path : string -> path
      val norm_path : path -> path
    end
  exception Eliom_Internal_Error of string
  module Lwt_ops :
    sig
      val ( >>= ) : 'Lwt.t -> ('-> 'Lwt.t) -> 'Lwt.t
      val ( =<< ) : ('-> 'Lwt.t) -> 'Lwt.t -> 'Lwt.t
      val ( >|= ) : 'Lwt.t -> ('-> 'b) -> 'Lwt.t
      val ( =|< ) : ('-> 'b) -> 'Lwt.t -> 'Lwt.t
    end
  module type Map_S =
    sig
      type key
      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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
      val max_binding : 'a t -> key * 'a
      val max_binding_opt : 'a t -> (key * 'a) option
      val choose : 'a t -> key * 'a
      val choose_opt : 'a t -> (key * 'a) option
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val find_opt : key -> 'a t -> 'a option
      val find_first : (key -> bool) -> 'a t -> key * 'a
      val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val find_last : (key -> bool) -> 'a t -> key * 'a
      val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
      val to_seq : 'a t -> (key * 'a) Seq.t
      val to_rev_seq : 'a t -> (key * 'a) Seq.t
      val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
      val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
      val of_seq : (key * 'a) Seq.t -> 'a t
      val from_list : (key * 'a) list -> 'a t
      val to_string : ?sep:string -> ('-> string) -> 'a t -> string
    end
  module Int64_map :
    sig
      type key = int64
      type 'a t = 'Eliom_lib_base.Int64_map.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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
      val max_binding : 'a t -> key * 'a
      val max_binding_opt : 'a t -> (key * 'a) option
      val choose : 'a t -> key * 'a
      val choose_opt : 'a t -> (key * 'a) option
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val find_opt : key -> 'a t -> 'a option
      val find_first : (key -> bool) -> 'a t -> key * 'a
      val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val find_last : (key -> bool) -> 'a t -> key * 'a
      val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
      val to_seq : 'a t -> (key * 'a) Seq.t
      val to_rev_seq : 'a t -> (key * 'a) Seq.t
      val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
      val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
      val of_seq : (key * 'a) Seq.t -> 'a t
      val from_list : (key * 'a) list -> 'a t
      val to_string : ?sep:string -> ('-> string) -> 'a t -> string
    end
  module Int_map :
    sig
      type key = int
      type 'a t = 'Eliom_lib_base.Int_map.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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
      val max_binding : 'a t -> key * 'a
      val max_binding_opt : 'a t -> (key * 'a) option
      val choose : 'a t -> key * 'a
      val choose_opt : 'a t -> (key * 'a) option
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val find_opt : key -> 'a t -> 'a option
      val find_first : (key -> bool) -> 'a t -> key * 'a
      val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val find_last : (key -> bool) -> 'a t -> key * 'a
      val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
      val to_seq : 'a t -> (key * 'a) Seq.t
      val to_rev_seq : 'a t -> (key * 'a) Seq.t
      val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
      val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
      val of_seq : (key * 'a) Seq.t -> 'a t
      val from_list : (key * 'a) list -> 'a t
      val to_string : ?sep:string -> ('-> string) -> 'a t -> string
    end
  module String_map :
    sig
      type key = string
      type 'a t = 'Eliom_lib_base.String_map.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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
      val max_binding : 'a t -> key * 'a
      val max_binding_opt : 'a t -> (key * 'a) option
      val choose : 'a t -> key * 'a
      val choose_opt : 'a t -> (key * 'a) option
      val split : key -> 'a t -> 'a t * 'a option * 'a t
      val find : key -> 'a t -> 'a
      val find_opt : key -> 'a t -> 'a option
      val find_first : (key -> bool) -> 'a t -> key * 'a
      val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val find_last : (key -> bool) -> 'a t -> key * 'a
      val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
      val map : ('-> 'b) -> 'a t -> 'b t
      val mapi : (key -> '-> 'b) -> 'a t -> 'b t
      val to_seq : 'a t -> (key * 'a) Seq.t
      val to_rev_seq : 'a t -> (key * 'a) Seq.t
      val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
      val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
      val of_seq : (key * 'a) Seq.t -> 'a t
      val from_list : (key * 'a) list -> 'a t
      val to_string : ?sep:string -> ('-> string) -> 'a t -> string
    end
  type pos = Lexing.position * Lexing.position
  val pos_to_string : pos -> string
  type file_info = Js_of_ocaml.File.file Js_of_ocaml.Js.t
  val to_json : ?typ:'-> '-> string
  val of_json : ?typ:'-> string -> 'b
  module Url :
    sig
      type t = string
      type uri = string
      val make_absolute_url :
        https:bool -> host:string -> port:int -> uri -> t
      type path = string list
      val remove_dotdot : path -> path
      val remove_end_slash : string -> string
      val remove_internal_slash : path -> path
      val change_empty_list : path -> path
      val add_end_slash_if_missing : path -> path
      val remove_slash_at_end : path -> path
      val remove_slash_at_beginning : path -> path
      val is_prefix_skip_end_slash : string list -> string list -> bool
      val split_fragment : string -> string * string option
      val join_path : path -> string
      val norm_path : path -> path
      val urldecode : string -> string
      val urlencode : ?with_plus:bool -> string -> string
      type http_url =
        Js_of_ocaml__Url.http_url = {
        hu_host : string;
        hu_port : int;
        hu_path : string list;
        hu_path_string : string;
        hu_arguments : (string * string) list;
        hu_fragment : string;
      }
      type file_url =
        Js_of_ocaml__Url.file_url = {
        fu_path : string list;
        fu_path_string : string;
        fu_arguments : (string * string) list;
        fu_fragment : string;
      }
      type url =
        Js_of_ocaml__Url.url =
          Http of http_url
        | Https of http_url
        | File of file_url
      val default_http_port : int
      val default_https_port : int
      val path_of_path_string : string -> string list
      val encode_arguments : (string * string) list -> string
      val decode_arguments : string -> (string * string) list
      val url_of_string : string -> url option
      val string_of_url : url -> string
      module Current :
        sig
          val host : string
          val port : int option
          val protocol : string
          val path_string : string
          val path : string list
          val arguments : (string * string) list
          val get_fragment : unit -> string
          val set_fragment : string -> unit
          val get : unit -> url option
          val set : url -> unit
          val as_string : string
        end
      val decode : string -> string
      val encode : ?plus:bool -> string -> string
      val make_encoded_parameters : (string * string) list -> string
      val split_path : string -> string list
      val get_ssl : string -> bool option
      val resolve : string -> string
      val add_get_args : string -> (string * string) list -> string
      val string_of_url_path : encode:bool -> string list -> string
      val path_of_url : url -> string list
      val path_of_url_string : string -> string list
    end
  module String :
    sig
      type t = string
      val make : int -> char -> string
      val init : int -> (int -> char) -> string
      val empty : string
      val of_bytes : bytes -> string
      val to_bytes : string -> bytes
      external length : string -> int = "%string_length"
      external get : string -> int -> char = "%string_safe_get"
      val concat : string -> string list -> string
      val cat : string -> string -> string
      val equal : t -> t -> bool
      val compare : t -> t -> int
      val starts_with : prefix:string -> string -> bool
      val ends_with : suffix:string -> string -> bool
      val contains_from : string -> int -> char -> bool
      val rcontains_from : string -> int -> char -> bool
      val contains : string -> char -> bool
      val sub : string -> int -> int -> string
      val split_on_char : char -> string -> string list
      val map : (char -> char) -> string -> string
      val mapi : (int -> char -> char) -> string -> string
      val fold_left : ('-> char -> 'a) -> '-> string -> 'a
      val fold_right : (char -> '-> 'a) -> string -> '-> 'a
      val for_all : (char -> bool) -> string -> bool
      val exists : (char -> bool) -> string -> bool
      val trim : string -> string
      val escaped : string -> string
      val uppercase_ascii : string -> string
      val lowercase_ascii : string -> string
      val capitalize_ascii : string -> string
      val uncapitalize_ascii : string -> string
      val iter : (char -> unit) -> string -> unit
      val iteri : (int -> char -> unit) -> string -> unit
      val index_from : string -> int -> char -> int
      val index_from_opt : string -> int -> char -> int option
      val rindex_from : string -> int -> char -> int
      val rindex_from_opt : string -> int -> char -> int option
      val index : string -> char -> int
      val index_opt : string -> char -> int option
      val rindex : string -> char -> int
      val rindex_opt : string -> char -> int option
      val to_seq : t -> char Seq.t
      val to_seqi : t -> (int * char) Seq.t
      val of_seq : char Seq.t -> t
      external create : int -> bytes = "caml_create_string"
      external set : bytes -> int -> char -> unit = "%string_safe_set"
      val blit : string -> int -> bytes -> int -> int -> unit
      val copy : string -> string
      val fill : bytes -> int -> int -> char -> unit
      val uppercase : string -> string
      val lowercase : string -> string
      val capitalize : string -> string
      val uncapitalize : string -> string
      val get_uint8 : string -> int -> int
      val get_int8 : string -> int -> int
      val get_uint16_ne : string -> int -> int
      val get_uint16_be : string -> int -> int
      val get_uint16_le : string -> int -> int
      val get_int16_ne : string -> int -> int
      val get_int16_be : string -> int -> int
      val get_int16_le : string -> int -> int
      val get_int32_ne : string -> int -> int32
      val get_int32_be : string -> int -> int32
      val get_int32_le : string -> int -> int32
      val get_int64_ne : string -> int -> int64
      val get_int64_be : string -> int -> int64
      val get_int64_le : string -> int -> int64
      external unsafe_get : string -> int -> char = "%string_unsafe_get"
      external unsafe_set : bytes -> int -> char -> unit
        = "%string_unsafe_set"
      external unsafe_blit : string -> int -> bytes -> int -> int -> unit
        = "caml_blit_string" [@@noalloc]
      external unsafe_fill : bytes -> int -> int -> char -> unit
        = "caml_fill_string" [@@noalloc]
      val remove_spaces : string -> int -> int -> string
      val basic_sep : char -> string -> string * string
      val sep : char -> string -> string * string
      val split : ?multisep:bool -> char -> string -> string list
      val may_append : string -> sep:string -> string -> string
      val may_concat : string -> sep:string -> string -> string
      val first_diff : string -> string -> int -> int -> int
      module Table :
        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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
          val max_binding : 'a t -> key * 'a
          val max_binding_opt : 'a t -> (key * 'a) option
          val choose : 'a t -> key * 'a
          val choose_opt : 'a t -> (key * 'a) option
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val find_opt : key -> 'a t -> 'a option
          val find_first : (key -> bool) -> 'a t -> key * 'a
          val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val find_last : (key -> bool) -> 'a t -> key * 'a
          val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val to_seq : 'a t -> (key * 'a) Seq.t
          val to_rev_seq : 'a t -> (key * 'a) Seq.t
          val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
          val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
          val of_seq : (key * 'a) Seq.t -> 'a t
        end
      module Set :
        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 disjoint : t -> t -> bool
          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 map : (elt -> elt) -> t -> t
          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 filter_map : (elt -> elt option) -> t -> t
          val partition : (elt -> bool) -> t -> t * t
          val cardinal : t -> int
          val elements : t -> elt list
          val min_elt : t -> elt
          val min_elt_opt : t -> elt option
          val max_elt : t -> elt
          val max_elt_opt : t -> elt option
          val choose : t -> elt
          val choose_opt : t -> elt option
          val split : elt -> t -> t * bool * t
          val find : elt -> t -> elt
          val find_opt : elt -> t -> elt option
          val find_first : (elt -> bool) -> t -> elt
          val find_first_opt : (elt -> bool) -> t -> elt option
          val find_last : (elt -> bool) -> t -> elt
          val find_last_opt : (elt -> bool) -> t -> elt option
          val of_list : elt list -> t
          val to_seq_from : elt -> t -> elt Seq.t
          val to_seq : t -> elt Seq.t
          val to_rev_seq : t -> elt Seq.t
          val add_seq : elt Seq.t -> t -> t
          val of_seq : elt Seq.t -> t
        end
      module Map :
        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 update : key -> ('a option -> 'a option) -> '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 union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a 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 filter_map : (key -> '-> 'b option) -> 'a t -> 'b 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 min_binding_opt : 'a t -> (key * 'a) option
          val max_binding : 'a t -> key * 'a
          val max_binding_opt : 'a t -> (key * 'a) option
          val choose : 'a t -> key * 'a
          val choose_opt : 'a t -> (key * 'a) option
          val split : key -> 'a t -> 'a t * 'a option * 'a t
          val find : key -> 'a t -> 'a
          val find_opt : key -> 'a t -> 'a option
          val find_first : (key -> bool) -> 'a t -> key * 'a
          val find_first_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val find_last : (key -> bool) -> 'a t -> key * 'a
          val find_last_opt : (key -> bool) -> 'a t -> (key * 'a) option
          val map : ('-> 'b) -> 'a t -> 'b t
          val mapi : (key -> '-> 'b) -> 'a t -> 'b t
          val to_seq : 'a t -> (key * 'a) Seq.t
          val to_rev_seq : 'a t -> (key * 'a) Seq.t
          val to_seq_from : key -> 'a t -> (key * 'a) Seq.t
          val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t
          val of_seq : (key * 'a) Seq.t -> 'a t
        end
      val remove_eols : string -> string
    end
  module Lwt_log :
    sig
      type level =
        Lwt_log_core.level =
          Debug
        | Info
        | Notice
        | Warning
        | Error
        | Fatal
      type logger = Lwt_log_core.logger
      type section = Lwt_log_core.section
      val string_of_level : level -> string
      val level_of_string : string -> level option
      val load_rules : ?fail_on_error:bool -> string -> unit
      val add_rule : string -> level -> unit
      val append_rule : string -> level -> unit
      val reset_rules : unit -> unit
      module Section :
        sig
          type t = Lwt_log_core.section
          val make : string -> Lwt_log_core.section
          val name : Lwt_log_core.section -> string
          val main : Lwt_log_core.section
          val level : Lwt_log_core.section -> Lwt_log_core.level
          val set_level : Lwt_log_core.section -> Lwt_log_core.level -> unit
          val reset_level : Lwt_log_core.section -> unit
        end
      type template = Lwt_log_core.template
      val render :
        buffer:Buffer.t ->
        template:template ->
        section:section -> level:level -> message:string -> unit
      val location_key : (string * int * int) Lwt.key
      exception Logger_closed
      val make :
        output:(section -> level -> string list -> unit Lwt.t) ->
        close:(unit -> unit Lwt.t) -> logger
      val close : logger -> unit Lwt.t
      val default : logger ref
      val broadcast : logger list -> logger
      val dispatch : (section -> level -> logger) -> logger
      val null : logger
      val console : Lwt_log_core.logger
      val log :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> level:level -> string -> unit Lwt.t
      val log_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger ->
        level:level -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_log :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> level:level -> string -> unit
      val ign_log_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger ->
        level:level -> ('a, unit, string, unit) format4 -> 'a
      val debug :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> string -> unit Lwt.t
      val debug_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_debug :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> unit
      val ign_debug_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit) format4 -> 'a
      val info :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> string -> unit Lwt.t
      val info_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_info :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> unit
      val ign_info_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit) format4 -> 'a
      val notice :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> string -> unit Lwt.t
      val notice_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_notice :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> unit
      val ign_notice_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit) format4 -> 'a
      val warning :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> string -> unit Lwt.t
      val warning_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_warning :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> unit
      val ign_warning_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit) format4 -> 'a
      val error :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> string -> unit Lwt.t
      val error_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_error :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> unit
      val ign_error_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit) format4 -> 'a
      val fatal :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> string -> unit Lwt.t
      val fatal_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit Lwt.t) format4 -> 'a
      val ign_fatal :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> unit
      val ign_fatal_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, unit) format4 -> 'a
      val raise_error :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int -> ?logger:logger -> string -> 'a
      val raise_error_f :
        ?inspect:'->
        ?exn:exn ->
        ?section:section ->
        ?location:string * int * int ->
        ?logger:logger -> ('a, unit, string, 'any) Stdlib.format4 -> 'a
      val eliom : section
    end
  val error : ('a, unit, string, 'b) Stdlib.format4 -> 'a
  val error_any : '-> ('a, unit, string, 'b) Stdlib.format4 -> 'a
  val debug : ('a, unit, string, unit) Stdlib.format4 -> 'a
  val debug_exn : ('a, unit, string, unit) Stdlib.format4 -> exn -> 'a
  val jsdebug : '-> unit
  val alert : ('a, unit, string, unit) Stdlib.format4 -> 'a
  val jsalert : Js_of_ocaml.Js.js_string Js_of_ocaml.Js.t -> unit
  val confirm : ('a, unit, string, bool) Stdlib.format4 -> 'a
  val debug_var : string -> '-> unit
  val trace : ('a, unit, string, unit) Stdlib.format4 -> 'a
  val lwt_ignore : ?message:string -> unit Lwt.t -> unit
  val encode_form_value : '-> string
  val unmarshal_js : Js_of_ocaml.Js.js_string Js_of_ocaml.Js.t -> 'a
  val encode_header_value : '-> string
  val make_cryptographic_safe_string : ?len:int -> unit -> string
end