package dune-rpc
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=84f7a82c6d80a7124f3847e9a489e80cfbeafb7bed3573ac01286ef56fd08d94
sha512=d9fa44e24036d2593adfe59e52e0ad64f3e7e973d23f84af57fc79e38fa210630b0cb55590f314d6ef455333b96a8e0ce188c2720eaae44576222541ba78efb3
doc/dune-rpc.private/Dune_rpc_private/Conv/index.html
Module Dune_rpc_private.ConvSource
Bidirectional parsing of canonical s-expressions
iso t to_ from creates a parser for a type 'b out of a parser for a type 'a, where 'a and 'b are isomorphic to one another. The functions to_ and from convert between the two types 'a and 'b. A typical approach for parsing record types is to convert them to/from tuples (via the three, four, etc. combinators) which can be parsed with record, and then use iso to convert the parser for a tuple type into a parser for the original record type.
parsing records
parsing sums
type error = | Parse_error of {message : string;payload : (string * Stdune.Sexp.t) list;
}| Version_error of {since : int * int;until : (int * int) option;message : string;payload : (string * Stdune.Sexp.t) list;
}
conversion from/to
fixpoint f is a helper for creating parsers of recursive data structures such as ASTs. f is a function which returns a parser for a single node in the hierarchy, and f is passed a parser which it can use for parsing children of the current node. fixpoint f then returns a parser for the recursive data structure.