You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

87 lines
1.8 KiB

(*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*)
(** Singleton types for compare functions *)
type ('a, 'compare_a) t = 'a -> 'a -> int
module type S = sig
type ('a, 'compare_a) comparer := ('a, 'compare_a) t
type t
type compare [@@deriving compare, equal, sexp]
val comparer : (t, compare) comparer
end
module type S1 = sig
type ('a, 'compare_a) comparer := ('a, 'compare_a) t
type 'a t
type 'compare_a compare [@@deriving compare, equal, sexp]
val comparer :
('a, 'compare_a) comparer -> ('a t, 'compare_a compare) comparer
end
module Make (Ord : sig
type t [@@deriving compare]
end) =
struct
include Ord
type compare [@@deriving compare, equal, sexp]
let comparer = Ord.compare
end
module Counterfeit (Ord : sig
type t [@@deriving compare]
type compare [@@deriving compare, equal, sexp]
end) =
struct
include Ord
let comparer = Ord.compare
end
module Apply (F : sig
type ('a, 'compare_a) t [@@deriving compare]
type 'compare_a compare [@@deriving compare, equal, sexp]
end)
(A : S) =
struct
module A = struct
include A
let compare = comparer
end
type t = (A.t, A.compare) F.t [@@deriving compare]
type compare = A.compare F.compare [@@deriving compare, equal, sexp]
let comparer = compare
end
module Apply1 (F : sig
type ('a, 'b, 'compare_a) t [@@deriving compare]
type ('compare_a, 'compare_b) compare [@@deriving compare, equal, sexp]
end)
(A : S) =
struct
module A = struct
include A
let compare = comparer
end
type 'b t = (A.t, 'b, A.compare) F.t [@@deriving compare]
type 'b compare = (A.compare, 'b) F.compare
[@@deriving compare, equal, sexp]
let comparer = compare
end