package octez-libs
Compare
Monomorphic comparison for common ground types and common type constructors.
Compare
provides a module signature for the standard comparison functions and operators as well as modules of that signature for the common OCaml ground types (int
, bool
, etc.) and type constructors (list
, option
, etc.).
Compare
also provides some additional helpers for comparison-related tasks.
Signatures and a functor
module type COMPARABLE = sig ... end
module type S = sig ... end
S
is a signature for a fully-fledge comparison module. It includes all the functions and operators derived from a compare
function.
Base types
The specialised comparison and all the specialised functions and operators on the base types are compatible with the polymorphic comparison and all the polymorphic functions and operators from the Stdlib
.
module Int : sig ... end
Int
is a comparison module. Out of performance concerns, the signature actually contains compiler builtins (external
) rather than val
.
Type constructors
Provided the functor argument(s) are compatible with the polymorphic comparison of the Stdlib
, then the specialised comparison and all the specialised functions and operators on the derived types are compatible with the polymorphic comparison and all the polymorphic functions and operators from the Stdlib
.
module Result
(Ok : COMPARABLE)
(Error : COMPARABLE) :
S with type t = (Ok.t, Error.t) result
List lengths
Helpers for more readable Stdlib.List.compare_lengths
and Stdlib.List.compare_length_with
.
These modules are intended to be used as Module.(expression)
, most often within an if
condition. E.g.,
if Compare.List_length_with.(chunks > max_number_of_chunks) then
raise Maximum_size_exceeded
else
..
module List_length_with : sig ... end
module List_lengths : sig ... end