Safe Haskell | None |
---|---|
Language | Haskell2010 |
This module deals with finding imported modules and loading their interface files.
- data MainInterface
- mergeInterface :: Interface -> TCM ()
- addImportedThings :: Signature -> BuiltinThings PrimFun -> Set String -> Set String -> PatternSynDefns -> DisplayForms -> TCM ()
- scopeCheckImport :: ModuleName -> TCM (ModuleName, Map ModuleName Scope)
- data MaybeWarnings' a
- = NoWarnings
- | SomeWarnings a
- type MaybeWarnings = MaybeWarnings' [TCWarning]
- applyFlagsToMaybeWarnings :: IgnoreFlags -> MaybeWarnings -> TCM MaybeWarnings
- hasWarnings :: MaybeWarnings -> Bool
- alreadyVisited :: TopLevelModuleName -> TCM (Interface, MaybeWarnings) -> TCM (Interface, MaybeWarnings)
- typeCheckMain :: AbsolutePath -> TCM (Interface, MaybeWarnings)
- getInterface :: ModuleName -> TCM Interface
- getInterface_ :: TopLevelModuleName -> TCM Interface
- getInterface' :: TopLevelModuleName -> MainInterface -> TCM (Interface, MaybeWarnings)
- isCached :: TopLevelModuleName -> AbsolutePath -> MaybeT TCM Interface
- getStoredInterface :: TopLevelModuleName -> AbsolutePath -> Bool -> TCM (Bool, (Interface, MaybeWarnings))
- typeCheck :: TopLevelModuleName -> AbsolutePath -> Bool -> TCM (Bool, (Interface, MaybeWarnings))
- chaseMsg :: String -> TopLevelModuleName -> Maybe String -> TCM ()
- highlightFromInterface :: Interface -> AbsolutePath -> TCM ()
- readInterface :: FilePath -> TCM (Maybe Interface)
- writeInterface :: FilePath -> Interface -> TCM ()
- removePrivates :: ScopeInfo -> ScopeInfo
- createInterface :: AbsolutePath -> TopLevelModuleName -> Bool -> TCM (Interface, MaybeWarnings)
- data WhichWarnings
- classifyWarning :: Warning -> WhichWarnings
- classifyWarnings :: [TCWarning] -> ([TCWarning], [TCWarning])
- getAllWarnings' :: WhichWarnings -> IgnoreFlags -> TCM [TCWarning]
- getAllWarnings :: WhichWarnings -> IgnoreFlags -> TCM MaybeWarnings
- constructIScope :: Interface -> Interface
- buildInterface :: AbsolutePath -> TopLevelInfo -> HighlightingInfo -> Set String -> Set String -> [OptionsPragma] -> TCM Interface
- getInterfaceFileHashes :: FilePath -> TCM (Maybe (Hash, Hash))
- moduleHash :: ModuleName -> TCM Hash
- isNewerThan :: FilePath -> FilePath -> IO Bool
Documentation
data MainInterface Source #
Are we loading the interface for the user-loaded file or for an import?
MainInterface | Interface for main file. |
NotMainInterface | Interface for imported file. |
mergeInterface :: Interface -> TCM () Source #
Merge an interface into the current proof state.
addImportedThings :: Signature -> BuiltinThings PrimFun -> Set String -> Set String -> PatternSynDefns -> DisplayForms -> TCM () Source #
scopeCheckImport :: ModuleName -> TCM (ModuleName, Map ModuleName Scope) Source #
Scope checks the given module. A proper version of the module name (with correct definition sites) is returned.
data MaybeWarnings' a Source #
type MaybeWarnings = MaybeWarnings' [TCWarning] Source #
hasWarnings :: MaybeWarnings -> Bool Source #
alreadyVisited :: TopLevelModuleName -> TCM (Interface, MaybeWarnings) -> TCM (Interface, MaybeWarnings) Source #
If the module has already been visited (without warnings), then its interface is returned directly. Otherwise the computation is used to find the interface and the computed interface is stored for potential later use.
typeCheckMain :: AbsolutePath -> TCM (Interface, MaybeWarnings) Source #
Type checks the main file of the interaction. This could be the file loaded in the interacting editor (emacs), or the file passed on the command line.
First, the primitive modules are imported.
Then, getInterface'
is called to do the main work.
getInterface :: ModuleName -> TCM Interface Source #
Tries to return the interface associated to the given (imported) module. The time stamp of the relevant interface file is also returned. Calls itself recursively for the imports of the given module. May type check the module. An error is raised if a warning is encountered.
Do not use this for the main file, use typeCheckMain
instead.
getInterface_ :: TopLevelModuleName -> TCM Interface Source #
See getInterface
.
:: TopLevelModuleName | |
-> MainInterface | If type checking is necessary,
should all state changes inflicted by |
-> TCM (Interface, MaybeWarnings) |
A more precise variant of getInterface
. If warnings are
encountered then they are returned instead of being turned into
errors.
:: TopLevelModuleName | Module name of file we process. |
-> AbsolutePath | File we process. |
-> MaybeT TCM Interface |
Check whether interface file exists and is in cache in the correct version (as testified by the interface file hash).
:: TopLevelModuleName | Module name of file we process. |
-> AbsolutePath | File we process. |
-> Bool | If type checking is necessary,
should all state changes inflicted by |
-> TCM (Bool, (Interface, MaybeWarnings)) |
|
Try to get the interface from interface file or cache.
:: TopLevelModuleName | Module name of file we process. |
-> AbsolutePath | File we process. |
-> Bool | If type checking is necessary,
should all state changes inflicted by |
-> TCM (Bool, (Interface, MaybeWarnings)) |
|
Run the type checker on a file and create an interface.
Mostly, this function calls createInterface
.
But if it is not the main module we check,
we do it in a fresh state, suitably initialize,
in order to forget some state changes after successful type checking.
:: String | The prefix, like |
-> TopLevelModuleName | The module name. |
-> Maybe String | Optionally: the file name. |
-> TCM () |
highlightFromInterface Source #
:: Interface | |
-> AbsolutePath | The corresponding file. |
-> TCM () |
Print the highlighting information contained in the given interface.
writeInterface :: FilePath -> Interface -> TCM () Source #
Writes the given interface to the given file.
removePrivates :: ScopeInfo -> ScopeInfo Source #
:: AbsolutePath | The file to type check. |
-> TopLevelModuleName | The expected module name. |
-> Bool | |
-> TCM (Interface, MaybeWarnings) |
Tries to type check a module and write out its interface. The function only writes out an interface file if it does not encounter any warnings.
If appropriate this function writes out syntax highlighting information.
data WhichWarnings Source #
Collect all warnings that have accumulated in the state. Depending on the argument, we either respect the flags passed in by the user, or not (for instance when deciding if we are writing an interface file or not)
ErrorWarnings | |
AllWarnings | order of constructors important for derived Ord instance |
getAllWarnings' :: WhichWarnings -> IgnoreFlags -> TCM [TCWarning] Source #
constructIScope :: Interface -> Interface Source #
:: AbsolutePath | |
-> TopLevelInfo |
|
-> HighlightingInfo | Syntax highlighting info for the module. |
-> Set String | MAlonzo: Haskell modules imported in imported modules (transitively). |
-> Set String | UHC backend: Haskell modules imported in imported modules (transitively). |
-> [OptionsPragma] | Options set in |
-> TCM Interface |
Builds an interface for the current module, which should already have been successfully type checked.
getInterfaceFileHashes :: FilePath -> TCM (Maybe (Hash, Hash)) Source #
Returns (iSourceHash, iFullHash)
moduleHash :: ModuleName -> TCM Hash Source #