Safe Haskell | None |
---|---|
Language | GHC2021 |
Synopsis
- data ModuleGraph
- data ModuleGraphNode
- nodeDependencies :: Bool -> ModuleGraphNode -> [NodeKey]
- emptyMG :: ModuleGraph
- mkModuleGraph :: [ModuleGraphNode] -> ModuleGraph
- extendMG :: ModuleGraph -> [NodeKey] -> ModSummary -> ModuleGraph
- extendMGInst :: ModuleGraph -> UnitId -> InstantiatedUnit -> ModuleGraph
- extendMG' :: ModuleGraph -> ModuleGraphNode -> ModuleGraph
- unionMG :: ModuleGraph -> ModuleGraph -> ModuleGraph
- isTemplateHaskellOrQQNonBoot :: ModSummary -> Bool
- filterToposortToModules :: [SCC ModuleGraphNode] -> [SCC ModSummary]
- mapMG :: (ModSummary -> ModSummary) -> ModuleGraph -> ModuleGraph
- mgModSummaries :: ModuleGraph -> [ModSummary]
- mgModSummaries' :: ModuleGraph -> [ModuleGraphNode]
- mgLookupModule :: ModuleGraph -> Module -> Maybe ModSummary
- showModMsg :: DynFlags -> Bool -> ModuleGraphNode -> SDoc
- moduleGraphNodeModule :: ModuleGraphNode -> Maybe ModuleName
- moduleGraphNodeModSum :: ModuleGraphNode -> Maybe ModSummary
- moduleGraphModulesBelow :: ModuleGraph -> UnitId -> ModuleNameWithIsBoot -> Set ModNodeKeyWithUid
- mgReachable :: HasCallStack => ModuleGraph -> NodeKey -> Maybe [ModuleGraphNode]
- mgQuery :: ModuleGraph -> NodeKey -> NodeKey -> Bool
- moduleGraphNodes :: Bool -> [ModuleGraphNode] -> (Graph SummaryNode, NodeKey -> Maybe SummaryNode)
- type SummaryNode = Node Int ModuleGraphNode
- summaryNodeSummary :: SummaryNode -> ModuleGraphNode
- data NodeKey
- nodeKeyUnitId :: NodeKey -> UnitId
- nodeKeyModName :: NodeKey -> Maybe ModuleName
- type ModNodeKey = ModuleNameWithIsBoot
- mkNodeKey :: ModuleGraphNode -> NodeKey
- msKey :: ModSummary -> ModNodeKeyWithUid
- moduleGraphNodeUnitId :: ModuleGraphNode -> UnitId
- data ModNodeKeyWithUid = ModNodeKeyWithUid {}
Documentation
data ModuleGraph Source #
A 'ModuleGraph
' contains all the nodes from the home package (only). See
'ModuleGraphNode
' for information about the nodes.
Modules need to be compiled. hs-boots need to be typechecked before the associated "real" module so modules with {-# SOURCE #-} imports can be built. Instantiations also need to be typechecked to ensure that the module fits the signature. Substantiation typechecking is roughly comparable to the check that the module and its hs-boot agree.
The graph is not necessarily stored in topologically-sorted order. Use
topSortModuleGraph
and flattenSCC
to achieve this.
data ModuleGraphNode Source #
A 'ModuleGraphNode
' is a node in the 'ModuleGraph
'.
Edges between nodes mark dependencies arising from module imports
and dependencies arising from backpack instantiations.
InstantiationNode UnitId InstantiatedUnit | Instantiation nodes track the instantiation of other units (backpack dependencies) with the holes (signatures) of the current package. |
ModuleNode [NodeKey] ModSummary | There is a module summary node for each module, signature, and boot module being built. |
LinkNode [NodeKey] UnitId | Link nodes are whether are are creating a linked product (ie executable/shared object etc) for a unit. |
Instances
Outputable ModuleGraphNode Source # | |
Defined in GHC.Unit.Module.Graph ppr :: ModuleGraphNode -> SDoc Source # | |
Eq ModuleGraphNode Source # | |
Defined in GHC.Unit.Module.Graph (==) :: ModuleGraphNode -> ModuleGraphNode -> Bool # (/=) :: ModuleGraphNode -> ModuleGraphNode -> Bool # | |
Ord ModuleGraphNode Source # | |
Defined in GHC.Unit.Module.Graph compare :: ModuleGraphNode -> ModuleGraphNode -> Ordering # (<) :: ModuleGraphNode -> ModuleGraphNode -> Bool # (<=) :: ModuleGraphNode -> ModuleGraphNode -> Bool # (>) :: ModuleGraphNode -> ModuleGraphNode -> Bool # (>=) :: ModuleGraphNode -> ModuleGraphNode -> Bool # max :: ModuleGraphNode -> ModuleGraphNode -> ModuleGraphNode # min :: ModuleGraphNode -> ModuleGraphNode -> ModuleGraphNode # |
nodeDependencies :: Bool -> ModuleGraphNode -> [NodeKey] Source #
Collect the immediate dependencies of a ModuleGraphNode, optionally avoiding hs-boot dependencies. If the drop_hs_boot_nodes flag is False, and if this is a .hs and there is an equivalent .hs-boot, add a link from the former to the latter. This has the effect of detecting bogus cases where the .hs-boot depends on the .hs, by introducing a cycle. Additionally, it ensures that we will always process the .hs-boot before the .hs, and so the HomePackageTable will always have the most up to date information.
mkModuleGraph :: [ModuleGraphNode] -> ModuleGraph Source #
extendMG :: ModuleGraph -> [NodeKey] -> ModSummary -> ModuleGraph Source #
Add an ExtendedModSummary to ModuleGraph. Assumes that the new ModSummary is not an element of the ModuleGraph.
extendMGInst :: ModuleGraph -> UnitId -> InstantiatedUnit -> ModuleGraph Source #
extendMG' :: ModuleGraph -> ModuleGraphNode -> ModuleGraph Source #
unionMG :: ModuleGraph -> ModuleGraph -> ModuleGraph Source #
filterToposortToModules :: [SCC ModuleGraphNode] -> [SCC ModSummary] Source #
This function filters out all the instantiation nodes from each SCC of a topological sort. Use this with care, as the resulting "strongly connected components" may not really be strongly connected in a direct way, as instantiations have been removed. It would probably be best to eliminate uses of this function where possible.
mapMG :: (ModSummary -> ModSummary) -> ModuleGraph -> ModuleGraph Source #
Map a function f
over all the ModSummaries
.
To preserve invariants f
can't change the isBoot status.
mgModSummaries :: ModuleGraph -> [ModSummary] Source #
mgModSummaries' :: ModuleGraph -> [ModuleGraphNode] Source #
mgLookupModule :: ModuleGraph -> Module -> Maybe ModSummary Source #
Look up a ModSummary in the ModuleGraph Looks up the non-boot ModSummary Linear in the size of the module graph
showModMsg :: DynFlags -> Bool -> ModuleGraphNode -> SDoc Source #
moduleGraphModulesBelow :: ModuleGraph -> UnitId -> ModuleNameWithIsBoot -> Set ModNodeKeyWithUid Source #
This function returns all the modules belonging to the home-unit that can be reached by following the given dependencies. Additionally, if both the boot module and the non-boot module can be reached, it only returns the non-boot one.
mgReachable :: HasCallStack => ModuleGraph -> NodeKey -> Maybe [ModuleGraphNode] Source #
:: ModuleGraph | g |
-> NodeKey | a |
-> NodeKey | b |
-> Bool |
|
Reachability Query. mgQuery(g, a, b)
asks: Can we reach b
from a
in
graph g
?
INVARIANT: Both a
and b
must be in g
.
moduleGraphNodes :: Bool -> [ModuleGraphNode] -> (Graph SummaryNode, NodeKey -> Maybe SummaryNode) Source #
Turn a list of graph nodes into an efficient queriable graph. The first boolean parameter indicates whether nodes corresponding to hs-boot files should be collapsed into their relevant hs nodes.
type SummaryNode = Node Int ModuleGraphNode Source #
nodeKeyUnitId :: NodeKey -> UnitId Source #
nodeKeyModName :: NodeKey -> Maybe ModuleName Source #
type ModNodeKey = ModuleNameWithIsBoot Source #
mkNodeKey :: ModuleGraphNode -> NodeKey Source #
msKey :: ModSummary -> ModNodeKeyWithUid Source #
data ModNodeKeyWithUid Source #
Instances
Outputable ModNodeKeyWithUid Source # | |
Defined in GHC.Unit.Module.Graph ppr :: ModNodeKeyWithUid -> SDoc Source # | |
Eq ModNodeKeyWithUid Source # | |
Defined in GHC.Unit.Module.Graph (==) :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Bool # (/=) :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Bool # | |
Ord ModNodeKeyWithUid Source # | |
Defined in GHC.Unit.Module.Graph compare :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Ordering # (<) :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Bool # (<=) :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Bool # (>) :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Bool # (>=) :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> Bool # max :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> ModNodeKeyWithUid # min :: ModNodeKeyWithUid -> ModNodeKeyWithUid -> ModNodeKeyWithUid # |