-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcompiler.l
110 lines (106 loc) · 2.68 KB
/
compiler.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
107
108
109
110
%{
#include <iostream>
#include <cstdlib>
#include "ast.h"
#include "Visitor.h"
#include "compiler.tab.h"
#define YY_DECL extern "C" int yylex()
char * translateString(char *, int);
%}
%option noyywrap
%option yylineno
%option nounput
UNDERSCOREDALPHA [a-zA-Z_]
CHAR ([\40-\176]{-}['"\\])|\\n|\\t|\\\\|\\\"|\\\'
HEXADECIMAL [0-9a-fA-F]
DIGIT [0-9]
ALPHA [a-zA-Z]
%%
\/\/.*\n {}
\, {return COMMA;}
\; {return SEMICOLON;}
\( {return OP;}
\) {return CP;}
\[ {return LSB;}
\] {return RSB;}
\{ {return OB;}
\} {return CB;}
\+\= {return ADD_ASSIGN;}
\+ {return ADD;}
\-\= {return SUB_ASSIGN;}
\- {return SUB;}
\* {return MUL;}
\/ {return DIV;}
\% {return PERCENTAGE;}
\!\= {return NOT_EQUAL;}
\! {return NOT;}
\<\= {return LTE;}
\< {return LT;}
\>\= {return GTE;}
\> {return GT;}
\=\= {return EQUAL;}
\= {return ASSIGN;}
\|\| {return CONDITIONAL_OR;}
\&\& {return CONDITIONAL_AND;}
boolean {return BOOL_LITERAL;}
break {return BREAK;}
callout {return CALLOUT;}
class {return CLASS;}
continue {return CONTINUE;}
else {return ELSE;}
false {return FALSE;}
for {return FOR;}
if {return IF;}
int {return INT_LITERAL;}
return {return RETURN;}
true {return TRUE;}
void {return VOID;}
{UNDERSCOREDALPHA}({UNDERSCOREDALPHA}|{DIGIT})* {yylval.sval = strdup(yytext);return IDENTIFIER;}
{DIGIT}+ {yylval.ival = atoi(yytext);return INT_VALUE;}
0x{HEXADECIMAL}+ {yylval.ival = atoi(yytext);return INT_VALUE;}
\"{CHAR}*\" {yylval.sval = translateString(yytext + 1, strlen(yytext) - 2);return STRING_VALUE;}
\'{CHAR}\' {yylval.cval = yytext[1];return CHAR_VALUE;}
[\t\ \n] {}
. {std::cerr << "UNRECOGNIZED TEXT ENCOUNTERED" << yytext;}
%%
char *translateString(char *string, int size){
char *ch = string, *newString = (char *) malloc(size + 1);
char *temp = newString;
for(int i = 0; i < size; i++){
switch(*ch){
case '\\':
i++;
ch++;
if(*ch == 'a')
*temp = '\a';
else if(*ch == 'b')
*temp = '\b';
else if(*ch == '\f')
*temp = '\f';
else if(*ch == '\n')
*temp = '\n';
else if(*ch == '\r')
*temp = '\r';
else if(*ch == '\t')
*temp = '\t';
else if(*ch == '\v')
*temp = '\v';
else if(*ch == '\\')
*temp = '\\';
else if(*ch == '\'')
*temp = '\'';
else if(*ch == '\"')
*temp = '\"';
else if(*ch == '?')
*temp = '\?';
break;
default:
*temp = *ch;
break;
}
ch++;
temp++;
}
*temp = '\0';
return newString;
}