Copyright | (c) 2013-2016 Galois Inc. |
---|---|
License | BSD3 |
Maintainer | cryptol@galois.com |
Stability | provisional |
Portability | portable |
Safe Haskell | None |
Language | Haskell2010 |
Synopsis
- data ImportSource
- importedModule :: ImportSource -> ModName
- data ModuleError
- = ModuleNotFound ModName [FilePath]
- | CantFindFile FilePath
- | BadUtf8 ModulePath UnicodeException
- | OtherIOError FilePath IOException
- | ModuleParseError ModulePath ParseError
- | RecursiveModules [ImportSource]
- | RenamerErrors ImportSource [RenamerError]
- | NoPatErrors ImportSource [Error]
- | NoIncludeErrors ImportSource [IncludeError]
- | TypeCheckingFailed ImportSource NameMap [(Range, Error)]
- | OtherFailure String
- | ModuleNameMismatch ModName (Located ModName)
- | DuplicateModuleName ModName FilePath FilePath
- | ImportedParamModule ModName
- | FailedToParameterizeModDefs ModName [Name]
- | NotAParameterizedModule ModName
- | ErrorInFile ModulePath ModuleError
- moduleNotFound :: ModName -> [FilePath] -> ModuleM a
- cantFindFile :: FilePath -> ModuleM a
- badUtf8 :: ModulePath -> UnicodeException -> ModuleM a
- otherIOError :: FilePath -> IOException -> ModuleM a
- moduleParseError :: ModulePath -> ParseError -> ModuleM a
- recursiveModules :: [ImportSource] -> ModuleM a
- renamerErrors :: [RenamerError] -> ModuleM a
- noPatErrors :: [Error] -> ModuleM a
- noIncludeErrors :: [IncludeError] -> ModuleM a
- typeCheckingFailed :: NameMap -> [(Range, Error)] -> ModuleM a
- moduleNameMismatch :: ModName -> Located ModName -> ModuleM a
- duplicateModuleName :: ModName -> FilePath -> FilePath -> ModuleM a
- importParamModule :: ModName -> ModuleM a
- failedToParameterizeModDefs :: ModName -> [Name] -> ModuleM a
- notAParameterizedModule :: ModName -> ModuleM a
- errorInFile :: ModulePath -> ModuleM a -> ModuleM a
- data ModuleWarning
- warn :: [ModuleWarning] -> ModuleM ()
- typeCheckWarnings :: NameMap -> [(Range, Warning)] -> ModuleM ()
- renamerWarnings :: [RenamerWarning] -> ModuleM ()
- data RO m = RO {
- roLoading :: [ImportSource]
- roEvalOpts :: m EvalOpts
- roCallStacks :: Bool
- roFileReader :: FilePath -> m ByteString
- roTCSolver :: Solver
- emptyRO :: ModuleInput m -> RO m
- newtype ModuleT m a = ModuleT {
- unModuleT :: ReaderT (RO m) (StateT ModuleEnv (ExceptionT ModuleError (WriterT [ModuleWarning] m))) a
- data ModuleInput m = ModuleInput {
- minpCallStacks :: Bool
- minpEvalOpts :: m EvalOpts
- minpByteReader :: FilePath -> m ByteString
- minpModuleEnv :: ModuleEnv
- minpTCSolver :: Solver
- runModuleT :: Monad m => ModuleInput m -> ModuleT m a -> m (Either ModuleError (a, ModuleEnv), [ModuleWarning])
- type ModuleM = ModuleT IO
- runModuleM :: ModuleInput IO -> ModuleM a -> IO (Either ModuleError (a, ModuleEnv), [ModuleWarning])
- io :: BaseM m IO => IO a -> ModuleT m a
- getByteReader :: Monad m => ModuleT m (FilePath -> m ByteString)
- getCallStacks :: Monad m => ModuleT m Bool
- readBytes :: Monad m => FilePath -> ModuleT m ByteString
- getModuleEnv :: Monad m => ModuleT m ModuleEnv
- getTCSolver :: Monad m => ModuleT m Solver
- setModuleEnv :: Monad m => ModuleEnv -> ModuleT m ()
- modifyModuleEnv :: Monad m => (ModuleEnv -> ModuleEnv) -> ModuleT m ()
- getLoadedMaybe :: ModName -> ModuleM (Maybe LoadedModule)
- isLoaded :: ModName -> ModuleM Bool
- loadingImport :: Located Import -> ModuleM a -> ModuleM a
- loadingModule :: ModName -> ModuleM a -> ModuleM a
- loadingModInstance :: Located ModName -> ModuleM a -> ModuleM a
- interactive :: ModuleM a -> ModuleM a
- loading :: ImportSource -> ModuleM a -> ModuleM a
- getImportSource :: ModuleM ImportSource
- getIface :: ModName -> ModuleM Iface
- getLoaded :: ModName -> ModuleM Module
- getNameSeeds :: ModuleM NameSeeds
- getSupply :: ModuleM Supply
- getMonoBinds :: ModuleM Bool
- setMonoBinds :: Bool -> ModuleM ()
- setNameSeeds :: NameSeeds -> ModuleM ()
- setSupply :: Supply -> ModuleM ()
- unloadModule :: (LoadedModule -> Bool) -> ModuleM ()
- loadedModule :: ModulePath -> Fingerprint -> Module -> ModuleM ()
- modifyEvalEnv :: (EvalEnv -> Eval EvalEnv) -> ModuleM ()
- getEvalEnv :: ModuleM EvalEnv
- getEvalOptsAction :: ModuleM (IO EvalOpts)
- getEvalOpts :: ModuleM EvalOpts
- getNewtypes :: ModuleM (Map Name Newtype)
- getFocusedModule :: ModuleM (Maybe ModName)
- setFocusedModule :: ModName -> ModuleM ()
- getSearchPath :: ModuleM [FilePath]
- withPrependedSearchPath :: [FilePath] -> ModuleM a -> ModuleM a
- getFocusedEnv :: ModuleM ModContext
- getDynEnv :: ModuleM DynamicEnv
- setDynEnv :: DynamicEnv -> ModuleM ()
- setSolver :: SolverConfig -> ModuleM ()
- getSolverConfig :: ModuleM SolverConfig
- withLogger :: (Logger -> a -> IO b) -> a -> ModuleM b
Documentation
data ImportSource Source #
Instances
importedModule :: ImportSource -> ModName Source #
data ModuleError Source #
ModuleNotFound ModName [FilePath] | Unable to find the module given, tried looking in these paths |
CantFindFile FilePath | Unable to open a file |
BadUtf8 ModulePath UnicodeException | Bad UTF-8 encoding in while decoding this file |
OtherIOError FilePath IOException | Some other IO error occurred while reading this file |
ModuleParseError ModulePath ParseError | Generated this parse error when parsing the file for module m |
RecursiveModules [ImportSource] | Recursive module group discovered |
RenamerErrors ImportSource [RenamerError] | Problems during the renaming phase |
NoPatErrors ImportSource [Error] | Problems during the NoPat phase |
NoIncludeErrors ImportSource [IncludeError] | Problems during the NoInclude phase |
TypeCheckingFailed ImportSource NameMap [(Range, Error)] | Problems during type checking |
OtherFailure String | Problems after type checking, eg. specialization |
ModuleNameMismatch ModName (Located ModName) | Module loaded by 'import' statement has the wrong module name |
DuplicateModuleName ModName FilePath FilePath | Two modules loaded from different files have the same module name |
ImportedParamModule ModName | Attempt to import a parametrized module that was not instantiated. |
FailedToParameterizeModDefs ModName [Name] | Failed to add the module parameters to all definitions in a module. |
NotAParameterizedModule ModName | |
ErrorInFile ModulePath ModuleError | This is just a tag on the error, indicating the file containing it. It is convenient when we had to look for the module, and we'd like to communicate the location of pthe problematic module to the handler. |
Instances
Show ModuleError Source # | |
Defined in Cryptol.ModuleSystem.Monad showsPrec :: Int -> ModuleError -> ShowS # show :: ModuleError -> String # showList :: [ModuleError] -> ShowS # | |
NFData ModuleError Source # | |
Defined in Cryptol.ModuleSystem.Monad rnf :: ModuleError -> () # | |
PP ModuleError Source # | |
Defined in Cryptol.ModuleSystem.Monad |
cantFindFile :: FilePath -> ModuleM a Source #
badUtf8 :: ModulePath -> UnicodeException -> ModuleM a Source #
otherIOError :: FilePath -> IOException -> ModuleM a Source #
moduleParseError :: ModulePath -> ParseError -> ModuleM a Source #
recursiveModules :: [ImportSource] -> ModuleM a Source #
renamerErrors :: [RenamerError] -> ModuleM a Source #
noPatErrors :: [Error] -> ModuleM a Source #
noIncludeErrors :: [IncludeError] -> ModuleM a Source #
importParamModule :: ModName -> ModuleM a Source #
notAParameterizedModule :: ModName -> ModuleM a Source #
errorInFile :: ModulePath -> ModuleM a -> ModuleM a Source #
Run the computation, and if it caused and error, tag the error with the given file.
data ModuleWarning Source #
Instances
warn :: [ModuleWarning] -> ModuleM () Source #
renamerWarnings :: [RenamerWarning] -> ModuleM () Source #
RO | |
|
emptyRO :: ModuleInput m -> RO m Source #
ModuleT | |
|
Instances
MonadT ModuleT Source # | |
Defined in Cryptol.ModuleSystem.Monad | |
Monad m => Monad (ModuleT m) Source # | |
Monad m => Functor (ModuleT m) Source # | |
MonadFail m => MonadFail (ModuleT m) Source # | |
Defined in Cryptol.ModuleSystem.Monad | |
Monad m => Applicative (ModuleT m) Source # | |
MonadIO m => MonadIO (ModuleT m) Source # | |
Defined in Cryptol.ModuleSystem.Monad | |
Monad m => FreshM (ModuleT m) Source # | |
Defined in Cryptol.ModuleSystem.Monad |
data ModuleInput m Source #
ModuleInput | |
|
runModuleT :: Monad m => ModuleInput m -> ModuleT m a -> m (Either ModuleError (a, ModuleEnv), [ModuleWarning]) Source #
runModuleM :: ModuleInput IO -> ModuleM a -> IO (Either ModuleError (a, ModuleEnv), [ModuleWarning]) Source #
getByteReader :: Monad m => ModuleT m (FilePath -> m ByteString) Source #
getLoadedMaybe :: ModName -> ModuleM (Maybe LoadedModule) Source #
interactive :: ModuleM a -> ModuleM a Source #
Push an "interactive" context onto the loading stack. A bit of a hack, as it uses a faked module name
getImportSource :: ModuleM ImportSource Source #
Get the currently focused import source.
setMonoBinds :: Bool -> ModuleM () Source #
setNameSeeds :: NameSeeds -> ModuleM () Source #
unloadModule :: (LoadedModule -> Bool) -> ModuleM () Source #
loadedModule :: ModulePath -> Fingerprint -> Module -> ModuleM () Source #
setFocusedModule :: ModName -> ModuleM () Source #
getSearchPath :: ModuleM [FilePath] Source #
withPrependedSearchPath :: [FilePath] -> ModuleM a -> ModuleM a Source #
Run a ModuleM
action in a context with a prepended search
path. Useful for temporarily looking in other places while
resolving imports, for example.
setDynEnv :: DynamicEnv -> ModuleM () Source #
setSolver :: SolverConfig -> ModuleM () Source #