import Data.Func
import System.CommandLine
import GenPrint
+import Data.Map
from Text import class Text(concat,join), instance Text String
import parse
<<< " --help Show this help\n"
<<< " --version Show the version\n"
<<< " --[no-]lex Lexer output(default: disabled)\n"
- <<< " --[no-]parse Parser output(default: enabled)\n"
+ <<< " --[no-]parse Parser output(default: disabled)\n"
+ <<< " --[no-]sem Semantic analysis output(default: enabled)\n"
= snd $ fclose stdin w
# (contents, stdin, w) = readFileOrStdin stdin args.fp w
= case contents of
# stdin = if (not args.parse) stdin (
stdin <<< "//PARSER\n" <<< toString parseOut <<< "//PARSER\n")
= case sem parseOut of
- (Left e) = snd $ fclose (stdin <<< "SEMERRORS: " <<<
- join "\n" (map toString e)) w
- (Right semOut)
- # stdin = if (not args.sem) stdin (
- stdin <<< "//SEM\n" <<< toString semOut <<< "//SEM\n")
- = snd $ fclose stdin w
+ (Left e) = snd $ fclose (stdin <<< join "\n" (map toString e)) w
+ (Right (semOut, gamma))
+ # stdin = if (not args.sem) stdin (stdin
+ <<< "//SEM G\n" <<< toString gamma <<< "//SEM A\n"
+ <<< "//SEM A\n" <<< toString semOut <<< "//SEM A\n")
+ = snd $ fclose (stdin <<< "\n") w
where
printTokens :: [Token] -> String
printTokens ts = concat $ flatten $ map pt ts