* src/lex.h: Prototype `lex.c' exported functions.

* src/reader.c: Adjust.
* src/lex.c: Formatting changes.
(safegetc): Rename as...
(xgetc): this.
This commit is contained in:
Akim Demaille
2000-10-02 07:59:08 +00:00
parent 720d742f8e
commit abadc11757
4 changed files with 288 additions and 239 deletions

View File

@@ -1,3 +1,12 @@
2000-10-02 Akim Demaille <akim@epita.fr>
* src/lex.h: Prototype `lex.c' exported functions.
* src/reader.c: Adjust.
* src/lex.c: Formatting changes.
(safegetc): Rename as...
(xgetc): this.
2000-10-02 Akim Demaille <akim@epita.fr> 2000-10-02 Akim Demaille <akim@epita.fr>
* src/lalr.h: New file. * src/lalr.h: New file.

403
src/lex.c
View File

@@ -18,14 +18,6 @@
the Free Software Foundation, Inc., 59 Temple Place - Suite 330, the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */ Boston, MA 02111-1307, USA. */
/*
lex is the entry point. It is called from reader.c.
It returns one of the token-type codes defined in lex.h.
When an identifier is seen, the code IDENTIFIER is returned
and the name is looked up in the symbol table using symtab.c;
symval is set to a pointer to the entry found. */
#include "system.h" #include "system.h"
#include "getargs.h" #include "getargs.h"
#include "files.h" #include "files.h"
@@ -39,18 +31,8 @@
extern int translations; extern int translations;
extern void init_lex PARAMS((void));
extern char *grow_token_buffer PARAMS((char *));
extern int skip_white_space PARAMS((void));
extern void unlex PARAMS((int));
extern int lex PARAMS((void));
extern int parse_percent_token PARAMS((void));
static int safegetc PARAMS((FILE *));
static int literalchar PARAMS((char **, int *, char));
/* functions from main.c */ /* functions from main.c */
extern char *printable_version PARAMS((int)); extern char *printable_version PARAMS ((int));
/* Buffer for storing the current token. */ /* Buffer for storing the current token. */
char *token_buffer; char *token_buffer;
@@ -79,7 +61,7 @@ grow_token_buffer (char *p)
{ {
int offset = p - token_buffer; int offset = p - token_buffer;
maxtoken *= 2; maxtoken *= 2;
token_buffer = (char *) xrealloc(token_buffer, maxtoken + 1); token_buffer = (char *) xrealloc (token_buffer, maxtoken + 1);
return token_buffer + offset; return token_buffer + offset;
} }
@@ -87,10 +69,10 @@ grow_token_buffer (char *p)
int int
skip_white_space (void) skip_white_space (void)
{ {
register int c; int c;
register int inside; int inside;
c = getc(finput); c = getc (finput);
for (;;) for (;;)
{ {
@@ -99,7 +81,7 @@ skip_white_space (void)
switch (c) switch (c)
{ {
case '/': case '/':
c = getc(finput); c = getc (finput);
if (c != '*' && c != '/') if (c != '*' && c != '/')
{ {
complain (_("unexpected `/' found and ignored")); complain (_("unexpected `/' found and ignored"));
@@ -107,7 +89,7 @@ skip_white_space (void)
} }
cplus_comment = (c == '/'); cplus_comment = (c == '/');
c = getc(finput); c = getc (finput);
inside = 1; inside = 1;
while (inside) while (inside)
@@ -115,12 +97,12 @@ skip_white_space (void)
if (!cplus_comment && c == '*') if (!cplus_comment && c == '*')
{ {
while (c == '*') while (c == '*')
c = getc(finput); c = getc (finput);
if (c == '/') if (c == '/')
{ {
inside = 0; inside = 0;
c = getc(finput); c = getc (finput);
} }
} }
else if (c == '\n') else if (c == '\n')
@@ -128,12 +110,12 @@ skip_white_space (void)
lineno++; lineno++;
if (cplus_comment) if (cplus_comment)
inside = 0; inside = 0;
c = getc(finput); c = getc (finput);
} }
else if (c == EOF) else if (c == EOF)
fatal (_("unterminated comment")); fatal (_("unterminated comment"));
else else
c = getc(finput); c = getc (finput);
} }
break; break;
@@ -144,7 +126,7 @@ skip_white_space (void)
case ' ': case ' ':
case '\t': case '\t':
case '\f': case '\f':
c = getc(finput); c = getc (finput);
break; break;
default: default:
@@ -155,33 +137,35 @@ skip_white_space (void)
/* do a getc, but give error message if EOF encountered */ /* do a getc, but give error message if EOF encountered */
static int static int
safegetc (FILE *f) xgetc (FILE *f)
{ {
register int c = getc(f); int c = getc (f);
if (c == EOF) if (c == EOF)
fatal (_("unexpected end of file")); fatal (_("unexpected end of file"));
return c; return c;
} }
/* read one literal character from finput. process \ escapes.
append the normalized string version of the char to *pp. /*------------------------------------------------------------------.
assign the character code to *pcode | Read one literal character from finput. Process \ escapes. |
return 1 unless the character is an unescaped `term' or \n | Append the normalized string version of the char to *PP. Assign |
report error for \n | the character code to *PCODE. Return 1 unless the character is an |
*/ | unescaped `term' or \n report error for \n |
`------------------------------------------------------------------*/
static int static int
literalchar (char **pp, int *pcode, char term) literalchar (char **pp, int *pcode, char term)
{ {
register int c; int c;
register char *p; char *p;
register int code; int code;
int wasquote = 0; int wasquote = 0;
c = safegetc(finput); c = xgetc (finput);
if (c == '\n') if (c == '\n')
{ {
complain (_("unescaped newline in constant")); complain (_("unescaped newline in constant"));
ungetc(c, finput); ungetc (c, finput);
code = '?'; code = '?';
wasquote = 1; wasquote = 1;
} }
@@ -193,17 +177,27 @@ literalchar (char **pp, int *pcode, char term)
} }
else else
{ {
c = safegetc(finput); c = xgetc (finput);
if (c == 't') code = '\t'; if (c == 't')
else if (c == 'n') code = '\n'; code = '\t';
else if (c == 'a') code = '\007'; else if (c == 'n')
else if (c == 'r') code = '\r'; code = '\n';
else if (c == 'f') code = '\f'; else if (c == 'a')
else if (c == 'b') code = '\b'; code = '\007';
else if (c == 'v') code = '\013'; else if (c == 'r')
else if (c == '\\') code = '\\'; code = '\r';
else if (c == '\'') code = '\''; else if (c == 'f')
else if (c == '\"') code = '\"'; code = '\f';
else if (c == 'b')
code = '\b';
else if (c == 'v')
code = '\013';
else if (c == '\\')
code = '\\';
else if (c == '\'')
code = '\'';
else if (c == '\"')
code = '\"';
else if (c <= '7' && c >= '0') else if (c <= '7' && c >= '0')
{ {
code = 0; code = 0;
@@ -217,42 +211,41 @@ literalchar (char **pp, int *pcode, char term)
code &= 0xFF; code &= 0xFF;
break; break;
} }
c = safegetc(finput); c = xgetc (finput);
} }
ungetc(c, finput); ungetc (c, finput);
} }
else if (c == 'x') else if (c == 'x')
{ {
c = safegetc(finput); c = xgetc (finput);
code = 0; code = 0;
while (1) while (1)
{ {
if (c >= '0' && c <= '9') if (c >= '0' && c <= '9')
code *= 16, code += c - '0'; code *= 16, code += c - '0';
else if (c >= 'a' && c <= 'f') else if (c >= 'a' && c <= 'f')
code *= 16, code += c - 'a' + 10; code *= 16, code += c - 'a' + 10;
else if (c >= 'A' && c <= 'F') else if (c >= 'A' && c <= 'F')
code *= 16, code += c - 'A' + 10; code *= 16, code += c - 'A' + 10;
else else
break; break;
if (code >= 256 || code<0) if (code >= 256 || code < 0)
{ {
complain (_("hexadecimal value above 255: `\\x%x'"), complain (_("hexadecimal value above 255: `\\x%x'"), code);
code);
code &= 0xFF; code &= 0xFF;
break; break;
} }
c = safegetc(finput); c = xgetc (finput);
} }
ungetc(c, finput); ungetc (c, finput);
} }
else else
{ {
complain (_("unknown escape sequence: `\\' followed by `%s'"), complain (_("unknown escape sequence: `\\' followed by `%s'"),
printable_version(c)); printable_version (c));
code = '?'; code = '?';
} }
} /* has \ */ } /* has \ */
/* now fill token_buffer with the canonical name for this character /* now fill token_buffer with the canonical name for this character
as a literal token. Do not use what the user typed, as a literal token. Do not use what the user typed,
@@ -261,17 +254,53 @@ literalchar (char **pp, int *pcode, char term)
p = *pp; p = *pp;
if (code == term && wasquote) if (code == term && wasquote)
*p++ = code; *p++ = code;
else if (code == '\\') {*p++ = '\\'; *p++ = '\\';} else if (code == '\\')
else if (code == '\'') {*p++ = '\\'; *p++ = '\'';} {
else if (code == '\"') {*p++ = '\\'; *p++ = '\"';} *p++ = '\\';
*p++ = '\\';
}
else if (code == '\'')
{
*p++ = '\\';
*p++ = '\'';
}
else if (code == '\"')
{
*p++ = '\\';
*p++ = '\"';
}
else if (code >= 040 && code < 0177) else if (code >= 040 && code < 0177)
*p++ = code; *p++ = code;
else if (code == '\t') {*p++ = '\\'; *p++ = 't';} else if (code == '\t')
else if (code == '\n') {*p++ = '\\'; *p++ = 'n';} {
else if (code == '\r') {*p++ = '\\'; *p++ = 'r';} *p++ = '\\';
else if (code == '\v') {*p++ = '\\'; *p++ = 'v';} *p++ = 't';
else if (code == '\b') {*p++ = '\\'; *p++ = 'b';} }
else if (code == '\f') {*p++ = '\\'; *p++ = 'f';} else if (code == '\n')
{
*p++ = '\\';
*p++ = 'n';
}
else if (code == '\r')
{
*p++ = '\\';
*p++ = 'r';
}
else if (code == '\v')
{
*p++ = '\\';
*p++ = 'v';
}
else if (code == '\b')
{
*p++ = '\\';
*p++ = 'b';
}
else if (code == '\f')
{
*p++ = '\\';
*p++ = 'f';
}
else else
{ {
*p++ = '\\'; *p++ = '\\';
@@ -281,7 +310,7 @@ literalchar (char **pp, int *pcode, char term)
} }
*pp = p; *pp = p;
*pcode = code; *pcode = code;
return ! wasquote; return !wasquote;
} }
@@ -296,7 +325,7 @@ unlex (int token)
int int
lex (void) lex (void)
{ {
register int c; int c;
char *p; char *p;
if (unlexed >= 0) if (unlexed >= 0)
@@ -307,66 +336,66 @@ lex (void)
return c; return c;
} }
c = skip_white_space(); c = skip_white_space ();
*token_buffer = c; /* for error messages (token buffer always valid) */ *token_buffer = c; /* for error messages (token buffer always valid) */
token_buffer[1] = 0; token_buffer[1] = 0;
switch (c) switch (c)
{ {
case EOF: case EOF:
strcpy(token_buffer, "EOF"); strcpy (token_buffer, "EOF");
return ENDFILE; return ENDFILE;
case 'A': case 'B': case 'C': case 'D': case 'E': case 'A': case 'B': case 'C': case 'D': case 'E':
case 'F': case 'G': case 'H': case 'I': case 'J': case 'F': case 'G': case 'H': case 'I': case 'J':
case 'K': case 'L': case 'M': case 'N': case 'O': case 'K': case 'L': case 'M': case 'N': case 'O':
case 'P': case 'Q': case 'R': case 'S': case 'T': case 'P': case 'Q': case 'R': case 'S': case 'T':
case 'U': case 'V': case 'W': case 'X': case 'Y': case 'U': case 'V': case 'W': case 'X': case 'Y':
case 'Z': case 'Z':
case 'a': case 'b': case 'c': case 'd': case 'e': case 'a': case 'b': case 'c': case 'd': case 'e':
case 'f': case 'g': case 'h': case 'i': case 'j': case 'f': case 'g': case 'h': case 'i': case 'j':
case 'k': case 'l': case 'm': case 'n': case 'o': case 'k': case 'l': case 'm': case 'n': case 'o':
case 'p': case 'q': case 'r': case 's': case 't': case 'p': case 'q': case 'r': case 's': case 't':
case 'u': case 'v': case 'w': case 'x': case 'y': case 'u': case 'v': case 'w': case 'x': case 'y':
case 'z': case 'z':
case '.': case '_': case '.': case '_':
p = token_buffer; p = token_buffer;
while (isalnum(c) || c == '_' || c == '.') while (isalnum (c) || c == '_' || c == '.')
{ {
if (p == token_buffer + maxtoken) if (p == token_buffer + maxtoken)
p = grow_token_buffer(p); p = grow_token_buffer (p);
*p++ = c; *p++ = c;
c = getc(finput); c = getc (finput);
} }
*p = 0; *p = 0;
ungetc(c, finput); ungetc (c, finput);
symval = getsym(token_buffer); symval = getsym (token_buffer);
return IDENTIFIER; return IDENTIFIER;
case '0': case '1': case '2': case '3': case '4': case '0': case '1': case '2': case '3': case '4':
case '5': case '6': case '7': case '8': case '9': case '5': case '6': case '7': case '8': case '9':
{ {
numval = 0; numval = 0;
p = token_buffer; p = token_buffer;
while (isdigit(c)) while (isdigit (c))
{ {
if (p == token_buffer + maxtoken) if (p == token_buffer + maxtoken)
p = grow_token_buffer(p); p = grow_token_buffer (p);
*p++ = c; *p++ = c;
numval = numval*10 + c - '0'; numval = numval * 10 + c - '0';
c = getc(finput); c = getc (finput);
} }
*p = 0; *p = 0;
ungetc(c, finput); ungetc (c, finput);
return NUMBER; return NUMBER;
} }
case '\'': case '\'':
/* parse the literal token and compute character code in code */ /* parse the literal token and compute character code in code */
translations = -1; translations = -1;
@@ -376,45 +405,44 @@ lex (void)
p = token_buffer; p = token_buffer;
*p++ = '\''; *p++ = '\'';
literalchar(&p, &code, '\''); literalchar (&p, &code, '\'');
c = getc(finput); c = getc (finput);
if (c != '\'') if (c != '\'')
{ {
complain (_("use \"...\" for multi-character literal tokens")); complain (_("use \"...\" for multi-character literal tokens"));
while (1) while (1)
{ {
dp = discard; dp = discard;
if (! literalchar(&dp, &discode, '\'')) if (!literalchar (&dp, &discode, '\''))
break; break;
} }
} }
*p++ = '\''; *p++ = '\'';
*p = 0; *p = 0;
symval = getsym(token_buffer); symval = getsym (token_buffer);
symval->class = STOKEN; symval->class = STOKEN;
if (! symval->user_token_number) if (!symval->user_token_number)
symval->user_token_number = code; symval->user_token_number = code;
return IDENTIFIER; return IDENTIFIER;
} }
case '\"': case '\"':
/* parse the literal string token and treat as an identifier */ /* parse the literal string token and treat as an identifier */
translations = -1; translations = -1;
{ {
int code; /* ignored here */ int code; /* ignored here */
p = token_buffer; p = token_buffer;
*p++ = '\"'; *p++ = '\"';
while (literalchar(&p, &code, '\"')) /* read up to and including " */ while (literalchar (&p, &code, '\"')) /* read up to and including " */
{ {
if (p >= token_buffer + maxtoken - 4) if (p >= token_buffer + maxtoken - 4)
p = grow_token_buffer(p); p = grow_token_buffer (p);
} }
*p = 0; *p = 0;
symval = getsym(token_buffer); symval = getsym (token_buffer);
symval->class = STOKEN; symval->class = STOKEN;
return IDENTIFIER; return IDENTIFIER;
@@ -438,25 +466,26 @@ lex (void)
case '=': case '=':
do do
{ {
c = getc(finput); c = getc (finput);
if (c == '\n') lineno++; if (c == '\n')
lineno++;
} }
while(c==' ' || c=='\n' || c=='\t'); while (c == ' ' || c == '\n' || c == '\t');
if (c == '{') if (c == '{')
{ {
strcpy(token_buffer, "={"); strcpy (token_buffer, "={");
return LEFT_CURLY; return LEFT_CURLY;
} }
else else
{ {
ungetc(c, finput); ungetc (c, finput);
return ILLEGAL; return ILLEGAL;
} }
case '<': case '<':
p = token_buffer; p = token_buffer;
c = getc(finput); c = getc (finput);
while (c != '>') while (c != '>')
{ {
if (c == EOF) if (c == EOF)
@@ -464,81 +493,78 @@ lex (void)
if (c == '\n') if (c == '\n')
{ {
complain (_("unterminated type name")); complain (_("unterminated type name"));
ungetc(c, finput); ungetc (c, finput);
break; break;
} }
if (p == token_buffer + maxtoken) if (p == token_buffer + maxtoken)
p = grow_token_buffer(p); p = grow_token_buffer (p);
*p++ = c; *p++ = c;
c = getc(finput); c = getc (finput);
} }
*p = 0; *p = 0;
return TYPENAME; return TYPENAME;
case '%': case '%':
return parse_percent_token(); return parse_percent_token ();
default: default:
return ILLEGAL; return ILLEGAL;
} }
} }
/* the following table dictates the action taken for the various /* the following table dictates the action taken for the various %
% directives. A setflag value causes the named flag to be directives. A setflag value causes the named flag to be set. A
set. A retval action returns the code. retval action returns the code. */
*/ struct percent_table_struct
struct percent_table_struct {
const char *name;
void *setflag;
int retval;
} percent_table[] =
{ {
{"token", NULL, TOKEN}, const char *name;
{"term", NULL, TOKEN}, void *setflag;
{"nterm", NULL, NTERM}, int retval;
{"type", NULL, TYPE}, }
{"guard", NULL, GUARD}, percent_table[] =
{"union", NULL, UNION}, {
{"expect", NULL, EXPECT}, { "token", NULL, TOKEN },
{"thong", NULL, THONG}, { "term", NULL, TOKEN },
{"start", NULL, START}, { "nterm", NULL, NTERM },
{"left", NULL, LEFT}, { "type", NULL, TYPE },
{"right", NULL, RIGHT}, { "guard", NULL, GUARD },
{"nonassoc", NULL, NONASSOC}, { "union", NULL, UNION },
{"binary", NULL, NONASSOC}, { "expect", NULL, EXPECT },
{"semantic_parser", NULL, SEMANTIC_PARSER}, { "thong", NULL, THONG },
{"pure_parser", NULL, PURE_PARSER}, { "start", NULL, START },
{"prec", NULL, PREC}, { "left", NULL, LEFT },
{ "right", NULL, RIGHT },
{"no_lines", &nolinesflag, NOOP}, /* -l */ { "nonassoc", NULL, NONASSOC },
{"raw", &rawtoknumflag, NOOP}, /* -r */ { "binary", NULL, NONASSOC },
{"token_table", &toknumflag, NOOP}, /* -k */ { "semantic_parser", NULL, SEMANTIC_PARSER },
{ "pure_parser", NULL, PURE_PARSER },
{ "prec", NULL, PREC },
{ "no_lines", &nolinesflag, NOOP}, /* -l */
{ "raw", &rawtoknumflag, NOOP }, /* -r */
{ "token_table", &toknumflag, NOOP}, /* -k */
#if 0 #if 0
/* These can be utilized after main is reoganized so /* These can be utilized after main is reoganized so
open_files() is deferred 'til after read_declarations(). open_files() is deferred 'til after read_declarations().
But %{ and %union both put information into files But %{ and %union both put information into files
that have to be opened before read_declarations(). that have to be opened before read_declarations().
*/ */
{"yacc", &fixed_outfiles, NOOP}, /* -y */ { "yacc", &fixed_outfiles, NOOP}, /* -y */
{"fixed_output_files", &fixed_outfiles, NOOP}, /* -y */ { "fixed_output_files", &fixed_outfiles, NOOP}, /* -y */
{"defines", &definesflag, NOOP}, /* -d */ { "defines", &definesflag, NOOP}, /* -d */
{"no_parser", &noparserflag, NOOP}, /* -n */ { "no_parser", &noparserflag, NOOP}, /* -n */
{"output_file", &spec_outfile, SETOPT}, /* -o */ { "output_file", &spec_outfile, SETOPT}, /* -o */
{"file_prefix", &spec_file_prefix, SETOPT}, /* -b */ { "file_prefix", &spec_file_prefix, SETOPT}, /* -b */
{"name_prefix", &spec_name_prefix, SETOPT}, /* -p */ { "name_prefix", &spec_name_prefix, SETOPT}, /* -p */
/* These would be acceptable, but they do not affect processing */
/* These would be acceptable, but they do not affect processing */ { "verbose", &verboseflag, NOOP}, /* -v */
{"verbose", &verboseflag, NOOP}, /* -v */ { "debug", &debugflag, NOOP}, /* -t */
{"debug", &debugflag, NOOP}, /* -t */ /* {"help", <print usage stmt>, NOOP}, *//* -h */
/* {"help", <print usage stmt>, NOOP},*/ /* -h */ /* {"version", <print version number> , NOOP}, *//* -V */
/* {"version", <print version number> , NOOP},*/ /* -V */
#endif #endif
{ NULL, NULL, ILLEGAL}
{NULL, NULL, ILLEGAL}
}; };
/* Parse a token which starts with %. /* Parse a token which starts with %.
@@ -547,14 +573,14 @@ struct percent_table_struct {
int int
parse_percent_token (void) parse_percent_token (void)
{ {
register int c; int c;
register char *p; char *p;
register struct percent_table_struct *tx; struct percent_table_struct *tx;
p = token_buffer; p = token_buffer;
c = getc(finput); c = getc (finput);
*p++ = '%'; *p++ = '%';
*p++ = c; /* for error msg */ *p++ = c; /* for error msg */
*p = 0; *p = 0;
switch (c) switch (c)
@@ -580,37 +606,38 @@ parse_percent_token (void)
case '=': case '=':
return PREC; return PREC;
} }
if (!isalpha(c)) if (!isalpha (c))
return ILLEGAL; return ILLEGAL;
p = token_buffer; p = token_buffer;
*p++ = '%'; *p++ = '%';
while (isalpha(c) || c == '_' || c == '-') while (isalpha (c) || c == '_' || c == '-')
{ {
if (p == token_buffer + maxtoken) if (p == token_buffer + maxtoken)
p = grow_token_buffer(p); p = grow_token_buffer (p);
if (c == '-') c = '_'; if (c == '-')
c = '_';
*p++ = c; *p++ = c;
c = getc(finput); c = getc (finput);
} }
ungetc(c, finput); ungetc (c, finput);
*p = 0; *p = 0;
/* table lookup % directive */ /* table lookup % directive */
for (tx = percent_table; tx->name; tx++) for (tx = percent_table; tx->name; tx++)
if (strcmp(token_buffer+1, tx->name) == 0) if (strcmp (token_buffer + 1, tx->name) == 0)
break; break;
if (tx->retval == SETOPT) if (tx->retval == SETOPT)
{ {
*((char **)(tx->setflag)) = optarg; *((char **) (tx->setflag)) = optarg;
return NOOP; return NOOP;
} }
if (tx->setflag) if (tx->setflag)
{ {
*((int *)(tx->setflag)) = 1; *((int *) (tx->setflag)) = 1;
return NOOP; return NOOP;
} }
return tx->retval; return tx->retval;

