Parser.T
type ('a, 'e) t = char list -> ( 'a * char list, 'e ) M.t
val return : 'a -> 'b -> ( 'c * 'd, 'e ) M.t
val bind : ( 'a, 'e ) t -> f:( 'a -> ( 'b, 'e ) t ) -> ( 'b, 'e ) t
val map : [> `Define_using_bind ]