-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathLexer.hs
53 lines (46 loc) · 1.68 KB
/
Lexer.hs
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
module Lexer
( identifier
, reservedOp
, allChars
, whiteSpace
, parens
, braces
, brackets
, angles
, natural
, comma
) where
import Text.ParserCombinators.Parsec
import Text.ParserCombinators.Parsec.Language
import qualified Text.ParserCombinators.Parsec.Token as Token
---- Character Definitions
greek = oneOf "αβδεφγηιθκμνοπχρστυξψζΑΒΔΕΦΓΗΙΘΚΛΜΝΟΠΧΡΣΤΥΞΨΖ"
math = oneOf "∧∨⇔↔⇒→⊕⊻⩒¬←∀⋀∃⋁⩒∄⊢⊨⊤⊥∴∵∇∆∫∮≤≥≠±∓ℵℶ𝔠ℕℤℚℝℂ⊂⊆∈∉∅+*^|#@.-"
allChars = alphaNum <|> greek <|> math
---- Lexer Definition
languageDef =
emptyDef { Token.commentStart = "{-"
, Token.commentEnd = "-}"
, Token.commentLine = "--"
, Token.identStart = allChars
, Token.identLetter = allChars
, Token.reservedNames = ["UNL" ,"INT", "CHR", "PRT"]
, Token.reservedOpNames = [":=", "::", "λ"]
, Token.caseSensitive = True
}
-- This saved my life
lexer = Token.makeTokenParser languageDef
identifier, comma :: Parser String
parens, braces :: Parser a -> Parser a
reservedOp :: String -> Parser ()
whiteSpace :: Parser ()
natural :: Parser Integer
identifier = Token.identifier lexer
reservedOp = Token.reservedOp lexer
whiteSpace = Token.whiteSpace lexer
parens = Token.parens lexer
braces = Token.braces lexer
brackets = Token.brackets lexer
angles = Token.angles lexer
natural = Token.natural lexer
comma = Token.comma lexer