|
|
|
/* Generated by re2c 0.9.1-C on Thu Apr 11 22:20:20 2002
|
|
|
|
*/
|
|
|
|
#line 1 "scanner.re"
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "scanner.h"
|
|
|
|
#include "parse.h"
|
|
|
|
#include "parser.h"
|
|
|
|
|
|
|
|
extern YYSTYPE yylval;
|
|
|
|
|
|
|
|
#define BSIZE 8192
|
|
|
|
|
|
|
|
#define YYCTYPE uchar
|
|
|
|
#define YYCURSOR cursor
|
|
|
|
#define YYLIMIT s->lim
|
|
|
|
#define YYMARKER s->ptr
|
|
|
|
#define YYFILL(n) {cursor = fill(s, cursor);}
|
|
|
|
|
|
|
|
#define RETURN(i) {s->cur = cursor; return i;}
|
|
|
|
|
|
|
|
static uchar *fill(Scanner*, uchar*);
|
|
|
|
|
|
|
|
void
|
|
|
|
Scanner_init(Scanner *s, FILE *i)
|
|
|
|
{
|
|
|
|
s->in = i;
|
|
|
|
s->bot = s->tok = s->ptr = s->cur = s->pos = s->lim = s->top =
|
|
|
|
s->eof = NULL;
|
|
|
|
s->tchar = s->tline = 0;
|
|
|
|
s->cline = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static uchar *
|
|
|
|
fill(Scanner *s, uchar *cursor)
|
|
|
|
{
|
|
|
|
if(!s->eof){
|
|
|
|
uint cnt = s->tok - s->bot;
|
|
|
|
if(cnt){
|
|
|
|
memcpy(s->bot, s->tok, s->lim - s->tok);
|
|
|
|
s->tok = s->bot;
|
|
|
|
s->ptr -= cnt;
|
|
|
|
cursor -= cnt;
|
|
|
|
s->pos -= cnt;
|
|
|
|
s->lim -= cnt;
|
|
|
|
}
|
|
|
|
if((s->top - s->lim) < BSIZE){
|
|
|
|
uchar *buf = malloc(sizeof(uchar)*((s->lim - s->bot) + BSIZE));
|
|
|
|
memcpy(buf, s->tok, s->lim - s->tok);
|
|
|
|
s->tok = buf;
|
|
|
|
s->ptr = &buf[s->ptr - s->bot];
|
|
|
|
cursor = &buf[cursor - s->bot];
|
|
|
|
s->pos = &buf[s->pos - s->bot];
|
|
|
|
s->lim = &buf[s->lim - s->bot];
|
|
|
|
s->top = &s->lim[BSIZE];
|
|
|
|
free(s->bot);
|
|
|
|
s->bot = buf;
|
|
|
|
}
|
|
|
|
if((cnt = fread(s->lim, sizeof(uchar), BSIZE, s->in)) != BSIZE){
|
|
|
|
s->eof = &s->lim[cnt]; *s->eof++ = '\n';
|
|
|
|
}
|
|
|
|
s->lim += cnt;
|
|
|
|
}
|
|
|
|
return cursor;
|
|
|
|
}
|
|
|
|
|
|
|
|
#line 75
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
Scanner_echo(Scanner *s, FILE *out)
|
|
|
|
{
|
|
|
|
uchar *cursor = s->cur;
|
|
|
|
s->tok = cursor;
|
|
|
|
echo:
|
|
|
|
{
|
|
|
|
YYCTYPE yych;
|
|
|
|
unsigned int yyaccept;
|
|
|
|
goto yy0;
|
|
|
|
yy1: ++YYCURSOR;
|
|
|
|
yy0:
|
|
|
|
if((YYLIMIT - YYCURSOR) < 7) YYFILL(7);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych == '\n') goto yy4;
|
|
|
|
if(yych != '/') goto yy6;
|
|
|
|
yy2: yyaccept = 0;
|
|
|
|
yych = *(YYMARKER = ++YYCURSOR);
|
|
|
|
if(yych == '*') goto yy7;
|
|
|
|
yy3:
|
|
|
|
#line 91
|
|
|
|
{ goto echo; }
|
|
|
|
yy4: yych = *++YYCURSOR;
|
|
|
|
yy5:
|
|
|
|
#line 87
|
|
|
|
{ if(cursor == s->eof) RETURN(0);
|
|
|
|
fwrite(s->tok, 1, cursor - s->tok, out);
|
|
|
|
s->tok = s->pos = cursor; s->cline++;
|
|
|
|
goto echo; }
|
|
|
|
yy6: yych = *++YYCURSOR;
|
|
|
|
goto yy3;
|
|
|
|
yy7: yych = *++YYCURSOR;
|
|
|
|
if(yych == '!') goto yy9;
|
|
|
|
yy8: YYCURSOR = YYMARKER;
|
|
|
|
switch(yyaccept){
|
|
|
|
case 0: goto yy3;
|
|
|
|
}
|
|
|
|
yy9: yych = *++YYCURSOR;
|
|
|
|
if(yych != 'r') goto yy8;
|
|
|
|
yy10: yych = *++YYCURSOR;
|
|
|
|
if(yych != 'e') goto yy8;
|
|
|
|
yy11: yych = *++YYCURSOR;
|
|
|
|
if(yych != '2') goto yy8;
|
|
|
|
yy12: yych = *++YYCURSOR;
|
|
|
|
if(yych != 'c') goto yy8;
|
|
|
|
yy13: yych = *++YYCURSOR;
|
|
|
|
yy14:
|
|
|
|
#line 84
|
|
|
|
{ fwrite(s->tok, 1, &cursor[-7] - s->tok, out);
|
|
|
|
s->tok = cursor;
|
|
|
|
RETURN(1); }
|
|
|
|
}
|
|
|
|
#line 92
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
Scanner_scan(Scanner *s)
|
|
|
|
{
|
|
|
|
uchar *cursor = s->cur;
|
|
|
|
uint depth;
|
|
|
|
|
|
|
|
scan:
|
|
|
|
s->tchar = cursor - s->pos;
|
|
|
|
s->tline = s->cline;
|
|
|
|
s->tok = cursor;
|
|
|
|
{
|
|
|
|
YYCTYPE yych;
|
|
|
|
unsigned int yyaccept;
|
|
|
|
goto yy15;
|
|
|
|
yy16: ++YYCURSOR;
|
|
|
|
yy15:
|
|
|
|
if((YYLIMIT - YYCURSOR) < 2) YYFILL(2);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych <= ':'){
|
|
|
|
if(yych <= '"'){
|
|
|
|
if(yych <= '\n'){
|
|
|
|
if(yych <= '\b') goto yy35;
|
|
|
|
if(yych <= '\t') goto yy31;
|
|
|
|
goto yy33;
|
|
|
|
} else {
|
|
|
|
if(yych == ' ') goto yy31;
|
|
|
|
if(yych <= '!') goto yy35;
|
|
|
|
goto yy23;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if(yych <= '*'){
|
|
|
|
if(yych <= '\'') goto yy35;
|
|
|
|
if(yych <= ')') goto yy27;
|
|
|
|
goto yy21;
|
|
|
|
} else {
|
|
|
|
if(yych <= '+') goto yy28;
|
|
|
|
if(yych == '/') goto yy19;
|
|
|
|
goto yy35;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if(yych <= 'Z'){
|
|
|
|
if(yych <= '='){
|
|
|
|
if(yych == '<') goto yy35;
|
|
|
|
goto yy27;
|
|
|
|
} else {
|
|
|
|
if(yych == '?') goto yy28;
|
|
|
|
if(yych <= '@') goto yy35;
|
|
|
|
goto yy29;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if(yych <= '`'){
|
|
|
|
if(yych <= '[') goto yy25;
|
|
|
|
if(yych <= '\\') goto yy27;
|
|
|
|
goto yy35;
|
|
|
|
} else {
|
|
|
|
if(yych <= 'z') goto yy29;
|
|
|
|
if(yych <= '{') goto yy17;
|
|
|
|
if(yych <= '|') goto yy27;
|
|
|
|
goto yy35;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
yy17: yych = *++YYCURSOR;
|
|
|
|
yy18:
|
|
|
|
#line 107
|
|
|
|
{ depth = 1;
|
|
|
|
goto code;
|
|
|
|
}
|
|
|
|
yy19: yych = *++YYCURSOR;
|
|
|
|
if(yych == '*') goto yy54;
|
|
|
|
yy20:
|
|
|
|
#line 126
|
|
|
|
{ RETURN(*s->tok); }
|
|
|
|
yy21: yych = *++YYCURSOR;
|
|
|
|
if(yych == '/') goto yy52;
|
|
|
|
yy22:
|
|
|
|
#line 128
|
|
|
|
{ yylval.op = *s->tok;
|
|
|
|
RETURN(CLOSE); }
|
|
|
|
yy23: yyaccept = 0;
|
|
|
|
yych = *(YYMARKER = ++YYCURSOR);
|
|
|
|
if(yych != '\n') goto yy48;
|
|
|
|
yy24:
|
|
|
|
#line 119
|
|
|
|
{ Scanner_fatal(s, "bad string"); }
|
|
|
|
yy25: yyaccept = 1;
|
|
|
|
yych = *(YYMARKER = ++YYCURSOR);
|
|
|
|
if(yych != '\n') goto yy42;
|
|
|
|
yy26:
|
|
|
|
#line 124
|
|
|
|
{ Scanner_fatal(s, "bad character constant"); }
|
|
|
|
yy27: yych = *++YYCURSOR;
|
|
|
|
goto yy20;
|
|
|
|
yy28: yych = *++YYCURSOR;
|
|
|
|
goto yy22;
|
|
|
|
yy29: yych = *++YYCURSOR;
|
|
|
|
goto yy40;
|
|
|
|
yy30:
|
|
|
|
#line 131
|
|
|
|
{ SubStr substr;
|
|
|
|
s->cur = cursor;
|
|
|
|
substr = Scanner_token(s);
|
|
|
|
yylval.symbol = Symbol_find(&substr);
|
|
|
|
return ID; }
|
|
|
|
yy31: yych = *++YYCURSOR;
|
|
|
|
goto yy38;
|
|
|
|
yy32:
|
|
|
|
#line 137
|
|
|
|
{ goto scan; }
|
|
|
|
yy33: yych = *++YYCURSOR;
|
|
|
|
yy34:
|
|
|
|
#line 139
|
|
|
|
{ if(cursor == s->eof) RETURN(0);
|
|
|
|
s->pos = cursor; s->cline++;
|
|
|
|
goto scan;
|
|
|
|
}
|
|
|
|
yy35: yych = *++YYCURSOR;
|
|
|
|
yy36:
|
|
|
|
#line 144
|
|
|
|
{ fprintf(stderr, "unexpected character: '%c'\n", *s->tok);
|
|
|
|
goto scan;
|
|
|
|
}
|
|
|
|
yy37: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
yy38: if(yych == '\t') goto yy37;
|
|
|
|
if(yych == ' ') goto yy37;
|
|
|
|
goto yy32;
|
|
|
|
yy39: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
yy40: if(yych <= '@'){
|
|
|
|
if(yych <= '/') goto yy30;
|
|
|
|
if(yych <= '9') goto yy39;
|
|
|
|
goto yy30;
|
|
|
|
} else {
|
|
|
|
if(yych <= 'Z') goto yy39;
|
|
|
|
if(yych <= '`') goto yy30;
|
|
|
|
if(yych <= 'z') goto yy39;
|
|
|
|
goto yy30;
|
|
|
|
}
|
|
|
|
yy41: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
yy42: if(yych <= '['){
|
|
|
|
if(yych != '\n') goto yy41;
|
|
|
|
} else {
|
|
|
|
if(yych <= '\\') goto yy44;
|
|
|
|
if(yych <= ']') goto yy45;
|
|
|
|
goto yy41;
|
|
|
|
}
|
|
|
|
yy43: YYCURSOR = YYMARKER;
|
|
|
|
switch(yyaccept){
|
|
|
|
case 0: goto yy24;
|
|
|
|
case 1: goto yy26;
|
|
|
|
}
|
|
|
|
yy44: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych == '\n') goto yy43;
|
|
|
|
goto yy41;
|
|
|
|
yy45: yych = *++YYCURSOR;
|
|
|
|
yy46:
|
|
|
|
#line 121
|
|
|
|
{ s->cur = cursor;
|
|
|
|
yylval.regexp = ranToRE(Scanner_token(s));
|
|
|
|
return RANGE; }
|
|
|
|
yy47: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
yy48: if(yych <= '!'){
|
|
|
|
if(yych == '\n') goto yy43;
|
|
|
|
goto yy47;
|
|
|
|
} else {
|
|
|
|
if(yych <= '"') goto yy50;
|
|
|
|
if(yych != '\\') goto yy47;
|
|
|
|
}
|
|
|
|
yy49: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych == '\n') goto yy43;
|
|
|
|
goto yy47;
|
|
|
|
yy50: yych = *++YYCURSOR;
|
|
|
|
yy51:
|
|
|
|
#line 116
|
|
|
|
{ s->cur = cursor;
|
|
|
|
yylval.regexp = strToRE(Scanner_token(s));
|
|
|
|
return STRING; }
|
|
|
|
yy52: yych = *++YYCURSOR;
|
|
|
|
yy53:
|
|
|
|
#line 113
|
|
|
|
{ s->tok = cursor;
|
|
|
|
RETURN(0); }
|
|
|
|
yy54: yych = *++YYCURSOR;
|
|
|
|
yy55:
|
|
|
|
#line 110
|
|
|
|
{ depth = 1;
|
|
|
|
goto comment; }
|
|
|
|
}
|
|
|
|
#line 147
|
|
|
|
|
|
|
|
|
|
|
|
code:
|
|
|
|
{
|
|
|
|
YYCTYPE yych;
|
|
|
|
unsigned int yyaccept;
|
|
|
|
goto yy56;
|
|
|
|
yy57: ++YYCURSOR;
|
|
|
|
yy56:
|
|
|
|
if((YYLIMIT - YYCURSOR) < 2) YYFILL(2);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych <= '&'){
|
|
|
|
if(yych <= '\n'){
|
|
|
|
if(yych <= '\t') goto yy64;
|
|
|
|
goto yy62;
|
|
|
|
} else {
|
|
|
|
if(yych == '"') goto yy66;
|
|
|
|
goto yy64;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if(yych <= '{'){
|
|
|
|
if(yych <= '\'') goto yy67;
|
|
|
|
if(yych <= 'z') goto yy64;
|
|
|
|
goto yy60;
|
|
|
|
} else {
|
|
|
|
if(yych != '}') goto yy64;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
yy58: yych = *++YYCURSOR;
|
|
|
|
yy59:
|
|
|
|
#line 151
|
|
|
|
{ if(--depth == 0){
|
|
|
|
s->cur = cursor;
|
|
|
|
yylval.token = Token_new(Scanner_token(s), s->tline);
|
|
|
|
return CODE;
|
|
|
|
}
|
|
|
|
goto code; }
|
|
|
|
yy60: yych = *++YYCURSOR;
|
|
|
|
yy61:
|
|
|
|
#line 157
|
|
|
|
{ ++depth;
|
|
|
|
goto code; }
|
|
|
|
yy62: yych = *++YYCURSOR;
|
|
|
|
yy63:
|
|
|
|
#line 159
|
|
|
|
{ if(cursor == s->eof) Scanner_fatal(s, "missing '}'");
|
|
|
|
s->pos = cursor; s->cline++;
|
|
|
|
goto code;
|
|
|
|
}
|
|
|
|
yy64: yych = *++YYCURSOR;
|
|
|
|
yy65:
|
|
|
|
#line 163
|
|
|
|
{ goto code; }
|
|
|
|
yy66: yyaccept = 0;
|
|
|
|
yych = *(YYMARKER = ++YYCURSOR);
|
|
|
|
if(yych == '\n') goto yy65;
|
|
|
|
goto yy73;
|
|
|
|
yy67: yyaccept = 0;
|
|
|
|
yych = *(YYMARKER = ++YYCURSOR);
|
|
|
|
if(yych == '\n') goto yy65;
|
|
|
|
goto yy69;
|
|
|
|
yy68: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
yy69: if(yych <= '&'){
|
|
|
|
if(yych != '\n') goto yy68;
|
|
|
|
} else {
|
|
|
|
if(yych <= '\'') goto yy64;
|
|
|
|
if(yych == '\\') goto yy71;
|
|
|
|
goto yy68;
|
|
|
|
}
|
|
|
|
yy70: YYCURSOR = YYMARKER;
|
|
|
|
switch(yyaccept){
|
|
|
|
case 0: goto yy65;
|
|
|
|
}
|
|
|
|
yy71: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych == '\n') goto yy70;
|
|
|
|
goto yy68;
|
|
|
|
yy72: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
yy73: if(yych <= '!'){
|
|
|
|
if(yych == '\n') goto yy70;
|
|
|
|
goto yy72;
|
|
|
|
} else {
|
|
|
|
if(yych <= '"') goto yy64;
|
|
|
|
if(yych != '\\') goto yy72;
|
|
|
|
}
|
|
|
|
yy74: ++YYCURSOR;
|
|
|
|
if(YYLIMIT == YYCURSOR) YYFILL(1);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych == '\n') goto yy70;
|
|
|
|
goto yy72;
|
|
|
|
}
|
|
|
|
#line 164
|
|
|
|
|
|
|
|
|
|
|
|
comment:
|
|
|
|
{
|
|
|
|
YYCTYPE yych;
|
|
|
|
unsigned int yyaccept;
|
|
|
|
goto yy75;
|
|
|
|
yy76: ++YYCURSOR;
|
|
|
|
yy75:
|
|
|
|
if((YYLIMIT - YYCURSOR) < 2) YYFILL(2);
|
|
|
|
yych = *YYCURSOR;
|
|
|
|
if(yych <= ')'){
|
|
|
|
if(yych == '\n') goto yy80;
|
|
|
|
goto yy82;
|
|
|
|
} else {
|
|
|
|
if(yych <= '*') goto yy77;
|
|
|
|
if(yych == '/') goto yy79;
|
|
|
|
goto yy82;
|
|
|
|
}
|
|
|
|
yy77: yych = *++YYCURSOR;
|
|
|
|
if(yych == '/') goto yy85;
|
|
|
|
yy78:
|
|
|
|
#line 178
|
|
|
|
{ goto comment; }
|
|
|
|
yy79: yych = *++YYCURSOR;
|
|
|
|
if(yych == '*') goto yy83;
|
|
|
|
goto yy78;
|
|
|
|
yy80: yych = *++YYCURSOR;
|
|
|
|
yy81:
|
|
|
|
#line 174
|
|
|
|
{ if(cursor == s->eof) RETURN(0);
|
|
|
|
s->tok = s->pos = cursor; s->cline++;
|
|
|
|
goto comment;
|
|
|
|
}
|
|
|
|
yy82: yych = *++YYCURSOR;
|
|
|
|
goto yy78;
|
|
|
|
yy83: yych = *++YYCURSOR;
|
|
|
|
yy84:
|
|
|
|
#line 172
|
|
|
|
{ ++depth;
|
|
|
|
goto comment; }
|
|
|
|
yy85: yych = *++YYCURSOR;
|
|
|
|
yy86:
|
|
|
|
#line 168
|
|
|
|
{ if(--depth == 0)
|
|
|
|
goto scan;
|
|
|
|
else
|
|
|
|
goto comment; }
|
|
|
|
}
|
|
|
|
#line 179
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
Scanner_fatal(Scanner *s, char *msg)
|
|
|
|
{
|
|
|
|
fprintf(stderr, "line %d, column %d: %s\n", s->tline, s->tchar + 1, msg);
|
|
|
|
exit(1);
|
|
|
|
}
|