mirror of
https://github.com/anoma/juvix.git
synced 2024-12-15 18:13:56 +03:00
5d85cb44f2
* Closes #2177
42 lines
1.0 KiB
Haskell
42 lines
1.0 KiB
Haskell
module Commands.Eval.Options where
|
|
|
|
import CommonOptions
|
|
import Evaluator qualified as Eval
|
|
import Juvix.Compiler.Core.Pretty.Options qualified as Core
|
|
|
|
data EvalOptions = EvalOptions
|
|
{ _evalInputFile :: AppPath File,
|
|
_evalSymbolName :: Maybe Text
|
|
}
|
|
deriving stock (Data)
|
|
|
|
makeLenses ''EvalOptions
|
|
|
|
instance CanonicalProjection EvalOptions Core.Options where
|
|
project _ =
|
|
Core.defaultOptions
|
|
{ Core._optShowDeBruijnIndices = False
|
|
}
|
|
|
|
instance CanonicalProjection EvalOptions Eval.EvalOptions where
|
|
project c =
|
|
Eval.EvalOptions
|
|
{ _evalInputFile = c ^. evalInputFile,
|
|
_evalNoIO = False,
|
|
_evalNoDisambiguate = False,
|
|
_evalPrintValues = True
|
|
}
|
|
|
|
parseEvalOptions :: Parser EvalOptions
|
|
parseEvalOptions = do
|
|
_evalInputFile <- parseInputJuvixFile
|
|
_evalSymbolName <-
|
|
optional $
|
|
strOption
|
|
( long "symbol-name"
|
|
<> short 's'
|
|
<> help "Evaluate a specific function identifier (default: main)"
|
|
<> metavar "NAME"
|
|
)
|
|
pure EvalOptions {..}
|