1
1
mirror of https://github.com/anoma/juvix.git synced 2024-12-14 08:27:03 +03:00
juvix/app/Main.hs
2022-01-18 17:29:04 +01:00

73 lines
1.8 KiB
Haskell

{-# LANGUAGE ApplicativeDo #-}
module Main (main) where
import MiniJuvix.Utils.Prelude
import qualified MiniJuvix.Syntax.Concrete.Parser as M
import qualified MiniJuvix.Syntax.Concrete.Scoped.Scoper as M
import Options.Applicative
import Options.Applicative.Help.Pretty
data Command =
Scope ScopeOptions
| Parse ParseOptions
data ScopeOptions = ScopeOptions {
_rootDir :: FilePath
, _inputFile :: FilePath
}
data ParseOptions = ParseOptions
parseScope :: Parser ScopeOptions
parseScope = do
_rootDir <- strOption
(long "rootDir"
<> short 'd'
<> metavar "DIR"
<> value "."
<> showDefault
<> help "Root directory")
_inputFile <- argument str
(metavar "MINIJUVIX_FILE"
<> help "Path to a .mjuvix file"
)
pure ScopeOptions {..}
parseParse :: Parser ParseOptions
parseParse = pure ParseOptions
descr :: ParserInfo Command
descr = info (parseCommand <**> helper)
(fullDesc
<> progDesc "The MiniJuvix compiler."
<> headerDoc (Just $ dullblue $ bold $ underline "MiniJuvix help")
<> footerDoc (Just foot)
)
where
foot :: Doc
foot = bold "maintainers: " <> "jan@heliax.dev; jonathan@heliax.dev"
parseCommand :: Parser Command
parseCommand = subparser (
command "parse" (info (Parse <$> parseParse) (progDesc "Parse some .mjuvix files"))
<> command "scope" (info (Scope <$> parseScope) (progDesc "Parse and scope some .mjuvix files"))
)
go :: Command -> IO ()
go c = case c of
Scope ScopeOptions {..} -> do
res <- M.runModuleParserIO _inputFile
case res of
Left err -> print err
Right m -> do
print m
putStrLn "\n\n"
s <- M.scopeCheck _inputFile [m]
case s of
Left err -> print err
Right r -> print r
Parse _ -> putStrLn "not implemented"
main :: IO ()
main = execParser descr >>= go