Compare commits
No commits in common. "7cbf8aad08cd65eec959db0537b269677fdca548" and "93702071fb7a911fde7ae135555dc915722df7b9" have entirely different histories.
7cbf8aad08
...
93702071fb
@ -4,46 +4,14 @@ import Test.HUnit
|
|||||||
import Parser.Lexer
|
import Parser.Lexer
|
||||||
|
|
||||||
|
|
||||||
emptyTokenList :: [Token]
|
testCommentSomething = TestCase $ assertEqual "scan /*Something*/" [Comment "/*Something*/"] $ alexScanTokens "/*Something*/"
|
||||||
emptyTokenList = []
|
testEmptyComment = TestCase $ assertEqual "scan /*x*/" [Comment "/**/"] $ alexScanTokens "/**/"
|
||||||
testCommentSomething = TestCase $ assertEqual "scan '/*Something*/'" emptyTokenList $ alexScanTokens "/*Something*/"
|
testLineComment = TestCase $ assertEqual "scan // comment" [Comment "// comment"] $ alexScanTokens "// comment"
|
||||||
testEmptyComment = TestCase $ assertEqual "scan '/*x*/'" emptyTokenList $ alexScanTokens "/**/"
|
|
||||||
testLineComment = TestCase $ assertEqual "scan '// comment'" emptyTokenList $ alexScanTokens "// comment"
|
|
||||||
testLineCommentEnds = TestCase $ assertEqual "scan '// com\\n'" emptyTokenList $ alexScanTokens "// com\n"
|
|
||||||
|
|
||||||
testIdentifier = TestCase $ assertEqual "scan 'identifier'" [IDENTIFIER "identifier"] $ alexScanTokens "identifier"
|
|
||||||
testShortIdentifier = TestCase $ assertEqual "scan 'i'" [IDENTIFIER "i"] $ alexScanTokens "i"
|
|
||||||
testIdentifierWithNumber = TestCase $ assertEqual "scan 'i2'" [IDENTIFIER "i2"] $ alexScanTokens "i2"
|
|
||||||
|
|
||||||
testKeywordBreak = TestCase $ assertEqual "scan 'break'" [BREAK] $ alexScanTokens "break"
|
|
||||||
testKeywordInt = TestCase $ assertEqual "scan 'int'" [INT] $ alexScanTokens "int"
|
|
||||||
|
|
||||||
testIntLiteral = TestCase $ assertEqual "scan '234'" [INTEGERLITERAL 234] $ alexScanTokens "234"
|
|
||||||
testIntLiteral2 = TestCase $ assertEqual "scan '54_2'" [INTEGERLITERAL 542] $ alexScanTokens "54_2"
|
|
||||||
|
|
||||||
testCharLiteral = TestCase $ assertEqual "scan ''f''" [CHARLITERAL 'f'] $ alexScanTokens "'f'"
|
|
||||||
|
|
||||||
testBoolLiteralTrue = TestCase $ assertEqual "scan 'true'" [BOOLLITERAL True] $ alexScanTokens "true"
|
|
||||||
testBoolLiteralFalse = TestCase $ assertEqual "scan 'false'" [BOOLLITERAL False] $ alexScanTokens "false"
|
|
||||||
|
|
||||||
testLBrace = TestCase $ assertEqual "scan '('" [LBRACE] $ alexScanTokens "("
|
|
||||||
testAnd = TestCase $ assertEqual "scan '&&'" [AND] $ alexScanTokens "&&"
|
|
||||||
|
|
||||||
tests = TestList [
|
tests = TestList [
|
||||||
TestLabel "TestCommentSomething" testCommentSomething,
|
TestLabel "TestCommentSomething" testCommentSomething,
|
||||||
TestLabel "TestEmptyComment" testEmptyComment,
|
TestLabel "TestEmptyComment" testEmptyComment,
|
||||||
TestLabel "TestLineComment" testLineComment,
|
TestLabel "TestLineComment" testLineComment
|
||||||
TestLabel "TestLineCommentEnds" testLineCommentEnds,
|
|
||||||
TestLabel "TestIdentifier" testIdentifier,
|
|
||||||
TestLabel "TestShortIdentifier" testShortIdentifier,
|
|
||||||
TestLabel "TestIdentifierWithNumber" testIdentifierWithNumber,
|
|
||||||
TestLabel "TestKeywordBreak" testKeywordBreak,
|
|
||||||
TestLabel "TestKeywordInt" testKeywordInt,
|
|
||||||
TestLabel "TestIntLiteral" testIntLiteral,
|
|
||||||
TestLabel "TestIntLiteral2" testIntLiteral2,
|
|
||||||
TestLabel "TestCharLiteral" testCharLiteral,
|
|
||||||
TestLabel "TestBoolLiteralTrue" testBoolLiteralTrue,
|
|
||||||
TestLabel "TestBoolLiteralFalse" testBoolLiteralFalse,
|
|
||||||
TestLabel "TestLBrace" testLBrace,
|
|
||||||
TestLabel "TestAnd" testAnd
|
|
||||||
]
|
]
|
@ -1,28 +0,0 @@
|
|||||||
module TestParser(tests) where
|
|
||||||
|
|
||||||
import Test.HUnit
|
|
||||||
import Parser.Lexer
|
|
||||||
import Parser.JavaParser
|
|
||||||
import Ast
|
|
||||||
|
|
||||||
|
|
||||||
testSingleEmptyClass = TestCase $
|
|
||||||
assertEqual "expect single empty class hello" [Class "Hello" [] []] $
|
|
||||||
parse [CLASS, IDENTIFIER "Hello", LBRACKET, RBRACKET]
|
|
||||||
testTwoEmptyClasses = TestCase $
|
|
||||||
assertEqual "expect two empty classes" [Class "Class1" [] [], Class "Class2" [] []] $
|
|
||||||
parse [CLASS,IDENTIFIER "Class1",LBRACKET,RBRACKET,CLASS,IDENTIFIER "Class2",LBRACKET,RBRACKET]
|
|
||||||
testBooleanField = TestCase $
|
|
||||||
assertEqual "expect class with boolean field" [Class "WithBool" [] [VariableDeclaration "boolean" "value" Nothing]] $
|
|
||||||
parse [CLASS,IDENTIFIER "WithBool",LBRACKET,BOOLEAN,IDENTIFIER "value",SEMICOLON,RBRACKET]
|
|
||||||
testIntField = TestCase $
|
|
||||||
assertEqual "expect class with int field" [Class "WithInt" [] [VariableDeclaration "int" "value" Nothing]] $
|
|
||||||
parse [CLASS,IDENTIFIER "WithInt",LBRACKET,INT,IDENTIFIER "value",SEMICOLON,RBRACKET]
|
|
||||||
|
|
||||||
|
|
||||||
tests = TestList [
|
|
||||||
testSingleEmptyClass,
|
|
||||||
testTwoEmptyClasses,
|
|
||||||
testBooleanField,
|
|
||||||
testIntField
|
|
||||||
]
|
|
@ -3,12 +3,9 @@ module Main where
|
|||||||
import Test.HUnit
|
import Test.HUnit
|
||||||
import TestLexer
|
import TestLexer
|
||||||
import TestByteCodeGenerator
|
import TestByteCodeGenerator
|
||||||
import TestParser
|
|
||||||
|
|
||||||
|
otherTest = TestCase $ assertEqual "math" (4+3) 7
|
||||||
|
|
||||||
tests = TestList [
|
tests = TestList [TestLabel "TestLexer" TestLexer.tests, TestLabel "mathTest" otherTest, TestLabel "bytecodeTest" TestByteCodeGenerator.tests]
|
||||||
TestLabel "TestLexer" TestLexer.tests,
|
|
||||||
TestLabel "TestParser" TestParser.tests,
|
|
||||||
TestLabel "TestByteCodeGenerator" TestByteCodeGenerator.tests]
|
|
||||||
|
|
||||||
main = do runTestTTAndExit Main.tests
|
main = do runTestTTAndExit Main.tests
|
@ -16,15 +16,7 @@ executable compiler
|
|||||||
src/ByteCode,
|
src/ByteCode,
|
||||||
src/ByteCode/ClassFile
|
src/ByteCode/ClassFile
|
||||||
build-tool-depends: alex:alex, happy:happy
|
build-tool-depends: alex:alex, happy:happy
|
||||||
other-modules: Parser.Lexer,
|
other-modules: Ast, Example, Typecheck, ByteCode.ByteUtil, ByteCode.ClassFile, ByteCode.ClassFile.Generator, ByteCode.Constants
|
||||||
Parser.JavaParser
|
|
||||||
Ast,
|
|
||||||
Example,
|
|
||||||
Typecheck,
|
|
||||||
ByteCode.ByteUtil,
|
|
||||||
ByteCode.ClassFile,
|
|
||||||
ByteCode.ClassFile.Generator,
|
|
||||||
ByteCode.Constants
|
|
||||||
|
|
||||||
test-suite tests
|
test-suite tests
|
||||||
type: exitcode-stdio-1.0
|
type: exitcode-stdio-1.0
|
||||||
@ -36,13 +28,4 @@ test-suite tests
|
|||||||
utf8-string,
|
utf8-string,
|
||||||
bytestring
|
bytestring
|
||||||
build-tool-depends: alex:alex, happy:happy
|
build-tool-depends: alex:alex, happy:happy
|
||||||
other-modules: Parser.Lexer,
|
other-modules: TestLexer, TestByteCodeGenerator
|
||||||
Parser.JavaParser,
|
|
||||||
Ast,
|
|
||||||
TestLexer,
|
|
||||||
TestParser,
|
|
||||||
TestByteCodeGenerator,
|
|
||||||
ByteCode.ByteUtil,
|
|
||||||
ByteCode.ClassFile,
|
|
||||||
ByteCode.ClassFile.Generator,
|
|
||||||
ByteCode.Constants
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
module Parser.JavaParser (parse) where
|
module Parser.JavaParser (parse) where
|
||||||
import Ast
|
--import AbsSyn
|
||||||
import Parser.Lexer
|
import Parser.Lexer
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -14,10 +14,10 @@ import Parser.Lexer
|
|||||||
CASE { CASE }
|
CASE { CASE }
|
||||||
CHAR { CHAR }
|
CHAR { CHAR }
|
||||||
CLASS { CLASS}
|
CLASS { CLASS}
|
||||||
IDENTIFIER { IDENTIFIER $$ }
|
IDENTIFIER { IDENTIFIER $$}
|
||||||
INTLITERAL { INTEGERLITERAL $$}
|
INTLITERAL { INTLITERAL $$}
|
||||||
DOT { DOT }
|
DOT { DOT }
|
||||||
MOD { MODULO }
|
MOD { MOD }
|
||||||
TIMESEQUAL { TIMESEQUAL }
|
TIMESEQUAL { TIMESEQUAL }
|
||||||
GREATEREQUAL { GREATEREQUAL }
|
GREATEREQUAL { GREATEREQUAL }
|
||||||
WHILE { WHILE }
|
WHILE { WHILE }
|
||||||
@ -29,29 +29,30 @@ import Parser.Lexer
|
|||||||
THIS { THIS }
|
THIS { THIS }
|
||||||
STATIC { STATIC }
|
STATIC { STATIC }
|
||||||
PROTECTED { PROTECTED }
|
PROTECTED { PROTECTED }
|
||||||
TILDE { BITWISENOT }
|
TILDE { TILDE }
|
||||||
MUL { TIMES }
|
MUL { MUL }
|
||||||
MINUS { MINUS }
|
MINUS { MINUS }
|
||||||
EXCLMARK { NOT }
|
EXCLMARK { EXCLMARK }
|
||||||
IF { IF }
|
IF { IF }
|
||||||
ELSE { ELSE }
|
ELSE { ELSE }
|
||||||
DIVIDEEQUAL { DIVEQUAL }
|
DIVIDEEQUAL { DIVIDEEQUAL }
|
||||||
NEW { NEW }
|
NEW { NEW }
|
||||||
LBRACKET { LBRACKET }
|
LBRACKET { LBRACKET }
|
||||||
JNULL { NULLLITERAL }
|
JNULL { JNULL }
|
||||||
BOOLLITERAL { BOOLLITERAL $$ }
|
BOOLLITERAL { BOOLLITERAL }
|
||||||
DIV { DIV }
|
DIV { DIV }
|
||||||
LOGICALOR { OR }
|
LOGICALOR { LOGICALOR }
|
||||||
NOTEQUAL { NOTEQUAL }
|
NOTEQUAL { NOTEQUAL }
|
||||||
INSTANCEOF { INSTANCEOF }
|
INSTANCEOF { INSTANCEOF }
|
||||||
ANDEQUAL { ANDEQUAL }
|
ANDEQUAL { ANDEQUAL }
|
||||||
ASSIGN { ASSIGN }
|
ASSIGN { ASSIGN }
|
||||||
DECREMENT { DECREMENT }
|
DECREMENT { DECREMENT }
|
||||||
CHARLITERAL { CHARLITERAL $$ }
|
STRINGLITERAL { STRINGLITERAL }
|
||||||
|
CHARLITERAL { CHARLITERAL }
|
||||||
AND { AND }
|
AND { AND }
|
||||||
XOREQUAL { XOREQUAL }
|
XOREQUAL { XOREQUAL }
|
||||||
RETURN { RETURN }
|
RETURN { RETURN }
|
||||||
QUESMARK { QUESTIONMARK }
|
QUESMARK { QUESMARK }
|
||||||
SHIFTLEFTEQUAL { SHIFTLEFTEQUAL }
|
SHIFTLEFTEQUAL { SHIFTLEFTEQUAL }
|
||||||
RBRACKET { RBRACKET }
|
RBRACKET { RBRACKET }
|
||||||
COMMA { COMMA }
|
COMMA { COMMA }
|
||||||
@ -67,7 +68,7 @@ import Parser.Lexer
|
|||||||
INT { INT }
|
INT { INT }
|
||||||
ABSTRACT { ABSTRACT }
|
ABSTRACT { ABSTRACT }
|
||||||
SEMICOLON { SEMICOLON }
|
SEMICOLON { SEMICOLON }
|
||||||
SIGNEDSHIFTRIGHTEQUAL { SHIFTRIGHTEQUAL }
|
SIGNEDSHIFTRIGHTEQUAL { SIGNEDSHIFTRIGHTEQUAL }
|
||||||
UNSIGNEDSHIFTRIGHTEQUAL { UNSIGNEDSHIFTRIGHTEQUAL }
|
UNSIGNEDSHIFTRIGHTEQUAL { UNSIGNEDSHIFTRIGHTEQUAL }
|
||||||
PLUSEQUAL { PLUSEQUAL }
|
PLUSEQUAL { PLUSEQUAL }
|
||||||
OREQUAL { OREQUAL }
|
OREQUAL { OREQUAL }
|
||||||
@ -75,39 +76,31 @@ import Parser.Lexer
|
|||||||
LESS { LESS }
|
LESS { LESS }
|
||||||
%%
|
%%
|
||||||
|
|
||||||
compilationunit : typedeclarations { $1 }
|
compilationunit : typedeclarations { }
|
||||||
|
|
||||||
typedeclarations : typedeclaration { [$1] }
|
typedeclarations : typedeclaration { }
|
||||||
| typedeclarations typedeclaration { $1 ++ [$2] }
|
| typedeclarations typedeclaration { }
|
||||||
|
|
||||||
name : qualifiedname { }
|
name : qualifiedname { }
|
||||||
| simplename { }
|
| simplename { }
|
||||||
|
|
||||||
typedeclaration : classdeclaration { $1 }
|
typedeclaration : classdeclaration { }
|
||||||
|
|
||||||
qualifiedname : name DOT IDENTIFIER { }
|
qualifiedname : name DOT IDENTIFIER { }
|
||||||
|
|
||||||
simplename : IDENTIFIER { }
|
simplename : IDENTIFIER { }
|
||||||
|
|
||||||
classdeclaration : CLASS IDENTIFIER classbody { case $3 of (methods, fields) -> Class $2 methods fields }
|
classdeclaration : CLASS IDENTIFIER classbody { }
|
||||||
-- | modifiers CLASS IDENTIFIER classbody { case $4 of (methods, fields) -> Class $3 methods fields }
|
| modifiers CLASS IDENTIFIER classbody { }
|
||||||
|
|
||||||
classbody : LBRACKET RBRACKET { ([], []) }
|
classbody : LBRACKET RBRACKET { ([], []) }
|
||||||
| LBRACKET classbodydeclarations RBRACKET { $2 }
|
| LBRACKET classbodydeclarations RBRACKET { }
|
||||||
|
|
||||||
modifiers : modifier { }
|
modifiers : modifier { }
|
||||||
| modifiers modifier { }
|
| modifiers modifier { }
|
||||||
|
|
||||||
classbodydeclarations : classbodydeclaration {
|
classbodydeclarations : classbodydeclaration { }
|
||||||
case $1 of
|
| classbodydeclarations classbodydeclaration{ }
|
||||||
MethodDecl method -> ([method], [])
|
|
||||||
FieldDecls fields -> ([], fields)
|
|
||||||
}
|
|
||||||
-- | classbodydeclarations classbodydeclaration {
|
|
||||||
-- case ($1, $2) of
|
|
||||||
-- ((methods, fields), MethodDecl method) -> ((methods ++ [method]), fields)
|
|
||||||
-- ((methods, fields), FieldDecl field) -> (methods, (fields ++ [field]))
|
|
||||||
-- }
|
|
||||||
|
|
||||||
modifier : PUBLIC { }
|
modifier : PUBLIC { }
|
||||||
| PROTECTED { }
|
| PROTECTED { }
|
||||||
@ -117,19 +110,19 @@ modifier : PUBLIC { }
|
|||||||
|
|
||||||
classtype : classorinterfacetype{ }
|
classtype : classorinterfacetype{ }
|
||||||
|
|
||||||
classbodydeclaration : classmemberdeclaration { $1 }
|
classbodydeclaration : classmemberdeclaration { }
|
||||||
-- | constructordeclaration { FieldDecl $ VariableDeclaration "int" "a" Nothing } -- TODO
|
| constructordeclaration { }
|
||||||
|
|
||||||
classorinterfacetype : name{ }
|
classorinterfacetype : name{ }
|
||||||
|
|
||||||
classmemberdeclaration : fielddeclaration { $1 }
|
classmemberdeclaration : fielddeclaration { }
|
||||||
-- | methoddeclaration { }
|
| methoddeclaration { }
|
||||||
|
|
||||||
constructordeclaration : constructordeclarator constructorbody { }
|
constructordeclaration : constructordeclarator constructorbody { }
|
||||||
| modifiers constructordeclarator constructorbody { }
|
| modifiers constructordeclarator constructorbody { }
|
||||||
|
|
||||||
fielddeclaration : type variabledeclarators SEMICOLON { FieldDecls $ map (convertDeclarator $1) $2 }
|
fielddeclaration : type variabledeclarators SEMICOLON { }
|
||||||
-- | modifiers type variabledeclarators SEMICOLON {}
|
| modifiers type variabledeclarators SEMICOLON { }
|
||||||
|
|
||||||
methoddeclaration : methodheader methodbody { }
|
methoddeclaration : methodheader methodbody { }
|
||||||
|
|
||||||
@ -149,11 +142,11 @@ methodheader : type methoddeclarator { }
|
|||||||
| VOID methoddeclarator { }
|
| VOID methoddeclarator { }
|
||||||
| modifiers VOID methoddeclarator { }
|
| modifiers VOID methoddeclarator { }
|
||||||
|
|
||||||
type : primitivetype { $1 }
|
type : primitivetype { }
|
||||||
-- | referencetype { }
|
| referencetype { }
|
||||||
|
|
||||||
variabledeclarators : variabledeclarator { [$1] }
|
variabledeclarators : variabledeclarator { }
|
||||||
-- | variabledeclarators COMMA variabledeclarator { $1 ++ [$3] }
|
| variabledeclarators COMMA variabledeclarator { }
|
||||||
|
|
||||||
methodbody : block { }
|
methodbody : block { }
|
||||||
| SEMICOLON { }
|
| SEMICOLON { }
|
||||||
@ -173,14 +166,14 @@ classtypelist : classtype { }
|
|||||||
methoddeclarator : IDENTIFIER LBRACE RBRACE { }
|
methoddeclarator : IDENTIFIER LBRACE RBRACE { }
|
||||||
| IDENTIFIER LBRACE formalparameterlist RBRACE { }
|
| IDENTIFIER LBRACE formalparameterlist RBRACE { }
|
||||||
|
|
||||||
primitivetype : BOOLEAN { "boolean" }
|
primitivetype : BOOLEAN { }
|
||||||
| numerictype { $1 }
|
| numerictype { }
|
||||||
|
|
||||||
referencetype : classorinterfacetype { }
|
referencetype : classorinterfacetype { }
|
||||||
|
|
||||||
|
|
||||||
variabledeclarator : variabledeclaratorid { Declarator $1 Nothing }
|
variabledeclarator : variabledeclaratorid { }
|
||||||
-- | variabledeclaratorid ASSIGN variableinitializer { Declarator $1 Nothing } -- TODO
|
| variabledeclaratorid ASSIGN variableinitializer { }
|
||||||
|
|
||||||
blockstatement : localvariabledeclarationstatement { }
|
blockstatement : localvariabledeclarationstatement { }
|
||||||
| statement { }
|
| statement { }
|
||||||
@ -190,9 +183,9 @@ formalparameter : type variabledeclaratorid { }
|
|||||||
argumentlist : expression { }
|
argumentlist : expression { }
|
||||||
| argumentlist COMMA expression { }
|
| argumentlist COMMA expression { }
|
||||||
|
|
||||||
numerictype : integraltype { $1 }
|
numerictype : integraltype { }
|
||||||
|
|
||||||
variabledeclaratorid : IDENTIFIER { $1 }
|
variabledeclaratorid : IDENTIFIER { }
|
||||||
|
|
||||||
variableinitializer : expression { }
|
variableinitializer : expression { }
|
||||||
|
|
||||||
@ -206,8 +199,8 @@ statement : statementwithouttrailingsubstatement{ }
|
|||||||
|
|
||||||
expression : assignmentexpression { }
|
expression : assignmentexpression { }
|
||||||
|
|
||||||
integraltype : INT { "int" }
|
integraltype : INT { }
|
||||||
| CHAR { "char" }
|
| CHAR { }
|
||||||
|
|
||||||
localvariabledeclaration : type variabledeclarators { }
|
localvariabledeclaration : type variabledeclarators { }
|
||||||
|
|
||||||
@ -327,6 +320,7 @@ exclusiveorexpression : andexpression { }
|
|||||||
literal : INTLITERAL { }
|
literal : INTLITERAL { }
|
||||||
| BOOLLITERAL { }
|
| BOOLLITERAL { }
|
||||||
| CHARLITERAL { }
|
| CHARLITERAL { }
|
||||||
|
| STRINGLITERAL { }
|
||||||
| JNULL { }
|
| JNULL { }
|
||||||
|
|
||||||
castexpression : LBRACE primitivetype RBRACE unaryexpression { }
|
castexpression : LBRACE primitivetype RBRACE unaryexpression { }
|
||||||
@ -360,18 +354,7 @@ multiplicativeexpression : unaryexpression { }
|
|||||||
|
|
||||||
{
|
{
|
||||||
|
|
||||||
data MethodOrFieldDeclaration = MethodDecl MethodDeclaration
|
|
||||||
| FieldDecls [VariableDeclaration]
|
|
||||||
|
|
||||||
data Declarator = Declarator Identifier (Maybe Expression)
|
|
||||||
|
|
||||||
-- convertDeclaratorList :: [DataType] -> MethodOrFieldDeclaration
|
|
||||||
-- convertDeclaratorList = FieldDecls $ map
|
|
||||||
|
|
||||||
convertDeclarator :: DataType -> Declarator -> VariableDeclaration
|
|
||||||
convertDeclarator dataType (Declarator id assigment) = VariableDeclaration dataType id assigment
|
|
||||||
|
|
||||||
parseError :: [Token] -> a
|
parseError :: [Token] -> a
|
||||||
parseError msg = error ("Parse error: " ++ show msg)
|
parseError _ = error "Parse error"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
{
|
{
|
||||||
module Parser.Lexer(Token(..), alexScanTokens) where
|
module Parser.Lexer(Token(..), alexScanTokens) where
|
||||||
import Text.Read
|
|
||||||
}
|
}
|
||||||
|
|
||||||
%wrapper "basic"
|
%wrapper "basic"
|
||||||
@ -8,221 +7,18 @@ import Text.Read
|
|||||||
$digit = 0-9
|
$digit = 0-9
|
||||||
$alpha = [a-zA-Z]
|
$alpha = [a-zA-Z]
|
||||||
$alphanum = [a-zA-Z0-9]
|
$alphanum = [a-zA-Z0-9]
|
||||||
$JavaLetter = [A-Za-z\_\$]
|
|
||||||
$JavaLetterOrDigit = [A-Za-z\_\$0-9]
|
|
||||||
|
|
||||||
tokens :-
|
tokens :-
|
||||||
$white ;
|
$white ;
|
||||||
"/*"(.|\n)*"*/" ;
|
"/*"(.|\n)*"*/" { \s -> Comment s }
|
||||||
"//".* ;
|
"//".* {\s -> Comment s}
|
||||||
-- keywords
|
|
||||||
"abstract" { \_ -> ABSTRACT }
|
|
||||||
"assert" { \_ -> BOOLEAN }
|
|
||||||
"boolean" { \_ -> BOOLEAN}
|
|
||||||
"break" { \_ -> BREAK}
|
|
||||||
"byte" { \_ -> BYTE}
|
|
||||||
"case" { \_ -> CASE}
|
|
||||||
"catch" { \_ -> CATCH}
|
|
||||||
"char" { \_ -> CHAR}
|
|
||||||
"class" { \_ -> CLASS}
|
|
||||||
"const" { \_ -> CONST}
|
|
||||||
"continue" { \_ -> CONTINUE}
|
|
||||||
"default" { \_ -> DEFAULT}
|
|
||||||
"do" { \_ -> DO}
|
|
||||||
"double" { \_ -> DOUBLE}
|
|
||||||
("else"|"ifn't") { \_ -> ELSE}
|
|
||||||
"enum" { \_ -> ENUM}
|
|
||||||
"extends" { \_ -> EXTENDS}
|
|
||||||
"final" { \_ -> FINAL}
|
|
||||||
"finally" { \_ -> FINALLY}
|
|
||||||
"float" { \_ -> FLOAT}
|
|
||||||
"for" { \_ -> FOR}
|
|
||||||
"if" { \_ -> IF}
|
|
||||||
"goto" { \_ -> GOTO}
|
|
||||||
"implements" { \_ -> IMPLEMENTS}
|
|
||||||
"import" { \_ -> IMPORT}
|
|
||||||
"instanceof" { \_ -> INSTANCEOF}
|
|
||||||
"int" { \_ -> INT}
|
|
||||||
"long" { \_ -> LONG}
|
|
||||||
"native" { \_ -> NATIVE}
|
|
||||||
"new" { \_ -> NEW}
|
|
||||||
"package" { \_ -> PACKAGE}
|
|
||||||
"private" { \_ -> PRIVATE}
|
|
||||||
"protected" { \_ -> PROTECTED}
|
|
||||||
"public" { \_ -> PUBLIC}
|
|
||||||
"return" { \_ -> RETURN}
|
|
||||||
"short" { \_ -> SHORT}
|
|
||||||
"static" { \_ -> STATIC}
|
|
||||||
"strictfp" { \_ -> STRICTFP}
|
|
||||||
"super" { \_ -> SUPER}
|
|
||||||
"switch" { \_ -> SWITCH}
|
|
||||||
"synchronized" { \_ -> SYNCHRONIZED}
|
|
||||||
"this" { \_ -> THIS}
|
|
||||||
"throw" { \_ -> THROW}
|
|
||||||
"throws" { \_ -> THROWS}
|
|
||||||
"transient" { \_ -> TRANSIENT}
|
|
||||||
"try" { \_ -> TRY}
|
|
||||||
"void" { \_ -> VOID}
|
|
||||||
"volatile" { \_ -> VOLATILE}
|
|
||||||
"while" { \_ -> WHILE}
|
|
||||||
-- Literals
|
|
||||||
"true" { \_ -> BOOLLITERAL True }
|
|
||||||
"false" { \_ -> BOOLLITERAL False }
|
|
||||||
"null" { \_ -> NULLLITERAL }
|
|
||||||
-- end keywords
|
|
||||||
$JavaLetter$JavaLetterOrDigit* { \s -> IDENTIFIER s }
|
|
||||||
-- Literals
|
|
||||||
[1-9]([0-9\_]*[0-9])* { \s -> case readMaybe $ filter ((/=) '_') s of Just a -> INTEGERLITERAL a; Nothing -> error ("failed to parse INTLITERAL " ++ s) }
|
|
||||||
"'"."'" { \s -> case (s) of _ : c : _ -> CHARLITERAL c; _ -> error ("failed to parse CHARLITERAL " ++ s) }
|
|
||||||
-- separators
|
|
||||||
"(" { \_ -> LBRACE }
|
|
||||||
")" { \_ -> RBRACE }
|
|
||||||
"{" { \_ -> LBRACKET }
|
|
||||||
"}" { \_ -> RBRACKET }
|
|
||||||
";" { \_ -> SEMICOLON }
|
|
||||||
"," { \_ -> COMMA}
|
|
||||||
"." { \_ -> DOT }
|
|
||||||
-- operators
|
|
||||||
"=" { \_ -> ASSIGN }
|
|
||||||
"==" { \_ -> EQUAL }
|
|
||||||
"+" { \_ -> PLUS }
|
|
||||||
"+=" { \_ -> PLUSEQUAL }
|
|
||||||
">" { \_ -> GREATER }
|
|
||||||
">=" { \_ -> GREATEREQUAL }
|
|
||||||
"-" { \_ -> MINUS }
|
|
||||||
"-=" { \_ -> MINUSEQUAL }
|
|
||||||
"<" { \_ -> LESS }
|
|
||||||
"<=" { \_ -> LESSEQUAL }
|
|
||||||
"*" { \_ -> TIMES }
|
|
||||||
"*=" { \_ -> TIMESEQUAL }
|
|
||||||
"!" { \_ -> NOT }
|
|
||||||
"!=" { \_ -> NOTEQUAL }
|
|
||||||
"/" { \_ -> DIV }
|
|
||||||
"/=" { \_ -> DIVEQUAL }
|
|
||||||
"~" { \_ -> BITWISENOT }
|
|
||||||
"&&" { \_ -> AND }
|
|
||||||
"&" { \_ -> BITWISEAND }
|
|
||||||
"&=" { \_ -> ANDEQUAL }
|
|
||||||
"?" { \_ -> QUESTIONMARK }
|
|
||||||
"||" { \_ -> OR }
|
|
||||||
"|" { \_ -> BITWISEOR }
|
|
||||||
"|=" { \_ -> OREQUAL }
|
|
||||||
":" { \_ -> COLON }
|
|
||||||
"++" { \_ -> INCREMENT }
|
|
||||||
"^" { \_ -> XOR }
|
|
||||||
"^=" { \_ -> XOREQUAL }
|
|
||||||
"--" { \_ -> DECREMENT }
|
|
||||||
"%" { \_ -> MODULO }
|
|
||||||
"%=" { \_ -> MODULOEQUAL }
|
|
||||||
"<<" { \_ -> SHIFTLEFT }
|
|
||||||
"<<=" { \_ -> SHIFTLEFTEQUAL }
|
|
||||||
">>" { \_ -> SHIFTRIGHT }
|
|
||||||
">>=" { \_ -> SHIFTRIGHTEQUAL }
|
|
||||||
">>>" { \_ -> UNSIGNEDSHIFTRIGHT }
|
|
||||||
">>>=" { \_ -> UNSIGNEDSHIFTRIGHTEQUAL }
|
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
data Token
|
data Token
|
||||||
= ABSTRACT
|
= Comment String
|
||||||
| ASSERT
|
| Different
|
||||||
| BOOLEAN
|
|
||||||
| BREAK
|
|
||||||
| BYTE
|
|
||||||
| CASE
|
|
||||||
| CATCH
|
|
||||||
| CHAR
|
|
||||||
| CLASS
|
|
||||||
| CONST
|
|
||||||
| CONTINUE
|
|
||||||
| DEFAULT
|
|
||||||
| DO
|
|
||||||
| DOUBLE
|
|
||||||
| ELSE
|
|
||||||
| ENUM
|
|
||||||
| EXTENDS
|
|
||||||
| FINAL
|
|
||||||
| FINALLY
|
|
||||||
| FLOAT
|
|
||||||
| FOR
|
|
||||||
| IF
|
|
||||||
| GOTO
|
|
||||||
| IMPLEMENTS
|
|
||||||
| IMPORT
|
|
||||||
| INSTANCEOF
|
|
||||||
| INT
|
|
||||||
| INTERFACE
|
|
||||||
| LONG
|
|
||||||
| NATIVE
|
|
||||||
| NEW
|
|
||||||
| PACKAGE
|
|
||||||
| PRIVATE
|
|
||||||
| PROTECTED
|
|
||||||
| PUBLIC
|
|
||||||
| RETURN
|
|
||||||
| SHORT
|
|
||||||
| STATIC
|
|
||||||
| STRICTFP
|
|
||||||
| SUPER
|
|
||||||
| SWITCH
|
|
||||||
| SYNCHRONIZED
|
|
||||||
| THIS
|
|
||||||
| THROW
|
|
||||||
| THROWS
|
|
||||||
| TRANSIENT
|
|
||||||
| TRY
|
|
||||||
| VOID
|
|
||||||
| VOLATILE
|
|
||||||
| WHILE
|
|
||||||
| IDENTIFIER String
|
|
||||||
| INTEGERLITERAL Int
|
|
||||||
| CHARLITERAL Char
|
|
||||||
| BOOLLITERAL Bool
|
|
||||||
| NULLLITERAL
|
|
||||||
| LBRACE
|
|
||||||
| RBRACE
|
|
||||||
| LBRACKET
|
|
||||||
| RBRACKET
|
|
||||||
| SEMICOLON
|
|
||||||
| COMMA
|
|
||||||
| DOT
|
|
||||||
| ASSIGN
|
|
||||||
| EQUAL
|
|
||||||
| PLUS
|
|
||||||
| PLUSEQUAL
|
|
||||||
| GREATER
|
|
||||||
| GREATEREQUAL
|
|
||||||
| MINUS
|
|
||||||
| MINUSEQUAL
|
|
||||||
| LESS
|
|
||||||
| LESSEQUAL
|
|
||||||
| TIMES
|
|
||||||
| TIMESEQUAL
|
|
||||||
| NOT
|
|
||||||
| NOTEQUAL
|
|
||||||
| DIV
|
|
||||||
| DIVEQUAL
|
|
||||||
| BITWISENOT
|
|
||||||
| AND
|
|
||||||
| BITWISEAND
|
|
||||||
| ANDEQUAL
|
|
||||||
| QUESTIONMARK
|
|
||||||
| OR
|
|
||||||
| BITWISEOR
|
|
||||||
| OREQUAL
|
|
||||||
| COLON
|
|
||||||
| INCREMENT
|
|
||||||
| XOR
|
|
||||||
| XOREQUAL
|
|
||||||
| DECREMENT
|
|
||||||
| MODULO
|
|
||||||
| MODULOEQUAL
|
|
||||||
| SHIFTLEFT
|
|
||||||
| SHIFTLEFTEQUAL
|
|
||||||
| SHIFTRIGHT
|
|
||||||
| SHIFTRIGHTEQUAL
|
|
||||||
| UNSIGNEDSHIFTRIGHT
|
|
||||||
| UNSIGNEDSHIFTRIGHTEQUAL
|
|
||||||
deriving(Eq,Show)
|
deriving(Eq,Show)
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user