Protocol_version_headerThis library offers a lightweight way for applications protocols to version themselves. The more protocols that add themselves to Known_protocol, the nicer error messages we will get when connecting to a service while using the wrong protocol.
include Core_kernel.Bin_prot.Binable.S with type t := tinclude Bin_prot.Binable.S_only_functions with type t := tval bin_size_t : t Bin_prot.Size.sizerval bin_write_t : t Bin_prot.Write.writerval bin_read_t : t Bin_prot.Read.readerval __bin_read_t__ : (int -> t) Bin_prot.Read.readerThis function only needs implementation if t exposed to be a polymorphic variant. Despite what the type reads, this does *not* produce a function after reading; instead it takes the constructor tag (int) before reading and reads the rest of the variant t afterwards.
val bin_shape_t : Bin_prot.Shape.tval bin_writer_t : t Bin_prot.Type_class.writerval bin_reader_t : t Bin_prot.Type_class.readerval bin_t : t Bin_prot.Type_class.tval create_exn :
protocol:Protocol_version_header__.Known_protocol.t ->
supported_versions:int list ->
tcreate_exn ~protocol ~supported_version raises if List.length supported_versions >= 100
val negotiate :
allow_legacy_peer:bool ->
us:t ->
peer:t ->
int Core_kernel.Or_error.tnegotiate ~allow_legacy_peer ~us ~peer inspects the magic numbers of us and peer. If the magic numbers match, the highest shared version number is returned.
If allow_legacy_peer then the magic number of peer is assumed to be us if no magic number exists.
val contains_magic_prefix :
protocol:Protocol_version_header__.Known_protocol.t ->
bool Core_kernel.Bin_prot.Type_class.readercontains_magic_prefix reads a bin_protted value of type t and returns a boolean saying whether this magic number was observed.
val any_magic_prefix :
Protocol_version_header__.Known_protocol.t option
Core_kernel.Bin_prot.Type_class.readerany_magic_prefix reads the magic number for one of the known protocols.
module For_test : sig ... end