To focus the search input from anywhere on the page, press the 'S' key.
in-package search v0.1.0
Library
Module
Module type
Parameter
Class
Class type
This 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).
The main advantage of this module is its simplicity.
Type of the JSON tree
type t = [
|
`Null
|
`Bool of bool
|
`Int of int
|
`Float of float
|
`String of string
|
`Assoc of (string * t) list
|
`List of t list
]
All possible cases defined in Yojson:
- `Null: JSON null
- `Bool of bool: JSON boolean
- `Int of int: JSON number without decimal point or exponent.
- `Intlit of string: JSON number without decimal point or exponent, preserved as a string.
- `Float of float: JSON number, Infinity, -Infinity or NaN.
- `Floatlit of string: JSON number, Infinity, -Infinity or NaN, preserved as a string.
- `String of string: JSON string. Bytes in the range 128-255 are preserved as-is without encoding validation for both reading and writing.
- `Stringlit of string: JSON string literal including the double quotes.
- `Assoc of (string * json) list: JSON object.
- `List of json list: JSON array.
- `Tuple of json list: Tuple (non-standard extension of JSON). Syntax:
("abc", 123)
. - `Variant of (string * json option): Variant (non-standard extension of JSON). Syntax:
<"Foo">
or<"Bar":123>
.
JSON writers
Write a compact JSON value to a string.
val to_channel :
?buf:Buffer.t ->
?len:int ->
?suf:string ->
?std:bool ->
out_channel ->
t ->
unit
Write a compact JSON value to a channel. Note: the out_channel
is not flushed by this function.
See to_string
for the role of the optional arguments and raised exceptions.
val to_output :
?buf:Buffer.t ->
?len:int ->
?suf:string ->
?std:bool ->
< output : string -> int -> int -> int.. > ->
t ->
unit
Write a compact JSON value to an OO channel.
See to_string
for the role of the optional arguments and raised exceptions.
val to_file : ?len:int -> ?std:bool -> ?suf:string -> string -> t -> unit
Write a compact JSON value to a file. See to_string
for the role of the optional arguments and raised exceptions.
Write a compact JSON value to an existing buffer. See to_string
for the role of the optional argument and raised exceptions.
Write a sequence of suf
-suffixed compact one-line JSON values to a string.
val seq_to_channel :
?buf:Buffer.t ->
?len:int ->
?suf:string ->
?std:bool ->
out_channel ->
t Seq.t ->
unit
Write a sequence of suf
-suffixed compact one-line JSON values to a channel.
Write a sequence of suf
-suffixed compact one-line JSON values to a file.
Write a sequence of suf
-suffixed compact one-line JSON values to an existing buffer.
Write the given JSON value to the given buffer. Provided as a writer function for atdgen.
Miscellaneous
Sort object fields (stable sort, comparing field names and treating them as byte sequences)
val pp : Format.formatter -> t -> unit
Pretty printer, useful for debugging
val show : t -> string
Convert 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.
JSON pretty-printing
val pretty_print : ?std:bool -> Format.formatter -> t -> unit
Pretty-print into a Format.formatter
. See to_string
for the role of the optional std
argument.
val pretty_to_string : ?std:bool -> t -> string
Pretty-print into a string. See to_string
for the role of the optional std
argument. See pretty_print
for raised exceptions.
val pretty_to_channel : ?std:bool -> out_channel -> t -> unit
Pretty-print to a channel. See to_string
for the role of the optional std
argument. See pretty_print
for raised exceptions.
Combined parser and pretty-printer. See to_string
for the role of the optional std
argument and raised exceptions.
Combined parser and printer. See to_string
for the role of the optional std
argument and raised exceptions.
JSON readers
Read a JSON value from a string.
val from_channel :
?buf:Buffer.t ->
?fname:string ->
?lnum:int ->
in_channel ->
t
Read a JSON value from a channel. See from_string
for the meaning of the optional arguments and raised exceptions.
Read a JSON value from a file. See from_string
for the meaning of the optional arguments and raised exceptions.
type lexer_state = Lexer_state.t = {
buf : Buffer.t;
mutable lnum : int;
mutable bol : int;
mutable fname : string option;
}
This alias is provided for backward compatibility. New code should refer to Yojson.lexer_state
directly.
val init_lexer :
?buf:Buffer.t ->
?fname:string ->
?lnum:int ->
unit ->
lexer_state
This alias is provided for backward compatibility. New code should use Yojson.init_lexer
directly.
val from_lexbuf : lexer_state -> ?stream:bool -> Lexing.lexbuf -> t
Read a JSON value from a lexbuf. A valid initial lexer_state
can be created with init_lexer
. See from_string
for the meaning of the optional arguments and raised exceptions.
Input a sequence of JSON values from a string. Whitespace between JSON values is fine but not required. See from_string
for the meaning of the optional arguments and raised exceptions.
val seq_from_channel :
?buf:Buffer.t ->
?fin:(unit -> unit) ->
?fname:string ->
?lnum:int ->
in_channel ->
t Seq.t
Input a sequence of JSON values from a channel. Whitespace between JSON values is fine but not required.
Input a sequence of JSON values from a file. Whitespace between JSON values is fine but not required.
See from_string
for the meaning of the optional arguments and raised exceptions.
val seq_from_lexbuf :
lexer_state ->
?fin:(unit -> unit) ->
Lexing.lexbuf ->
t Seq.t
Input a sequence of JSON values from a lexbuf. A valid initial lexer_state
can be created with init_lexer
. Whitespace between JSON values is fine but not required.
The type of values resulting from a parsing attempt of a JSON value.
val lineseq_from_channel :
?buf:Buffer.t ->
?fin:(unit -> unit) ->
?fname:string ->
?lnum:int ->
in_channel ->
json_line Seq.t
Input a sequence of JSON values, one per line, from a channel. Exceptions raised when reading malformed lines are caught and represented using `Exn
.
See seq_from_channel
for the meaning of the optional fin
argument. See from_string
for the meaning of the other optional arguments and raised exceptions.
Input a sequence of JSON values, one per line, from a file. Exceptions raised when reading malformed lines are caught and represented using `Exn
.
See seq_from_channel
for the meaning of the optional fin
argument. See from_string
for the meaning of the other optional arguments and raised exceptions.
val read_t : lexer_state -> Lexing.lexbuf -> t
Read a JSON value from the given lexer_state and lexing buffer and return it. Provided as a reader function for atdgen.
module Util : sig ... end
This module provides combinators for extracting fields from JSON values.