Professional Documents
Culture Documents
Table
Grammar Parsing Table
Generator
Driver Parsing
Input Routine Table Output
The parser has an input, a stack, and a parsing table as shown below:
Input
a1 . . . . . . $
Sm
Driver Parsing
Routine Table
LR Parser
31
Compiler Design (SHG)
It determines Sm, the state currently on top of the stack, and ai, the current
input symbol.
It then consults ACTION[Sm, ai], the parsing action table entry for state Sm
and input ai. The entry ACTION[Sm, ai] can have one of the following four
values:-
1. Shift S
2. Reduce A B
3. Accept
4. Error
A .XYZ
A X.YZ
A XY.Z
A XYZ.
32
The production A Є generates only one item, “A .”. Inside the computer,
items are easily represented by pairs of integers, the first giving the number
of the production and the second the position of the dot.
GOTO
GOTO(I,X) is defined to be the closure of the set of all items [A ?X.β] such
that [A ?X.β] is in I. Intuitively, if I is the set of items that are valid for
some workable prefix γ, then GOTO(I,X) is the set of items that are valid for
the viable prefix γX.
procedure ITEMS(G’ )
begin
C := { CLOSURE ( {S’ .S } ) };
repeat
for each set of items I in C and each grammar symbol X such
that GOTO (I,X) is not empty and is not in C
do add GOTO (I,X) to C
until no more sets of items can be added to C
end
33
Compiler Design (SHG)
The SLR method begins with LR(0) items and LR(0) automata. That is, given
a grammar, G, G is augmented to produce G’, with a new start symbol S’.
From G', we construct C, the canonical collection of sets of items for G’
together with the GOT0 function.
2. GOTO:
34