-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathlexer.l
106 lines (86 loc) · 2.84 KB
/
lexer.l
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
%option noyywrap
%{
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "symtab.h"
#include "semantics.h"
#include "ast.h"
#include "parser.tab.h"
extern FILE *yyin;
extern FILE *yyout;
int lineno = 1; // initialize to 1
void ret_print(char *token_type);
void yyerror();
%}
%x ML_COMMENT
alpha [a-zA-Z]
digit [0-9]
alnum {alpha}|{digit}
print [ -~]
ID {alpha}+{alnum}*
ICONST "0"|[0-9]{digit}*
FCONST "0"|{digit}*"."{digit}+
CCONST (\'{print}\')|(\'\\[nftrbv]\')
STRING \"{print}*\"
%%
"//".* { /* printf("Eat up comment at line %d\n", lineno); */ }
"/*" { /* printf("Eat up comment from line %d ", lineno); */ BEGIN(ML_COMMENT); }
<ML_COMMENT>"*/" { /* printf("to line %d\n", lineno); */ BEGIN(INITIAL); }
<ML_COMMENT>[^*\n]+
<ML_COMMENT>"*"
<ML_COMMENT>"\n" { lineno += 1; }
"char"|"CHAR" { return CHAR; }
"int"|"INT" { return INT; }
"float"|"FLOAT" { return FLOAT; }
"double"|"DOUBLE" { return DOUBLE; }
"if"|"IF" { return IF; }
"else"|"ELSE" { return ELSE; }
"while"|"WHILE" { return WHILE; }
"for"|"FOR" { return FOR; }
"continue"|"CONTINUE" { return CONTINUE; }
"break"|"BREAK" { return BREAK; }
"void"|"VOID" { return VOID; }
"return"|"RETURN" { return RETURN; }
"+" { yylval.val.ival = ADD; return ADDOP; }
"-" { yylval.val.ival = SUB; return ADDOP; }
"*" { return MULOP; }
"/" { return DIVOP; }
"++" { yylval.val.ival = INC; return INCR; }
"--" { yylval.val.ival = DEC; return INCR; }
"||" { return OROP; }
"&&" { return ANDOP; }
"!" { return NOTOP; }
"==" { yylval.val.ival = EQUAL; return EQUOP; }
"!=" { yylval.val.ival = NOT_EQUAL; return EQUOP; }
">" { yylval.val.ival = GREATER; return RELOP; }
"<" { yylval.val.ival = LESS; return RELOP; }
">=" { yylval.val.ival = GREATER_EQUAL; return RELOP; }
"<=" { yylval.val.ival = LESS_EQUAL; return RELOP; }
"(" { return LPAREN; }
")" { return RPAREN; }
"]" { return RBRACK; }
"[" { return LBRACK; }
"{" { return LBRACE; }
"}" { return RBRACE; }
";" { return SEMI; }
"," { return COMMA; }
"=" { return ASSIGN; }
"&" { return REFER; }
{ID} {
// insert identifier into symbol table
insert(yytext, strlen(yytext), UNDEF, lineno);
yylval.symtab_item = lookup(yytext);
return ID;
}
{ICONST} { yylval.val.ival = atoi(yytext); return ICONST; }
{FCONST} { yylval.val.fval = atof(yytext); return FCONST; }
{CCONST} { yylval.val.cval = yytext[1]; return CCONST; }
{STRING} {
yylval.val.sval = malloc(yyleng * sizeof(char));
strcpy(yylval.val.sval, yytext); return STRING;
}
"\n" { lineno += 1; }
[ \t\r\f]+ /* eat up whitespace */
. { yyerror("Unrecognized character"); }
%%