Module Bin_shape_lib.Bin_shape
type tShape.tare constructed by thebin_shapesyntax extension from Ocaml type definitions & expressions.There is a direct mapping from ocaml type definition syntax to the corresponding
Shape.groupand from ocaml type expression syntax to the correspondingShape.t.
val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t
module Tid : sig ... endmodule Vid : sig ... endmodule Location : sig ... endLocation.tis required when constructing shapes for which evaluation might fail.
module Uuid : sig ... endUuid.tis used bybasetypeandannotate.
val group : Location.t -> (Tid.t * Vid.t list * t) list -> groupThis function is generative; repeated calls create distinct groups
val constr : string -> t option -> poly_variant_rowval inherit_ : Location.t -> t -> poly_variant_rowval poly_variant : Location.t -> poly_variant_row list -> tval rec_app : Tid.t -> t list -> trecursive apps within the current group
val var : Location.t -> Vid.t -> tval basetype : Uuid.t -> t list -> tBuilt-in types and types with custom serialization: i.e. int,list,... To avoid accidental protocol compatibility, pass a UUID as the
stringargument
module Digest : sig ... endmodule Canonical : sig ... endval eval : t -> Canonical.teval treturns the canonical-shape for a shape-expressionShape.t. Type aliases are expanded, so that noTid.torVid.thave significance in the resulting canonical-shape. Type-recursion, including non-regular recursion, is translated to the de-bruijn representation used in canonical-shapes.
val eval_to_digest : t -> Digest.teval_to_digest treturns a hash-value direct from theShape.t, potentially avoiding the intermediateCanonical.tfrom being constructed. This is important as the size of a canonical-shape might be exponential in terms of the size of the shape expression. The following holds:Digest.(eval_to_digest exp = Canonical.to_digest (eval exp))
val eval_to_digest_string : t -> stringeval_to_digest_string t==Digest.to_hex (eval_to_digest t)Convenience function useful for writing unit tests.
module For_typerep : sig ... end