Yojson.RawInts, 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 |
| `Intlit of string |
| `Floatlit 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.
val 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.
Combined parser and pretty-printer. See to_string for the role of the optional std argument.
Combined parser and printer. See to_string for the role of the optional std argument.
val from_string : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> string -> tRead a JSON value from a string.
val from_channel : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> in_channel -> tRead a JSON value from a channel. See from_string for the meaning of the optional arguments.
val from_file : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> string -> tRead a JSON value from a file. See from_string for the meaning of the optional arguments.
type lexer_state = Lexer_state.t = {buf : Bi_outbuf.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:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> unit -> lexer_stateThis alias is provided for backward compatibility. New code should use Yojson.init_lexer directly.
val from_lexbuf : lexer_state -> ?stream:bool -> Lexing.lexbuf -> tRead 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.
val stream_from_string : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> string -> t Stream.tInput 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.
val stream_from_channel : ?buf:Bi_outbuf.t -> ?fin:(unit -> unit) -> ?fname:string -> ?lnum:int ->
in_channel -> t Stream.tInput a sequence of JSON values from a channel. Whitespace between JSON values is fine but not required.
val stream_from_file : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> string -> t Stream.tInput 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.
val stream_from_lexbuf : lexer_state -> ?fin:(unit -> unit) -> Lexing.lexbuf -> t Stream.tInput 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 linestream_from_channel : ?buf:Bi_outbuf.t -> ?fin:(unit -> unit) -> ?fname:string ->
?lnum:int -> in_channel -> json_line Stream.tInput a sequence of JSON values, one per line, from a channel. Exceptions raised when reading malformed lines are caught and represented using `Exn.
See stream_from_channel for the meaning of the optional fin argument. See from_string for the meaning of the other optional arguments.
val linestream_from_file : ?buf:Bi_outbuf.t -> ?fname:string -> ?lnum:int -> string -> json_line Stream.tInput a sequence of JSON values, one per line, from a file. Exceptions raised when reading malformed lines are caught and represented using `Exn.
See stream_from_channel for the meaning of the optional fin argument. See from_string for the meaning of the other optional arguments.
val read_t : lexer_state -> Lexing.lexbuf -> tRead a JSON value from the given lexer_state and lexing buffer and return it. Provided as a reader function for atdgen.