Download presentation
Presentation is loading. Please wait.
Published byHollie Sullivan Modified over 8 years ago
1
Syntax and Semantics Structure of programming languages
2
Parsing Parsing is a process that constructs a syntactic structure (i.e. parse tree) from the stream of tokens. We already learn how to describe the syntactic structure of a language using (context-free) grammar. So, a parser only need to do this? Stream of tokens Context-free grammar Parser Parse tree
3
Top–Down Parsing Bottom–Up Parsing A parse tree is created from root to leaves Tracing leftmost derivation Two types: –Backtracking parser –Predictive parser A parse tree is created from leaves to root Tracing rightmost derivation More powerful than top-down parsing
4
Top-down Parsing What does a parser need to decide? –Which production rule is to be used at each point of time ? How to guess? What is the guess based on? –What is the next token? Reserved word if, open parentheses, etc. –What is the structure to be built? If statement, expression, etc.
5
Top-down Parsing Why is it difficult? –Cannot decide until later Next token: ifStructure to be built: St St MatchedSt | UnmatchedSt UnmatchedSt if ( E ) St| if ( E ) MatchedSt else UnmatchedSt MatchedSt if ( E ) MatchedSt else MatchedSt |... –Production with empty string Next token: idStructure to be built: par par parList | parList exp, parList | exp
6
Recursive-Descent Write one procedure for each set of productions with the same nonterminal in the LHS Each procedure recognizes a structure described by a nonterminal. A procedure calls other procedures if it need to recognize other structures. A procedure calls match procedure if it need to recognize a terminal.
7
Recursive-Descent: Example E E O F | F O + | - F ( E ) | id procedure F {switch token {case (: match(‘(‘); E; match(‘)’); case id: match(id); default: error; } } For this grammar: –We cannot decide which rule to use for E, and –If we choose E E O F, it leads to infinitely recursive loops. Rewrite the grammar into EBNF procedure E {F; while (token=+ or token=- ) {O; F;} } procedure E {E; O; F; } E ::= F {O F} O ::= + | - F ::= ( E ) | id
8
Problems in Recursive-Descent Difficult to convert grammars into EBNF Cannot decide which production to use at each point Cannot decide when to use -production A
9
LL(1) Parsing LL(1) –Read input from (L) left to right –Simulate (L) leftmost derivation –1 lookahead symbol Use stack to simulate leftmost derivation –Part of sentential form produced in the leftmost derivation is stored in the stack. –Top of stack is the leftmost nonterminal symbol in the fragment of sentential form.
10
Concept of LL(1) Parsing Simulate leftmost derivation of the input. Keep part of sentential form in the stack. If the symbol on the top of stack is a terminal, try to match it with the next input token and pop it out of stack. If the symbol on the top of stack is a nonterminal X, replace it with Y if we have a production rule X Y. –Which production will be chosen, if there are both X Y and X Z ?
11
Example of LL(1) Parsing (n+(n))*n$ $ E E T XE T X X A T X | A + | - T F NT F N N M F N | M * F ( E ) | n T X F N ) E ( T X F N n A T X + F N ( E ) T X F N n M F N * n Finished E TX FNX (E)NX (TX)NX (FNX)NX (nNX)NX (nX)NX (nATX)NX (n+TX)NX (n+FNX)NX (n+(E)NX)NX (n+(TX)NX)NX (n+(FNX)NX)NX (n+(nNX)NX)NX (n+(nX)NX)NX (n+(n)NX)NX (n+(n)X)NX (n+(n))NX (n+(n))MFNX (n+(n))*FNX (n+(n))*nNX (n+(n))*nX (n+(n))*n
12
LL(1) Parsing Algorithm Push the start symbol into the stack WHILE stack is not empty ($ is not on top of stack) and the stream of tokens is not empty (the next input token is not $) SWITCH (Top of stack, next token) CASE (terminal a, a): Pop stack;Get next token CASE (nonterminal A, terminal a): IF the parsing table entry M[A, a] is not empty THEN Get A X 1 X 2... X n from the parsing table entry M[A, a] Pop stack; Push X n... X 2 X 1 into stack in that order ELSEError CASE ($,$):Accept OTHER:Error
13
Consider the context-free grammar S a X X b X | b Y Y c Detail how an shift-reduce parser will parse the sentence abbc
14
Example ::= | & ::= - | ::= | * ::= | ::= A|B|C|D|E|F|G|H|I|J|Y|Z &*-
15
Bottom-up Parsing Use explicit stack to perform a parse Simulate rightmost derivation (R) from left (L) to right, thus called LR parsing More powerful than top-down parsing –Left recursion does not cause problem Two actions –Shift: take next input token into the stack –Reduce: replace a string B on top of stack by a nonterminal A, given a production A B
16
Bottom-up Parsing (cont.) Shift-Reduce Algorithms –Reduce is the action of replacing the handle on the top of the parse stack with its corresponding LHS –Shift is the action of moving the next token to the top of the parse stack
17
Example of Shift-reduce Parsing Reverse of rightmost derivation from left to right 1 ( ( ) ) 2 ( ( ) ) 3 ( ( ) ) 4 ( ( S ) ) 5 ( ( S ) ) 6 ( ( S ) S ) 7 ( S ) 8 ( S ) 9 ( S ) S 10 S’ S Grammar S’ S S (S)S | Parsing actions StackInputAction $ ( ( ) ) $shift $ ( ( ) ) $ reduce S $ ( ( S ) ) $shift $ ( ( S ) ) $reduce S $ ( ( S ) S) $reduce S ( S ) S $ ( S) $shift $ ( S ) $reduce S $ ( S ) S $reduce S ( S ) S $ S $ accept
18
18 Example of LR(0) Parsing StackInputAction $0( ( a ) ) $shift $0(3 ( a ) ) $shift $0(3(3 a ) ) $shift $0(3(3a2 ) ) $reduce $0(3(3A4 ) ) $shift $0(3(3A4)5 ) $reduce $0(3A4 ) $shift $0(3A4)5$reduce $0A1$accept
19
19 Introduction(3) adbbc INPUT: Bottom-Up Parsing Program e OUTPUT: $ Production S aABe A Abc A b B d Bottom-Up Parser Example Shift a
20
20 Introduction(4) adbbc INPUT: Bottom-Up Parsing Program e OUTPUT: A b $ Production S aABe A Abc A b B d Bottom-Up Parser Example Shift b Reduce from b to A
21
21 Introduction(5) adbAc INPUT: Bottom-Up Parsing Program e OUTPUT: A b $ Production S aABe A Abc A b B d Bottom-Up Parser Example Shift A
22
22 Introduction(6) adbAc INPUT: Bottom-Up Parsing Program e OUTPUT: A b $ Production S aABe A Abc A b B d Bottom-Up Parser Example Shift b
23
23 Introduction(7) adbAc INPUT: Bottom-Up Parsing Program e OUTPUT: A b $ Production S aABe A Abc A b B d c A b Bottom-Up Parser Example Shift c Reduce from Abc to A
24
24 Introduction(8) adA INPUT: Bottom-Up Parsing Program e OUTPUT: Ac A b $ Production S aABe A Abc A b B d b Bottom-Up Parser Example Shift A
25
25 Introduction(9) adA INPUT: Bottom-Up Parsing Program e OUTPUT: Ac A b $ Production S aABe A Abc A b B d b B d Bottom-Up Parser Example Shift d Reduce from d to B
26
26 Introduction(10) aBA INPUT: Bottom-Up Parsing Program e OUTPUT: Ac A b $ Production S aABe A Abc A b B d b B d Bottom-Up Parser Example Shift B
27
27 Introduction(11) aBA INPUT: Bottom-Up Parsing Program e OUTPUT: Ac A b $ Production S aABe A Abc A b B d b B d a S e Bottom-Up Parser Example Shift e Reduce from aABe to S
28
28 Introduction(12) S INPUT: Bottom-Up Parsing Program OUTPUT: Ac A b $ Production S aABe A Abc A b B d b B d a S e This parser is known as an LR Parser because it scans the input from Left to right, and it constructs a Rightmost derivation in reverse order. Bottom-Up Parser Example Shift S Hit the target $
29
7 8 7 Shift-Reduce Parsing Idea: build the parse tree bottom-up –Lexer supplies a token, parser find production rule with matching right-hand side (i.e., run rules in reverse) –If start symbol is reached, parsing is successful Production rules: Num Digit | Digit Num Digit 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 789 reduce shift reduce shift reduce
30
Consider the context-free grammar S a X X b X | b Y Y c Detail how an shift-reduce parser will parse the sentence abbc
31
Example ::= | & ::= - | ::= | * ::= | ::= A|B|C|D|E|F|G|H|I|J|Y|Z &*-
32
Bottom-up Parsing (cont.) LR parsers are table driven, where the table has two components, an ACTION table and a GOTO table –The ACTION table specifies the action of the parser, given the parser state and the next token Rows are state names; columns are terminals –The GOTO table specifies which state to put on top of the parse stack after a reduction action is done Rows are state names; columns are nonterminals
33
LR Parsing Table
34
LR(0) parsing Keep track of what is left to be done in the parsing process by using finite automata of items –An item A w. B y means: A w B y might be used for the reduction in the future, at the time, we know we already construct w in the parsing process, if B is constructed next, we get the new item A w B. Y
35
35 LR(0) items LR(0) item –production with a distinguished position in the RHS Initial Item –Item with the distinguished position on the leftmost of the production Complete Item –Item with the distinguished position on the rightmost of the production Closure Item of x –Item x together with items which can be reached from x via -transition Kernel Item –Original item, not including closure items
36
Finite automata of items Grammar: S’ S S (S)S S Items: S’ .S S’ S. S .(S)S S (.S)S S (S.)S S (S).S S (S)S. S . S’ .SS’ S.S .(S)SS .S (S.)SS (.S)SS (S).SS (S)S. S S ( ) S
37
DFA of LR(0) Items S’ .SS’ S. S .(S)S S . S (S.)SS (.S)S S (S).SS (S)S. S S ( ) S S’ .S S .(S)S S . S (.S)S S .(S)S S . S’ S. S (S).S S .(S)S S . S (S.)S S (S)S. S ( S ) ( ( S
38
LR(0) Parsing Table A’ .A A .(A) A .a A’ A. A a. A (A). A (.A) A .(A) A .a A (A.) A A a a ( ( ) 0 4 3 2 1 5
39
Bottom Up Technique It begins with terminal token, and scan for sub-expression whose operators have higher precedence and interprets it into terms of the rule of grammar until the root of the tree
40
The method A + B * C - D Then the sub-expression B * C is computed before other operations in the statement
41
The method So the bottom-up parser should recognize B * C (in terms of grammar) before considering the surrounding terms. First, we determine the precedence relations between operators in the grammar.
42
Operator Precedence We have Program = var Begin < for Which means program and var have equal precedence
43
Example We have – ;.> END But – END.> ; So which is first, is higher
44
Example read ( value ); = Start with higher operator or terminal one “ value ” as id
45
Example Search for non-terminal for id and so assign it as –READ( ) Next take read to another nonterminal
46
The method The operator precedence parser used a stack to save token that have been scanned.
47
Example ::= | & ::= - | ::= | * ::= | ::= A|B|C|D|E|F|G|H|I|J|Y|Z Use one LL and shift reduce method to draw the parse tree for expression F * A & G - Y
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.