YojsonThe Yojson library provides runtime functions for reading and writing JSON data from OCaml. It addresses a few shortcomings of its predecessor json-wheel and is about twice as fast (2.7x reading, 1.3x writing; results may vary). The design goals of Yojson are the following:
type lexer_state = {buf : Bi_outbuf.t; | (* Buffer used to accumulate substrings *) |
mutable lnum : int; | (* Current line number (counting from 1) *) |
mutable bol : int; | (* Absolute position of the first character of the current line (counting from 0) *) |
mutable fname : string option; | (* Name referencing the input file in error messages *) |
}module Lexer_state : sig ... endval init_lexer : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> unit -> lexer_stateCreate a fresh lexer_state record.
module Basic : sig ... endThis module supports standard JSON nodes only, i.e. no special syntax for variants or tuples as supported by Yojson.Safe. Arbitrary integers are not supported as they must all fit within the standard OCaml int type (31 or 63 bits depending on the platform).
module Safe : sig ... endThis module supports a specific syntax for variants and tuples in addition to the standard JSON nodes. Arbitrary integers are supported and represented as a decimal string using `Intlit when they cannot be represented using OCaml's int type.
module Raw : sig ... endInts, floats and strings literals are systematically preserved using `Intlit, `Floatlit and `Stringlit. This module also supports the specific syntax for variants and tuples supported by Yojson.Safe.
type t = [ | `Null |
| `Bool of bool |
| `Int of int |
| `Intlit of string |
| `Float of float |
| `Floatlit of string |
| `String of string |
| `Stringlit of string |
| `Assoc of (string * t) list |
| `List of t list |
| `Tuple of t list |
| `Variant of string * t option |
]All possible cases defined in Yojson:
("abc", 123).<"Foo"> or <"Bar":123>.type json = t* Compatibility type alias for type `t`
val pp : Format.formatter -> t -> unitPretty printer, useful for debugging
val show : t -> stringConvert value to string, useful for debugging
equal a b is the monomorphic equality. Determines whether two JSON values are considered equal. In the case of JSON objects, the order of the keys does not matter, except for duplicate keys which will be considered equal as long as they are in the same input order.
type json_max = tval to_string : ?buf:Bi_outbuf.t -> ?len:int -> ?std:bool -> t -> stringWrite a compact JSON value to a string.
val to_channel : ?buf:Bi_outbuf.t -> ?len:int -> ?std:bool -> out_channel -> t -> unitWrite a compact JSON value to a channel.
val to_output : ?buf:Bi_outbuf.t -> ?len:int -> ?std:bool ->
< output : string -> int -> int -> int; .. > -> t -> unitWrite a compact JSON value to an OO channel.
val to_file : ?len:int -> ?std:bool -> string -> t -> unitWrite a compact JSON value to a file. See to_string for the role of the optional arguments.
val to_outbuf : ?std:bool -> Bi_outbuf.t -> t -> unitWrite a compact JSON value to an existing buffer. See to_string for the role of the optional argument.
val stream_to_string : ?buf:Bi_outbuf.t -> ?len:int -> ?std:bool -> t Stream.t -> stringWrite a newline-separated sequence of compact one-line JSON values to a string. See to_string for the role of the optional arguments.
val stream_to_channel : ?buf:Bi_outbuf.t -> ?len:int -> ?std:bool -> out_channel -> t Stream.t -> unitWrite a newline-separated sequence of compact one-line JSON values to a channel. See to_channel for the role of the optional arguments.
Write a newline-separated sequence of compact one-line JSON values to a file. See to_string for the role of the optional arguments.
val stream_to_outbuf : ?std:bool -> Bi_outbuf.t -> t Stream.t -> unitWrite a newline-separated sequence of compact one-line JSON values to an existing buffer. See to_string for the role of the optional arguments.
val write_t : Bi_outbuf.t -> t -> unitWrite the given JSON value to the given buffer. Provided as a writer function for atdgen.
Sort object fields (stable sort, comparing field names and treating them as byte sequences)
val pretty_format : ?std:bool -> t -> Easy_format.tConvert into a pretty-printable tree. See to_string for the role of the optional std argument.
val pretty_print : ?std:bool -> Format.formatter -> t -> unitPretty-print into a Format.formatter. See to_string for the role of the optional std argument.
val pretty_to_string : ?std:bool -> t -> stringPretty-print into a string. See to_string for the role of the optional std argument.
val pretty_to_channel : ?std:bool -> out_channel -> t -> unitPretty-print to a channel. See to_string for the role of the optional std argument.