Yacc
Yacc ist ein Computerprogramm, welches der Herstellung von Compilern dient. Das Wort Yacc ist ein Akronym, das selbstironisch für yet another compiler compiler steht.
Yacc dient der syntaktischen Analyse. Es implementiert einen Parsergenerator, der aus Syntaxdefinitionen von Programmiersprachen, die durch LALR(1)-Grammatiken (besondere LR(k)-Grammatiken) in einer BNF-ähnlichen Notation angegeben sind, automatisiert einen Parser auf Basis eines Kellerautomaten erzeugen kann.
Yacc erzeugt aus der Sprachdefinition Programmcode, der typischerweise in C bereitgestellt wird. Daneben gibt es weitere Yacc-Varianten, die Code für andere Sprachen erzeugen, wie beispielsweise Ayacc für die Sprache Ada.
Um einen Compiler oder Interpreter zu erstellen, benötigt ein von Yacc generierter Parser noch ein weiteres Programmmodul zur lexikalischen Analyse des Quellcodes. Hierfür wird häufig das ebenfalls für UNIX entwickelte Programm Lex eingesetzt.
Yacc wurde ursprünglich von Stephen C. Johnson bei AT&T im Rahmen des UNIX-Projektes entwickelt. Später sind weitere Varianten des Programms entstanden, wie Berkeley Yacc (Kurz byacc) in modernen BSD-Betriebssystemen, GNU Bison im Rahmen des GNU-Projekts, MKS Yacc and Abraxas Yacc. Diese basieren auf dem gleichen Grundkonzept wie Yacc, bieten aber Verbesserungen im Detail. Der Quellcode von yacc ist heute ebenfalls unter einer freien Lizenz veröffentlicht. Yacc ist unter anderem Bestandteil von OpenSolaris und Plan 9.
Literatur
- Herold, Helmut: lex & yacc. Die Profitools zur lexikalischen und syntaktischen Textanalyse. Addison-Wesley, 2003, ISBN 3-82732-096-8
- John R. Levine, Tony Mason, Doug Brown: lex & yacc. O'Reilly 1992, ISBN 1-56592-000-7
- S. C. Johnson, Yacc: Yet Another Compiler Compiler. Computing Science Technical Report No. 32, 1975, Bell Laboratories, Murray Hill, New Jersey 07974
- Simson L. Garfinkel & Michael K. Mahoney, NeXtstep(Tm) Programming: Step One: Object-Oriented Applications, Springer, 1993, ISBN 978-0387978840
Weblinks
yacc
: yet another compiler compiler – Open Group Base Specificationyacc(P)
: yet another compiler compiler – Debian GNU/Linux POSIX Programmer's Manual Handbuchseiteyacc(1)
: an LALR(1) parser generator – OpenBSD General Commands Manualayacc(1)
: An Ada LALR(1) parser generator – FreeBSD General Commands Manualyecc(3)
: LALR-1 Parser Generator (for Erlang) – FreeBSD Library Functions Manual- Der Parser-Generator Yacc