/* Generated by re2c 0.9.1-C on Thu Apr 11 22:20:20 2002 */ #line 1 "scanner.re" #include #include #include #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); }