module std/text/parsestd/text/parse
import std/core/undivstd/core/undiv
pub alias parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> = () -> <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> aa: V
pubstd/text/parse/parse: (E, V) -> V effect parsestd/text/parse/parse: (E, V) -> V
fun satisfy( predpred: (sslice) -> maybe<($478, sslice)> : sslicestd/core/sslice/sslice: V -> totalstd/core/types/total: E maybestd/core/types/maybe: V -> V<(std/core/types/tuple2: (V, V) -> Vaa: V,sslicestd/core/sslice/sslice: V)> ) : maybestd/core/types/maybe: V -> V<aa: V>
ctl fail(msgmsg: string : stringstd/core/types/string: V) : aa: V
ctl pick() : boolstd/core/types/bool: V
fun current-input() : sslicestd/core/sslice/sslice: V
pub fun starts-withstd/text/parse/starts-with: forall<a> (s : string, p : () -> parse a) -> maybe<(a, sslice)>( ss: string : stringstd/core/types/string: V, pp: () -> parse $1463 : () -> parsestd/text/parse/parse: (E, V) -> V aa: V )result: -> total maybe<(1515, sslice)> : maybestd/core/types/maybe: V -> V<(std/core/types/tuple2: (V, V) -> Vaa: V,sslicestd/core/sslice/sslice: V)>
match ss: string.slicestd/core/sslice/slice: (s : string) -> sslice.parsestd/text/parse/parse: (input0 : sslice, p : () -> parse $1463) -> parse-error<$1463>(pp: () -> parse $1463)
ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(xx: $1463,restrest: sslice) -> Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)xx: $1463,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b))
_ -> Nothingstd/core/types/Nothing: forall<a> maybe<a>
pub type parse-errorstd/text/parse/parse-error: V -> V<aa: V>
ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>( result: aa: V, reststd/text/parse/parse-error/rest: forall<a> (parse-error<a>) -> sslice : sslicestd/core/sslice/sslice: V )
ParseErrorstd/text/parse/ParseError: forall<a> (msg : string, rest : sslice) -> parse-error<a>( msg : stringstd/core/types/string: V, rest : sslicestd/core/sslice/sslice: V )
pub fun maybestd/text/parse/maybe: forall<a> (perr : parse-error<a>) -> maybe<a>( perrperr: parse-error<$988> : parse-errorstd/text/parse/parse-error: V -> V<aa: V> )result: -> total maybe<1028> : maybestd/core/types/maybe: V -> V<aa: V>
perrperr: parse-error<$988>.eitherstd/text/parse/either: (perr : parse-error<$988>) -> either<string,$988>.maybestd/core/either/maybe: (e : either<string,$988>) -> maybe<$988>
pub fun eitherstd/text/parse/either: forall<a> (perr : parse-error<a>) -> either<string,a>( perrperr: parse-error<$944> : parse-errorstd/text/parse/parse-error: V -> V<aa: V> )result: -> total either<string,983> : eitherstd/core/types/either: (V, V) -> V<stringstd/core/types/string: V,aa: V>
match perrperr: parse-error<$944>
ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(xx: $944,_) -> Rightstd/core/types/Right: forall<a,b> (right : b) -> either<a,b>(xx: $944)
ParseErrorstd/text/parse/ParseError: forall<a> (msg : string, rest : sslice) -> parse-error<a>(msgmsg: string,_) -> Leftstd/core/types/Left: forall<a,b> (left : a) -> either<a,b>(msgmsg: string)
pub fun parse-eofstd/text/parse/parse-eof: forall<a,e> (input : sslice, p : () -> <parse|e> a) -> e parse-error<a>( inputinput: sslice : sslicestd/core/sslice/sslice: V, pp: () -> <parse|$1752> $1751 : () -> <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> aa: V)result: -> 1780 parse-error<1779> : ee: E parse-errorstd/text/parse/parse-error: V -> V<aa: V>
parsestd/text/parse/parse: (input0 : sslice, p : () -> <parse|$1752> $1751) -> $1752 parse-error<$1751>(inputinput: sslice)
val xx: $1751 = pp: () -> <parse|$1752> $1751()
eofstd/text/parse/eof: () -> <parse|$1752> ()()
xx: $1751
pub fun parsestd/text/parse/parse: forall<a,e> (input0 : sslice, p : () -> <parse|e> a) -> e parse-error<a>( input0input0: sslice : sslicestd/core/sslice/sslice: V, pp: () -> <parse|$1049> $1048 : () -> <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> aa: V )result: -> 1456 parse-error<1455> : ee: E parse-errorstd/text/parse/parse-error: V -> V<aa: V>
var inputinput: local-var<$1059,sslice> := input0input0: sslice
handlehandler: (() -> <parse,local<$1059>|$1049> $1048) -> <local<$1059>|$1049> parse-error<$1048> pp: () -> <parse|$1049> $1048
returnreturn: (x : $1048) -> <local<$1059>|_1089> parse-error<$1048>(xx: $1048)
ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(xx: $1048,inputinput: sslice
?hdiv=iev@1090
?hdiv=iev@1406)
fun current-inputcurrent-input: () -> <local<$1059>|$1049> sslice()
inputinput: sslice
?hdiv=iev@1163
brk failfail: (msg : string) -> <local<$1059>|$1049> parse-error<$1048>(msgmsg: string)
ParseErrorstd/text/parse/ParseError: forall<a> (msg : string, rest : sslice) -> parse-error<a>(msgmsg: string,inputinput: sslice
?hdiv=iev@1208)
fun satisfysatisfy: (pred : (sslice) -> maybe<(_1113, sslice)>) -> <local<$1059>|$1049> maybe<_1113>(predpred: (sslice) -> maybe<(_1113, sslice)>)
val inpinp: sslice = inputinput: sslice
?hdiv=iev@1330
val mm: () -> maybe<(_1113, sslice)> = fnfn: () -> maybe<(_1113, sslice)>() : totalstd/core/types/total: E __w-l61-c30: V { predpred: (sslice) -> maybe<(_1113, sslice)>(inpinp: sslice) }
match mm: () -> <local<$1059>|$1049> maybe<(_1113, sslice)>()
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)xx: _1113,capcap: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)) -> { inputinput: local-var<$1059,sslice> :=std/core/types/local-set: (v : local-var<$1059,sslice>, assigned : sslice) -> <local<$1059>|$1049> () capcap: sslice; Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>(xx: _1113) }
Nothingstd/core/types/Nothing: forall<a> maybe<a> -> Nothingstd/core/types/Nothing: forall<a> maybe<a>
ctl pickpick: (resume : (bool) -> <local<$1059>|$1049> parse-error<$1048>) -> <local<$1059>|$1049> parse-error<$1048>
()
val savesave: sslice = inputinput: sslice
?hdiv=iev@1243;
match resumeresume: (bool) -> <local<$1059>|$1049> parse-error<$1048>(Truestd/core/types/True: bool)
ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(x1x1: $1048,rest1rest1: sslice) -> ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(x1x1: $1048,rest1rest1: sslice)
err1err1: parse-error<$1048> ->
inputinput: local-var<$1059,sslice> :=std/core/types/local-set: (v : local-var<$1059,sslice>, assigned : sslice) -> <local<$1059>|$1049> () savesave: sslice
match resumeresume: (bool) -> <local<$1059>|$1049> parse-error<$1048>(Falsestd/core/types/False: bool) ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(x2x2: $1048,rest2rest2: sslice) -> ParseOkstd/text/parse/ParseOk: forall<a> (result : a, rest : sslice) -> parse-error<a>(x2x2: $1048,rest2rest2: sslice)
_err2 -> err1err1: parse-error<$1048>
pub fun (||)std/text/parse/(||): forall<a,e> (p1 : parser<e,a>, p2 : parser<e,a>) -> <parse|e> a( p1p1: parser<$1521,$1520> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V>, p2p2: parser<$1521,$1520> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> )result: -> <parse|1543> 1542 : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> aa: V
if pickstd/text/parse/pick: () -> <parse|$1521> bool() then p1p1: parser<$1521,$1520>() else p2p2: parser<$1521,$1520>()
pub fun optionalstd/text/parse/optional: forall<a,e> (default : a, p : parser<e,a>) -> <parse|e> a( defaultdefault: $1550 : aa: V, pp: parser<$1551,$1550> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> )result: -> <parse|1576> 1575 : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> aa: V
pp: parser<$1551,$1550> ||std/text/parse/(||): (p1 : parser<$1551,$1550>, p2 : parser<$1551,$1550>) -> <parse|$1551> $1550 (fnfn: () -> <parse|$1551> $1550() defaultdefault: $1550)
pub fun choosestd/text/parse/choose: forall<a,e> (ps : list<parser<e,a>>) -> <parse|e> a( psps: list<parser<$1584,$1583>> : liststd/core/types/list: V -> V<parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V>> )result: -> <parse|1640> 1639 : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> aa: V
match psps: list<parser<$1584,$1583>>
Nilstd/core/types/Nil: forall<a> list<a> -> failstd/text/parse/fail: (msg : string) -> <parse|$1584> $1583("no further alternatives"literal: string
count= 23)
Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(pp: parser<$1584,$1583>,Nilstd/core/types/Nil: forall<a> list<a>) -> pp: parser<$1584,$1583>()
Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(pp: parser<$1584,$1583>,pppp: list<parser<$1584,$1583>>) -> if pickstd/text/parse/pick: () -> <parse|$1584> bool() then pp: parser<$1584,$1583>() else choosestd/text/parse/choose: (ps : list<parser<$1584,$1583>>) -> <parse|$1584> $1583(pppp: list<parser<$1584,$1583>>)
pub fun satisfy-failstd/text/parse/satisfy-fail: forall<a> (msg : string, pred : (sslice) -> maybe<(a, sslice)>) -> parse a( msgmsg: string : stringstd/core/types/string: V, predpred: (sslice) -> maybe<($1647, sslice)> : sslicestd/core/sslice/sslice: V -> maybestd/core/types/maybe: V -> V<(std/core/types/tuple2: (V, V) -> Vaa: V,sslicestd/core/sslice/sslice: V)> )result: -> parse 1682 : parsestd/text/parse/parse: (E, V) -> V aa: V
match satisfystd/text/parse/satisfy: (pred : (sslice) -> maybe<($1647, sslice)>) -> parse maybe<$1647>(predpred: (sslice) -> maybe<($1647, sslice)>)
Nothingstd/core/types/Nothing: forall<a> maybe<a> -> failstd/text/parse/fail: (msg : string) -> parse $1647(msgmsg: string)
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>(xx: $1647) -> xx: $1647
pub fun eofstd/text/parse/eof: () -> parse ()()result: -> parse () : parsestd/text/parse/parse: (E, V) -> V (std/core/types/unit: V)std/core/types/unit: V
match satisfystd/text/parse/satisfy: (pred : (sslice) -> maybe<((), sslice)>) -> parse maybe<()>( fnfn: (s : sslice) -> maybe<((), sslice)>(ss: sslice) if ss: sslice.is-emptystd/core/sslice/is-empty: (slice : sslice) -> bool then Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)(std/core/types/Unit: ())std/core/types/Unit: (),ss: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)) else Nothingstd/core/types/Nothing: forall<a> maybe<a> )
Nothingstd/core/types/Nothing: forall<a> maybe<a> -> failstd/text/parse/fail: (msg : string) -> parse ()("expecting end-of-input"literal: string
count= 22)
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a> -> (std/core/types/Unit: ())std/core/types/Unit: ()
pub fun char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char( msgmsg: string :stringstd/core/types/string: V, predpred: (char) -> bool : charstd/core/types/char: V -> boolstd/core/types/bool: V )result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
satisfy-failstd/text/parse/satisfy-fail: (msg : string, pred : (sslice) -> maybe<(char, sslice)>) -> parse char(msgmsg: string) fnfn: (slice : sslice) -> maybe<(char, sslice)>(sliceslice: sslice)
match sliceslice: sslice.nextstd/core/sslice/next: (slice : sslice) -> maybe<(char, sslice)>
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)cc: char,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)) | predpred: (char) -> bool(cc: char) -> Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)cc: char,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b))
_ -> Nothingstd/core/types/Nothing: forall<a> maybe<a>
fun next-while0std/text/parse/next-while0: (slice : sslice, pred : (char) -> bool, acc : list<char>) -> (list<char>, sslice)( sliceslice: sslice : sslicestd/core/sslice/sslice: V, predpred: (char) -> bool : charstd/core/types/char: V -> boolstd/core/types/bool: V, accacc: list<char> : liststd/core/types/list: V -> V<charstd/core/types/char: V> )result: -> total (list<char>, sslice) : (std/core/types/tuple2: (V, V) -> Vliststd/core/types/list: V -> V<charstd/core/types/char: V>,sslicestd/core/sslice/sslice: V)
match sliceslice: sslice.nextstd/core/sslice/next: (slice : sslice) -> maybe<(char, sslice)>
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)cc: char,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)) | predpred: (char) -> bool(cc: char) -> next-while0std/text/parse/next-while0: (slice : sslice, pred : (char) -> bool, acc : list<char>) -> (list<char>, sslice)(pretend-decreasingstd/core/undiv/pretend-decreasing: (x : sslice) -> sslice(restrest: sslice), predpred: (char) -> bool, Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(cc: char,accacc: list<char>) )
_ -> (std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)accacc: list<char>.reversestd/core/list/reverse: (xs : list<char>) -> list<char>,sliceslice: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)
pub fun chars-arestd/text/parse/chars-are: (msg : string, pred : (char) -> bool) -> parse list<char>( msgmsg: string :stringstd/core/types/string: V, predpred: (char) -> bool : charstd/core/types/char: V -> boolstd/core/types/bool: V )result: -> parse list<char> : parsestd/text/parse/parse: (E, V) -> V liststd/core/types/list: V -> V<charstd/core/types/char: V>
satisfy-failstd/text/parse/satisfy-fail: (msg : string, pred : (sslice) -> maybe<(list<char>, sslice)>) -> parse list<char>(msgmsg: string) fnfn: (slice : sslice) -> maybe<(list<char>, sslice)>(sliceslice: sslice)
match sliceslice: sslice.next-while0std/text/parse/next-while0: (slice : sslice, pred : (char) -> bool, acc : list<char>) -> (list<char>, sslice)(predpred: (char) -> bool,[std/core/types/Nil: forall<a> list<a>]std/core/types/Nil: forall<a> list<a>)
(std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)[std/core/types/Nil: forall<a> list<a>]std/core/types/Nil: forall<a> list<a>,_)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b) -> Nothingstd/core/types/Nothing: forall<a> maybe<a>
(std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)xsxs: list<char>,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b) -> Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)xsxs: list<char>,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b))
fun next-matchstd/text/parse/next-match: (slice : sslice, cs : list<char>) -> maybe<sslice>( sliceslice: sslice : sslicestd/core/sslice/sslice: V, cscs: list<char> : liststd/core/types/list: V -> V<charstd/core/types/char: V> )result: -> total maybe<sslice> : maybestd/core/types/maybe: V -> V<sslicestd/core/sslice/sslice: V>
match cscs: list<char>
Nilstd/core/types/Nil: forall<a> list<a> -> Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>(sliceslice: sslice)
Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(cc: char,cccc: list<char>) -> match sliceslice: sslice.nextstd/core/sslice/next: (slice : sslice) -> maybe<(char, sslice)>
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)dd: char,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)) | cc: char==std/core/char/(==): (char, char) -> booldd: char -> restrest: sslice.next-matchstd/text/parse/next-match: (slice : sslice, cs : list<char>) -> maybe<sslice>( cccc: list<char> )
_ -> Nothingstd/core/types/Nothing: forall<a> maybe<a>
pub fun pstringstd/text/parse/pstring: (s : string) -> parse string( ss: string : stringstd/core/types/string: V )result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
satisfy-failstd/text/parse/satisfy-fail: (msg : string, pred : (sslice) -> maybe<(string, sslice)>) -> parse string(ss: string) fnfn: (slice : sslice) -> maybe<(string, sslice)>(sliceslice: sslice)
match sliceslice: sslice.next-matchstd/text/parse/next-match: (slice : sslice, cs : list<char>) -> maybe<sslice>(ss: string.liststd/core/string/list: (s : string) -> list<char>)
Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>(restrest: sslice) -> Juststd/core/types/Just: forall<a> (value : a) -> maybe<a>((std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b)ss: string,restrest: sslice)std/core/types/Tuple2: forall<a,b> (fst : a, snd : b) -> (a, b))
Nothingstd/core/types/Nothing: forall<a> maybe<a> -> Nothingstd/core/types/Nothing: forall<a> maybe<a>
pub fun charstd/text/parse/char: (c : char) -> parse char( cc: char : charstd/core/types/char: V )result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char( showstd/core/show/char/show: (c : char) -> parse string(cc: char), fnfn: (c0 : char) -> bool(c0c0: char) cc: char ==std/core/char/(==): (char, char) -> bool c0c0: char )
pub fun no-digitstd/text/parse/no-digit: () -> parse char()result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char("not a digit"literal: string
count= 11, fnfn: (c : char) -> bool(cc: char) !std/core/types/bool/(!): (b : bool) -> boolcc: char.is-digitstd/core/char/is-digit: (c : char) -> bool )
pub fun digitstd/text/parse/digit: () -> parse int()result: -> parse int : parsestd/text/parse/parse: (E, V) -> V intstd/core/types/int: V
val cc: char = char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char("digit"literal: string
count= 5, is-digitstd/core/char/is-digit: (c : char) -> bool)
(cc: char -std/core/char/(-): (c : char, d : char) -> parse char '0'literal: char
unicode= u0030).intstd/core/char/int: (char) -> parse int
pub fun alphastd/text/parse/alpha: () -> parse char()result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char("alpha"literal: string
count= 5, is-alphastd/core/char/is-alpha: (c : char) -> bool)
pub fun alpha-numstd/text/parse/alpha-num: () -> parse char()result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char("alpha-num"literal: string
count= 9, is-alpha-numstd/core/char/is-alpha-num: (c : char) -> bool)
pub fun whitestd/text/parse/white: () -> parse char()result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char(""literal: string
count= 0, is-whitestd/core/char/is-white: (c : char) -> bool)
pub fun whitespacestd/text/parse/whitespace: () -> parse string()result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
chars-arestd/text/parse/chars-are: (msg : string, pred : (char) -> bool) -> parse list<char>(""literal: string
count= 0, is-whitestd/core/char/is-white: (c : char) -> bool).stringstd/core/string/listchar/string: (cs : list<char>) -> parse string
pub fun whitespace0std/text/parse/whitespace0: () -> parse string()result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
optionalstd/text/parse/optional: (default : string, p : parser<total,string>) -> parse string(""literal: string
count= 0, whitespacestd/text/parse/whitespace: () -> parse string)
pub fun digitsstd/text/parse/digits: () -> parse string()result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
chars-arestd/text/parse/chars-are: (msg : string, pred : (char) -> bool) -> parse list<char>("digit"literal: string
count= 5, is-digitstd/core/char/is-digit: (c : char) -> bool ).stringstd/core/string/listchar/string: (cs : list<char>) -> parse string
pub fun digits0std/text/parse/digits0: () -> parse string()result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
optionalstd/text/parse/optional: (default : string, p : parser<total,string>) -> parse string("0"literal: string
count= 1, digitsstd/text/parse/digits: () -> parse string)
pub fun signstd/text/parse/sign: () -> parse bool()result: -> parse bool : parsestd/text/parse/parse: (E, V) -> V boolstd/core/types/bool: V
val cc: char = one-of-orstd/text/parse/one-of-or: (chars : string, default : char) -> parse char("+-"literal: string
count= 2, '+'literal: char
unicode= u002B)
(cc: char==std/core/char/(==): (char, char) -> parse bool'-'literal: char
unicode= u002D)
pub fun pnatstd/text/parse/pnat: () -> parse int()result: -> parse int : parsestd/text/parse/parse: (E, V) -> V intstd/core/types/int: V
digitsstd/text/parse/digits: () -> parse string().parse-intstd/core/int/parse-int: (s : string, hex : ? bool) -> parse maybe<int>.defaultstd/core/maybe/default: (m : maybe<int>, nothing : int) -> parse int(0literal: int
dec = 0
hex8 = 0x00
bit8 = 0b00000000)
pub fun pintstd/text/parse/pint: () -> parse int()result: -> parse int : parsestd/text/parse/parse: (E, V) -> V intstd/core/types/int: V
val negneg: bool = signstd/text/parse/sign: () -> parse bool()
val ii: int = pnatstd/text/parse/pnat: () -> parse int()
if negneg: bool then ~std/core/int/(~): (i : int) -> parse intii: int else ii: int
pub fun none-ofstd/text/parse/none-of: (chars : string) -> parse char( charschars: string : stringstd/core/types/string: V )result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char(""literal: string
count= 0, fnfn: (c : char) -> bool(cc: char) !std/core/types/bool/(!): (b : bool) -> boolcharschars: string.containsstd/core/string/contains: (s : string, sub : string) -> bool(cc: char.stringstd/core/string/char/string: (c : char) -> string) )
pub fun none-of-many1std/text/parse/none-of-many1: (chars : string) -> parse string( charschars: string : stringstd/core/types/string: V )result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
chars-arestd/text/parse/chars-are: (msg : string, pred : (char) -> bool) -> parse list<char>(""literal: string
count= 0, fnfn: (c : char) -> bool(cc: char) !std/core/types/bool/(!): (b : bool) -> boolcharschars: string.containsstd/core/string/contains: (s : string, sub : string) -> bool(cc: char.stringstd/core/string/char/string: (c : char) -> string)).stringstd/core/string/listchar/string: (cs : list<char>) -> parse string
pub fun one-ofstd/text/parse/one-of: (chars : string) -> parse char( charschars: string : stringstd/core/types/string: V )result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
char-isstd/text/parse/char-is: (msg : string, pred : (char) -> bool) -> parse char(charschars: string, fnfn: (c : char) -> bool(cc: char) charschars: string.containsstd/core/string/contains: (s : string, sub : string) -> bool(cc: char.stringstd/core/string/char/string: (c : char) -> string))
fun many-accstd/text/parse/many-acc: forall<a,e> (p : parser<e,a>, acc : list<a>) -> <parse|e> list<a>( pp: parser<$2659,$2658> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V>, accacc: list<$2658> : liststd/core/types/list: V -> V<aa: V> )result: -> <parse|2718> list<2717> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
(fnfn: () -> <parse|$2659> list<$2658>() val xx: $2658 = pp: parser<$2659,$2658>() in many-accstd/text/parse/many-acc: (p : parser<$2659,$2658>, acc : list<$2658>) -> <parse|$2659> list<$2658>(pretend-decreasingstd/core/undiv/pretend-decreasing: (x : parser<$2659,$2658>) -> <parse|$2659> parser<$2659,$2658>(pp: parser<$2659,$2658>),Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(xx: $2658,accacc: list<$2658>))) ||std/text/parse/(||): (p1 : parser<$2659,list<$2658>>, p2 : parser<$2659,list<$2658>>) -> <parse|$2659> list<$2658> (fnfn: () -> <parse|$2659> list<$2658>() accacc: list<$2658>.reversestd/core/list/reverse: (xs : list<$2658>) -> <parse|$2659> list<$2658>)
pub fun manystd/text/parse/many: forall<a,e> (p : parser<e,a>) -> <parse|e> list<a>( pp: parser<$2726,$2725> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> )result: -> <parse|2749> list<2748> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
many-accstd/text/parse/many-acc: (p : parser<$2726,$2725>, acc : list<$2725>) -> <parse|$2726> list<$2725>(pp: parser<$2726,$2725>,[std/core/types/Nil: forall<a> list<a>]std/core/types/Nil: forall<a> list<a>)
pub fun many1std/text/parse/many1: forall<a,e> (p : parser<e,a>) -> <parse|e> list<a>( pp: parser<$2757,$2756> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> )result: -> <parse|2786> list<2785> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(pp: parser<$2757,$2756>(), manystd/text/parse/many: (p : parser<$2757,$2756>) -> <parse|$2757> list<$2756>(pp: parser<$2757,$2756>))
pub fun sep-bystd/text/parse/sep-by: forall<a,b,e> (p : parser<e,a>, sep : parser<e,b>) -> <parse|e> list<a>( pp: parser<$3145,$3143> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V>, sepsep: parser<$3145,$3144> : parserstd/text/parse/parser: (E, V) -> V<ee: E,bb: V> )result: -> <parse|3186> list<3184> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
optionalstd/text/parse/optional: (default : list<$3143>, p : parser<$3145,list<$3143>>) -> <parse|$3145> list<$3143>([std/core/types/Nil: forall<a> list<a>]std/core/types/Nil: forall<a> list<a>){ sep-by1std/text/parse/sep-by1: (p : parser<$3145,$3143>, sep : parser<$3145,$3144>) -> <parse|$3145> list<$3143>(pp: parser<$3145,$3143>, sepsep: parser<$3145,$3144>) }
pub fun sep-by1std/text/parse/sep-by1: forall<a,b,e> (p : parser<e,a>, sep : parser<e,b>) -> <parse|e> list<a>( pp: parser<$3095,$3093> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V>, sepsep: parser<$3095,$3094> : parserstd/text/parse/parser: (E, V) -> V<ee: E,bb: V> )result: -> <parse|3133> list<3131> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(pp: parser<$3095,$3093>(), manystd/text/parse/many: (p : parser<$3095,$3093>) -> <parse|$3095> list<$3093>{ sepsep: parser<$3095,$3094>(); pp: parser<$3095,$3093>(); })
fun count-accstd/text/parse/count-acc: forall<a,e> (n : int, acc : list<a>, p : parser<e,a>) -> <parse|e> list<a>( nn: int : intstd/core/types/int: V, accacc: list<$2793> : liststd/core/types/list: V -> V<aa: V>, pp: parser<$2794,$2793> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> )result: -> <parse|2884> list<2883> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
if nn: int <=std/core/int/(<=): (x : int, y : int) -> <parse|$2794> bool 0literal: int
dec = 0
hex8 = 0x00
bit8 = 0b00000000 then accacc: list<$2793>.reversestd/core/list/reverse: (xs : list<$2793>) -> <parse|$2794> list<$2793> else
val xx: $2793 = pp: parser<$2794,$2793>()
count-accstd/text/parse/count-acc: (n : int, acc : list<$2793>, p : parser<$2794,$2793>) -> <parse|$2794> list<$2793>(pretend-decreasingstd/core/undiv/pretend-decreasing: (x : int) -> <parse|$2794> int(nn: int -std/core/int/(-): (x : int, y : int) -> <parse|$2794> int 1literal: int
dec = 1
hex8 = 0x01
bit8 = 0b00000001), Consstd/core/types/Cons: forall<a> (head : a, tail : list<a>) -> list<a>(xx: $2793,accacc: list<$2793>), pp: parser<$2794,$2793>)
pub fun countstd/text/parse/count: forall<a,e> (n : int, p : parser<e,a>) -> <parse|e> list<a>( nn: int : intstd/core/types/int: V, pp: parser<$2892,$2891> : parserstd/text/parse/parser: (E, V) -> V<ee: E,aa: V> )result: -> <parse|2916> list<2915> : <parsestd/text/parse/parse: (E, V) -> V|std/core/types/effect-extend: (X, E) -> Eee: E> liststd/core/types/list: V -> V<aa: V>
count-accstd/text/parse/count-acc: (n : int, acc : list<$2891>, p : parser<$2892,$2891>) -> <parse|$2892> list<$2891>(nn: int, [std/core/types/Nil: forall<a> list<a>]std/core/types/Nil: forall<a> list<a>, pp: parser<$2892,$2891>)
pub fun one-of-orstd/text/parse/one-of-or: (chars : string, default : char) -> parse char( charschars: string : stringstd/core/types/string: V, defaultdefault: char : charstd/core/types/char: V )result: -> parse char : parsestd/text/parse/parse: (E, V) -> V charstd/core/types/char: V
optionalstd/text/parse/optional: (default : char, p : parser<total,char>) -> parse char(defaultdefault: char){ one-ofstd/text/parse/one-of: (chars : string) -> parse char(charschars: string) }
pub fun hex-digitsstd/text/parse/hex-digits: () -> parse string()result: -> parse string : parsestd/text/parse/parse: (E, V) -> V stringstd/core/types/string: V
chars-arestd/text/parse/chars-are: (msg : string, pred : (char) -> bool) -> parse list<char>("digit"literal: string
count= 5, is-hex-digitstd/core/char/is-hex-digit: (c : char) -> bool ).stringstd/core/string/listchar/string: (cs : list<char>) -> parse string