-- file ParseTable.mesa
-- created by PGS from PackTreeBuild.mesa, 28-Sep-81 14:56
ParseTable: DEFINITIONS = {
Symbol: TYPE = [0..255];
TSymbol: TYPE = Symbol [0.. 23];
NTSymbol: TYPE = Symbol [0.. 24];
-- token indices for the scanner and parser
tokenID: TSymbol = 1;
InitialSymbol: TSymbol = 9;
TrueEndOfFile: TSymbol = 2;
DefaultMarker: TSymbol = FIRST[TSymbol];
EndMarker: TSymbol = LAST[TSymbol];
HashIndex: TYPE = [0.. 35];
VIndex: TYPE = [0.. 75];
VocabHashEntry: TYPE = MACHINE DEPENDENT RECORD [
symbol: [0..377B], -- symbol index (TSymbol)
link: [0..377B]]; -- link to next entry (HashIndex)
State: TYPE = [0.. 68];
NTState: TYPE = State [0.. 17];
TIndex: TYPE = [0.. 95];
NTIndex: TYPE = [0.. 17];
Production: TYPE = [0.. 51];
ActionTag: TYPE = MACHINE DEPENDENT RECORD [
reduce: BOOLEAN, -- TRUE iff reduce entry
pLength: [0..17B]]; -- number of symbols in production rhs
ActionEntry: TYPE = MACHINE DEPENDENT RECORD [
tag: ActionTag, -- [FALSE,0] if a shift entry
transition: [0..3777B]]; -- production number / next state
ProductionInfo: TYPE = MACHINE DEPENDENT RECORD [
rule: [0..377B], -- reduction rule
lhs: Symbol]; -- production lhs symbol (NTSymbol)
ScanTable: TYPE = ARRAY CHARACTER [40C..177C] OF TSymbol;
HashTable: TYPE = ARRAY HashIndex OF VocabHashEntry;
IndexTable: TYPE = ARRAY TSymbol OF CARDINAL;
Vocabulary: TYPE = RECORD [
length, maxlength: CARDINAL,
text: PACKED ARRAY VIndex OF CHARACTER];
ProdData: TYPE = ARRAY Production OF ProductionInfo;
NStarts: TYPE = ARRAY NTState OF NTIndex;
NLengths: TYPE = ARRAY NTState OF CARDINAL;
NSymbols: TYPE = ARRAY NTIndex OF NTSymbol;
NActions: TYPE = ARRAY NTIndex OF ActionEntry;
NTDefaults: TYPE = ARRAY NTSymbol OF ActionEntry;
TStarts: TYPE = ARRAY State OF TIndex;
TLengths: TYPE = ARRAY State OF CARDINAL;
TSymbols: TYPE = ARRAY TIndex OF TSymbol;
TActions: TYPE = ARRAY TIndex OF ActionEntry;
InitialState: State = 1;
FinalState: State = 0;
Table: TYPE = MACHINE DEPENDENT RECORD [
scanTable: RECORD [
scanTab: TableRef RELATIVE POINTER TO ScanTable,
hashTab: TableRef RELATIVE POINTER TO HashTable,
vocabIndex: TableRef RELATIVE POINTER TO IndexTable,
vocabBody: TableRef RELATIVE POINTER TO Vocabulary],
parseTable: RECORD [
prodData: TableRef RELATIVE POINTER TO ProdData,
nStart: TableRef RELATIVE POINTER TO NStarts,
nLength: TableRef RELATIVE POINTER TO NLengths,
nSymbol: TableRef RELATIVE POINTER TO NSymbols,
nAction: TableRef RELATIVE POINTER TO NActions,
ntDefaults: TableRef RELATIVE POINTER TO NTDefaults,
tStart: TableRef RELATIVE POINTER TO TStarts,
tLength: TableRef RELATIVE POINTER TO TLengths,
tSymbol: TableRef RELATIVE POINTER TO TSymbols,
tAction: TableRef RELATIVE POINTER TO TActions]];
TableRef: TYPE = LONG BASE POINTER TO Table;
ScanTableRef: TYPE = LONG POINTER TO ScanTable;
HashTableRef: TYPE = LONG POINTER TO HashTable;
IndexTableRef: TYPE = LONG POINTER TO IndexTable;
VocabularyRef: TYPE = LONG POINTER TO Vocabulary;
ProdDataRef: TYPE = LONG POINTER TO ProdData;
NStartsRef: TYPE = LONG POINTER TO NStarts;
NLengthsRef: TYPE = LONG POINTER TO NLengths;
NSymbolsRef: TYPE = LONG POINTER TO NSymbols;
NActionsRef: TYPE = LONG POINTER TO NActions;
NTDefaultsRef: TYPE = LONG POINTER TO NTDefaults;
TStartsRef: TYPE = LONG POINTER TO TStarts;
TLengthsRef: TYPE = LONG POINTER TO TLengths;
TSymbolsRef: TYPE = LONG POINTER TO TSymbols;
TActionsRef: TYPE = LONG POINTER TO TActions;
}.