data-encoding

Library of JSON and binary encoding combinators
README

A library for encoding and decoding data. It offers a great degree of control over the layout of data. It supports json and binary serialisation/deserialisation.

Usage

For a type t, you can use the library's combinators to build an encoding t encoding. You can then use the various reading/writing functions with this
encoding to serialise and deserialise values of the type t.

Example:

open Data_encoding

type t = (string * int) list
let encoding = list (tup2 string int31)
let v = [("foo", 32); ("bar", 0)]
let j = Json.construct encoding v
let w = Json.destruct encoding j
let () = assert (v = w)

Build and Install

data-encoding can be built from source using dune:

dune build

or installed directly from opam:

opam install data-encoding
Install
Published
02 Jun 2021
Sources
data-encoding-v0.4.tar.gz
md5=7b687e25619637d40d2bbcd2c21b00c2
sha512=65e33b1a56e9058a2e9c7f3dc18cb72c21270e0e5b9584fe856285d16e4cb8e98adac826373d4109a5e080486ec31cdd9870b402249ac5d55c7b0de6ffb68b0a
Dependencies
ocamlformat
= "0.15.0" & dev
crowbar
>= "0.2" & with-test
alcotest
with-test
hex
>= "1.3.0"
zarith
>= "1.4"
dune
>= "1.11"
ocaml
>= "4.08"
Reverse Dependencies