Module Parsexp__.Parser_automaton_internal.Public

type ('user_state, 'stack) state

Internal state of the automaton

type ('u, 's) mode =
| Single

(** Parse a single s-expression *)

| Many

(** Parse a list of s-expressions *)

| Eager of {
got_sexp : ('u'sstate ‑> 's ‑> 's;

(** Whether to consider no s-expression in the input as an error or not.

The mutability is used in Parsexp.Eager*.Lexbuf_consumer. *)

mutable no_sexp_is_error : bool;
}

(** Gives back s-expressions as soon as they are found. *)

type stack
val empty_stack : stack
type state_cst
type stack_cst
val empty_stack_cst : stack_cst
type ('u, 's) kind =
| Positions : (Parsexp.Positions.Builder.t, unit) kind
| Sexp : (unit, stackkind
| Sexp_with_positions : (Parsexp.Positions.Builder.tstackkind
| Cst : (state_cststack_cstkind
val new_state : ?⁠initial_pos:Parsexp.Positions.pos ‑> ('u'smode ‑> ('u'skind ‑> ('u'sstate
val reset : ?⁠pos:Parsexp.Positions.pos ‑> (__state ‑> unit
val positions : (Parsexp.Positions.Builder.t_state ‑> Parsexp.Positions.t
val mode : ('u'sstate ‑> ('u'smode
val offset : (__state ‑> int

Number of characters fed to the parser

val line : (__state ‑> int

Position in the text

val column : (__state ‑> int
val has_unclosed_paren : ('u'sstate ‑> bool

Whether there are some unclosed parentheses

val set_error_state : (__state ‑> unit
val sexp_of_stack : stack ‑> Parsexp__.Import.Ppx_sexp_conv_lib.Sexp.t
val sexps_of_stack : stack ‑> Parsexp__.Import.Ppx_sexp_conv_lib.Sexp.t list
val sexps_cst_of_stack : stack_cst ‑> Parsexp.Cst.t_or_comment list
module Error : sig ... end
exception Parse_error of Error.t