1 / 18

Introduction to YACC

Learn the fundamentals of YACC - Yet Another Compiler Compiler - including Lex specifications, translation rules, integration with C/C++ code, rule actions, and more. Discover how to build YACC parsers and deal with common issues like debugging conflicts. Dive into examples such as expression grammar and grid scenarios, and understand the importance of specifying precedence and associativity in YACC for smooth parsing.

rpalomares
Download Presentation

Introduction to YACC

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Introduction to YACC CS 540 George Mason University

  2. YACC – Yet Another Compiler Compiler Lex spec Lex lex.yy.c compiler a.out YACC spec YACC y.tab.c Again, we will focus on c/c++ -- see online information re: Java tools CS 540 Spring 2007 GMU

  3. YACC Specifications Declarations %% Translation rules %% Supporting C/C++ code Similar to Lex CS 540 Spring 2007 GMU

  4. YACC Declarations Section • Includes: • Optional C/C++ code (%{ … %} ) – copied directly into y.tab.c • YACC definitions (%token, %start, …) – used to provide additional information • %token – interface to lex • %start – start symbol • Others: %type, %left, %right, %union … CS 540 Spring 2007 GMU

  5. YACC Rules • A rule captures all of the productions for a single non-terminal. • Left_side : production 1 | production 2 … | production n ; • Actions may be associated with rules and are executed when the associated production is reduced. CS 540 Spring 2007 GMU

  6. YACC Actions • Actions are C/C++ code. • Actions can include references to attributes associated with terminals and non-terminals in the productions. • Actions may be put inside a rule – action performed when symbol is pushed on stack • Safest (i.e. most predictable) place to put action is at end of rule. CS 540 Spring 2007 GMU

  7. Integration with Lex • yyparse() calls yylex() when it needs a new token. YACC handles the interface details • yylval is used to return attribute information CS 540 Spring 2007 GMU

  8. If using #include “lex.yy.c” flex input.l yacc input.y gcc y.tab.c –ly -ll If compiling separately: In .l spec, need to #include “y.tab.h” flex input.l yacc –d input.y gcc y.tab.c lex.yy.c –ly -ll Building YACC parsers CS 540 Spring 2007 GMU

  9. %% [a-zA-Z]+ {return(NAME);} [0-9]{3}”-”[0-9]{4} {return(NUMBER); } [ \n\t] ; %% %token NAME NUMBER %% file : file line | line ; line : NAME NUMBER ; %% #include “lex.yy.c” Basic Lex/YACC example Lex YACC CS 540 Spring 2007 GMU

  10. Expression Grammar Example %token NUMBER %% line : expr ; expr : expr ‘+’ term | term ; term : term ‘*’ factor | factor ; factor : ‘(‘ expr ‘)’ | NUMBER ; %% #include “lex.yy.c” CS 540 Spring 2007 GMU

  11. Associated Lex Specification %% \* {return(‘*’); } \+ {return(‘+’); } \( {return(‘(‘); } \) {return(‘)’); } [0-9]+ {return(NUMBER);} . ; %% CS 540 Spring 2007 GMU

  12. Grid Example %token NORTH SOUTH EAST WEST %token BEGIN %% seq : seq instr | BEGIN ; instr : NORTH | SOUTH | EAST | WEST ; %% #include “lex.yy.c” CS 540 Spring 2007 GMU

  13. Associated Lex Specification %% N {return(NORTH); } S {return(SOUTH); } E {return(EAST); } W {return(WEST); } BEGIN {return(BEGIN);} . ; %% CS 540 Spring 2007 GMU

  14. Notes: Debugging YACC conflicts: shift/reduce • Sometimes you get shift/reduce errors if you run YACC on an incomplete program. Don’t stress about these too much UNTIL you are done with the grammar. • If you get shift/reduce errors, YACC can generate information for you (y.output) if you tell it to (-v) CS 540 Spring 2007 GMU

  15. Example: IF stmts %token IF_T THEN_T ELSE_T STMT_T %% if_stmt : IF_T condition THEN_T stmt | IF_T condition THEN_T stmt ELSE_T stmt ; condition: '(' ')' ; stmt : STMT_T | if_stmt ; %% This input produces a shift/reduce error CS 540 Spring 2007 GMU

  16. In y.output file: 7: shift/reduce conflict (shift 10, red'n 1) on ELSE_T state 7 if_stmt : IF_T condition THEN_T stmt_ (1) if_stmt : IF_T condition THEN_T stmt_ELSE_T stmt ELSE_T shift 10 . reduce 1 CS 540 Spring 2007 GMU

  17. Precedence/Associativity in YACC • Forgetting about precedence and associativity is a major source of shift/reduce conflict in YACC. • You can specify precedence and associativity in YACC, making your grammar simpler. • Associativity: %left, %right, %nonassoc • Precedence given order of specifications” %left PLUS MINUS %left MULT DIV %nonassoc UMINUS • P. 62-64 in Lex/YACC book CS 540 Spring 2007 GMU

  18. Precedence/Associativity in YACC %left PLUS MINUS %left MULT DIV %nonassoc UMINUS … %% … expression : expression PLUS expression | expression MINUS expression … CS 540 Spring 2007 GMU

More Related