108
src/lex.h
View File

@@ -1,51 +1,71 @@
/* Token type definitions for bison's input reader, /* Token type definitions for bison's input reader,
Copyright (C) 1984, 1989, 1992 Free Software Foundation, Inc. Copyright (C) 1984, 1989, 1992, 2000 Free Software Foundation, Inc.
This file is part of Bison, the GNU Compiler Compiler. This file is part of Bison, the GNU Compiler Compiler.
Bison is free software; you can redistribute it and/or modify Bison is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option) the Free Software Foundation; either version 2, or (at your option)
any later version. any later version.
Bison is distributed in the hope that it will be useful, Bison is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details. GNU General Public License for more details.
You should have received a copy of the GNU General Public License You should have received a copy of the GNU General Public License
along with Bison; see the file COPYING. If not, write to along with Bison; see the file COPYING. If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330, the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */ Boston, MA 02111-1307, USA. */
#ifndef LEX_H_
# define LEX_H_
/* Token-type codes. */
# define ENDFILE 0
# define IDENTIFIER 1
# define COMMA 2
# define COLON 3
# define SEMICOLON 4
# define BAR 5
# define LEFT_CURLY 6
# define TWO_PERCENTS 7
# define PERCENT_LEFT_CURLY 8
# define TOKEN 9
# define NTERM 10
# define GUARD 11
# define TYPE 12
# define UNION 13
# define START 14
# define LEFT 15
# define RIGHT 16
# define NONASSOC 17
# define PREC 18
# define SEMANTIC_PARSER 19
# define PURE_PARSER 20
# define TYPENAME 21
# define NUMBER 22
# define EXPECT 23
# define THONG 24
# define NOOP 25
# define SETOPT 26
# define ILLEGAL 27
# define MAXTOKEN 1024
void init_lex PARAMS ((void));
char *grow_token_buffer PARAMS ((char *));
int skip_white_space PARAMS ((void));
void unlex PARAMS ((int));
/* Return one of the token-type codes. When an identifier is seen,
the code IDENTIFIER is returned and the name is looked up in the
symbol table using symtab.c; symval is set to a pointer to the
entry found. */
int lex PARAMS ((void));
int parse_percent_token PARAMS ((void));
#define ENDFILE 0 #endif /* !LEX_H_ */
#define IDENTIFIER 1
#define COMMA 2
#define COLON 3
#define SEMICOLON 4
#define BAR 5
#define LEFT_CURLY 6
#define TWO_PERCENTS 7
#define PERCENT_LEFT_CURLY 8
#define TOKEN 9
#define NTERM 10
#define GUARD 11
#define TYPE 12
#define UNION 13
#define START 14
#define LEFT 15
#define RIGHT 16
#define NONASSOC 17
#define PREC 18
#define SEMANTIC_PARSER 19
#define PURE_PARSER 20
#define TYPENAME 21
#define NUMBER 22
#define EXPECT 23
#define THONG 24
#define NOOP 25
#define SETOPT 26
#define ILLEGAL 27
#define MAXTOKEN 1024

View File

@@ -68,17 +68,10 @@ extern int expected_conflicts;
extern char *token_buffer; extern char *token_buffer;
extern int maxtoken; extern int maxtoken;
extern void init_lex PARAMS((void));
extern char *grow_token_buffer PARAMS((char *));
extern void tabinit PARAMS((void)); extern void tabinit PARAMS((void));
extern void free_symtab PARAMS((void)); extern void free_symtab PARAMS((void));
extern void open_extra_files PARAMS((void)); extern void open_extra_files PARAMS((void));
extern char *printable_version PARAMS((int)); extern char *printable_version PARAMS((int));
extern void unlex PARAMS((int));
extern int skip_white_space PARAMS((void));
extern int parse_percent_token PARAMS((void));
extern int lex PARAMS((void));
typedef typedef
struct symbol_list struct symbol_list