GNU Bison
GNU Bison | |||
---|---|---|---|
Skaper(e) | Robert P. Corbett[1] | ||
Utvikler(e) | GNU-prosjektet | ||
Utgitt | Juni 1985[1] | ||
Nyeste versjon | 3.8.2 (25. september 2021)[2] | ||
Kodelager | https://git.savannah.gnu.org/cgit/bison.git | ||
Operativsystem | GNU/Linux BSD Unix-liknende | ||
Skrevet i | C | ||
Type | Leksikalsk analyse, parser, semantisk analyse | ||
Lisens | GPL-3.0+[3] | ||
Nettsted | www.gnu.org (en)[4] | ||
Forgjenger | yacc |
GNU Bison er en fri og åpen parsergenerator for Unix og Unix-liknende operativsystemer.[5] GNU Bison inngår i GNU-prosjektet og er tilgjengelig under GNU General Public License versjon 3, med unntak som tillater den genererte kode å bli brukt uten lisensen copyleft.[6][7]
GNU Bison leser en spesifikasjon i en kontekstfri grammatikk, advarer mot tvetydigheter og genererer en parser i C, C++[8] eller Java.[9] Parseren leser sekvensen av token og bestemmer hvorvidt sekvensen følger syntaksen som er spesifisert av grammatikken. Den genererte parser er plattformuavhengig, og er ikke avhengig av noen spesifikk kompilator. GNU Bison genererer LALR-parsere som standard, men kan også generere LR(1)-, IELR(1)- og GLR-parsere.[10][11] Flex, som genererer leksikalske analysatorer, kan dele strømmen av innmatede data opp i token før de behandles av GNU Bison.
GNU Bison ble skapt i 1988 av Robert Corbett fra University of Berkeley; den 2. september 1989 lanserte han også parsergeneratoren Berkeley Yacc, og GNU Bison ble påvirket mye av tidligere versjoner av Berkeley Yacc.[12] Richard Stallman gjorde programmet kompatibelt med POSIX og Yacc,[13] men det har flere forbedringer i forhold til Yacc. Versjon 3.8.2 ble lansert 25. september 2021.
Historie
[rediger | rediger kilde]Yacc
[rediger | rediger kilde]Utdypende artikler: Yacc, TMG og Portable C Compiler
GNU Bison oppstod som en avlegger av Yacc – Yet Another Compiler Compiler.[14][15] Yacc ble laget i 1971 av Stephen C. Johnson ved Bell Laboratories innenfor AT&T Corporation.[16] Yacc ble opprinnelig skrevet i programmeringsspråket B på en 36-biter stormaskin av typen Ge-635 fra General Electric,[16][17] men ble raskt skrevet på nytt i C.[17]
Yacc var i sin tur etterfølgeren til parsergeneratoren TMG (TransMoGrifier),[16] som ble laget i 1964 for Multics, OS/360 og tidlige versjoner av UNIX.[16][18] TMG ble i 1964 brukt til å utvikle EPL, som var en tidlig versjon av PL/I.[18] I 1969 brukte Ken Thompson TMG for å lage programmeringsspråket B, og i 1970 brukte han også denne parsergeneratoren som et verktøy til å utvikle en Fortrankompilator på 18-biter minidatamaskinen PDP-7. TMG genererte rekursivt descendant parsere som er et særtilfelle av ovenfra-ned-parsere,[16] mens Yacc genererte LALR-parsere.
Yacc var en del av den tidlige utviklingen av UNIX,[14] og ble en del av Unix versjon 3 som ble lansert i februar 1973.[19] Yacc hadde stor betydning i utbredelsen av UNIX, ved at det ble brukt til å generere parsere for operativsystemet. Yacc ble brukt til utviklingen av Portable C Compiler (pcc) på midten av 1970-tallet. Stephen C. Johnson var opphavsmannen til både Yacc og pcc.[20] En full beskrivelse av Yacc ble publisert i juli 1975.[14] Yacc blir noen ganger skrevet YACC (med store bokstaver), men opphavsmannen brukte navneformen Yacc (med små bokstaver), deriblant i beskrivelsen som er gitt i Version 7 Unix Manual i januar 1979.[15]
Omkring 1990 kom Yacc mer eller mindre ut av bruk, fordi parsergeneratorer med mindre restriktive lisenser og flere egenskaper var blitt tilgjengelige. I 2002 gjorde Caldera International kildekoden til Yacc på gamle versjoner av Unix – fra UNIX versjon 7 til UNIX/32V, åpent tilgjengelig. På denne tiden hadde Yacc lenge vært erstattet av GNU Bison selv på Yacc’s egne Unix-varianter.
Prefikset ya- (Yet Another) levde sitt eget liv lenge etter at Yacc kom ut av bruk. Et eksempel er Yahoo! (Yet Another Hierarchical Officious Oracle),[16] som er navnet på et IT-selskap som ble opprettet i California i 1994. Et annet eksempel er installerings- og konfigureringsverktøyet YaST (Yet another Setup Tool) på SUSE Linux som ble lansert i 1996.
yacchack
[rediger | rediger kilde]Yacc manglet evnen til å produsere innadgående parsere. Dette ble ordnet ved et sett med modifikasjoner, kalt yacchack, som ble publisert av Eric S. Raymond på USENET omkring 1983. Disse utvidelsene ble overflødige da parsergeneratorene zoo og Berkeley Yacc ble tilgjengelige noen få år senere.
Berkeley Yacc
[rediger | rediger kilde]Utdypende artikkel: Berkeley Yacc
Parsergeneratoren zoo ble skapt i 1985 av Robert Corbett ved University of California, Berkeley.[21] Den 2. september 1989 skiftet den navn til Berkeley Yacc (byacc).
Berkeley Yacc hadde tre forbedringer i forhold til Yacc: Den genererte raskere parsere, den kunne generere innadgående parsere, og kildekoden var offentlig eiendom i stedet for å være under en proprietær lisens fra AT&T. Forbedret ytelse oppstod ved å implementere teknikker som Franklin DeRemer og Thomas Penello hadde beskrevet i deres avhandling om LALR-parsere fra 1982.[22]
Bruken av byacc spredte seg raskt på grunn av dens liberale lisens. Da GNU Bison ble tilgjengelig, gikk likevel byacc ut av offentlig bruk.
zoo, Byson og GNU Bison
[rediger | rediger kilde]Robert Corbett laget to beslektede LALR-parsergeneratorer i 1985, som begge benyttet teknikkene til DeRemer og Penello. Den ene var zoo, den andre var Byson. I 1987 begynte Richard Stallman å arbeide med Byson; han endret navnet til Bison og gjorde grensesnittet kompatibelt med Yacc.
Til forskjell fra Yacc, støttet Byson konstruksjonen @n. Denne ga tilgang til det innledende og det avsluttende linjenummer og til antall tegn knyttet til alle symbolene i den gjeldende regel. Kommandoen %expect n
sa at konflikter ikke skulle nevnes hvis der er n skift/reduser konflikter og ingen reduser/reduser konflikter. I nyere versjoner av Bison, kan %expect
og varianten %expect-rr
anvendes på individuelle regler med reduser-reduser konflikter.
Senere versjoner av Bison tilføyde mange flere egenskaper, deriblant bedre feilmeldinger. Av disse kan vi merke oss at Yacc og Byson manglet tegnet ^
i feilmeldinger.
Sammenlignet med Yacc benytter Bison en raskere men mindre plass-effektiv koding for parsertabellene.[21] og mer moderne teknikker for generering av mengden av lookahead.[22] Dette har vært standard siden første versjon. Det har vært påstått at disse forskjeller stammer fra den temporære løsning som Johnson måtte benytte for å få den opprinnelige Yacc til å passe på 16-biter minidatamaskinen PDP-11.
Navngitte referanser, semantiske predikater, %locations,
%glr-parser
, %printer
, %destructor
, dumping av avfall til DOT, %parse-param
, %lex-param
, og dumping av avfall til XSLT, LAC og generering av IELR(1)-parsere er nytt i Bison.
Bison har også egenskaper for å støtte C++ som manglet i Yacc og Byson.
Alle tidligere Yacc-varianter, og lignende parsergeneratorer som genererte C-kode, ble gjort foreldet av Bison i 1995.
PLY, goyacc og ocamlyacc
[rediger | rediger kilde]Yacc-konseptet har ofte blitt portert til andre programmeringsspråk. Noen av de tidligere porteringer er opphørt å eksistere sammen med språkene som ble brukt på dem; andre har blitt erstattet av parserskjeletter som leveres sammen med Bison.
Det finnes også uavhengige implementasjoner, deriblant David Beazley’s PLY (Python Lex-Yacc) for Python, goyacc for programmeringsspråket Go og Ocamlyacc for Objective Caml.
Operativsystemer
[rediger | rediger kilde]GNU Bison har blitt portert til blant annet følgende operativsystemer:
Programvare generert ved hjelp av GNU Bison
[rediger | rediger kilde]Eksempler på programmeringsspråk og annen programvare som er generert ved hjelp av GNU Bison:
- Ruby[42]
- PHP[43]
- Go[44]
- GNU Octave[45]
- GNU Pascal[46]
- GNU CHILL i versjon 2.95 av GCC
- C++ i GNU Compiler Collection (GCC) forut for versjon 3.4 som utkom den 18. april 2004[47]
- GNU Ada i GCC forut for versjon 3.4[47]
- GNU Fortran i GCC forut for versjon 3.4[47]
- GNU Java forut for versjon 3.4[47]
- C og Objective C i GCC forut for versjon 4.1 som utkom den 28. februar 2006[48]
- Perl 5 versjon 5.10 eller høyere[49]
- Unix-skallet og kommandospråket Bash[50]
- Noteprogrammet LilyPond[51]
- Structured Query Language (SQL) i databasene PostgreSQL,[52] MySQL[53] og MariaDB.[54]
Eksempelprogram: Kalkulator
[rediger | rediger kilde]Følgende eksempel viser hvordan GNU Bison og Flex kan brukes til å lage et enkelt kalkulatorprogram (kun addisjon og multiplikasjon) og et program for å skape et abstrakt syntakstre. De to neste filene sørger for definisjoner og implementasjon av syntakstreets funksjoner.
Expression.h
[rediger | rediger kilde]/*
* Expression.h
* Definisjon av strukturen brukt til å bygge syntakstreet. */
#ifndef __EXPRESSION_H__
#define __EXPRESSION_H__
/**
* Operasjonstyper
*/
typedef enum tagEOperationType
{
eVALUE,
eMULTIPLY,
ePLUS
} EOperationType;
/**
* Uttrykks-struktur
*/
typedef struct tagSExpression
{
EOperationType type;///< typen av operasjon
int value;///< gyldig bare hvis typen er eVALUE
struct tagSExpression *left; ///< venstre side av treet
struct tagSExpression *right;///< høyre side av treet
} SExpression;
/**
* Skapelse av en identifikator
* Parameteren er tallverdien
* Funksjonen returnerer uttrykket eller NULL hvis det ikke er nok minne
*/
SExpression *createNumber(int value);
/**
* Skapelse av en operasjon
* Parameteren "type" definerer operasjonstype
* Parameteren "left" definerer venstre operand
* Parameteren "right" definerer høyre operand
* Funksjonen returnerer uttrykket eller NULL hvis det ikke er nok minne
*/
SExpression *createOperation(EOperationType type, SExpression *left, SExpression *right);
/**
* Sletter et uttrykk
* Parameteren b er uttrykket
*/
void deleteExpression(SExpression *b);
#endif // __EXPRESSION_H__
Expression.c
[rediger | rediger kilde]/*
* Expression.c
* Implementasjon av funksjoner til å bygge syntakstreet.
*/
#include "Expression.h"
#include <stdlib.h>
/**
* Allokerer plass for uttrykket
* Funksjonen returnerer uttrykket eller NULL hvis det ikke er nok minne
*/
static SExpression *allocateExpression()
{
SExpression *b = (SExpression *)malloc(sizeof(SExpression));
if (b == NULL)
return NULL;
b->type = eVALUE;
b->value = 0;
b->left = NULL;
b->right = NULL;
return b;
}
SExpression *createNumber(int value)
{
SExpression *b = allocateExpression();
if (b == NULL)
return NULL;
b->type = eVALUE;
b->value = value;
return b;
}
SExpression *createOperation(EOperationType type, SExpression *left, SExpression *right)
{
SExpression *b = allocateExpression();
if (b == NULL)
return NULL;
b->type = type;
b->left = left;
b->right = right;
return b;
}
void deleteExpression(SExpression *b)
{
if (b == NULL)
return;
deleteExpression(b->left);
deleteExpression(b->right);
free(b);
}
Lexer.l
[rediger | rediger kilde]Token som behøves av parseren vil bli generert av Flex.
%{
/*
* Lexer.l filen
* For å generere den leksikalske analysator kjøres "flex Lexer.l"
*/
#include "Expression.h"
#include "Parser.h"
#include <stdio.h>
%}
%option outfile="Lexer.c" header-file="Lexer.h"
%option warn nodefault
%option reentrant noyywrap never-interactive nounistd
%option bison-bridge
LPAREN "("
RPAREN ")"
PLUS "+"
MULTIPLY "*"
NUMBER [0-9]+
WS [ \r\n\t]*
%%
{WS} { /* Fjern blanke tegn. */ }
{NUMBER} { sscanf(yytext, "%d", &yylval->value); return TOKEN_NUMBER; }
{MULTIPLY} { return TOKEN_MULTIPLY; }
{PLUS} { return TOKEN_PLUS; }
{LPAREN} { return TOKEN_LPAREN; }
{RPAREN} { return TOKEN_RPAREN; }
. { }
%%
int yyerror(const char *msg) {
fprintf(stderr,"Error:%s\n",msg); return 0;
}
Parser.y
[rediger | rediger kilde]Ettersom de ulike token er produsert av Flex må det være en kommunikasjon mellom parseren og den leksikalske analysatoren.[55] Datatypen som brukes til kommunikasjon, YYSTYPE, er satt til bruke Bisons %union deklarasjon.
Vi må også sørge for parametere til yylex-funksjonen, når den kalles fra yyparse.[55] Dette blir gjort gjennom Bison's %lex-param og %parse-param deklarasjoner.[56]
%{
/*
* Parser.y file
* For å generere parseren, kjør "bison Parser.y"
*/
#include "Expression.h"
#include "Parser.h"
#include "Lexer.h"
int yyerror(SExpression **expression, yyscan_t scanner, const char *msg) {
// Feilhåndteringsrutiner
}
%}
%code requires {
#ifndef YY_TYPEDEF_YY_SCANNER_T
#define YY_TYPEDEF_YY_SCANNER_T
typedef void* yyscan_t;
#endif
}
%output "Parser.c"
%defines "Parser.h"
%define api.pure
%lex-param { yyscan_t scanner }
%parse-param { SExpression **expression }
%parse-param { yyscan_t scanner }
%union {
int value;
SExpression *expression;
}
%left '+' TOKEN_PLUS
%left '*' TOKEN_MULTIPLY
%token TOKEN_LPAREN
%token TOKEN_RPAREN
%token TOKEN_PLUS
%token TOKEN_MULTIPLY
%token <value> TOKEN_NUMBER
%type <expression> expr
%%
input
: expr { *expression = $1; }
;
expr
: expr[L] TOKEN_PLUS expr[R] { $$ = createOperation( ePLUS, $L, $R ); }
| expr[L] TOKEN_MULTIPLY expr[R] { $$ = createOperation( eMULTIPLY, $L, $R ); }
| TOKEN_LPAREN expr[E] TOKEN_RPAREN { $$ = $E; }
| TOKEN_NUMBER { $$ = createNumber($1); }
;
%%
Main.c
[rediger | rediger kilde]Den følgende koden skaper syntakstreet ved å bruke parseren generert av Bison og den leksikalske analysator som er generert av Flex.
/*
* main.c file
*/
#include "Expression.h"
#include "Parser.h"
#include "Lexer.h"
#include <stdio.h>
int yyparse(SExpression **expression, yyscan_t scanner);
SExpression *getAST(const char *expr)
{
SExpression *expression;
yyscan_t scanner;
YY_BUFFER_STATE state;
if (yylex_init(&scanner)) {
// couldn't initialize
return NULL;
}
state = yy_scan_string(expr, scanner);
if (yyparse(&expression, scanner)) {
// error parsing
return NULL;
}
yy_delete_buffer(state, scanner);
yylex_destroy(scanner);
return expression;
}
int evaluate(SExpression *e)
{
switch (e->type) {
case eVALUE:
return e->value;
case eMULTIPLY:
return evaluate(e->left) * evaluate(e->right);
case ePLUS:
return evaluate(e->left) + evaluate(e->right);
default:
// shouldn't be here
return 0;
}
}
int main(void)
{
SExpression *e = NULL;
char test[]=" 4 + 2*10 + 3*( 5 + 1 )";
int result = 0;
e = getAST(test);
result = evaluate(e);
printf("Result of '%s' is %d\n", test, result);
deleteExpression(e);
return 0;
}
Makefil
[rediger | rediger kilde]Til slutt en makefil som bygger prosjektet.
# Makefile
FILES = Lexer.c Parser.c Expression.c main.c
CC = g++
CFLAGS = -g -ansi
test: $(FILES)
$(CC) $(CFLAGS) $(FILES) -o test
Lexer.c: Lexer.l
flex Lexer.l
Parser.c: Parser.y Lexer.c
bison Parser.y
clean:
rm -f *.o *~ Lexer.c Lexer.h Parser.c Parser.h test
Versjonshistorikk
[rediger | rediger kilde]Versjon | Lansert | Merknader |
---|---|---|
1.22 | 7. september 1993 | |
1.23 | 1993[57] | |
1.24 | 30. mai 1995[58] | |
1.25 | 11. mai 1996 | |
1.26 | 11. februar 1999 | |
1.27 | 16. februar 1999 | |
1.28 | 6. juli 1999 | |
1.29 | 7. september 2001 | |
1.30 | 29. oktober 2001 | |
1.31 | 14. januar 2002 | |
1.32 | 23. januar 2002 | |
1.33 | 7. februar 2002 | |
1.34 | 12. mars 2002 | |
1.35 | 25. mars 2002 | |
1.50 | 5. oktober 2002 | |
1.75 | 14. oktober 2002 | |
1.875 | 1. januar 2003 | |
2.0 | 4. januar 2005 | |
2.1 | 19. september 2005 | |
2.2 | 19. mai 2006 | |
2.3 | 5. juni 2006 | |
2.4.0 | 2. november 2008 | |
2.4.1 | 11. desember 2008 | |
2.4.2 | 20. mars 2010 | |
2.4.3 | 5. august 2010 | |
2.5.0 | 14. mai 2012 | |
2.5.1 | 5. juni 2012 | |
2.6.0 | 19. juli 2012 | |
2.6.1 | 30. juli 2012 | |
2.6.2 | 3. august 2012 | |
2.6.3 | 22. oktober 2012 | |
2.6.4 | 23. oktober 2012 | |
2.6.5 | 7. november 2012 | |
2.7.0 | 12. desember 2012 | |
2.7.1 | 15. april 2013 | |
3.0.0 | 25. juli 2013 | |
3.0.1 | 12. november 2013 | |
3.0.2 | 5. desember 2013 | |
3.0.3 | 15. januar 2015 | |
3.0.4 | 23. januar 2015 | |
3.0.5 | 28. mai 2018 | |
3.1 | 27. august 2018 | |
3.2 | 29. oktober 2018 | |
3.2.1 | 9. november 2018 | |
3.2.2 | 21. november 2018 | |
3.2.3 | 18. desember 2018 | |
3.2.4 | 24. desember 2018 | |
3.3 | 26. januar 2019 | |
3.3.1 | 27. januar 2019 | |
3.3.2 | 3. februar 2019 | |
3.4 | 19. mai 2019 | |
3.4.1 | 22. mai 2019 | |
3.4.2 | 12. september 2019 | |
3.5 | 11. desember 2019 | |
3.5.1 | 19. januar 2020 | |
3.5.2 | 13. februar 2020 | |
3.5.3 | 8. mars 2020 | |
3.5.4 | 5. april 2020 | |
3.6 | 8. mai 2020 | |
3.6.1 | 10. mai 2020 | |
3.6.2 | 17. mai 2020 | |
3.6.3 | 3. juni 2020 | |
3.6.4 | 15. juni 2020 | |
3.7.0 | 23. juni 2020 | |
3.7.1 | 2. august 2020 | |
3.7.2 | 5. september 2020 | |
3.7.3 | 13. oktober 2020 | |
3.7.4 | 13. november 2020 | |
3.7.5 | 24. januar 2021 | |
3.7.6 | 9. mars 2021 | |
3.8.0 | 7. september 2021 | |
3.8.1 | 11. september 2021 | |
3.8.2 | 25. september 2021 |
Referanser
[rediger | rediger kilde]- ^ a b Robert P. Corbett (juni 1985) (på en), Static Semantics and Compiler Error Recovery, , Wikidata Q89537850, https://apps.dtic.mil/dtic/tr/fulltext/u2/a611756.pdf
- ^ Akim Demaille (25. september 2021). «Bison 3.8.2».
- ^ (på en) A Bibliographic Scan of Digital Scholarly Communication Infrastructure, Educopia Institute, 18. mai 2020, Free Software Directory ID bison, Wikidata Q2470288, https://educopia.org/
- ^ Free Software Directory, Free Software Directory ID bison, besøkt 4. august 2020[Hentet fra Wikidata]
- ^ Bison Manual, Introduction
- ^ Bison Manual, GNU GENERAL PUBLIC LICENSE
- ^ Bison Manual, Conditions for Using Bison
- ^ Bison Manual, 10.1 C++ Parsers
- ^ Bison Manual, 10.2 Java Parsers
- ^ Levine 2009, side 50
- ^ Bison Manual, 1.5 Writing GLR Parsers
- ^ Brown 1995, Appendix D, side 277
- ^ Bison Manual, 9.1 Bison Options
- ^ a b c Johnson 1975
- ^ a b Unix 1979
- ^ a b c d e f Eric S. Raymond: Steve Johnson's reply, lists.gnu.org, 13. februar 2019
- ^ a b Ritchie, Dennis M. (april 1993). The Development of the C Language (PDF). Association for Computing Machinery, Inc. Arkivert fra originalen (PDF) 24. juli 2015. Besøkt 14. juni 2019.
- ^ a b multicians.org - TMG, 2012-12-20
- ^ McIlroy, M. D. (1987). «A Research Unix reader: annotated excerpts from the Programmer's Manual, 1971–1986» (PDF). CSTR (139).
- ^ Johnson, S.C. (1978). «A portable compiler: theory and practice». Proceedings of the 5th ACM SIGACT-SIGPLAN symposium on Principles of programming languages. Tucson, Arizona. s. 97–104.
- ^ a b Corbett 1985
- ^ a b DeRemer 1982
- ^ a b c d e f Compilers available for free via Internet, old.la1k.no, 4. april 1995
- ^ Newbie - MVS 3.8j TSO programming information, h390-mvs.yahoogroups.narkive.com, besøkt 1. juli 2017
- ^ a b Open Source Software for z/OS and OS/390 UNIX, IBM, 2002
- ^ ISL Computing Software - SunOS, 5. mai 1999
- ^ OpenCSW: bison Solaris package, 2016
- ^ Georg Schwarz: gnu bison 2.2 on IRIX 5.3, lists.gnu.org, 21. mai 2006
- ^ a b NCO netCDF Operators, SourceForge.net, NCO on Tru64 UNIX, 1. desember 2003
- ^ BISON man page on QNX, Polarhome, 1999
- ^ Yacc is Not Dead, research.swtch.com 6. desember 2010
- ^ The SCO Group, Inc.: Release Notes GNU Utilities for OpenServer 6.0.0 6.0.0Da Arkivert 27. mars 2009 hos Wayback Machine., 2009
- ^ Caldera Skunkware Open Source Software Arkivert 16. mars 2016 hos Wayback Machine., 19. juli 2001
- ^ bison. GNU yacc replacement Arkivert 2015-11-29, hos Wayback Machine., Public Domain Software Library for AIX, 10. april 2006
- ^ HP-UX Porting and Archiving Centre: GNU Bison parser generator, besøkt 23. februar 2016
- ^ What's the deal with bison?, Apple Support Communities, 14. juli 2007
- ^ The FreeBSD Ports Archive bison. A parser generator from FSF, (mostly) compatible with Yacc Arkivert 4. juli 2017 hos Wayback Machine., 2007
- ^ OpenBSD/OCTEON, OSDN, 16. august 2010
- ^ bison-3.0.4nb3. GNU yacc(1) replacement, pkgsrc.se, 9. juli 2016
- ^ bison - GNU Project parser generator (yacc replacement), DragonFly On-Line Manual Pages, april 2013
- ^ Bison for Windows. Bison: Yacc-compatible parser generator. Version 2.4.1, gnuwin32.sourceforge.net, 4. mai 2009
- ^ Pat Shaughnessy: The Start of a Long Journey: How Ruby Parses and Compiles Your Code, 18. juni 2012
- ^ Mehdi Achour, Friedhelm Betz, Antony Dovgal, Nuno Lopes, Hannes Magnusson, Georg Richter, Damien Seguy, Jakub Vrana: Build Problems ¶, PHP Manual, 7. august 2016
- ^ Bison, libraries.io, 23. mai 2016
- ^ http://octave.org/doxygen/4.0/d5/d60/oct-parse_8cc_source.html
- ^ 4.3 Compiling GPC, The GNU Pascal Manual,
- ^ a b c d GCC 3.4
- ^ GCC 4.1
- ^ http://perldoc.perl.org/perl5100delta.html
- ^ Linux From Scratch: Version 4.0. Bison Official Download Location
- ^ LilyPond — Contributor’s Guide v2.19.36-1, 10.2 LilyPond programming languages
- ^ PostgreSQL 2015, kapittel 44.3
- ^ Levine 2009, kapittel 4
- ^ MariaDB Corporation Ab: Build Environment Setup for Linux. Required tools, 2016
- ^ a b GNU Bison Manual: C Scanners with Bison Parsers Arkivert 17. desember 2010 hos Wayback Machine.
- ^ GNU Bison Manual: Calling Conventions for Pure Parsers
- ^ Charles Donnelly, Richard Stallman: Bison. The YACC-compatible Parser Generator, 1993, Bison Version 1.23
- ^ Bison. The YACC-compatible Parser Generator, May 1995, Bison Version 1.24
Litteratur
[rediger | rediger kilde]- Bell Laboratories (1979). UNIX TM TIME-SHARING SYSTEM: UNIX PROGRAMMER’S MANUAL, Seventh Edition, Volume 2B (PDF). Bell Telephone Laboratories, Incorporated, Murray Hill, New Jersey, januar 1979.
- Brown, Doug; Levine, John; Mason, Tony (1995). lex & yacc. O'Reilly Media, 1. utgave, mai 1990, ISBN 0 937 175 498, ISBN 978-0937175491; 2. utgave, 1. februar 1995. ISBN 1 565 920 007. ISBN 978-1565920002.
- Corbett, Robert Paul (1985). Static Semantics in Compiler Error Recovery. Ph.D. Dissertation, Report No. UCB/CSD 85/251, Department of Electrical Engineering and Computer Science, Compute Science Division, University of California, Berkeley, California, juni 1985.
- DeRemer, Franklin Lewis, Pennello, Thomas (1982). Efficient Computation of LALR(1) Look-Ahead Sets. ACM Transactions on Programming Languages and Systems, Vol. 4, No. 4, oktober 1982, side 615–649.
- Donnelly, Charles (2015). Bison: The Yacc-compatible Parser Generator. Samurai Media Limited, 11. november 2015. ISBN 9 888 381 377. ISBN 978-9888381371.
- Free Software Foundation, Inc. (2015). Bison 3.0.4 Manual. 23. januar 2015.
- Free Software Foundation, Inc. (2004). GCC 3.4 Release Series Changes, New Features, and Fixes. 18. april 2004.
- Free Software Foundation, Inc. (2006). GCC 4.1 Release Series Changes, New Features, and Fixes. 24. mai 2006.
- Johnson, Stephen Curtis (1975). Yacc — Yet Another Compiler-Compiler (PDF). Computing Science Technical Report, Issue 32, AT&T Bell Laboratories, Murray Hill, New Jersey 07974, juli 1975.
- Levine, John (2009). flex & bison: Text Processing Tools. O'Reilly Media, 24. august 2009. ISBN 0 596 155 972. ISBN 978-0596155971.
- The PostgreSQL Global Development Group (2015). PostgreSQL 9.0.23 Documentation. 8. oktober 2015.
Eksterne lenker
[rediger | rediger kilde]- (en) Offisielt nettsted
- (en) Omtale i Free Software Directory
- (en) Forklaring av C-parsere som er generert av GNU Bison
- (en) C Parser With Bison, hos github-com
- (en) How to download and install Bison (GNU Parser Generator) on Linux (Geeks Worldwide)
- (en) GNU Bison for Microsoft Windows (versjon 2.4.1)
- GNU
- UC Berkeley
- Unix-programmer
- Linux-programmer
- AIX
- IRIX
- Programvare for Solaris
- Plan 9
- Slackware
- Debian
- Ubuntu
- Red Hat Linux
- Programvare for Fedora
- Programvare for Red Hat Enterprise Linux
- Gentoo
- SUSE Linux
- Arch Linux
- Mandriva
- FreeBSD
- OpenBSD
- DragonFly BSD
- Windows-programmer
- Parsergeneratorer
- Programvare fra 1988
- 1988 i USA