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
87 lines
1.8 KiB
4 years ago
|
(*
|
||
|
* 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
|