summaryrefslogtreecommitdiff
path: root/compiler/GHC/Tc/Utils
diff options
context:
space:
mode:
authorRichard Eisenberg <rae@richarde.dev>2020-12-24 15:04:06 -0500
committerMarge Bot <ben+marge-bot@smart-cactus.org>2020-12-25 03:48:37 -0500
commit164887da63eaac4e786921a9d3591d4b796ee39e (patch)
tree1b07e39811e3dd0c587cf5349a0ee06d5d24cbed /compiler/GHC/Tc/Utils
parentadaa6194753f33a705ac57cd8ddb94dc9aff1f54 (diff)
downloadhaskell-164887da63eaac4e786921a9d3591d4b796ee39e.tar.gz
Use mutable update to defer out-of-scope errors
Previously, we let-bound an identifier to use to carry the erroring evidence for an out-of-scope variable. But this failed for levity-polymorphic out-of-scope variables, leading to a panic (#17812). The new plan is to use a mutable update to just write the erroring expression directly where it needs to go. Close #17812. Test case: typecheck/should_compile/T17812
Diffstat (limited to 'compiler/GHC/Tc/Utils')
-rw-r--r--compiler/GHC/Tc/Utils/TcMType.hs23
-rw-r--r--compiler/GHC/Tc/Utils/Zonk.hs12
2 files changed, 23 insertions, 12 deletions
diff --git a/compiler/GHC/Tc/Utils/TcMType.hs b/compiler/GHC/Tc/Utils/TcMType.hs
index 075c14a987..8d14d9201d 100644
--- a/compiler/GHC/Tc/Utils/TcMType.hs
+++ b/compiler/GHC/Tc/Utils/TcMType.hs
@@ -275,16 +275,21 @@ emitWantedEvVars :: CtOrigin -> [TcPredType] -> TcM [EvVar]
emitWantedEvVars orig = mapM (emitWantedEvVar orig)
-- | Emit a new wanted expression hole
-emitNewExprHole :: OccName -- of the hole
- -> Id -- of the evidence
- -> Type -> TcM ()
-emitNewExprHole occ ev_id ty
- = do { loc <- getCtLocM (ExprHoleOrigin occ) (Just TypeLevel)
- ; let hole = Hole { hole_sort = ExprHole ev_id
- , hole_occ = getOccName ev_id
+emitNewExprHole :: OccName -- of the hole
+ -> Type -> TcM HoleExprRef
+emitNewExprHole occ ty
+ = do { u <- newUnique
+ ; ref <- newTcRef (pprPanic "unfilled unbound-variable evidence" (ppr u))
+ ; let her = HER ref ty u
+
+ ; loc <- getCtLocM (ExprHoleOrigin occ) (Just TypeLevel)
+
+ ; let hole = Hole { hole_sort = ExprHole her
+ , hole_occ = occ
, hole_ty = ty
, hole_loc = loc }
- ; emitHole hole }
+ ; emitHole hole
+ ; return her }
newDict :: Class -> [TcType] -> TcM DictId
newDict cls tys
@@ -2139,8 +2144,6 @@ zonkHole :: Hole -> TcM Hole
zonkHole hole@(Hole { hole_ty = ty })
= do { ty' <- zonkTcType ty
; return (hole { hole_ty = ty' }) }
- -- No need to zonk the Id in any ExprHole because we never look at it
- -- until after the final zonk and desugaring
{- Note [zonkCt behaviour]
~~~~~~~~~~~~~~~~~~~~~~~~~~
diff --git a/compiler/GHC/Tc/Utils/Zonk.hs b/compiler/GHC/Tc/Utils/Zonk.hs
index 93a43795dc..acfa24dd10 100644
--- a/compiler/GHC/Tc/Utils/Zonk.hs
+++ b/compiler/GHC/Tc/Utils/Zonk.hs
@@ -1,6 +1,7 @@
{-# LANGUAGE CPP #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE TypeFamilies #-}
+{-# LANGUAGE TypeApplications #-}
{-# OPTIONS_GHC -Wno-incomplete-record-updates #-}
@@ -735,8 +736,15 @@ zonkExpr env (HsVar x (L l id))
= ASSERT2( isNothing (isDataConId_maybe id), ppr id )
return (HsVar x (L l (zonkIdOcc env id)))
-zonkExpr env (HsUnboundVar v occ)
- = return (HsUnboundVar (zonkIdOcc env v) occ)
+zonkExpr env (HsUnboundVar her occ)
+ = do her' <- zonk_her her
+ return (HsUnboundVar her' occ)
+ where
+ zonk_her :: HoleExprRef -> TcM HoleExprRef
+ zonk_her (HER ref ty u)
+ = do updMutVarM ref (zonkEvTerm env)
+ ty' <- zonkTcTypeToTypeX env ty
+ return (HER ref ty' u)
zonkExpr env (HsRecFld _ (Ambiguous v occ))
= return (HsRecFld noExtField (Ambiguous (zonkIdOcc env v) occ))