module Language.PureScript (module P, compile) where
import Language.PureScript.Values as P
import Language.PureScript.Types as P
import Language.PureScript.Kinds as P
import Language.PureScript.Declarations as P
import Language.PureScript.Names as P
import Language.PureScript.Parser as P
import Language.PureScript.CodeGen as P
import Language.PureScript.TypeChecker as P
import Language.PureScript.Pretty as P
import Language.PureScript.Sugar as P
import Language.PureScript.Options as P
import Data.List (intercalate)
import Control.Monad (forM_)
compile :: Options -> [Module] -> Either String (String, String, Environment)
compile opts ms = do
desugared <- desugar ms
(_, env) <- runCheck $ forM_ desugared $ \(Module moduleName decls) -> typeCheckAll (ModuleName moduleName) decls
let js = prettyPrintJS . concatMap (flip (moduleToJs opts) env) $ desugared
let exts = intercalate "\n" . map (flip moduleToPs env) $ desugared
return (js, exts, env)