In computer science, a simple precedence parser is a type of bottom-up parser for context-free grammars that can be used only by simple precedence grammars.
Contents
The implementation of the parser is quite similar to the generic bottom-up parser. A stack is used to store a viable prefix of a sentential form from a rightmost derivation. Symbols
Implementation
SearchProductionToReduce (Stack)
Example
Given the language:
E --> E + T' | T'T' --> TT --> T * F | FF --> ( E' ) | numE' --> Enum is a terminal, and the lexer parse any integer as num.
and the Parsing table:
STACK PRECEDENCE INPUT ACTION$ < 2 * ( 1 + 3 )$ SHIFT$ < 2 > * ( 1 + 3 )$ REDUCE (F -> num)$ < F > * ( 1 + 3 )$ REDUCE (T -> F)$ < T = * ( 1 + 3 )$ SHIFT$ < T = * < ( 1 + 3 )$ SHIFT$ < T = * < ( < 1 + 3 )$ SHIFT$ < T = * < ( < 1 > + 3 )$ REDUCE 4 times (F -> num) (T -> F) (T' -> T) (E ->T ') $ < T = * < ( < E = + 3 )$ SHIFT$ < T = * < ( < E = + < 3 )$ SHIFT$ < T = * < ( < E = + < 3 > )$ REDUCE 3 times (F -> num) (T -> F) (T' -> T) $ < T = * < ( < E = + = T > )$ REDUCE 2 times (E -> E + T) (E' -> E)$ < T = * < ( < E' = )$ SHIFT$ < T = * < ( = E' = ) > $ REDUCE (F -> ( E' ))$ < T = * = F > $ REDUCE (T -> T * F)$ < T > $ REDUCE 2 times (T' -> T) (E -> T')$ < E > $ ACCEPTReferences
Simple precedence parser Wikipedia(Text) CC BY-SA