Link
LinkMethod: Static
GenerateRelocations: False
+ GenerateSymbolTable: False
GenerateLinkMap: False
LinkResources: False
ResourceSource:
ReadableABC: False
ReuseUniqueNodes: True
Fusion: False
++ Module
++ Name: System.OS
++ Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Linux-64
++ Compiler
++ NeverMemoryProfile: False
++ NeverTimeProfile: False
++ StrictnessAnalysis: True
++ ListTypes: StrictExportTypes
++ ListAttributes: True
++ Warnings: True
++ Verbose: True
++ ReadableABC: False
++ ReuseUniqueNodes: True
++ Fusion: False
++ Module
++ Name: System.OS
++ Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Linux-64
++ Compiler
++ NeverMemoryProfile: False
++ NeverTimeProfile: False
++ StrictnessAnalysis: True
++ ListTypes: StrictExportTypes
++ ListAttributes: True
++ Warnings: True
++ Verbose: True
++ ReadableABC: False
++ ReuseUniqueNodes: True
++ Fusion: False
Module
Name: Control.Applicative
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Control.Monad
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Either
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Foldable
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Func
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Functor
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.List
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Map
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Maybe
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Monoid
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Set
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Traversable
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Data.Void
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: System.CommandLine
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: System.IO
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: System._Pointer
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Text
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Text.JSON
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
Fusion: False
Module
Name: Text.PPrint
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Independent
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
ReuseUniqueNodes: True
Fusion: False
Module
- Name: System.OS
- Dir: {Application}/lib/iTasks-SDK/Dependencies/Platform/OS-Linux-64
+ Name: StdMaybe
+ Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Independent/Deprecated/StdLib
Compiler
NeverMemoryProfile: False
NeverTimeProfile: False
ReadableABC: False
ReuseUniqueNodes: True
Fusion: False
- Module
- Name: System.OS
- Dir: {Application}/lib/iTasks-SDK/Dependencies/clean-platform/src/libraries/OS-Mac
- Compiler
- NeverMemoryProfile: False
- NeverTimeProfile: False
- StrictnessAnalysis: True
- ListTypes: StrictExportTypes
- ListAttributes: True
- Warnings: True
- Verbose: True
- ReadableABC: False
- ReuseUniqueNodes: True
- Fusion: False
Module
Name: _SystemDynamic
Dir: {Application}/lib/iTasks-SDK/Patches/Dynamics
ReadableABC: False
ReuseUniqueNodes: True
Fusion: False
- Module
- Name: StdMaybe
- Dir: {Application}/lib/iTasks-SDK/Server/lib
- Compiler
- NeverMemoryProfile: False
- NeverTimeProfile: False
- StrictnessAnalysis: True
- ListTypes: StrictExportTypes
- ListAttributes: True
- Warnings: True
- Verbose: True
- ReadableABC: False
- ReuseUniqueNodes: True
- Fusion: False
//first pure makes singleton list from the statement
parseOneLine = liftM pure parseStmt
- parseBBraces :: (Parser Token a) -> Parser Token a
- parseBBraces p = satTok BraceOpenToken *> p <* satTok BraceCloseToken
-
- parseBCBraces :: (Parser Token a) -> Parser Token a
- parseBCBraces p = satTok CBraceOpenToken *> p <* satTok CBraceCloseToken
-
- parseBSqBraces :: (Parser Token a) -> Parser Token a
- parseBSqBraces p = satTok SquareOpenToken *> p <* satTok SquareCloseToken
-
parseFunType :: Parser Token FunType
parseFunType = satTok DoubleColonToken *>
(parseInOutType <|> (liftM (FunType []) parseVoidOrType))
trans1 CharTypeToken CharType <|>
trans1 BoolTypeToken BoolType <|>
(liftM ListType (parseBSqBraces parseType)) <|>
- (liftM2 TupleType
- (satTok BraceOpenToken *> parseType <* satTok CommaToken)
- (parseType <* satTok BraceCloseToken)) <|>
+ (liftM TupleType (parseTuple parseType)) <|>
(liftM IdType parseIdent)
- //TODO hieronder omzetten naar liftm notatie
parseExpr :: Parser Token Expr
parseExpr = //Operators in order of binding strength
parseOpR (trans1 ColonToken BiCons) $
parseBasicExpr :: Parser Token Expr
parseBasicExpr =
- (satTok BraceOpenToken *> parseExpr <* satTok CommaToken
- >>= \e1->parseExpr <* satTok BraceCloseToken
- >>= \e2->pure $ TupleExpr e1 e2) <|>
- (parseFunCall >>= \fc->pure $ FunExpr fc) <|>
+ (liftM TupleExpr (parseTuple parseExpr)) <|>
+ (liftM FunExpr parseFunCall) <|>
parseBBraces parseExpr <|>
trans1 EmptyListToken EmptyListExpr <|>
- trans2 TrueToken (const $ BoolExpr True) <|>
- trans2 FalseToken (const $ BoolExpr False) <|>
+ trans1 TrueToken (BoolExpr True) <|>
+ trans1 FalseToken (BoolExpr False) <|>
trans2 (NumberToken zero) (\(NumberToken i)->IntExpr i) <|>
trans2 (CharToken zero) (\(CharToken c)->CharExpr c) <|>
- (parseOp1 >>= \o->parseExpr >>= \e.pure $ Op1Expr o e) <|>
- (parseVarDef >>= \ve->pure $ VarExpr ve)
+ (liftM2 Op1Expr parseOp1 parseExpr) <|>
+ (liftM VarExpr parseVarDef)
parseFunCall :: Parser Token FunCall
- parseFunCall = parseIdent <* satTok BraceOpenToken
- >>= \i->parseSepList CommaToken parseExpr
- <* satTok BraceCloseToken >>= \es->pure $ FunCall i es
+ parseFunCall = liftM2 FunCall
+ parseIdent (parseBBraces $ parseSepList CommaToken parseExpr)
parseVarDef :: Parser Token VarDef
- parseVarDef = parseIdent
- >>= \i-> many (satTok DotToken *> (
+ parseVarDef = liftM2 VarDef
+ parseIdent
+ (many (satTok DotToken *> (
(parseIdent >>= (\i.if (i == "hd") (pure FieldHd) empty)) <|>
(parseIdent >>= \i.if (i == "tl") (pure FieldTl) empty) <|>
(parseIdent >>= \i.if (i == "fst") (pure FieldFst) empty) <|>
- (parseIdent >>= \i.if (i == "snd") (pure FieldSnd) empty))
- ) >>= \f->pure $ VarDef i f
+ (parseIdent >>= \i.if (i == "snd") (pure FieldSnd) empty))))
parseOp1 :: Parser Token Op1
parseOp1 = trans1 DashToken UnMinus <|>
trans1 ExclamationToken UnNegation
+ parseBBraces :: (Parser Token a) -> Parser Token a
+ parseBBraces p = satTok BraceOpenToken *> p <* satTok BraceCloseToken
+
+ parseBCBraces :: (Parser Token a) -> Parser Token a
+ parseBCBraces p = satTok CBraceOpenToken *> p <* satTok CBraceCloseToken
+
+ parseBSqBraces :: (Parser Token a) -> Parser Token a
+ parseBSqBraces p = satTok SquareOpenToken *> p <* satTok SquareCloseToken
+
+ parseTuple :: (Parser Token a) -> Parser Token (a, a)
+ parseTuple p = satTok BraceOpenToken *>
+ (liftM2 (\a->(\b->(a,b))) (p <* satTok CommaToken) p)
+ <* satTok BraceCloseToken
+
trans2 :: TokenValue (TokenValue -> a) -> Parser Token a
trans2 t f = satTok t >>= \(_, r).pure (f r)
derive gPrint TokenValue
derive gEq TokenValue
satTok :: TokenValue -> Parser Token Token
-satTok t = top >>= \tok=:(pos, tv) -> if (eq t tok) (return tok) (fail <?> (printToString t, pos))
+satTok t = top >>= \tok=:(pos, tv) -> if (eq t tok) (return tok) (fail <?> (printToString tv, pos))
where
eq (IdentToken _) (_, IdentToken _) = True
eq (NumberToken _) (_, NumberToken _) = True
parseSepList :: TokenValue (Parser Token a) -> Parser Token [a]
parseSepList sep p =
- (some (p <* satTok sep) >>= \es->p >>= \e.pure $ reverse [e:es]) <|>
- (p >>= \e->pure [e]) <|> pure []
+ (liftM2 (\es->(\e->reverse [e:es])) (some (p <* satTok sep)) p) <|>
+ (liftM pure p) <|> pure empty
parseIdent :: Parser Token String
parseIdent = trans2 (IdentToken []) (\(IdentToken e).toString e)
print (FunDecl i as t vs ss) =
["\n", i, " (":printersperse "," as] ++
[") :: ":print t] ++
- ["{":printersperse "\n\t" vs] ++
- ["\n":printStatements ss 1] ++ ["}"]
+ ["{\n\t":printersperse "\n\t" vs] ++
+ ["\n":printStatements ss 1] ++ ["}\n"]
printStatements :: [Stmt] Int -> [String]
printStatements [] i = []
print (VarDecl t i e) = print t ++ [" ":i:"=":print e] ++ [";"]
instance print Type where
- print (TupleType t1 t2) = ["(":print t1] ++ [",":print t2] ++ [")"]
+ print (TupleType (t1, t2)) = ["(":print t1] ++ [",":print t2] ++ [")"]
print (ListType t) = ["[":print t] ++ ["]"]
print (IdType s) = print s
print IntType = print "Int"
print (BoolExpr b) = [toString b]
print (FunExpr fc) = print fc
print EmptyListExpr = ["[]"]
- print (TupleExpr e1 e2) = ["(":print e1] ++ [",":print e2] ++ [")"]
+ print (TupleExpr (e1, e2)) = ["(":print e1] ++ [",":print e2] ++ [")"]