X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=spl.icl;h=80049330e52a8259bdf28f2864e94ace7d5438cf;hb=1233630930a7767b46ddc91b83c6463dce84dce0;hp=2a4fb97e0b4cdaf0e6e712e31fad5e233506aaab;hpb=3b2d959ee14ecfd95008dfe536c87b8b1629c1ae;p=cc1516.git diff --git a/spl.icl b/spl.icl index 2a4fb97..8004933 100644 --- a/spl.icl +++ b/spl.icl @@ -51,7 +51,8 @@ Start w <<< " --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 @@ -68,11 +69,16 @@ Start w stdin <<< "//PARSER\n" <<< toString parseOut <<< "//PARSER\n") = case sem parseOut of (Left e) = snd $ fclose (stdin <<< join "\n" (map toString e)) w - (Right (semOut, gamma)) - # stdin = if (not args.sem) stdin ( - stdin <<< "//SEM\n" <<< toString gamma <<< "//SEM\n") - = snd $ fclose stdin w + (Right constraints) + # stdin = if (not args.sem) stdin (stdin + <<< "//SEM G\n" <<< printConstraints constraints <<< "//SEMA\n") + = snd $ fclose (stdin <<< "\n") w where + printConstraints :: Constraints -> String + printConstraints [] = "" + printConstraints [(t1, t2):ts] = concat [ + "(", toString t1, ",", toString t2, ")"] +++ printConstraints ts + printTokens :: [Token] -> String printTokens ts = concat $ flatten $ map pt ts where