freebsd-ports/lang/mlton/files/yacc.grm.sml
Stefan Walter 776ae1fb28 This patch adds three features to the lang/mlton port:
* Support for FreeBSD 6.x
* Support for compilation with SML/NJ
* Cross-compilation with mingw32

PR:		124061
Submitted by:	Timothy Bourke <timbob@bigpond.com>
Approved by:	maintainer
2008-12-10 08:44:24 +00:00

1053 lines
36 KiB
Standard ML

functor MlyaccLrValsFun(structure Hdr : HEADER
where type prec = Header.prec
structure Token : TOKEN)
=
struct
structure ParserData=
struct
structure Header =
struct
(* ML-Yacc Parser Generator (c) 1989 Andrew W. Appel, David R. Tarditi *)
(* parser for the ML parser generator *)
open Hdr
end
structure LrTable = Token.LrTable
structure Token = Token
local open LrTable in
val table=let val actionRows =
"\
\\001\000\001\000\076\000\000\000\
\\001\000\005\000\025\000\008\000\024\000\014\000\023\000\016\000\022\000\
\\019\000\021\000\020\000\020\000\021\000\019\000\022\000\018\000\
\\024\000\017\000\025\000\016\000\026\000\015\000\027\000\014\000\
\\028\000\013\000\029\000\012\000\031\000\011\000\035\000\010\000\
\\036\000\009\000\037\000\008\000\039\000\007\000\040\000\006\000\000\000\
\\001\000\006\000\063\000\000\000\
\\001\000\006\000\074\000\000\000\
\\001\000\006\000\086\000\000\000\
\\001\000\006\000\098\000\000\000\
\\001\000\007\000\085\000\033\000\084\000\000\000\
\\001\000\009\000\000\000\000\000\
\\001\000\010\000\061\000\000\000\
\\001\000\011\000\003\000\000\000\
\\001\000\012\000\026\000\000\000\
\\001\000\012\000\028\000\000\000\
\\001\000\012\000\029\000\000\000\
\\001\000\012\000\032\000\000\000\
\\001\000\012\000\044\000\013\000\043\000\000\000\
\\001\000\012\000\044\000\013\000\043\000\017\000\042\000\032\000\041\000\
\\038\000\040\000\000\000\
\\001\000\012\000\048\000\000\000\
\\001\000\012\000\053\000\000\000\
\\001\000\012\000\071\000\015\000\070\000\000\000\
\\001\000\012\000\071\000\015\000\070\000\033\000\069\000\000\000\
\\001\000\012\000\077\000\000\000\
\\001\000\012\000\080\000\000\000\
\\001\000\012\000\101\000\000\000\
\\001\000\032\000\036\000\000\000\
\\001\000\032\000\037\000\000\000\
\\001\000\032\000\050\000\000\000\
\\001\000\032\000\057\000\000\000\
\\001\000\032\000\100\000\000\000\
\\001\000\032\000\104\000\000\000\
\\106\000\012\000\053\000\000\000\
\\107\000\000\000\
\\108\000\000\000\
\\109\000\004\000\058\000\000\000\
\\110\000\004\000\058\000\000\000\
\\111\000\000\000\
\\112\000\000\000\
\\113\000\000\000\
\\114\000\000\000\
\\115\000\000\000\
\\116\000\000\000\
\\117\000\000\000\
\\118\000\000\000\
\\119\000\000\000\
\\120\000\000\000\
\\121\000\000\000\
\\122\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\123\000\000\000\
\\124\000\000\000\
\\125\000\000\000\
\\126\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\127\000\000\000\
\\128\000\000\000\
\\129\000\004\000\075\000\000\000\
\\130\000\000\000\
\\131\000\000\000\
\\132\000\004\000\060\000\000\000\
\\133\000\000\000\
\\134\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\135\000\023\000\091\000\000\000\
\\136\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\137\000\023\000\059\000\000\000\
\\138\000\004\000\094\000\000\000\
\\139\000\000\000\
\\140\000\000\000\
\\141\000\000\000\
\\142\000\012\000\034\000\000\000\
\\143\000\000\000\
\\144\000\000\000\
\\145\000\000\000\
\\146\000\000\000\
\\147\000\000\000\
\\148\000\000\000\
\\149\000\000\000\
\\150\000\000\000\
\\151\000\012\000\044\000\013\000\043\000\000\000\
\\152\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\153\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\154\000\001\000\066\000\002\000\065\000\012\000\044\000\013\000\043\000\000\000\
\\155\000\000\000\
\\156\000\000\000\
\\157\000\000\000\
\\158\000\000\000\
\\159\000\000\000\
\\160\000\030\000\096\000\000\000\
\"
val actionRowNumbers =
"\009\000\031\000\001\000\030\000\
\\010\000\046\000\011\000\012\000\
\\013\000\065\000\065\000\023\000\
\\024\000\015\000\048\000\065\000\
\\065\000\011\000\047\000\016\000\
\\065\000\025\000\017\000\065\000\
\\026\000\032\000\060\000\035\000\
\\055\000\040\000\008\000\038\000\
\\065\000\034\000\043\000\002\000\
\\049\000\073\000\068\000\071\000\
\\019\000\014\000\078\000\036\000\
\\041\000\033\000\044\000\037\000\
\\042\000\029\000\063\000\003\000\
\\052\000\039\000\000\000\050\000\
\\020\000\015\000\013\000\021\000\
\\064\000\015\000\072\000\015\000\
\\015\000\006\000\004\000\070\000\
\\081\000\080\000\079\000\062\000\
\\065\000\065\000\065\000\058\000\
\\059\000\054\000\056\000\045\000\
\\074\000\075\000\069\000\018\000\
\\015\000\061\000\083\000\051\000\
\\053\000\015\000\005\000\077\000\
\\065\000\027\000\022\000\057\000\
\\015\000\083\000\066\000\082\000\
\\076\000\028\000\067\000\007\000"
val gotoT =
"\
\\001\000\103\000\000\000\
\\006\000\002\000\000\000\
\\005\000\003\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\002\000\025\000\000\000\
\\000\000\
\\013\000\029\000\014\000\028\000\000\000\
\\003\000\031\000\000\000\
\\003\000\033\000\000\000\
\\000\000\
\\000\000\
\\007\000\037\000\017\000\036\000\000\000\
\\000\000\
\\003\000\043\000\000\000\
\\003\000\044\000\000\000\
\\002\000\045\000\000\000\
\\000\000\
\\000\000\
\\003\000\047\000\000\000\
\\000\000\
\\010\000\050\000\011\000\049\000\000\000\
\\003\000\054\000\015\000\053\000\016\000\052\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\003\000\060\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\007\000\062\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\004\000\066\000\008\000\065\000\000\000\
\\007\000\070\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\010\000\071\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\007\000\037\000\017\000\076\000\000\000\
\\013\000\077\000\014\000\028\000\000\000\
\\000\000\
\\000\000\
\\007\000\037\000\017\000\079\000\000\000\
\\000\000\
\\007\000\037\000\017\000\080\000\000\000\
\\007\000\037\000\017\000\081\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\000\000\
\\003\000\086\000\009\000\085\000\000\000\
\\003\000\054\000\015\000\087\000\016\000\052\000\000\000\
\\003\000\088\000\000\000\
\\000\000\
\\007\000\062\000\000\000\
\\000\000\
\\000\000\
\\007\000\062\000\000\000\
\\007\000\062\000\000\000\
\\007\000\062\000\000\000\
\\000\000\
\\004\000\090\000\000\000\
\\007\000\037\000\017\000\091\000\000\000\
\\000\000\
\\012\000\093\000\000\000\
\\000\000\
\\000\000\
\\007\000\037\000\017\000\095\000\000\000\
\\000\000\
\\007\000\062\000\000\000\
\\003\000\097\000\000\000\
\\000\000\
\\000\000\
\\007\000\062\000\000\000\
\\007\000\037\000\017\000\100\000\000\000\
\\012\000\101\000\000\000\
\\000\000\
\\000\000\
\\007\000\062\000\000\000\
\\000\000\
\\000\000\
\\000\000\
\"
val numstates = 104
val numrules = 55
val s = ref "" and index = ref 0
val string_to_int = fn () =>
let val i = !index
in index := i+2; Char.ord(String.sub(!s,i)) + Char.ord(String.sub(!s,i+1)) * 256
end
val string_to_list = fn s' =>
let val len = String.size s'
fun f () =
if !index < len then string_to_int() :: f()
else nil
in index := 0; s := s'; f ()
end
val string_to_pairlist = fn (conv_key,conv_entry) =>
let fun f () =
case string_to_int()
of 0 => EMPTY
| n => PAIR(conv_key (n-1),conv_entry (string_to_int()),f())
in f
end
val string_to_pairlist_default = fn (conv_key,conv_entry) =>
let val conv_row = string_to_pairlist(conv_key,conv_entry)
in fn () =>
let val default = conv_entry(string_to_int())
val row = conv_row()
in (row,default)
end
end
val string_to_table = fn (convert_row,s') =>
let val len = String.size s'
fun f ()=
if !index < len then convert_row() :: f()
else nil
in (s := s'; index := 0; f ())
end
local
val memo = Array.array(numstates+numrules,ERROR)
val _ =let fun g i=(Array.update(memo,i,REDUCE(i-numstates)); g(i+1))
fun f i =
if i=numstates then g i
else (Array.update(memo,i,SHIFT (STATE i)); f (i+1))
in f 0 handle Subscript => ()
end
in
val entry_to_action = fn 0 => ACCEPT | 1 => ERROR | j => Array.sub(memo,(j-2))
end
val gotoT=Array.fromList(string_to_table(string_to_pairlist(NT,STATE),gotoT))
val actionRows=string_to_table(string_to_pairlist_default(T,entry_to_action),actionRows)
val actionRowNumbers = string_to_list actionRowNumbers
val actionT = let val actionRowLookUp=
let val a=Array.fromList(actionRows) in fn i=>Array.sub(a,i) end
in Array.fromList(map actionRowLookUp actionRowNumbers)
end
in LrTable.mkLrTable {actions=actionT,gotos=gotoT,numRules=numrules,
numStates=numstates,initialState=STATE 0}
end
end
local open Header in
type pos = int
type arg = Hdr.inputSource
structure MlyValue =
struct
datatype svalue = VOID | ntVOID of unit -> unit
| UNKNOWN of unit -> (string) | TYVAR of unit -> (string)
| PROG of unit -> (string) | PREC of unit -> (Header.prec)
| INT of unit -> (string) | IDDOT of unit -> (string)
| ID of unit -> (string*int) | HEADER of unit -> (string)
| TY of unit -> (string)
| CHANGE_DEC of unit -> ( ( Hdr.symbol list * Hdr.symbol list ) )
| CHANGE_DECL of unit -> ( ( Hdr.symbol list * Hdr.symbol list ) list)
| SUBST_DEC of unit -> ( ( Hdr.symbol list * Hdr.symbol list ) )
| SUBST_DECL of unit -> ( ( Hdr.symbol list * Hdr.symbol list ) list)
| G_RULE_PREC of unit -> (Hdr.symbol option)
| G_RULE_LIST of unit -> (Hdr.rule list)
| G_RULE of unit -> (Hdr.rule list)
| RHS_LIST of unit -> ({ rhs:Hdr.symbol list,code:string,prec:Hdr.symbol option } list)
| RECORD_LIST of unit -> (string) | QUAL_ID of unit -> (string)
| MPC_DECLS of unit -> (Hdr.declData)
| MPC_DECL of unit -> (Hdr.declData) | LABEL of unit -> (string)
| ID_LIST of unit -> (Hdr.symbol list)
| CONSTR_LIST of unit -> ( ( Hdr.symbol * Hdr.ty option ) list)
| BEGIN of unit -> (string*Hdr.declData* ( Hdr.rule list ) )
end
type svalue = MlyValue.svalue
type result = string*Hdr.declData* ( Hdr.rule list )
end
structure EC=
struct
open LrTable
infix 5 $$
fun x $$ y = y::x
val is_keyword =
fn _ => false
val preferred_change : (term list * term list) list =
nil
val noShift =
fn (T 8) => true | _ => false
val showTerminal =
fn (T 0) => "ARROW"
| (T 1) => "ASTERISK"
| (T 2) => "BLOCK"
| (T 3) => "BAR"
| (T 4) => "CHANGE"
| (T 5) => "COLON"
| (T 6) => "COMMA"
| (T 7) => "DELIMITER"
| (T 8) => "EOF"
| (T 9) => "FOR"
| (T 10) => "HEADER"
| (T 11) => "ID"
| (T 12) => "IDDOT"
| (T 13) => "PERCENT_HEADER"
| (T 14) => "INT"
| (T 15) => "KEYWORD"
| (T 16) => "LBRACE"
| (T 17) => "LPAREN"
| (T 18) => "NAME"
| (T 19) => "NODEFAULT"
| (T 20) => "NONTERM"
| (T 21) => "NOSHIFT"
| (T 22) => "OF"
| (T 23) => "PERCENT_EOP"
| (T 24) => "PERCENT_PURE"
| (T 25) => "PERCENT_POS"
| (T 26) => "PERCENT_ARG"
| (T 27) => "PERCENT_TOKEN_SIG_INFO"
| (T 28) => "PREC"
| (T 29) => "PREC_TAG"
| (T 30) => "PREFER"
| (T 31) => "PROG"
| (T 32) => "RBRACE"
| (T 33) => "RPAREN"
| (T 34) => "SUBST"
| (T 35) => "START"
| (T 36) => "TERM"
| (T 37) => "TYVAR"
| (T 38) => "VERBOSE"
| (T 39) => "VALUE"
| (T 40) => "UNKNOWN"
| (T 41) => "BOGUS_VALUE"
| _ => "bogus-term"
local open Header in
val errtermvalue=
fn _ => MlyValue.VOID
end
val terms : term list = nil
$$ (T 41) $$ (T 39) $$ (T 38) $$ (T 36) $$ (T 35) $$ (T 34) $$ (T 33)
$$ (T 32) $$ (T 30) $$ (T 29) $$ (T 27) $$ (T 26) $$ (T 25) $$ (T 24)
$$ (T 23) $$ (T 22) $$ (T 21) $$ (T 20) $$ (T 19) $$ (T 18) $$ (T 17)
$$ (T 16) $$ (T 15) $$ (T 13) $$ (T 9) $$ (T 8) $$ (T 7) $$ (T 6) $$
(T 5) $$ (T 4) $$ (T 3) $$ (T 2) $$ (T 1) $$ (T 0)end
structure Actions =
struct
type int = Int.int
exception mlyAction of int
local open Header in
val actions =
fn (i392:int,defaultPos,stack,
(inputSource):arg) =>
case (i392,stack)
of ( 0, ( ( _, ( MlyValue.G_RULE_LIST G_RULE_LIST1, _,
G_RULE_LIST1right)) :: _ :: ( _, ( MlyValue.MPC_DECLS MPC_DECLS1, _, _
)) :: ( _, ( MlyValue.HEADER HEADER1, HEADER1left, _)) :: rest671)) =>
let val result = MlyValue.BEGIN (fn _ => let val (HEADER as HEADER1
) = HEADER1 ()
val (MPC_DECLS as MPC_DECLS1) = MPC_DECLS1 ()
val (G_RULE_LIST as G_RULE_LIST1) = G_RULE_LIST1 ()
in (HEADER,MPC_DECLS,rev G_RULE_LIST)
end)
in ( LrTable.NT 0, ( result, HEADER1left, G_RULE_LIST1right), rest671
)
end
| ( 1, ( ( _, ( MlyValue.MPC_DECL MPC_DECL1, MPC_DECLleft,
MPC_DECL1right)) :: ( _, ( MlyValue.MPC_DECLS MPC_DECLS1,
MPC_DECLS1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECLS (fn _ => let val (MPC_DECLS as MPC_DECLS1) =
MPC_DECLS1 ()
val (MPC_DECL as MPC_DECL1) = MPC_DECL1 ()
in (join_decls(MPC_DECLS,MPC_DECL,inputSource,MPC_DECLleft))
end)
in ( LrTable.NT 5, ( result, MPC_DECLS1left, MPC_DECL1right), rest671
)
end
| ( 2, ( rest671)) => let val result = MlyValue.MPC_DECLS (fn _ => (
DECL {prec=nil,nonterm=NONE,term=NONE,eop=nil,control=nil,
keyword=nil,change=nil,
value=nil}
))
in ( LrTable.NT 5, ( result, defaultPos, defaultPos), rest671)
end
| ( 3, ( ( _, ( MlyValue.CONSTR_LIST CONSTR_LIST1, _,
CONSTR_LIST1right)) :: ( _, ( _, TERM1left, _)) :: rest671)) => let
val result = MlyValue.MPC_DECL (fn _ => let val (CONSTR_LIST as
CONSTR_LIST1) = CONSTR_LIST1 ()
in (
DECL { prec=nil,nonterm=NONE,
term = SOME CONSTR_LIST, eop =nil,control=nil,
change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, TERM1left, CONSTR_LIST1right), rest671)
end
| ( 4, ( ( _, ( MlyValue.CONSTR_LIST CONSTR_LIST1, _,
CONSTR_LIST1right)) :: ( _, ( _, NONTERM1left, _)) :: rest671)) => let
val result = MlyValue.MPC_DECL (fn _ => let val (CONSTR_LIST as
CONSTR_LIST1) = CONSTR_LIST1 ()
in (
DECL { prec=nil,control=nil,nonterm= SOME CONSTR_LIST,
term = NONE, eop=nil,change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, NONTERM1left, CONSTR_LIST1right),
rest671)
end
| ( 5, ( ( _, ( MlyValue.ID_LIST ID_LIST1, _, ID_LIST1right)) :: ( _,
( MlyValue.PREC PREC1, PREC1left, _)) :: rest671)) => let val result
= MlyValue.MPC_DECL (fn _ => let val (PREC as PREC1) = PREC1 ()
val (ID_LIST as ID_LIST1) = ID_LIST1 ()
in (
DECL {prec= [(PREC,ID_LIST)],control=nil,
nonterm=NONE,term=NONE,eop=nil,change=nil,
keyword=nil,value=nil}
)
end)
in ( LrTable.NT 4, ( result, PREC1left, ID_LIST1right), rest671)
end
| ( 6, ( ( _, ( MlyValue.ID ID1, _, ID1right)) :: ( _, ( _,
START1left, _)) :: rest671)) => let val result = MlyValue.MPC_DECL
(fn _ => let val (ID as ID1) = ID1 ()
in (
DECL {prec=nil,control=[START_SYM (symbolMake ID)],nonterm=NONE,
term = NONE, eop = nil,change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, START1left, ID1right), rest671)
end
| ( 7, ( ( _, ( MlyValue.ID_LIST ID_LIST1, _, ID_LIST1right)) :: ( _,
( _, PERCENT_EOP1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (ID_LIST as ID_LIST1) = ID_LIST1
()
in (
DECL {prec=nil,control=nil,nonterm=NONE,term=NONE,
eop=ID_LIST, change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, PERCENT_EOP1left, ID_LIST1right),
rest671)
end
| ( 8, ( ( _, ( MlyValue.ID_LIST ID_LIST1, _, ID_LIST1right)) :: ( _,
( _, KEYWORD1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (ID_LIST as ID_LIST1) = ID_LIST1
()
in (
DECL {prec=nil,control=nil,nonterm=NONE,term=NONE,eop=nil,
change=nil,keyword=ID_LIST,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, KEYWORD1left, ID_LIST1right), rest671)
end
| ( 9, ( ( _, ( MlyValue.ID_LIST ID_LIST1, _, ID_LIST1right)) :: ( _,
( _, PREFER1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (ID_LIST as ID_LIST1) = ID_LIST1
()
in (
DECL {prec=nil,control=nil,nonterm=NONE,term=NONE,eop=nil,
change=map (fn i=>([],[i])) ID_LIST,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, PREFER1left, ID_LIST1right), rest671)
end
| ( 10, ( ( _, ( MlyValue.CHANGE_DECL CHANGE_DECL1, _,
CHANGE_DECL1right)) :: ( _, ( _, CHANGE1left, _)) :: rest671)) => let
val result = MlyValue.MPC_DECL (fn _ => let val (CHANGE_DECL as
CHANGE_DECL1) = CHANGE_DECL1 ()
in (
DECL {prec=nil,control=nil,nonterm=NONE,term=NONE,eop=nil,
change=CHANGE_DECL,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, CHANGE1left, CHANGE_DECL1right), rest671
)
end
| ( 11, ( ( _, ( MlyValue.SUBST_DECL SUBST_DECL1, _, SUBST_DECL1right
)) :: ( _, ( _, SUBST1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (SUBST_DECL as SUBST_DECL1) =
SUBST_DECL1 ()
in (
DECL {prec=nil,control=nil,nonterm=NONE,term=NONE,eop=nil,
change=SUBST_DECL,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, SUBST1left, SUBST_DECL1right), rest671)
end
| ( 12, ( ( _, ( MlyValue.ID_LIST ID_LIST1, _, ID_LIST1right)) :: ( _
, ( _, NOSHIFT1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (ID_LIST as ID_LIST1) = ID_LIST1
()
in (
DECL {prec=nil,control=[NSHIFT ID_LIST],nonterm=NONE,term=NONE,
eop=nil,change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, NOSHIFT1left, ID_LIST1right), rest671)
end
| ( 13, ( ( _, ( MlyValue.PROG PROG1, _, PROG1right)) :: ( _, ( _,
PERCENT_HEADER1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (PROG as PROG1) = PROG1 ()
in (
DECL {prec=nil,control=[FUNCTOR PROG],nonterm=NONE,term=NONE,
eop=nil,change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, PERCENT_HEADER1left, PROG1right),
rest671)
end
| ( 14, ( ( _, ( MlyValue.PROG PROG1, _, PROG1right)) :: ( _, ( _,
PERCENT_TOKEN_SIG_INFO1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (PROG as PROG1) = PROG1 ()
in (
DECL {prec=nil,control=[TOKEN_SIG_INFO PROG],
nonterm=NONE,term=NONE,
eop=nil,change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, PERCENT_TOKEN_SIG_INFO1left, PROG1right)
, rest671)
end
| ( 15, ( ( _, ( MlyValue.ID ID1, _, ID1right)) :: ( _, ( _,
NAME1left, _)) :: rest671)) => let val result = MlyValue.MPC_DECL (fn
_ => let val (ID as ID1) = ID1 ()
in (
DECL {prec=nil,control=[PARSER_NAME (symbolMake ID)],
nonterm=NONE,term=NONE,
eop=nil,change=nil,keyword=nil, value=nil}
)
end)
in ( LrTable.NT 4, ( result, NAME1left, ID1right), rest671)
end
| ( 16, ( ( _, ( MlyValue.TY TY1, _, TY1right)) :: _ :: ( _, (
MlyValue.PROG PROG1, _, _)) :: ( _, ( _, PERCENT_ARG1left, _)) ::
rest671)) => let val result = MlyValue.MPC_DECL (fn _ => let val (
PROG as PROG1) = PROG1 ()
val (TY as TY1) = TY1 ()
in (
DECL {prec=nil,control=[PARSE_ARG(PROG,TY)],nonterm=NONE,
term=NONE,eop=nil,change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, PERCENT_ARG1left, TY1right), rest671)
end
| ( 17, ( ( _, ( _, VERBOSE1left, VERBOSE1right)) :: rest671)) => let
val result = MlyValue.MPC_DECL (fn _ => (
DECL {prec=nil,control=[Hdr.VERBOSE],
nonterm=NONE,term=NONE,eop=nil,
change=nil,keyword=nil,
value=nil}
))
in ( LrTable.NT 4, ( result, VERBOSE1left, VERBOSE1right), rest671)
end
| ( 18, ( ( _, ( _, NODEFAULT1left, NODEFAULT1right)) :: rest671)) =>
let val result = MlyValue.MPC_DECL (fn _ => (
DECL {prec=nil,control=[Hdr.NODEFAULT],
nonterm=NONE,term=NONE,eop=nil,
change=nil,keyword=nil,
value=nil}
))
in ( LrTable.NT 4, ( result, NODEFAULT1left, NODEFAULT1right),
rest671)
end
| ( 19, ( ( _, ( _, PERCENT_PURE1left, PERCENT_PURE1right)) ::
rest671)) => let val result = MlyValue.MPC_DECL (fn _ => (
DECL {prec=nil,control=[Hdr.PURE],
nonterm=NONE,term=NONE,eop=nil,
change=nil,keyword=nil,
value=nil}
))
in ( LrTable.NT 4, ( result, PERCENT_PURE1left, PERCENT_PURE1right),
rest671)
end
| ( 20, ( ( _, ( MlyValue.TY TY1, _, TY1right)) :: ( _, ( _,
PERCENT_POS1left, _)) :: rest671)) => let val result =
MlyValue.MPC_DECL (fn _ => let val (TY as TY1) = TY1 ()
in (
DECL {prec=nil,control=[Hdr.POS TY],
nonterm=NONE,term=NONE,eop=nil,
change=nil,keyword=nil,
value=nil}
)
end)
in ( LrTable.NT 4, ( result, PERCENT_POS1left, TY1right), rest671)
end
| ( 21, ( ( _, ( MlyValue.PROG PROG1, _, PROG1right)) :: ( _, (
MlyValue.ID ID1, _, _)) :: ( _, ( _, VALUE1left, _)) :: rest671)) =>
let val result = MlyValue.MPC_DECL (fn _ => let val (ID as ID1) =
ID1 ()
val (PROG as PROG1) = PROG1 ()
in (
DECL {prec=nil,control=nil,
nonterm=NONE,term=NONE,eop=nil,
change=nil,keyword=nil,
value=[(symbolMake ID,PROG)]}
)
end)
in ( LrTable.NT 4, ( result, VALUE1left, PROG1right), rest671)
end
| ( 22, ( ( _, ( MlyValue.CHANGE_DECL CHANGE_DECL1, _,
CHANGE_DECL1right)) :: _ :: ( _, ( MlyValue.CHANGE_DEC CHANGE_DEC1,
CHANGE_DEC1left, _)) :: rest671)) => let val result =
MlyValue.CHANGE_DECL (fn _ => let val (CHANGE_DEC as CHANGE_DEC1) =
CHANGE_DEC1 ()
val (CHANGE_DECL as CHANGE_DECL1) = CHANGE_DECL1 ()
in (CHANGE_DEC :: CHANGE_DECL)
end)
in ( LrTable.NT 14, ( result, CHANGE_DEC1left, CHANGE_DECL1right),
rest671)
end
| ( 23, ( ( _, ( MlyValue.CHANGE_DEC CHANGE_DEC1, CHANGE_DEC1left,
CHANGE_DEC1right)) :: rest671)) => let val result =
MlyValue.CHANGE_DECL (fn _ => let val (CHANGE_DEC as CHANGE_DEC1) =
CHANGE_DEC1 ()
in ([CHANGE_DEC])
end)
in ( LrTable.NT 14, ( result, CHANGE_DEC1left, CHANGE_DEC1right),
rest671)
end
| ( 24, ( ( _, ( MlyValue.ID_LIST ID_LIST2, _, ID_LIST2right)) :: _
:: ( _, ( MlyValue.ID_LIST ID_LIST1, ID_LIST1left, _)) :: rest671))
=> let val result = MlyValue.CHANGE_DEC (fn _ => let val ID_LIST1 =
ID_LIST1 ()
val ID_LIST2 = ID_LIST2 ()
in (ID_LIST1, ID_LIST2)
end)
in ( LrTable.NT 15, ( result, ID_LIST1left, ID_LIST2right), rest671)
end
| ( 25, ( ( _, ( MlyValue.SUBST_DECL SUBST_DECL1, _, SUBST_DECL1right
)) :: _ :: ( _, ( MlyValue.SUBST_DEC SUBST_DEC1, SUBST_DEC1left, _))
:: rest671)) => let val result = MlyValue.SUBST_DECL (fn _ => let
val (SUBST_DEC as SUBST_DEC1) = SUBST_DEC1 ()
val (SUBST_DECL as SUBST_DECL1) = SUBST_DECL1 ()
in (SUBST_DEC :: SUBST_DECL)
end)
in ( LrTable.NT 12, ( result, SUBST_DEC1left, SUBST_DECL1right),
rest671)
end
| ( 26, ( ( _, ( MlyValue.SUBST_DEC SUBST_DEC1, SUBST_DEC1left,
SUBST_DEC1right)) :: rest671)) => let val result =
MlyValue.SUBST_DECL (fn _ => let val (SUBST_DEC as SUBST_DEC1) =
SUBST_DEC1 ()
in ([SUBST_DEC])
end)
in ( LrTable.NT 12, ( result, SUBST_DEC1left, SUBST_DEC1right),
rest671)
end
| ( 27, ( ( _, ( MlyValue.ID ID2, _, ID2right)) :: _ :: ( _, (
MlyValue.ID ID1, ID1left, _)) :: rest671)) => let val result =
MlyValue.SUBST_DEC (fn _ => let val ID1 = ID1 ()
val ID2 = ID2 ()
in ([symbolMake ID2],[symbolMake ID1])
end)
in ( LrTable.NT 13, ( result, ID1left, ID2right), rest671)
end
| ( 28, ( ( _, ( MlyValue.TY TY1, _, TY1right)) :: _ :: ( _, (
MlyValue.ID ID1, _, _)) :: _ :: ( _, ( MlyValue.CONSTR_LIST
CONSTR_LIST1, CONSTR_LIST1left, _)) :: rest671)) => let val result =
MlyValue.CONSTR_LIST (fn _ => let val (CONSTR_LIST as CONSTR_LIST1) =
CONSTR_LIST1 ()
val (ID as ID1) = ID1 ()
val (TY as TY1) = TY1 ()
in ((symbolMake ID,SOME (tyMake TY))::CONSTR_LIST)
end)
in ( LrTable.NT 1, ( result, CONSTR_LIST1left, TY1right), rest671)
end
| ( 29, ( ( _, ( MlyValue.ID ID1, _, ID1right)) :: _ :: ( _, (
MlyValue.CONSTR_LIST CONSTR_LIST1, CONSTR_LIST1left, _)) :: rest671))
=> let val result = MlyValue.CONSTR_LIST (fn _ => let val (
CONSTR_LIST as CONSTR_LIST1) = CONSTR_LIST1 ()
val (ID as ID1) = ID1 ()
in ((symbolMake ID,NONE)::CONSTR_LIST)
end)
in ( LrTable.NT 1, ( result, CONSTR_LIST1left, ID1right), rest671)
end
| ( 30, ( ( _, ( MlyValue.TY TY1, _, TY1right)) :: _ :: ( _, (
MlyValue.ID ID1, ID1left, _)) :: rest671)) => let val result =
MlyValue.CONSTR_LIST (fn _ => let val (ID as ID1) = ID1 ()
val (TY as TY1) = TY1 ()
in ([(symbolMake ID,SOME (tyMake TY))])
end)
in ( LrTable.NT 1, ( result, ID1left, TY1right), rest671)
end
| ( 31, ( ( _, ( MlyValue.ID ID1, ID1left, ID1right)) :: rest671)) =>
let val result = MlyValue.CONSTR_LIST (fn _ => let val (ID as ID1)
= ID1 ()
in ([(symbolMake ID,NONE)])
end)
in ( LrTable.NT 1, ( result, ID1left, ID1right), rest671)
end
| ( 32, ( ( _, ( MlyValue.RHS_LIST RHS_LIST1, _, RHS_LIST1right)) ::
_ :: ( _, ( MlyValue.ID ID1, ID1left, _)) :: rest671)) => let val
result = MlyValue.G_RULE (fn _ => let val (ID as ID1) = ID1 ()
val (RHS_LIST as RHS_LIST1) = RHS_LIST1 ()
in (
map (fn {rhs,code,prec} =>
Hdr.RULE {lhs=symbolMake ID,rhs=rhs,
code=code,prec=prec})
RHS_LIST
)
end)
in ( LrTable.NT 9, ( result, ID1left, RHS_LIST1right), rest671)
end
| ( 33, ( ( _, ( MlyValue.G_RULE G_RULE1, _, G_RULE1right)) :: ( _, (
MlyValue.G_RULE_LIST G_RULE_LIST1, G_RULE_LIST1left, _)) :: rest671))
=> let val result = MlyValue.G_RULE_LIST (fn _ => let val (
G_RULE_LIST as G_RULE_LIST1) = G_RULE_LIST1 ()
val (G_RULE as G_RULE1) = G_RULE1 ()
in (G_RULE@G_RULE_LIST)
end)
in ( LrTable.NT 10, ( result, G_RULE_LIST1left, G_RULE1right),
rest671)
end
| ( 34, ( ( _, ( MlyValue.G_RULE G_RULE1, G_RULE1left, G_RULE1right))
:: rest671)) => let val result = MlyValue.G_RULE_LIST (fn _ => let
val (G_RULE as G_RULE1) = G_RULE1 ()
in (G_RULE)
end)
in ( LrTable.NT 10, ( result, G_RULE1left, G_RULE1right), rest671)
end
| ( 35, ( ( _, ( MlyValue.ID_LIST ID_LIST1, _, ID_LIST1right)) :: ( _
, ( MlyValue.ID ID1, ID1left, _)) :: rest671)) => let val result =
MlyValue.ID_LIST (fn _ => let val (ID as ID1) = ID1 ()
val (ID_LIST as ID_LIST1) = ID_LIST1 ()
in (symbolMake ID :: ID_LIST)
end)
in ( LrTable.NT 2, ( result, ID1left, ID_LIST1right), rest671)
end
| ( 36, ( rest671)) => let val result = MlyValue.ID_LIST (fn _ => (
nil))
in ( LrTable.NT 2, ( result, defaultPos, defaultPos), rest671)
end
| ( 37, ( ( _, ( MlyValue.PROG PROG1, _, PROG1right)) :: ( _, (
MlyValue.G_RULE_PREC G_RULE_PREC1, _, _)) :: ( _, ( MlyValue.ID_LIST
ID_LIST1, ID_LIST1left, _)) :: rest671)) => let val result =
MlyValue.RHS_LIST (fn _ => let val (ID_LIST as ID_LIST1) = ID_LIST1
()
val (G_RULE_PREC as G_RULE_PREC1) = G_RULE_PREC1 ()
val (PROG as PROG1) = PROG1 ()
in ([{rhs=ID_LIST,code=PROG,prec=G_RULE_PREC}])
end)
in ( LrTable.NT 8, ( result, ID_LIST1left, PROG1right), rest671)
end
| ( 38, ( ( _, ( MlyValue.PROG PROG1, _, PROG1right)) :: ( _, (
MlyValue.G_RULE_PREC G_RULE_PREC1, _, _)) :: ( _, ( MlyValue.ID_LIST
ID_LIST1, _, _)) :: _ :: ( _, ( MlyValue.RHS_LIST RHS_LIST1,
RHS_LIST1left, _)) :: rest671)) => let val result = MlyValue.RHS_LIST
(fn _ => let val (RHS_LIST as RHS_LIST1) = RHS_LIST1 ()
val (ID_LIST as ID_LIST1) = ID_LIST1 ()
val (G_RULE_PREC as G_RULE_PREC1) = G_RULE_PREC1 ()
val (PROG as PROG1) = PROG1 ()
in ({rhs=ID_LIST,code=PROG,prec=G_RULE_PREC}::RHS_LIST)
end)
in ( LrTable.NT 8, ( result, RHS_LIST1left, PROG1right), rest671)
end
| ( 39, ( ( _, ( MlyValue.TYVAR TYVAR1, TYVAR1left, TYVAR1right)) ::
rest671)) => let val result = MlyValue.TY (fn _ => let val (TYVAR
as TYVAR1) = TYVAR1 ()
in (TYVAR)
end)
in ( LrTable.NT 16, ( result, TYVAR1left, TYVAR1right), rest671)
end
| ( 40, ( ( _, ( _, _, RBRACE1right)) :: ( _, ( MlyValue.RECORD_LIST
RECORD_LIST1, _, _)) :: ( _, ( _, LBRACE1left, _)) :: rest671)) => let
val result = MlyValue.TY (fn _ => let val (RECORD_LIST as
RECORD_LIST1) = RECORD_LIST1 ()
in ("{ "^RECORD_LIST^" } ")
end)
in ( LrTable.NT 16, ( result, LBRACE1left, RBRACE1right), rest671)
end
| ( 41, ( ( _, ( _, _, RBRACE1right)) :: ( _, ( _, LBRACE1left, _))
:: rest671)) => let val result = MlyValue.TY (fn _ => ("{}"))
in ( LrTable.NT 16, ( result, LBRACE1left, RBRACE1right), rest671)
end
| ( 42, ( ( _, ( MlyValue.PROG PROG1, PROG1left, PROG1right)) ::
rest671)) => let val result = MlyValue.TY (fn _ => let val (PROG as
PROG1) = PROG1 ()
in (" ( "^PROG^" ) ")
end)
in ( LrTable.NT 16, ( result, PROG1left, PROG1right), rest671)
end
| ( 43, ( ( _, ( MlyValue.QUAL_ID QUAL_ID1, _, QUAL_ID1right)) :: ( _
, ( MlyValue.TY TY1, TY1left, _)) :: rest671)) => let val result =
MlyValue.TY (fn _ => let val (TY as TY1) = TY1 ()
val (QUAL_ID as QUAL_ID1) = QUAL_ID1 ()
in (TY^" "^QUAL_ID)
end)
in ( LrTable.NT 16, ( result, TY1left, QUAL_ID1right), rest671)
end
| ( 44, ( ( _, ( MlyValue.QUAL_ID QUAL_ID1, QUAL_ID1left,
QUAL_ID1right)) :: rest671)) => let val result = MlyValue.TY (fn _ =>
let val (QUAL_ID as QUAL_ID1) = QUAL_ID1 ()
in (QUAL_ID)
end)
in ( LrTable.NT 16, ( result, QUAL_ID1left, QUAL_ID1right), rest671)
end
| ( 45, ( ( _, ( MlyValue.TY TY2, _, TY2right)) :: _ :: ( _, (
MlyValue.TY TY1, TY1left, _)) :: rest671)) => let val result =
MlyValue.TY (fn _ => let val TY1 = TY1 ()
val TY2 = TY2 ()
in (TY1^"*"^TY2)
end)
in ( LrTable.NT 16, ( result, TY1left, TY2right), rest671)
end
| ( 46, ( ( _, ( MlyValue.TY TY2, _, TY2right)) :: _ :: ( _, (
MlyValue.TY TY1, TY1left, _)) :: rest671)) => let val result =
MlyValue.TY (fn _ => let val TY1 = TY1 ()
val TY2 = TY2 ()
in (TY1 ^ " -> " ^ TY2)
end)
in ( LrTable.NT 16, ( result, TY1left, TY2right), rest671)
end
| ( 47, ( ( _, ( MlyValue.TY TY1, _, TY1right)) :: _ :: ( _, (
MlyValue.LABEL LABEL1, _, _)) :: _ :: ( _, ( MlyValue.RECORD_LIST
RECORD_LIST1, RECORD_LIST1left, _)) :: rest671)) => let val result =
MlyValue.RECORD_LIST (fn _ => let val (RECORD_LIST as RECORD_LIST1) =
RECORD_LIST1 ()
val (LABEL as LABEL1) = LABEL1 ()
val (TY as TY1) = TY1 ()
in (RECORD_LIST^","^LABEL^":"^TY)
end)
in ( LrTable.NT 7, ( result, RECORD_LIST1left, TY1right), rest671)
end
| ( 48, ( ( _, ( MlyValue.TY TY1, _, TY1right)) :: _ :: ( _, (
MlyValue.LABEL LABEL1, LABEL1left, _)) :: rest671)) => let val result
= MlyValue.RECORD_LIST (fn _ => let val (LABEL as LABEL1) = LABEL1
()
val (TY as TY1) = TY1 ()
in (LABEL^":"^TY)
end)
in ( LrTable.NT 7, ( result, LABEL1left, TY1right), rest671)
end
| ( 49, ( ( _, ( MlyValue.ID ID1, ID1left, ID1right)) :: rest671)) =>
let val result = MlyValue.QUAL_ID (fn _ => let val (ID as ID1) =
ID1 ()
in ((fn (a,_) => a) ID)
end)
in ( LrTable.NT 6, ( result, ID1left, ID1right), rest671)
end
| ( 50, ( ( _, ( MlyValue.QUAL_ID QUAL_ID1, _, QUAL_ID1right)) :: ( _
, ( MlyValue.IDDOT IDDOT1, IDDOT1left, _)) :: rest671)) => let val
result = MlyValue.QUAL_ID (fn _ => let val (IDDOT as IDDOT1) = IDDOT1
()
val (QUAL_ID as QUAL_ID1) = QUAL_ID1 ()
in (IDDOT^QUAL_ID)
end)
in ( LrTable.NT 6, ( result, IDDOT1left, QUAL_ID1right), rest671)
end
| ( 51, ( ( _, ( MlyValue.ID ID1, ID1left, ID1right)) :: rest671)) =>
let val result = MlyValue.LABEL (fn _ => let val (ID as ID1) = ID1
()
in ((fn (a,_) => a) ID)
end)
in ( LrTable.NT 3, ( result, ID1left, ID1right), rest671)
end
| ( 52, ( ( _, ( MlyValue.INT INT1, INT1left, INT1right)) :: rest671)
) => let val result = MlyValue.LABEL (fn _ => let val (INT as INT1)
= INT1 ()
in (INT)
end)
in ( LrTable.NT 3, ( result, INT1left, INT1right), rest671)
end
| ( 53, ( ( _, ( MlyValue.ID ID1, _, ID1right)) :: ( _, ( _,
PREC_TAG1left, _)) :: rest671)) => let val result =
MlyValue.G_RULE_PREC (fn _ => let val (ID as ID1) = ID1 ()
in (SOME (symbolMake ID))
end)
in ( LrTable.NT 11, ( result, PREC_TAG1left, ID1right), rest671)
end
| ( 54, ( rest671)) => let val result = MlyValue.G_RULE_PREC (fn _
=> (NONE))
in ( LrTable.NT 11, ( result, defaultPos, defaultPos), rest671)
end
| _ => raise (mlyAction i392)
end
val void = MlyValue.VOID
val extract = fn a => (fn MlyValue.BEGIN x => x
| _ => let exception ParseInternal
in raise ParseInternal end) a ()
end
end
structure Tokens : Mlyacc_TOKENS =
struct
type svalue = ParserData.svalue
type ('a,'b) token = ('a,'b) Token.token
fun ARROW (p1,p2) = Token.TOKEN (ParserData.LrTable.T 0,(
ParserData.MlyValue.VOID,p1,p2))
fun ASTERISK (p1,p2) = Token.TOKEN (ParserData.LrTable.T 1,(
ParserData.MlyValue.VOID,p1,p2))
fun BLOCK (p1,p2) = Token.TOKEN (ParserData.LrTable.T 2,(
ParserData.MlyValue.VOID,p1,p2))
fun BAR (p1,p2) = Token.TOKEN (ParserData.LrTable.T 3,(
ParserData.MlyValue.VOID,p1,p2))
fun CHANGE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 4,(
ParserData.MlyValue.VOID,p1,p2))
fun COLON (p1,p2) = Token.TOKEN (ParserData.LrTable.T 5,(
ParserData.MlyValue.VOID,p1,p2))
fun COMMA (p1,p2) = Token.TOKEN (ParserData.LrTable.T 6,(
ParserData.MlyValue.VOID,p1,p2))
fun DELIMITER (p1,p2) = Token.TOKEN (ParserData.LrTable.T 7,(
ParserData.MlyValue.VOID,p1,p2))
fun EOF (p1,p2) = Token.TOKEN (ParserData.LrTable.T 8,(
ParserData.MlyValue.VOID,p1,p2))
fun FOR (p1,p2) = Token.TOKEN (ParserData.LrTable.T 9,(
ParserData.MlyValue.VOID,p1,p2))
fun HEADER (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 10,(
ParserData.MlyValue.HEADER (fn () => i),p1,p2))
fun ID (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 11,(
ParserData.MlyValue.ID (fn () => i),p1,p2))
fun IDDOT (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 12,(
ParserData.MlyValue.IDDOT (fn () => i),p1,p2))
fun PERCENT_HEADER (p1,p2) = Token.TOKEN (ParserData.LrTable.T 13,(
ParserData.MlyValue.VOID,p1,p2))
fun INT (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 14,(
ParserData.MlyValue.INT (fn () => i),p1,p2))
fun KEYWORD (p1,p2) = Token.TOKEN (ParserData.LrTable.T 15,(
ParserData.MlyValue.VOID,p1,p2))
fun LBRACE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 16,(
ParserData.MlyValue.VOID,p1,p2))
fun LPAREN (p1,p2) = Token.TOKEN (ParserData.LrTable.T 17,(
ParserData.MlyValue.VOID,p1,p2))
fun NAME (p1,p2) = Token.TOKEN (ParserData.LrTable.T 18,(
ParserData.MlyValue.VOID,p1,p2))
fun NODEFAULT (p1,p2) = Token.TOKEN (ParserData.LrTable.T 19,(
ParserData.MlyValue.VOID,p1,p2))
fun NONTERM (p1,p2) = Token.TOKEN (ParserData.LrTable.T 20,(
ParserData.MlyValue.VOID,p1,p2))
fun NOSHIFT (p1,p2) = Token.TOKEN (ParserData.LrTable.T 21,(
ParserData.MlyValue.VOID,p1,p2))
fun OF (p1,p2) = Token.TOKEN (ParserData.LrTable.T 22,(
ParserData.MlyValue.VOID,p1,p2))
fun PERCENT_EOP (p1,p2) = Token.TOKEN (ParserData.LrTable.T 23,(
ParserData.MlyValue.VOID,p1,p2))
fun PERCENT_PURE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 24,(
ParserData.MlyValue.VOID,p1,p2))
fun PERCENT_POS (p1,p2) = Token.TOKEN (ParserData.LrTable.T 25,(
ParserData.MlyValue.VOID,p1,p2))
fun PERCENT_ARG (p1,p2) = Token.TOKEN (ParserData.LrTable.T 26,(
ParserData.MlyValue.VOID,p1,p2))
fun PERCENT_TOKEN_SIG_INFO (p1,p2) = Token.TOKEN (
ParserData.LrTable.T 27,(ParserData.MlyValue.VOID,p1,p2))
fun PREC (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 28,(
ParserData.MlyValue.PREC (fn () => i),p1,p2))
fun PREC_TAG (p1,p2) = Token.TOKEN (ParserData.LrTable.T 29,(
ParserData.MlyValue.VOID,p1,p2))
fun PREFER (p1,p2) = Token.TOKEN (ParserData.LrTable.T 30,(
ParserData.MlyValue.VOID,p1,p2))
fun PROG (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 31,(
ParserData.MlyValue.PROG (fn () => i),p1,p2))
fun RBRACE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 32,(
ParserData.MlyValue.VOID,p1,p2))
fun RPAREN (p1,p2) = Token.TOKEN (ParserData.LrTable.T 33,(
ParserData.MlyValue.VOID,p1,p2))
fun SUBST (p1,p2) = Token.TOKEN (ParserData.LrTable.T 34,(
ParserData.MlyValue.VOID,p1,p2))
fun START (p1,p2) = Token.TOKEN (ParserData.LrTable.T 35,(
ParserData.MlyValue.VOID,p1,p2))
fun TERM (p1,p2) = Token.TOKEN (ParserData.LrTable.T 36,(
ParserData.MlyValue.VOID,p1,p2))
fun TYVAR (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 37,(
ParserData.MlyValue.TYVAR (fn () => i),p1,p2))
fun VERBOSE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 38,(
ParserData.MlyValue.VOID,p1,p2))
fun VALUE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 39,(
ParserData.MlyValue.VOID,p1,p2))
fun UNKNOWN (i,p1,p2) = Token.TOKEN (ParserData.LrTable.T 40,(
ParserData.MlyValue.UNKNOWN (fn () => i),p1,p2))
fun BOGUS_VALUE (p1,p2) = Token.TOKEN (ParserData.LrTable.T 41,(
ParserData.MlyValue.VOID,p1,p2))
end
end