Hopp til innhold

GNU Bison

Fra Wikipedia, den frie encyklopedi
GNU Bison
Skaper(e)Robert P. Corbett[1]
Utvikler(e)GNU-prosjektet
Utgitt Juni 1985[1]
Nyeste versjon3.8.2 (25. september 2021)[2]
Kodelagerhttps://git.savannah.gnu.org/cgit/bison.git
OperativsystemGNU/Linux BSD Unix-liknende
Skrevet iC
TypeLeksikalsk analyse, parser, semantisk analyse
LisensGPL-3.0+[3]
Nettstedwww.gnu.org (en)[4]
Forgjengeryacc

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.

Utdypende artikler: YaccTMG og Portable C Compiler

GNU Bison oppstod som en avlegger av YaccYet 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 Fortrankompilator18-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.

Yacc manglet evnen til å produsere innadgående parsere. Dette ble ordnet ved et sett med modifikasjoner, kalt yacchack, som ble publisert av Eric S. RaymondUSENET 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:

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);
}

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;
}

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); }
    ;
 
%%

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;
}

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]
  1. ^ a b Robert P. Corbett (juni 1985) (på en), Static Semantics and Compiler Error Recovery, OCLC 726759696, Wikidata Q89537850, https://apps.dtic.mil/dtic/tr/fulltext/u2/a611756.pdf 
  2. ^ Akim Demaille (25. september 2021). «Bison 3.8.2». 
  3. ^ Free Software Directory, Free Software Directory ID bison, Wikidata Q2470288, https://directory.fsf.org 
  4. ^ Free Software Directory, Free Software Directory ID bison, besøkt 4. august 2020[Hentet fra Wikidata]
  5. ^ Bison Manual, Introduction
  6. ^ Bison Manual, GNU GENERAL PUBLIC LICENSE
  7. ^ Bison Manual, Conditions for Using Bison
  8. ^ Bison Manual, 10.1 C++ Parsers
  9. ^ Bison Manual, 10.2 Java Parsers
  10. ^ Levine 2009, side 50
  11. ^ Bison Manual, 1.5 Writing GLR Parsers
  12. ^ Brown 1995, Appendix D, side 277
  13. ^ Bison Manual, 9.1 Bison Options
  14. ^ a b c Johnson 1975
  15. ^ a b Unix 1979
  16. ^ a b c d e f Eric S. Raymond: Steve Johnson's reply, lists.gnu.org, 13. februar 2019
  17. ^ 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. 
  18. ^ a b multicians.org - TMG, 2012-12-20
  19. ^ McIlroy, M. D. (1987). «A Research Unix reader: annotated excerpts from the Programmer's Manual, 1971–1986» (PDF). CSTR (139). 
  20. ^ 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. 
  21. ^ a b Corbett 1985
  22. ^ a b DeRemer 1982
  23. ^ a b c d e f Compilers available for free via Internet, old.la1k.no, 4. april 1995
  24. ^ Newbie - MVS 3.8j TSO programming information, h390-mvs.yahoogroups.narkive.com, besøkt 1. juli 2017
  25. ^ a b Open Source Software for z/OS and OS/390 UNIX, IBM, 2002
  26. ^ ISL Computing Software - SunOS, 5. mai 1999
  27. ^ OpenCSW: bison Solaris package, 2016
  28. ^ Georg Schwarz: gnu bison 2.2 on IRIX 5.3, lists.gnu.org, 21. mai 2006
  29. ^ a b NCO netCDF Operators, SourceForge.net, NCO on Tru64 UNIX, 1. desember 2003
  30. ^ BISON man page on QNX, Polarhome, 1999
  31. ^ Yacc is Not Dead, research.swtch.com 6. desember 2010
  32. ^ The SCO Group, Inc.: Release Notes GNU Utilities for OpenServer 6.0.0 6.0.0Da Arkivert 27. mars 2009 hos Wayback Machine., 2009
  33. ^ Caldera Skunkware Open Source Software Arkivert 16. mars 2016 hos Wayback Machine., 19. juli 2001
  34. ^ bison. GNU yacc replacement Arkivert 2015-11-29, hos Wayback Machine., Public Domain Software Library for AIX, 10. april 2006
  35. ^ HP-UX Porting and Archiving Centre: GNU Bison parser generator, besøkt 23. februar 2016
  36. ^ What's the deal with bison?, Apple Support Communities, 14. juli 2007
  37. ^ The FreeBSD Ports Archive bison. A parser generator from FSF, (mostly) compatible with Yacc Arkivert 4. juli 2017 hos Wayback Machine., 2007
  38. ^ OpenBSD/OCTEON Arkivert 19. august 2016 hos Wayback Machine., OSDN, 16. august 2010
  39. ^ bison-3.0.4nb3. GNU yacc(1) replacement, pkgsrc.se, 9. juli 2016
  40. ^ bison - GNU Project parser generator (yacc replacement), DragonFly On-Line Manual Pages, april 2013
  41. ^ Bison for Windows. Bison: Yacc-compatible parser generator. Version 2.4.1, gnuwin32.sourceforge.net, 4. mai 2009
  42. ^ Pat Shaughnessy: The Start of a Long Journey: How Ruby Parses and Compiles Your Code, 18. juni 2012
  43. ^ Mehdi Achour, Friedhelm Betz, Antony Dovgal, Nuno Lopes, Hannes Magnusson, Georg Richter, Damien Seguy, Jakub Vrana: Build Problems ¶, PHP Manual, 7. august 2016
  44. ^ Bison, libraries.io, 23. mai 2016
  45. ^ http://octave.org/doxygen/4.0/d5/d60/oct-parse_8cc_source.html
  46. ^ 4.3 Compiling GPC, The GNU Pascal Manual,
  47. ^ a b c d GCC 3.4
  48. ^ GCC 4.1
  49. ^ http://perldoc.perl.org/perl5100delta.html
  50. ^ Linux From Scratch: Version 4.0. Bison Official Download Location
  51. ^ LilyPond — Contributor’s Guide v2.19.36-1, 10.2 LilyPond programming languages
  52. ^ PostgreSQL 2015, kapittel 44.3
  53. ^ Levine 2009, kapittel 4
  54. ^ MariaDB Corporation Ab: Build Environment Setup for Linux. Required tools, 2016
  55. ^ a b GNU Bison Manual: C Scanners with Bison Parsers Arkivert 17. desember 2010 hos Wayback Machine.
  56. ^ GNU Bison Manual: Calling Conventions for Pure Parsers
  57. ^ Charles Donnelly, Richard Stallman: Bison. The YACC-compatible Parser Generator, 1993, Bison Version 1.23
  58. ^ Bison. The YACC-compatible Parser Generator, May 1995, Bison Version 1.24

Litteratur

[rediger | rediger kilde]

Eksterne lenker

[rediger | rediger kilde]
Autoritetsdata