summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Marlow <marlowsd@gmail.com>2012-03-02 11:57:32 +0000
committerSimon Marlow <marlowsd@gmail.com>2012-03-02 11:58:16 +0000
commit0bc6055bdc140b35c563c0fc9a7a1b2ca92494cc (patch)
treef56496ffb7c0d021fb2c4d5d2d939fb3003eab2e
parent085c7fe5d4ea6e7b59f944d46ecfeba3755a315b (diff)
downloadhaskell-0bc6055bdc140b35c563c0fc9a7a1b2ca92494cc.tar.gz
Fix crash caused by allowing duplicate *-modules in the context (#5904)
-rw-r--r--ghc/InteractiveUI.hs15
1 files changed, 13 insertions, 2 deletions
diff --git a/ghc/InteractiveUI.hs b/ghc/InteractiveUI.hs
index 2846bb637e..a6396ec77d 100644
--- a/ghc/InteractiveUI.hs
+++ b/ghc/InteractiveUI.hs
@@ -1317,7 +1317,7 @@ setContextKeepingPackageModules keep_ctx trans_ctx = do
new_rem_ctx <- if keep_ctx then return rem_ctx
else keepPackageImports rem_ctx
setGHCiState st{ remembered_ctx = new_rem_ctx,
- transient_ctx = trans_ctx }
+ transient_ctx = filterSubsumed new_rem_ctx trans_ctx }
setGHCContextFromGHCiState
@@ -1668,7 +1668,10 @@ addII :: InteractiveImport -> GHCi ()
addII iidecl = do
checkAdd iidecl
modifyGHCiState $ \st ->
- st { remembered_ctx = addNotSubsumed iidecl (remembered_ctx st) }
+ st { remembered_ctx = addNotSubsumed iidecl (remembered_ctx st)
+ , transient_ctx = filter (not . (iidecl `iiSubsumes`))
+ (transient_ctx st)
+ }
-- -----------------------------------------------------------------------------
-- Validate a module that we want to add to the context
@@ -1759,8 +1762,16 @@ addNotSubsumed i is
| any (`iiSubsumes` i) is = is
| otherwise = i : filter (not . (i `iiSubsumes`)) is
+-- | @filterSubsumed is js@ returns the elements of @js@ not subsumed
+-- by any of @is@.
+filterSubsumed :: [InteractiveImport] -> [InteractiveImport]
+ -> [InteractiveImport]
+filterSubsumed is js = filter (\j -> not (any (`iiSubsumes` j) is)) js
+
-- | Returns True if the left import subsumes the right one. Doesn't
-- need to be 100% accurate, conservatively returning False is fine.
+-- (EXCEPT: (IIModule m) *must* subsume itself, otherwise a panic in
+-- plusProv will ensue (#5904))
--
-- Note that an IIModule does not necessarily subsume an IIDecl,
-- because e.g. a module might export a name that is only available