mirror of
https://github.com/GaloisInc/cryptol.git
synced 2024-12-11 07:00:49 +03:00
53 lines
1.4 KiB
Haskell
Executable File
53 lines
1.4 KiB
Haskell
Executable File
#!/usr/bin/env runhaskell
|
|
|
|
-- |
|
|
-- Module : Main
|
|
-- Copyright : (c) 2013-2016 Galois, Inc.
|
|
-- License : BSD3
|
|
-- Maintainer : cryptol@galois.com
|
|
-- Stability : provisional
|
|
-- Portability : portable
|
|
|
|
import Cryptol.Parser as Parser
|
|
import Cryptol.Parser.AST(noPos)
|
|
import Cryptol.Parser.Position(Range(..),start)
|
|
import Cryptol.Parser.NoPat
|
|
import Cryptol.Utils.PP
|
|
import Cryptol.TypeCheck as TC
|
|
|
|
import System.Process(readProcess)
|
|
import System.IO(hPrint,stderr)
|
|
import qualified Data.Map as Map
|
|
import qualified Data.IntMap as IMap
|
|
|
|
main :: IO ()
|
|
main =
|
|
do txt <- getContents
|
|
let mb = parseProgram Layout txt
|
|
case mb of
|
|
Left err -> hPrint stderr $ Parser.ppError err
|
|
Right p ->
|
|
case removePatterns p of
|
|
(p1,[]) ->
|
|
tcProgram p1 inp >>= \res ->
|
|
case res of
|
|
InferOK ws _ prog ->
|
|
do mapM_ (print . TC.ppWarning IMap.empty) ws
|
|
print (pp prog)
|
|
InferFailed ws errs ->
|
|
do mapM_ (print . TC.ppWarning IMap.empty) ws
|
|
mapM_ (print . TC.ppError IMap.empty) errs
|
|
(_,errs) -> hPrint stderr $ vcat $ map pp errs
|
|
|
|
where
|
|
inp = InferInput { inpRange = Range start start ""
|
|
, inpVars = Map.empty
|
|
, inpTSyns = Map.empty
|
|
, inpNameSeeds = nameSeeds
|
|
}
|
|
|
|
|
|
|
|
|
|
|