2022-01-18 14:25:42 +03:00
|
|
|
{-# LANGUAGE ApplicativeDo #-}
|
2022-03-25 02:52:30 +03:00
|
|
|
|
2022-01-18 14:25:42 +03:00
|
|
|
module Main (main) where
|
|
|
|
|
2022-03-25 02:52:30 +03:00
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
import Commands.Extra
|
|
|
|
import Commands.MicroJuvix
|
|
|
|
import Commands.MiniHaskell
|
|
|
|
import Commands.Termination as T
|
2022-04-05 20:57:21 +03:00
|
|
|
import Control.Exception qualified as IO
|
2022-01-21 11:50:37 +03:00
|
|
|
import Control.Monad.Extra
|
2022-04-07 13:53:05 +03:00
|
|
|
import MiniJuvix.Pipeline
|
2022-03-25 02:52:30 +03:00
|
|
|
import MiniJuvix.Prelude hiding (Doc)
|
2022-04-11 14:08:37 +03:00
|
|
|
import MiniJuvix.Prelude.Pretty hiding (Doc)
|
2022-04-11 14:23:55 +03:00
|
|
|
import MiniJuvix.Syntax.Abstract.Pretty qualified as Abstract
|
2022-04-05 20:57:21 +03:00
|
|
|
import MiniJuvix.Syntax.Abstract.Pretty.Ansi qualified as A
|
|
|
|
import MiniJuvix.Syntax.Concrete.Language qualified as M
|
2022-04-07 13:49:08 +03:00
|
|
|
import MiniJuvix.Syntax.Concrete.Parser qualified as Parser
|
|
|
|
import MiniJuvix.Syntax.Concrete.Scoped.Highlight qualified as Scoper
|
|
|
|
import MiniJuvix.Syntax.Concrete.Scoped.InfoTable qualified as Scoper
|
2022-04-11 14:08:37 +03:00
|
|
|
import MiniJuvix.Syntax.Concrete.Scoped.Pretty qualified as Scoper
|
2022-03-25 02:52:30 +03:00
|
|
|
import MiniJuvix.Syntax.Concrete.Scoped.Pretty.Html
|
2022-04-07 13:49:08 +03:00
|
|
|
import MiniJuvix.Syntax.Concrete.Scoped.Scoper qualified as Scoper
|
2022-04-07 19:10:53 +03:00
|
|
|
import MiniJuvix.Syntax.MicroJuvix.Error qualified as Micro
|
2022-04-11 14:08:37 +03:00
|
|
|
import MiniJuvix.Syntax.MicroJuvix.Pretty qualified as Micro
|
|
|
|
import MiniJuvix.Syntax.MicroJuvix.TypeChecker qualified as MicroTyped
|
|
|
|
import MiniJuvix.Syntax.MiniHaskell.Pretty qualified as MiniHaskell
|
2022-04-05 20:57:21 +03:00
|
|
|
import MiniJuvix.Termination qualified as T
|
|
|
|
import MiniJuvix.Termination.CallGraph qualified as A
|
|
|
|
import MiniJuvix.Translation.AbstractToMicroJuvix qualified as Micro
|
2022-04-11 14:08:37 +03:00
|
|
|
import MiniJuvix.Translation.MicroJuvixToMiniHaskell qualified as MiniHaskell
|
2022-04-07 13:49:08 +03:00
|
|
|
import MiniJuvix.Translation.ScopedToAbstract qualified as Abstract
|
2022-03-25 02:52:30 +03:00
|
|
|
import MiniJuvix.Utils.Version (runDisplayVersion)
|
2022-01-18 14:25:42 +03:00
|
|
|
import Options.Applicative
|
|
|
|
import Options.Applicative.Help.Pretty
|
2022-04-08 12:41:47 +03:00
|
|
|
import System.Console.ANSI qualified as Ansi
|
|
|
|
import System.IO qualified as IO
|
2022-02-05 01:14:06 +03:00
|
|
|
import Text.Show.Pretty hiding (Html)
|
2022-03-25 02:52:30 +03:00
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
2022-01-18 14:25:42 +03:00
|
|
|
|
2022-04-11 14:23:55 +03:00
|
|
|
newtype GlobalOptions = GlobalOptions
|
2022-04-08 17:36:48 +03:00
|
|
|
{ _globalNoColors :: Bool
|
|
|
|
}
|
|
|
|
|
2022-01-21 11:50:37 +03:00
|
|
|
data Command
|
|
|
|
= Scope ScopeOptions
|
2022-01-18 14:25:42 +03:00
|
|
|
| Parse ParseOptions
|
2022-02-05 01:14:06 +03:00
|
|
|
| Html HtmlOptions
|
2022-03-08 14:53:26 +03:00
|
|
|
| Termination TerminationCommand
|
2022-03-15 20:01:28 +03:00
|
|
|
| MiniHaskell MiniHaskellOptions
|
2022-03-30 12:17:31 +03:00
|
|
|
| MicroJuvix MicroJuvixCommand
|
2022-03-25 02:52:30 +03:00
|
|
|
| DisplayVersion
|
2022-04-01 13:32:15 +03:00
|
|
|
| DisplayRoot
|
2022-04-01 01:39:53 +03:00
|
|
|
| Highlight HighlightOptions
|
2022-01-18 14:25:42 +03:00
|
|
|
|
2022-04-08 17:36:48 +03:00
|
|
|
data CLI = CLI
|
|
|
|
{ _cliGlobalOptions :: GlobalOptions,
|
|
|
|
_cliCommand :: Command
|
|
|
|
}
|
|
|
|
|
2022-01-21 11:50:37 +03:00
|
|
|
data ScopeOptions = ScopeOptions
|
2022-04-07 13:53:05 +03:00
|
|
|
{ _scopeInputFiles :: NonEmpty FilePath,
|
2022-02-03 12:24:43 +03:00
|
|
|
_scopeShowIds :: Bool,
|
2022-04-08 17:36:48 +03:00
|
|
|
_scopeInlineImports :: Bool
|
2022-01-18 14:25:42 +03:00
|
|
|
}
|
|
|
|
|
2022-01-21 11:50:37 +03:00
|
|
|
data ParseOptions = ParseOptions
|
|
|
|
{ _parseInputFile :: FilePath,
|
|
|
|
_parseNoPrettyShow :: Bool
|
2022-01-20 14:50:01 +03:00
|
|
|
}
|
|
|
|
|
2022-04-04 19:03:56 +03:00
|
|
|
newtype HighlightOptions = HighlightOptions
|
2022-04-01 01:39:53 +03:00
|
|
|
{ _highlightInputFile :: FilePath
|
|
|
|
}
|
|
|
|
|
2022-02-05 01:14:06 +03:00
|
|
|
data HtmlOptions = HtmlOptions
|
2022-02-05 21:08:03 +03:00
|
|
|
{ _htmlInputFile :: FilePath,
|
2022-02-06 01:15:42 +03:00
|
|
|
_htmlRecursive :: Bool,
|
|
|
|
_htmlTheme :: Theme
|
2022-02-05 01:14:06 +03:00
|
|
|
}
|
|
|
|
|
2022-04-08 19:54:19 +03:00
|
|
|
makeLenses ''GlobalOptions
|
|
|
|
makeLenses ''CLI
|
|
|
|
|
2022-04-08 17:36:48 +03:00
|
|
|
parseGlobalOptions :: Parser GlobalOptions
|
|
|
|
parseGlobalOptions = do
|
|
|
|
_globalNoColors <-
|
|
|
|
switch
|
|
|
|
( long "no-colors"
|
|
|
|
<> help "Disable globally ANSI formatting "
|
|
|
|
)
|
|
|
|
pure GlobalOptions {..}
|
|
|
|
|
|
|
|
parseCLI :: Parser CLI
|
|
|
|
parseCLI = do
|
|
|
|
_cliGlobalOptions <- parseGlobalOptions
|
|
|
|
_cliCommand <- parseCommand
|
|
|
|
pure CLI {..}
|
|
|
|
|
2022-02-05 01:14:06 +03:00
|
|
|
parseHtml :: Parser HtmlOptions
|
|
|
|
parseHtml = do
|
2022-03-02 13:10:11 +03:00
|
|
|
_htmlInputFile <- parseInputFile
|
2022-02-05 21:08:03 +03:00
|
|
|
_htmlRecursive <-
|
|
|
|
switch
|
|
|
|
( long "recursive"
|
|
|
|
<> help "export imported modules recursively"
|
|
|
|
)
|
2022-03-25 02:52:30 +03:00
|
|
|
_htmlTheme <-
|
|
|
|
option
|
|
|
|
(eitherReader parseTheme)
|
2022-02-06 01:15:42 +03:00
|
|
|
( long "theme"
|
|
|
|
<> metavar "THEME"
|
2022-03-25 02:52:30 +03:00
|
|
|
<> value Ayu
|
2022-02-06 01:15:42 +03:00
|
|
|
<> showDefault
|
|
|
|
<> help "selects a theme: ayu (light); nord (dark)"
|
|
|
|
)
|
2022-02-05 01:14:06 +03:00
|
|
|
pure HtmlOptions {..}
|
2022-02-06 01:15:42 +03:00
|
|
|
where
|
2022-03-25 02:52:30 +03:00
|
|
|
parseTheme :: String -> Either String Theme
|
|
|
|
parseTheme s = case s of
|
|
|
|
"nord" -> Right Nord
|
|
|
|
"ayu" -> Right Ayu
|
|
|
|
_ -> Left $ "unrecognised theme: " <> s
|
2022-02-24 13:03:02 +03:00
|
|
|
|
2022-04-01 01:39:53 +03:00
|
|
|
parseHighlight :: Parser HighlightOptions
|
|
|
|
parseHighlight = do
|
|
|
|
_highlightInputFile <- parseInputFile
|
|
|
|
pure HighlightOptions {..}
|
|
|
|
|
2022-03-02 13:10:11 +03:00
|
|
|
parseParse :: Parser ParseOptions
|
|
|
|
parseParse = do
|
|
|
|
_parseInputFile <- parseInputFile
|
2022-01-21 11:50:37 +03:00
|
|
|
_parseNoPrettyShow <-
|
|
|
|
switch
|
|
|
|
( long "no-pretty-show"
|
|
|
|
<> help "Disable formatting of the Haskell AST"
|
|
|
|
)
|
2022-01-20 14:50:01 +03:00
|
|
|
pure ParseOptions {..}
|
|
|
|
|
2022-01-18 14:25:42 +03:00
|
|
|
parseScope :: Parser ScopeOptions
|
|
|
|
parseScope = do
|
2022-02-17 21:28:19 +03:00
|
|
|
_scopeInputFiles <-
|
2022-04-07 10:43:17 +03:00
|
|
|
some1 $
|
2022-03-25 02:52:30 +03:00
|
|
|
argument
|
|
|
|
str
|
|
|
|
( metavar "MINIJUVIX_FILE(s)"
|
|
|
|
<> help "Path to one ore more MiniJuvix files"
|
2022-04-05 21:03:02 +03:00
|
|
|
<> action "file"
|
2022-03-25 02:52:30 +03:00
|
|
|
)
|
2022-01-21 11:50:37 +03:00
|
|
|
_scopeShowIds <-
|
|
|
|
switch
|
|
|
|
( long "show-name-ids"
|
2022-04-07 13:49:08 +03:00
|
|
|
<> help "Show the unique number of each identifier"
|
|
|
|
)
|
|
|
|
_scopeInlineImports <-
|
|
|
|
switch
|
2022-02-03 12:24:43 +03:00
|
|
|
( long "inline-imports"
|
|
|
|
<> help "Show the code of imported modules next to the import statement"
|
|
|
|
)
|
2022-03-23 19:21:44 +03:00
|
|
|
_scopeNoColors <-
|
|
|
|
switch
|
|
|
|
( long "no-colors"
|
2022-03-25 02:52:30 +03:00
|
|
|
<> help "Disable ANSI formatting"
|
2022-03-23 19:21:44 +03:00
|
|
|
)
|
2022-04-07 13:49:08 +03:00
|
|
|
pure ScopeOptions {..}
|
2022-01-18 14:25:42 +03:00
|
|
|
|
2022-03-25 02:52:30 +03:00
|
|
|
parseDisplayVersion :: Parser Command
|
2022-04-07 13:49:08 +03:00
|
|
|
parseDisplayVersion =
|
2022-03-25 02:52:30 +03:00
|
|
|
flag'
|
|
|
|
DisplayVersion
|
|
|
|
(long "version" <> short 'v' <> help "Print the version and exit")
|
|
|
|
|
2022-04-01 13:32:15 +03:00
|
|
|
parseDisplayRoot :: Parser Command
|
|
|
|
parseDisplayRoot =
|
|
|
|
flag'
|
|
|
|
DisplayRoot
|
|
|
|
(long "show-root" <> help "Print the detected root of the project")
|
|
|
|
|
2022-04-08 17:36:48 +03:00
|
|
|
descr :: ParserInfo CLI
|
2022-01-21 11:50:37 +03:00
|
|
|
descr =
|
|
|
|
info
|
2022-04-08 17:36:48 +03:00
|
|
|
(parseCLI <**> helper)
|
2022-01-21 11:50:37 +03:00
|
|
|
( fullDesc
|
2022-01-18 14:25:42 +03:00
|
|
|
<> progDesc "The MiniJuvix compiler."
|
2022-01-20 14:50:01 +03:00
|
|
|
<> headerDoc (Just headDoc)
|
2022-01-18 14:25:42 +03:00
|
|
|
<> footerDoc (Just foot)
|
2022-01-21 11:50:37 +03:00
|
|
|
)
|
2022-01-18 14:25:42 +03:00
|
|
|
where
|
2022-01-21 11:50:37 +03:00
|
|
|
headDoc :: Doc
|
|
|
|
headDoc = dullblue $ bold $ underline "MiniJuvix help"
|
2022-03-25 02:52:30 +03:00
|
|
|
|
2022-01-21 11:50:37 +03:00
|
|
|
foot :: Doc
|
2022-03-25 02:52:30 +03:00
|
|
|
foot = bold "maintainers: " <> "The MiniJuvix Team"
|
2022-01-18 14:25:42 +03:00
|
|
|
|
|
|
|
parseCommand :: Parser Command
|
2022-01-21 11:50:37 +03:00
|
|
|
parseCommand =
|
2022-03-25 02:52:30 +03:00
|
|
|
parseDisplayVersion
|
2022-04-05 20:57:21 +03:00
|
|
|
<|> parseDisplayRoot
|
|
|
|
<|> hsubparser
|
|
|
|
( mconcat
|
|
|
|
[ commandParse,
|
|
|
|
commandScope,
|
|
|
|
commandHtml,
|
|
|
|
commandTermination,
|
|
|
|
commandMicroJuvix,
|
|
|
|
commandMiniHaskell,
|
|
|
|
commandHighlight
|
|
|
|
]
|
2022-04-01 13:32:15 +03:00
|
|
|
)
|
2022-01-20 14:50:01 +03:00
|
|
|
where
|
2022-03-17 20:18:10 +03:00
|
|
|
commandMicroJuvix :: Mod CommandFields Command
|
|
|
|
commandMicroJuvix = command "microjuvix" minfo
|
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
2022-03-30 12:17:31 +03:00
|
|
|
(MicroJuvix <$> parseMicroJuvixCommand)
|
|
|
|
(progDesc "Subcommands related to MicroJuvix")
|
2022-03-17 20:18:10 +03:00
|
|
|
|
2022-03-15 20:01:28 +03:00
|
|
|
commandMiniHaskell :: Mod CommandFields Command
|
|
|
|
commandMiniHaskell = command "minihaskell" minfo
|
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
|
|
|
(MiniHaskell <$> parseMiniHaskell)
|
2022-03-25 02:52:30 +03:00
|
|
|
(progDesc "Translate a MiniJuvix file to MiniHaskell")
|
2022-03-15 20:01:28 +03:00
|
|
|
|
2022-04-01 01:39:53 +03:00
|
|
|
commandHighlight :: Mod CommandFields Command
|
|
|
|
commandHighlight = command "highlight" minfo
|
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
|
|
|
(Highlight <$> parseHighlight)
|
|
|
|
(progDesc "Highlight a MiniJuvix file")
|
|
|
|
|
2022-01-21 11:50:37 +03:00
|
|
|
commandParse :: Mod CommandFields Command
|
|
|
|
commandParse = command "parse" minfo
|
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
|
|
|
(Parse <$> parseParse)
|
2022-03-25 02:52:30 +03:00
|
|
|
(progDesc "Parse a MiniJuvix file")
|
2022-01-21 11:50:37 +03:00
|
|
|
|
2022-02-05 01:14:06 +03:00
|
|
|
commandHtml :: Mod CommandFields Command
|
|
|
|
commandHtml = command "html" minfo
|
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
|
|
|
(Html <$> parseHtml)
|
2022-03-25 02:52:30 +03:00
|
|
|
(progDesc "Generate HTML for a MiniJuvix file")
|
|
|
|
|
2022-01-21 11:50:37 +03:00
|
|
|
commandScope :: Mod CommandFields Command
|
|
|
|
commandScope = command "scope" minfo
|
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
|
|
|
(Scope <$> parseScope)
|
2022-03-25 02:52:30 +03:00
|
|
|
(progDesc "Parse and scope a MiniJuvix file")
|
|
|
|
|
2022-03-08 14:53:26 +03:00
|
|
|
commandTermination :: Mod CommandFields Command
|
|
|
|
commandTermination = command "termination" minfo
|
2022-03-02 13:10:11 +03:00
|
|
|
where
|
|
|
|
minfo :: ParserInfo Command
|
|
|
|
minfo =
|
|
|
|
info
|
2022-03-08 14:53:26 +03:00
|
|
|
(Termination <$> parseTerminationCommand)
|
|
|
|
(progDesc "Subcommands related to termination checking")
|
2022-03-02 13:10:11 +03:00
|
|
|
|
2022-04-08 19:54:19 +03:00
|
|
|
mkScopePrettyOptions :: ScopeOptions -> Scoper.Options
|
2022-02-23 23:22:28 +03:00
|
|
|
mkScopePrettyOptions ScopeOptions {..} =
|
2022-04-08 19:54:19 +03:00
|
|
|
Scoper.defaultOptions
|
|
|
|
{ Scoper._optShowNameId = _scopeShowIds,
|
|
|
|
Scoper._optInlineImports = _scopeInlineImports
|
2022-01-21 11:50:37 +03:00
|
|
|
}
|
2022-01-19 14:49:07 +03:00
|
|
|
|
2022-01-20 14:50:01 +03:00
|
|
|
parseModuleIO :: FilePath -> IO (M.Module 'M.Parsed 'M.ModuleTop)
|
2022-04-05 17:12:13 +03:00
|
|
|
parseModuleIO = fromRightIO id . Parser.runModuleParserIO
|
2022-01-20 14:50:01 +03:00
|
|
|
|
2022-04-06 16:10:29 +03:00
|
|
|
-- parseModuleIO' :: FilePath -> IO Parser.ParserResult
|
|
|
|
-- parseModuleIO' = fromRightIO id . Parser.runModuleParserIO'
|
2022-04-04 16:53:16 +03:00
|
|
|
|
2022-04-01 13:32:15 +03:00
|
|
|
minijuvixYamlFile :: FilePath
|
|
|
|
minijuvixYamlFile = "minijuvix.yaml"
|
|
|
|
|
|
|
|
findRoot :: IO FilePath
|
|
|
|
findRoot = do
|
|
|
|
r <- IO.try go :: IO (Either IO.SomeException FilePath)
|
|
|
|
case r of
|
|
|
|
Left err -> do
|
|
|
|
putStrLn "Something went wrong when figuring out the root of the project."
|
|
|
|
putStrLn (pack (IO.displayException err))
|
2022-04-04 16:53:16 +03:00
|
|
|
cur <- getCurrentDirectory
|
|
|
|
putStrLn ("I will try to use the current directory: " <> pack cur)
|
|
|
|
return cur
|
2022-04-01 13:32:15 +03:00
|
|
|
Right root -> return root
|
|
|
|
where
|
2022-04-05 20:57:21 +03:00
|
|
|
possiblePaths :: FilePath -> [FilePath]
|
|
|
|
possiblePaths start = takeWhile (/= "/") (aux start)
|
|
|
|
where
|
|
|
|
aux f = f : aux (takeDirectory f)
|
|
|
|
go :: IO FilePath
|
|
|
|
go = do
|
|
|
|
c <- getCurrentDirectory
|
|
|
|
l <- findFile (possiblePaths c) minijuvixYamlFile
|
|
|
|
case l of
|
|
|
|
Nothing -> return c
|
|
|
|
Just yaml -> return (takeDirectory yaml)
|
2022-04-01 13:32:15 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
class HasEntryPoint a where
|
|
|
|
getEntryPoint :: FilePath -> a -> EntryPoint
|
|
|
|
|
|
|
|
instance HasEntryPoint ScopeOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . _scopeInputFiles
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint ParseOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _parseInputFile
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint HighlightOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _highlightInputFile
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint HtmlOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _htmlInputFile
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint MicroJuvixOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _mjuvixInputFile
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint MiniHaskellOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _mhaskellInputFile
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint CallsOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _callsInputFile
|
2022-04-07 13:53:05 +03:00
|
|
|
|
2022-04-07 10:43:17 +03:00
|
|
|
instance HasEntryPoint CallGraphOptions where
|
|
|
|
getEntryPoint root = EntryPoint root . pure . _graphInputFile
|
|
|
|
|
2022-04-08 17:36:48 +03:00
|
|
|
runCLI :: CLI -> IO ()
|
2022-04-11 14:08:37 +03:00
|
|
|
runCLI cli = do
|
|
|
|
let useColors = not (cli ^. (cliGlobalOptions . globalNoColors))
|
|
|
|
renderIO' :: forall a. (HasAnsiBackend a, HasTextBackend a) => a -> IO ()
|
|
|
|
renderIO' = renderIO useColors
|
|
|
|
toAnsiText' :: forall a. (HasAnsiBackend a, HasTextBackend a) => a -> Text
|
|
|
|
toAnsiText' = toAnsiText useColors
|
2022-04-01 13:32:15 +03:00
|
|
|
root <- findRoot
|
2022-04-11 14:08:37 +03:00
|
|
|
case cli ^. cliCommand of
|
2022-03-25 02:52:30 +03:00
|
|
|
DisplayVersion -> runDisplayVersion
|
2022-04-01 13:32:15 +03:00
|
|
|
DisplayRoot -> putStrLn (pack root)
|
2022-04-11 14:08:37 +03:00
|
|
|
Scope opts -> do
|
2022-04-07 10:43:17 +03:00
|
|
|
l <- (^. Scoper.resultModules) <$> runIO (upToScoping (getEntryPoint root opts))
|
|
|
|
forM_ l $ \s -> do
|
2022-04-11 14:08:37 +03:00
|
|
|
renderIO' (Scoper.ppOut' (mkScopePrettyOptions opts) s)
|
2022-04-07 10:43:17 +03:00
|
|
|
Highlight o -> do
|
|
|
|
let entry :: EntryPoint
|
|
|
|
entry = getEntryPoint root o
|
|
|
|
res <- runIO (upToScoping entry)
|
|
|
|
let tbl = res ^. Scoper.resultParserTable
|
|
|
|
items = tbl ^. Parser.infoParsedItems
|
2022-04-07 13:49:08 +03:00
|
|
|
names = res ^. (Scoper.resultScoperTable . Scoper.infoNames)
|
|
|
|
putStrLn (Scoper.go items names)
|
2022-03-02 13:10:11 +03:00
|
|
|
Parse ParseOptions {..} -> do
|
|
|
|
m <- parseModuleIO _parseInputFile
|
|
|
|
if _parseNoPrettyShow then print m else pPrint m
|
2022-04-07 10:43:17 +03:00
|
|
|
Html o@HtmlOptions {..} -> do
|
|
|
|
res <- runIO (upToScoping (getEntryPoint root o))
|
|
|
|
let m = head (res ^. Scoper.resultModules)
|
2022-04-11 14:08:37 +03:00
|
|
|
genHtml Scoper.defaultOptions _htmlRecursive _htmlTheme m
|
2022-04-08 17:36:48 +03:00
|
|
|
MicroJuvix (Pretty opts) -> do
|
|
|
|
micro <- head . (^. Micro.resultModules) <$> runIO (upToMicroJuvix (getEntryPoint root opts))
|
2022-04-11 14:08:37 +03:00
|
|
|
renderIO' (Micro.ppOut micro)
|
|
|
|
MicroJuvix (TypeCheck opts) -> do
|
|
|
|
micro <- head . (^. MicroTyped.resultModules) <$> runIO (upToMicroJuvixTyped (getEntryPoint root opts))
|
|
|
|
case MicroTyped.checkModule micro of
|
2022-03-31 16:20:20 +03:00
|
|
|
Right _ -> putStrLn "Well done! It type checks"
|
2022-04-11 14:23:55 +03:00
|
|
|
Left (Micro.TypeCheckerErrors es) ->
|
|
|
|
sequence_
|
|
|
|
( intersperse
|
|
|
|
(putStrLn "")
|
|
|
|
(printErrorAnsi <$> toList es)
|
|
|
|
)
|
|
|
|
>> exitFailure
|
2022-04-07 10:43:17 +03:00
|
|
|
MiniHaskell o -> do
|
2022-04-11 14:08:37 +03:00
|
|
|
minihaskell <- head . (^. MiniHaskell.resultModules) <$> runIO (upToMiniHaskell (getEntryPoint root o))
|
|
|
|
supportsAnsi <- Ansi.hSupportsANSI IO.stdout
|
|
|
|
-- TODO fix #38
|
|
|
|
renderIO (supportsAnsi && useColors) (MiniHaskell.ppOut minihaskell)
|
2022-03-08 14:53:26 +03:00
|
|
|
Termination (Calls opts@CallsOptions {..}) -> do
|
2022-04-07 10:43:17 +03:00
|
|
|
a <- head . (^. Abstract.resultModules) <$> runIO (upToAbstract (getEntryPoint root opts))
|
2022-03-25 02:52:30 +03:00
|
|
|
let callMap0 = T.buildCallMap a
|
2022-03-07 18:32:24 +03:00
|
|
|
callMap = case _callsFunctionNameFilter of
|
|
|
|
Nothing -> callMap0
|
|
|
|
Just f -> T.filterCallMap f callMap0
|
2022-03-08 14:53:26 +03:00
|
|
|
opts' = T.callsPrettyOptions opts
|
2022-03-02 13:10:11 +03:00
|
|
|
A.printPrettyCode opts' callMap
|
|
|
|
putStrLn ""
|
2022-04-07 10:43:17 +03:00
|
|
|
Termination (CallGraph o@CallGraphOptions {..}) -> do
|
|
|
|
a <- head . (^. Abstract.resultModules) <$> runIO (upToAbstract (getEntryPoint root o))
|
2022-03-07 19:14:16 +03:00
|
|
|
let callMap = T.buildCallMap a
|
2022-03-02 13:10:11 +03:00
|
|
|
opts' = A.defaultOptions
|
2022-03-04 01:31:45 +03:00
|
|
|
completeGraph = T.completeCallGraph callMap
|
2022-03-07 19:14:16 +03:00
|
|
|
filteredGraph = maybe completeGraph (`T.unsafeFilterGraph` completeGraph) _graphFunctionNameFilter
|
|
|
|
recBehav = map T.recursiveBehaviour (T.reflexiveEdges filteredGraph)
|
|
|
|
A.printPrettyCode opts' filteredGraph
|
2022-03-02 13:10:11 +03:00
|
|
|
putStrLn ""
|
2022-03-04 04:13:43 +03:00
|
|
|
forM_ recBehav $ \r -> do
|
2022-04-11 14:08:37 +03:00
|
|
|
let n = toAnsiText' (Scoper.ppOut (A._recBehaviourFunction r))
|
|
|
|
renderIO useColors (Abstract.ppOut r)
|
2022-03-04 04:13:43 +03:00
|
|
|
putStrLn ""
|
|
|
|
case T.findOrder r of
|
2022-03-04 11:13:14 +03:00
|
|
|
Nothing -> putStrLn (n <> " Fails the termination checking")
|
2022-03-07 19:14:16 +03:00
|
|
|
Just (T.LexOrder k) -> putStrLn (n <> " Terminates with order " <> show (toList k))
|
2022-03-04 04:13:43 +03:00
|
|
|
putStrLn ""
|
|
|
|
|
2022-01-18 14:25:42 +03:00
|
|
|
main :: IO ()
|
2022-04-08 17:36:48 +03:00
|
|
|
main = execParser descr >>= runCLI
|