The standard library Parser api defines the Parser type used by the Mythryl-Yacc parser generator.
The Parser api source code is in src/app/yacc/lib/base.api.
The above information is manually maintained and may contain errors.
api { package token : api { package lr_table : api { Pairlist (X, Y) = EMPTY | PAIR (X , Y , Pairlist((X, Y))); State = STATE Int; Terminal = TERM Int; Nonterminal = NONTERM Int; Action = ACCEPT | ERROR | REDUCE Int | SHIFT State; Table; state_count : Table -> Int; rule_count : Table -> Int; describe_goto : Table -> State -> Pairlist((Nonterminal, State)); action : Table -> (State , Terminal) -> Action; goto : Table -> (State , Nonterminal) -> State; initial_state : Table -> State; describe_actions : Table -> State -> (Pairlist((Terminal, Action)) , Action); exception GOTO (State , Nonterminal); make_lr_table : {actions:Rw_Vector(((Pairlist((Terminal, Action)) , Action)) ), gotos:Rw_Vector(Pairlist((Nonterminal, State)) ), initial_state:State, rule_count:Int, state_count:Int} -> Table;};; Token (X, Y) = TOKEN (lr_table::Terminal , ((X , Y , Y))); same_token : (Token((X, Y)) , Token((X, Y))) -> Bool;};; package stream : api { Stream X; streamify : (Void -> X) -> Stream(X ); cons : (X , Stream(X )) -> Stream(X ); get : Stream(X ) -> (X , Stream(X ));};; exception PARSE_ERROR; Source_Position; Result; Arg; Semantic_Value; make_lexer : (Int -> String) -> stream::Stream(token::Token((Semantic_Value, Source_Position)) ); parse : ( Int , stream::Stream(token::Token((Semantic_Value, Source_Position)) ) , ((String , Source_Position , Source_Position) -> Void) , Arg ) -> (Result , stream::Stream(token::Token((Semantic_Value, Source_Position)) )); same_token : (token::Token((Semantic_Value, Source_Position)) , token::Token((Semantic_Value, Source_Position))) -> Bool;};