X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;ds=sidebyside;f=lex.dcl;h=f52404780343ecb6605a40735cafff7d71e967e6;hb=74b900cf6db033a51e177f7f85d835dae44217e5;hp=d6c421cf3425d5d78c02fed30c598528e2e9845a;hpb=98144e50ff2ca8e8d89dd1a39d4f2a41c2c6dab6;p=cc1516.git diff --git a/lex.dcl b/lex.dcl index d6c421c..f524047 100644 --- a/lex.dcl +++ b/lex.dcl @@ -1,12 +1,16 @@ definition module lex -import Data.Either +from Data.Either import :: Either +from yard import :: Error +from AST import :: Pos -:: Token +:: Token :== (Pos, TokenValue) +:: TokenValue //Value tokens - = IdentToken [Char] // Identifier - | NumberToken [Char]// Integer + = IdentToken String // Identifier + | NumberToken Int // Integer | CharToken Char // Character literal + | StringToken [Char]// String literal //Keyword tokens | VarToken // var keyword | ReturnToken // return keyword @@ -19,14 +23,17 @@ import Data.Either | IntTypeToken // Int keyword | CharTypeToken // Char keyword | BoolTypeToken // Bool keyword + | LetToken // Let keyword //Two character tokens | DoubleColonToken // :: + | NotEqualToken // != | LesserEqToken // <= | GreaterEqToken // >= | EqualsToken // == | AmpersandsToken // && | PipesToken // || | ArrowToken // -> + | EmptyListToken // [] //One character tokens | BraceOpenToken // ( | BraceCloseToken // ) @@ -47,11 +54,8 @@ import Data.Either | LesserToken // < | BiggerToken // > | ExclamationToken // ! - //Special tokens - | EndOfFileToken // EOF + | BackslashToken // \ -:: LexerOutput :== Either String [Token] - -instance toString LexerOutput +:: LexerOutput :== Either Error [Token] lexer :: [Char] -> LexerOutput