Merge branch 'Dev' into Sprint1-Type/Keywards-FE-t#07
This commit is contained in:
30
Makefile
30
Makefile
@ -1,14 +1,16 @@
|
|||||||
# Basic Makefile example from flex documentation -- provides explicit rules
|
CC := gcc
|
||||||
# Creates "myprogram" from "scan.l" and "myprogram.c"
|
FLEX := flex
|
||||||
#
|
LEX := lexicalStructure.lex
|
||||||
#LEX=flex
|
EXE := lexicalStructure
|
||||||
#myprogram: scan.o myprogram.o
|
|
||||||
#$(CC) -o $@ $(LDFLAGS) $^
|
lexicalStructure:
|
||||||
#myprogram.o: myprogram.c
|
$(FLEX) $(LEX)
|
||||||
#$(CC) $(CPPFLAGS) $(CFLAGS) -o $@ -c $^
|
$(CC) lex.yy.c -o $(EXE)
|
||||||
#scan.o: scan.c
|
|
||||||
#$(CC) $(CPPFLAGS) $(CFLAGS) -o $@ -c $^
|
test_operators:
|
||||||
#scan.c: scan.l
|
./$(EXE) ./tests/test_operators.alpha
|
||||||
#$(LEX) $(LFLAGS) -o $@ $^
|
|
||||||
#clean:
|
clean:
|
||||||
#$(RM) *.o scan.c
|
rm -f *.o
|
||||||
|
rm -f lex.yy.c
|
||||||
|
rm -f $(EXE)
|
||||||
|
@ -1,14 +1,26 @@
|
|||||||
/* Lexical Analysis with Flex (2.6.0) We used some of the code from this manual */
|
/* Lexical Analysis with Flex (1.6.0) We used some of the code from this manual */
|
||||||
/* so we placed the citation here. */
|
/* so we placed the citation here. */
|
||||||
/* definitions */
|
/* definitions */
|
||||||
|
|
||||||
%option noyywrap
|
%option noyywrap
|
||||||
%{
|
|
||||||
#include "typedefs.h"
|
%{
|
||||||
|
#include "typedefs.h"
|
||||||
%}
|
%}
|
||||||
int line_number = 1, column_number = 1;
|
int line_number = 1, column_number = 1;
|
||||||
|
|
||||||
|
DIGIT [0-9]
|
||||||
|
CHAR \\n|\\t|\\'|[^'\n\t\\]
|
||||||
|
/* char can be a newline, tab, an escaped quote, or anything but a single quote, an actual line break, an actual tab, or a backslash by itself (to prevent confusion from escaped quote */
|
||||||
|
SCHAR \\n|\\t|\\\"|[^\"\n\\]
|
||||||
|
/*similar to above, a string Char (SCHAR) is the same as a CHAR except we cannot have double quotes instead of single quotes. Double quotes need to be escaped in Flex unlike single quotes based on documentation */
|
||||||
|
STARTCOM \(\*
|
||||||
|
ENDCOM \*\)
|
||||||
|
COMMENTCHAR [^\*]|\*[^\)]
|
||||||
|
/*Making the contents of a comment anything that is either not a * or not a * followed by ) to terminate comments at the first ENDCOM */
|
||||||
%%
|
%%
|
||||||
|
|
||||||
|
|
||||||
\n line_number++ column_number = 1;
|
\n line_number++ column_number = 1;
|
||||||
. column_number++;
|
. column_number++;
|
||||||
|
|
||||||
@ -17,8 +29,11 @@
|
|||||||
"Boolean" {return T_BOOLEAN}
|
"Boolean" {return T_BOOLEAN}
|
||||||
"character" {return T_CHARACTER}
|
"character" {return T_CHARACTER}
|
||||||
|
|
||||||
/* KEYWARDS */
|
|
||||||
|
|
||||||
|
/* rules */
|
||||||
|
{DIGIT}+ {printf( "C_INTEGER: %s (%d)\n", yytext, atoi( yytext ) );}
|
||||||
|
|
||||||
|
"null" {printf( "C_NULL: %s (%d)\n", yytext, atoi( yytext ) );}
|
||||||
|
|
||||||
"while" {return WHILE}
|
"while" {return WHILE}
|
||||||
"if" {return IF}
|
"if" {return IF}
|
||||||
@ -30,5 +45,34 @@
|
|||||||
"external" {return EXTERNAL}
|
"external" {return EXTERNAL}
|
||||||
"as" {return AS}
|
"as" {return AS}
|
||||||
|
|
||||||
|
'{CHAR}' {printf( "C_CHARACTER: %s (%d)\n", yytext, atoi( yytext ) );} /*using double \ per documentation to show escaped chars*/
|
||||||
|
|
||||||
|
"true" {printf( "C_TRUE: %s (%d)\n", yytext, atoi( yytext ) );}
|
||||||
|
|
||||||
|
|
||||||
|
"false" {printf( "C_FALSE: %s (%d)\n", yytext, atoi( yytext ) );}
|
||||||
|
|
||||||
|
/* OPERATORS */
|
||||||
|
|
||||||
|
"+" {return ADD;}
|
||||||
|
"-" {return SUB_OR_NEG;}
|
||||||
|
"*" {return MUL;}
|
||||||
|
"/" {return DIV;}
|
||||||
|
"%" {return REM;}
|
||||||
|
"<" {return LESS_THAN;}
|
||||||
|
"=" {return EQUAL_TO;}
|
||||||
|
":=" {return ASSIGN;}
|
||||||
|
"!" {return NOT;}
|
||||||
|
"&" {return AND;}
|
||||||
|
"|" {return OR;}
|
||||||
|
"." {return DOT;}
|
||||||
|
"reserve" {return RESERVE;}
|
||||||
|
"release" {return RELEASE;}
|
||||||
|
|
||||||
|
|
||||||
|
\"{SCHAR}*\" {printf( "C_STRING: %s (%d)\n", yytext, atoi( yytext ) );}
|
||||||
|
|
||||||
|
{STARTCOM}{COMMENTCHAR}*{ENDCOM} {printf( "COMMENT: %s (%d)\n", yytext, atoi( yytext ) );}
|
||||||
|
|
||||||
|
|
||||||
%%
|
%%
|
||||||
|
4
simpleIntTest.txt
Normal file
4
simpleIntTest.txt
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
45
|
||||||
|
123
|
||||||
|
8392
|
||||||
|
|
46
simpleLiteralTest.a
Normal file
46
simpleLiteralTest.a
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
"this is a string" 721398 'g' '/n' (* should print 3 tokens before this *)
|
||||||
|
'
|
||||||
|
'
|
||||||
|
12893 "this is not a string (*one valid token before this*)
|
||||||
|
(* spacey comment here
|
||||||
|
over multiple lines
|
||||||
|
will it work? *)
|
||||||
|
"
|
||||||
|
'''
|
||||||
|
'\'
|
||||||
|
false
|
||||||
|
(**)
|
||||||
|
'''
|
||||||
|
nullfalse
|
||||||
|
"nulltrue
|
||||||
|
null
|
||||||
|
'7'
|
||||||
|
true
|
||||||
|
'189
|
||||||
|
'\t'
|
||||||
|
'"'
|
||||||
|
'/'
|
||||||
|
'\n'
|
||||||
|
'\''
|
||||||
|
'\t'
|
||||||
|
'\\'
|
||||||
|
'n'
|
||||||
|
'\'
|
||||||
|
'fdsf'
|
||||||
|
(*/jnewjno2893u86^ Lots of random characters /n /t '") *)
|
||||||
|
'
|
||||||
|
'
|
||||||
|
' '
|
||||||
|
'''
|
||||||
|
"STRINGwithnotSPaces"
|
||||||
|
' '
|
||||||
|
'\ '
|
||||||
|
"J"
|
||||||
|
""
|
||||||
|
" "
|
||||||
|
\"\"
|
||||||
|
"{SCHAR}"
|
||||||
|
"SCHAR"
|
||||||
|
"[SCHAR]"
|
||||||
|
"FINAL: I'd think this is a legal \"string\" that contains \n \t several escaped characters, isn't it?"
|
||||||
|
"I'd think this is a legal \"string\" that contains several \\n \t escaped characters, isn't it?"
|
23
tests/test_operators.alpha
Normal file
23
tests/test_operators.alpha
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
+
|
||||||
|
-
|
||||||
|
*
|
||||||
|
/
|
||||||
|
\
|
||||||
|
%
|
||||||
|
<
|
||||||
|
>
|
||||||
|
=
|
||||||
|
:=
|
||||||
|
=:
|
||||||
|
:
|
||||||
|
=
|
||||||
|
!
|
||||||
|
&
|
||||||
|
|
|
||||||
|
.
|
||||||
|
relEASE
|
||||||
|
release
|
||||||
|
RELEASE
|
||||||
|
reserve
|
||||||
|
RESERVE
|
||||||
|
reSERVe
|
Reference in New Issue
Block a user