{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TupleSections #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -Wno-incomplete-uni-patterns #-}
module GHC.Tc.Gen.Pat
( tcLetPat
, newLetBndr
, LetBndrSpec(..)
, tcCheckPat, tcCheckPat_O, tcInferPat
, tcMatchPats
, addDataConStupidTheta
, isIrrefutableHsPatRnTcM
)
where
import GHC.Prelude
import {-# SOURCE #-} GHC.Tc.Gen.Expr( tcSyntaxOp, tcSyntaxOpGen, tcInferRho )
import GHC.Hs
import GHC.Hs.Syn.Type
import GHC.Rename.Utils
import GHC.Tc.Errors.Types
import GHC.Tc.Gen.Sig( TcPragEnv, lookupPragEnv, addInlinePrags )
import GHC.Tc.Utils.Monad
import GHC.Tc.Utils.Instantiate
import GHC.Types.FieldLabel
import GHC.Types.Id
import GHC.Types.Var
import GHC.Types.Name
import GHC.Types.Name.Reader
import GHC.Core.Multiplicity
import GHC.Tc.Utils.Concrete ( hasFixedRuntimeRep_syntactic )
import GHC.Tc.Utils.Env
import GHC.Tc.Utils.TcMType
import GHC.Tc.Zonk.TcType
import GHC.Core.TyCo.Ppr ( pprTyVars )
import GHC.Tc.Utils.TcType
import GHC.Tc.Utils.Unify
import GHC.Tc.Gen.HsType
import GHC.Builtin.Types
import GHC.Tc.Types.Evidence
import GHC.Tc.Types.Origin
import GHC.Core.TyCon
import GHC.Core.Type
import GHC.Core.Coercion
import GHC.Core.DataCon
import GHC.Core.PatSyn
import GHC.Core.ConLike
import GHC.Builtin.Names
import GHC.Types.Basic hiding (SuccessFlag(..))
import GHC.Driver.DynFlags
import GHC.Types.SrcLoc
import GHC.Types.Var.Set
import GHC.Utils.Misc
import GHC.Utils.Outputable as Outputable
import GHC.Utils.Panic
import qualified GHC.LanguageExtensions as LangExt
import Control.Arrow ( second )
import Control.Monad
import GHC.Data.FastString
import qualified Data.List.NonEmpty as NE
import GHC.Data.List.SetOps ( getNth )
import Language.Haskell.Syntax.Basic (FieldLabelString(..))
import Data.List( partition )
import Data.Maybe (isJust)
import Control.Monad.Trans.Writer.CPS
import Control.Monad.Trans.Class
tcLetPat :: (Name -> Maybe TcId)
-> LetBndrSpec
-> LPat GhcRn -> Scaled ExpSigmaTypeFRR
-> TcM a
-> TcM (LPat GhcTc, a)
tcLetPat :: forall a.
(Name -> Maybe TyCoVar)
-> LetBndrSpec
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM a
-> TcM (LPat GhcTc, a)
tcLetPat Name -> Maybe TyCoVar
sig_fn LetBndrSpec
no_gen LPat (GhcPass 'Renamed)
pat Scaled ExpSigmaTypeFRR
pat_ty TcM a
thing_inside
= do { TcLevel
bind_lvl <- TcM TcLevel
getTcLevel
; let ctxt :: PatCtxt
ctxt = LetPat { pc_lvl :: TcLevel
pc_lvl = TcLevel
bind_lvl
, pc_sig_fn :: Name -> Maybe TyCoVar
pc_sig_fn = Name -> Maybe TyCoVar
sig_fn
, pc_new :: LetBndrSpec
pc_new = LetBndrSpec
no_gen }
penv :: PatEnv
penv = PE { pe_lazy :: Bool
pe_lazy = Bool
True
, pe_ctxt :: PatCtxt
pe_ctxt = PatCtxt
ctxt
, pe_orig :: CtOrigin
pe_orig = CtOrigin
PatOrigin }
; DynFlags
dflags <- IOEnv (Env TcGblEnv TcLclEnv) DynFlags
forall (m :: * -> *). HasDynFlags m => m DynFlags
getDynFlags
; HsWrapper
mult_co_wrap <- DynFlags
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
manyIfLazy DynFlags
dflags LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
pat
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', a
r) <- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM a
thing_inside
; Type
pat_ty' <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (GenLocated SrcSpanAnnA (Pat GhcTc), a)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), a)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> LPat GhcTc -> Type -> LPat GhcTc
mkLHsWrapPat HsWrapper
mult_co_wrap LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat' Type
pat_ty', a
r) }
where
manyIfLazy :: DynFlags
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
manyIfLazy DynFlags
dflags GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
lpat
| Extension -> DynFlags -> Bool
xopt Extension
LangExt.Strict DynFlags
dflags = GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
xstrict GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
lpat
| Bool
otherwise = GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
not_xstrict GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
lpat
where
xstrict :: GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
xstrict p :: GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p@(L SrcSpanAnnA
_ (LazyPat XLazyPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
_)) = NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
LazyPatternReason LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p Scaled ExpSigmaTypeFRR
pat_ty
xstrict (L SrcSpanAnnA
_ (ParPat XParPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
p)) = GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
xstrict LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p
xstrict GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
_ = HsWrapper -> TcM HsWrapper
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return HsWrapper
WpHole
not_xstrict :: GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
not_xstrict (L SrcSpanAnnA
_ (BangPat XBangPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
_)) = HsWrapper -> TcM HsWrapper
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return HsWrapper
WpHole
not_xstrict (L SrcSpanAnnA
_ (VarPat XVarPat (GhcPass 'Renamed)
_ LIdP (GhcPass 'Renamed)
_)) = HsWrapper -> TcM HsWrapper
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return HsWrapper
WpHole
not_xstrict (L SrcSpanAnnA
_ (ParPat XParPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
p)) = GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> TcM HsWrapper
not_xstrict LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p
not_xstrict GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p = NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
LazyPatternReason LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p Scaled ExpSigmaTypeFRR
pat_ty
tcMatchPats :: forall a.
HsMatchContextRn
-> [LPat GhcRn]
-> [ExpPatType]
-> TcM a
-> TcM ([LPat GhcTc], a)
tcMatchPats :: forall a.
HsMatchContextRn
-> [LPat (GhcPass 'Renamed)]
-> [ExpPatType]
-> TcM a
-> TcM ([LPat GhcTc], a)
tcMatchPats HsMatchContextRn
match_ctxt [LPat (GhcPass 'Renamed)]
pats [ExpPatType]
pat_tys TcM a
thing_inside
= Bool -> SDoc -> TcM ([LPat GhcTc], a) -> TcM ([LPat GhcTc], a)
forall a. HasCallStack => Bool -> SDoc -> a -> a
assertPpr ((ExpPatType -> Bool) -> [ExpPatType] -> Int
forall a. (a -> Bool) -> [a] -> Int
count ExpPatType -> Bool
isVisibleExpPatType [ExpPatType]
pat_tys Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
== (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)) -> Bool)
-> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> Int
forall a. (a -> Bool) -> [a] -> Int
count (Pat (GhcPass 'Renamed) -> Bool
forall p. Pat p -> Bool
isVisArgPat (Pat (GhcPass 'Renamed) -> Bool)
-> (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc) [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats)
([GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ [ExpPatType] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [ExpPatType]
pat_tys) (TcM ([LPat GhcTc], a) -> TcM ([LPat GhcTc], a))
-> TcM ([LPat GhcTc], a) -> TcM ([LPat GhcTc], a)
forall a b. (a -> b) -> a -> b
$
do { [ErrCtxt]
err_ctxt <- TcM [ErrCtxt]
getErrCtxt
; let loop :: [LPat GhcRn] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop :: [LPat (GhcPass 'Renamed)] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop [] [ExpPatType]
pat_tys
= Bool -> SDoc -> TcM ([LPat GhcTc], a) -> TcM ([LPat GhcTc], a)
forall a. HasCallStack => Bool -> SDoc -> a -> a
assertPpr (Bool -> Bool
not ((ExpPatType -> Bool) -> [ExpPatType] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any ExpPatType -> Bool
isVisibleExpPatType [ExpPatType]
pat_tys)) ([GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ [ExpPatType] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [ExpPatType]
pat_tys) (TcM ([LPat GhcTc], a) -> TcM ([LPat GhcTc], a))
-> TcM ([LPat GhcTc], a) -> TcM ([LPat GhcTc], a)
forall a b. (a -> b) -> a -> b
$
do { a
res <- [ErrCtxt] -> TcM a -> TcM a
forall a. [ErrCtxt] -> TcM a -> TcM a
setErrCtxt [ErrCtxt]
err_ctxt TcM a
thing_inside
; ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
-> IOEnv
(Env TcGblEnv TcLclEnv) ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([], a
res) }
loop all_pats :: [LPat (GhcPass 'Renamed)]
all_pats@(LPat (GhcPass 'Renamed)
pat : [LPat (GhcPass 'Renamed)]
pats) (ExpForAllPatTy (Bndr TyCoVar
tv ForAllTyFlag
vis) : [ExpPatType]
pat_tys)
| ForAllTyFlag -> Bool
isVisibleForAllTyFlag ForAllTyFlag
vis
= do { (GenLocated SrcSpanAnnA (Pat GhcTc)
_p, ([GenLocated SrcSpanAnnA (Pat GhcTc)]
ps, a
res)) <- TyCoVar -> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_forall_lpat TyCoVar
tv PatEnv
penv LPat (GhcPass 'Renamed)
pat (TcM ([LPat GhcTc], a) -> TcM (LPat GhcTc, ([LPat GhcTc], a)))
-> TcM ([LPat GhcTc], a) -> TcM (LPat GhcTc, ([LPat GhcTc], a))
forall a b. (a -> b) -> a -> b
$
[LPat (GhcPass 'Renamed)] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop [LPat (GhcPass 'Renamed)]
pats [ExpPatType]
pat_tys
; ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
-> IOEnv
(Env TcGblEnv TcLclEnv) ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([GenLocated SrcSpanAnnA (Pat GhcTc)]
ps, a
res) }
| L SrcSpanAnnA
_ (InvisPat XInvisPat (GhcPass 'Renamed)
_ HsTyPat (NoGhcTc (GhcPass 'Renamed))
tp) <- LPat (GhcPass 'Renamed)
pat
, ForAllTyFlag -> Bool
isSpecifiedForAllTyFlag ForAllTyFlag
vis
= do { (Type
_p, ([GenLocated SrcSpanAnnA (Pat GhcTc)]
ps, a
res)) <- HsTyPat (GhcPass 'Renamed)
-> TyCoVar
-> TcM ([LPat GhcTc], a)
-> TcM (Type, ([LPat GhcTc], a))
forall r.
HsTyPat (GhcPass 'Renamed) -> TyCoVar -> TcM r -> TcM (Type, r)
tc_ty_pat HsTyPat (NoGhcTc (GhcPass 'Renamed))
HsTyPat (GhcPass 'Renamed)
tp TyCoVar
tv (TcM ([LPat GhcTc], a) -> TcM (Type, ([LPat GhcTc], a)))
-> TcM ([LPat GhcTc], a) -> TcM (Type, ([LPat GhcTc], a))
forall a b. (a -> b) -> a -> b
$
[LPat (GhcPass 'Renamed)] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop [LPat (GhcPass 'Renamed)]
pats [ExpPatType]
pat_tys
; ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
-> IOEnv
(Env TcGblEnv TcLclEnv) ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([GenLocated SrcSpanAnnA (Pat GhcTc)]
ps, a
res) }
| Bool
otherwise
= [LPat (GhcPass 'Renamed)] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop [LPat (GhcPass 'Renamed)]
all_pats [ExpPatType]
pat_tys
loop (L SrcSpanAnnA
loc (InvisPat XInvisPat (GhcPass 'Renamed)
_ HsTyPat (NoGhcTc (GhcPass 'Renamed))
tp) : [LPat (GhcPass 'Renamed)]
_) [ExpPatType]
_ =
SrcSpan
-> TcRnMessage
-> IOEnv
(Env TcGblEnv TcLclEnv) ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
forall a. SrcSpan -> TcRnMessage -> TcRn a
failAt (SrcSpanAnnA -> SrcSpan
forall a. HasLoc a => a -> SrcSpan
locA SrcSpanAnnA
loc) (HsTyPat (GhcPass 'Renamed) -> TcRnMessage
TcRnInvisPatWithNoForAll HsTyPat (NoGhcTc (GhcPass 'Renamed))
HsTyPat (GhcPass 'Renamed)
tp)
loop (LPat (GhcPass 'Renamed)
pat : [LPat (GhcPass 'Renamed)]
pats) (ExpFunPatTy Scaled ExpSigmaTypeFRR
pat_ty : [ExpPatType]
pat_tys)
= do { (GenLocated SrcSpanAnnA (Pat GhcTc)
p, ([GenLocated SrcSpanAnnA (Pat GhcTc)]
ps, a
res)) <- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv LPat (GhcPass 'Renamed)
pat (TcM ([LPat GhcTc], a) -> TcM (LPat GhcTc, ([LPat GhcTc], a)))
-> TcM ([LPat GhcTc], a) -> TcM (LPat GhcTc, ([LPat GhcTc], a))
forall a b. (a -> b) -> a -> b
$
[LPat (GhcPass 'Renamed)] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop [LPat (GhcPass 'Renamed)]
pats [ExpPatType]
pat_tys
; ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
-> IOEnv
(Env TcGblEnv TcLclEnv) ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (GenLocated SrcSpanAnnA (Pat GhcTc)
p GenLocated SrcSpanAnnA (Pat GhcTc)
-> [GenLocated SrcSpanAnnA (Pat GhcTc)]
-> [GenLocated SrcSpanAnnA (Pat GhcTc)]
forall a. a -> [a] -> [a]
: [GenLocated SrcSpanAnnA (Pat GhcTc)]
ps, a
res) }
loop pats :: [LPat (GhcPass 'Renamed)]
pats@(LPat (GhcPass 'Renamed)
_:[LPat (GhcPass 'Renamed)]
_) [] = String
-> SDoc
-> IOEnv
(Env TcGblEnv TcLclEnv) ([GenLocated SrcSpanAnnA (Pat GhcTc)], a)
forall a. HasCallStack => String -> SDoc -> a
pprPanic String
"tcMatchPats" ([GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats)
; [LPat (GhcPass 'Renamed)] -> [ExpPatType] -> TcM ([LPat GhcTc], a)
loop [LPat (GhcPass 'Renamed)]
pats [ExpPatType]
pat_tys }
where
penv :: PatEnv
penv = PE { pe_lazy :: Bool
pe_lazy = Bool
False, pe_ctxt :: PatCtxt
pe_ctxt = HsMatchContextRn -> PatCtxt
LamPat HsMatchContextRn
match_ctxt, pe_orig :: CtOrigin
pe_orig = CtOrigin
PatOrigin }
tcInferPat :: FixedRuntimeRepContext
-> HsMatchContextRn
-> LPat GhcRn
-> TcM a
-> TcM ((LPat GhcTc, a), TcSigmaTypeFRR)
tcInferPat :: forall a.
FixedRuntimeRepContext
-> HsMatchContextRn
-> LPat (GhcPass 'Renamed)
-> TcM a
-> TcM ((LPat GhcTc, a), Type)
tcInferPat FixedRuntimeRepContext
frr_orig HsMatchContextRn
ctxt LPat (GhcPass 'Renamed)
pat TcM a
thing_inside
= FixedRuntimeRepContext
-> (ExpSigmaTypeFRR -> TcM (LPat GhcTc, a))
-> TcM ((LPat GhcTc, a), Type)
forall a.
FixedRuntimeRepContext
-> (ExpSigmaTypeFRR -> TcM a) -> TcM (a, Type)
tcInferFRR FixedRuntimeRepContext
frr_orig ((ExpSigmaTypeFRR -> TcM (LPat GhcTc, a))
-> TcM ((LPat GhcTc, a), Type))
-> (ExpSigmaTypeFRR -> TcM (LPat GhcTc, a))
-> TcM ((LPat GhcTc, a), Type)
forall a b. (a -> b) -> a -> b
$ \ ExpSigmaTypeFRR
exp_ty ->
Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a. a -> Scaled a
unrestricted ExpSigmaTypeFRR
exp_ty) PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM a
thing_inside
where
penv :: PatEnv
penv = PE { pe_lazy :: Bool
pe_lazy = Bool
False, pe_ctxt :: PatCtxt
pe_ctxt = HsMatchContextRn -> PatCtxt
LamPat HsMatchContextRn
ctxt, pe_orig :: CtOrigin
pe_orig = CtOrigin
PatOrigin }
tcCheckPat :: HsMatchContextRn
-> LPat GhcRn -> Scaled TcSigmaTypeFRR
-> TcM a
-> TcM (LPat GhcTc, a)
tcCheckPat :: forall a.
HsMatchContextRn
-> LPat (GhcPass 'Renamed)
-> Scaled Type
-> TcM a
-> TcM (LPat GhcTc, a)
tcCheckPat HsMatchContextRn
ctxt = HsMatchContextRn
-> CtOrigin
-> LPat (GhcPass 'Renamed)
-> Scaled Type
-> TcM a
-> TcM (LPat GhcTc, a)
forall a.
HsMatchContextRn
-> CtOrigin
-> LPat (GhcPass 'Renamed)
-> Scaled Type
-> TcM a
-> TcM (LPat GhcTc, a)
tcCheckPat_O HsMatchContextRn
ctxt CtOrigin
PatOrigin
tcCheckPat_O :: HsMatchContextRn
-> CtOrigin
-> LPat GhcRn -> Scaled TcSigmaTypeFRR
-> TcM a
-> TcM (LPat GhcTc, a)
tcCheckPat_O :: forall a.
HsMatchContextRn
-> CtOrigin
-> LPat (GhcPass 'Renamed)
-> Scaled Type
-> TcM a
-> TcM (LPat GhcTc, a)
tcCheckPat_O HsMatchContextRn
ctxt CtOrigin
orig LPat (GhcPass 'Renamed)
pat (Scaled Type
pat_mult Type
pat_ty) TcM a
thing_inside
= Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Type -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a. Type -> a -> Scaled a
Scaled Type
pat_mult (Type -> ExpSigmaTypeFRR
mkCheckExpType Type
pat_ty)) PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM a
thing_inside
where
penv :: PatEnv
penv = PE { pe_lazy :: Bool
pe_lazy = Bool
False, pe_ctxt :: PatCtxt
pe_ctxt = HsMatchContextRn -> PatCtxt
LamPat HsMatchContextRn
ctxt, pe_orig :: CtOrigin
pe_orig = CtOrigin
orig }
data PatEnv
= PE { PatEnv -> Bool
pe_lazy :: Bool
, PatEnv -> PatCtxt
pe_ctxt :: PatCtxt
, PatEnv -> CtOrigin
pe_orig :: CtOrigin
}
data PatCtxt
= LamPat
HsMatchContextRn
| LetPat
{ PatCtxt -> TcLevel
pc_lvl :: TcLevel
, PatCtxt -> Name -> Maybe TyCoVar
pc_sig_fn :: Name -> Maybe TcId
, PatCtxt -> LetBndrSpec
pc_new :: LetBndrSpec
}
data LetBndrSpec
= LetLclBndr
| LetGblBndr TcPragEnv
instance Outputable LetBndrSpec where
ppr :: LetBndrSpec -> SDoc
ppr LetBndrSpec
LetLclBndr = String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"LetLclBndr"
ppr (LetGblBndr {}) = String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"LetGblBndr"
makeLazy :: PatEnv -> PatEnv
makeLazy :: PatEnv -> PatEnv
makeLazy PatEnv
penv = PatEnv
penv { pe_lazy = True }
inPatBind :: PatEnv -> Bool
inPatBind :: PatEnv -> Bool
inPatBind (PE { pe_ctxt :: PatEnv -> PatCtxt
pe_ctxt = LetPat {} }) = Bool
True
inPatBind (PE { pe_ctxt :: PatEnv -> PatCtxt
pe_ctxt = LamPat {} }) = Bool
False
tcPatBndr :: PatEnv -> Name -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, TcId)
tcPatBndr :: PatEnv
-> Name -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, TyCoVar)
tcPatBndr penv :: PatEnv
penv@(PE { pe_ctxt :: PatEnv -> PatCtxt
pe_ctxt = LetPat { pc_lvl :: PatCtxt -> TcLevel
pc_lvl = TcLevel
bind_lvl
, pc_sig_fn :: PatCtxt -> Name -> Maybe TyCoVar
pc_sig_fn = Name -> Maybe TyCoVar
sig_fn
, pc_new :: PatCtxt -> LetBndrSpec
pc_new = LetBndrSpec
no_gen } })
Name
bndr_name Scaled ExpSigmaTypeFRR
exp_pat_ty
| Just TyCoVar
bndr_id <- Name -> Maybe TyCoVar
sig_fn Name
bndr_name
= do { HsWrapper
wrap <- PatEnv -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tc_sub_type PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
exp_pat_ty) (TyCoVar -> Type
idType TyCoVar
bndr_id)
; String -> SDoc -> TcRn ()
traceTc String
"tcPatBndr(sig)" (TyCoVar -> SDoc
forall a. Outputable a => a -> SDoc
ppr TyCoVar
bndr_id SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr (TyCoVar -> Type
idType TyCoVar
bndr_id) SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ Scaled ExpSigmaTypeFRR -> SDoc
forall a. Outputable a => a -> SDoc
ppr Scaled ExpSigmaTypeFRR
exp_pat_ty)
; (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper
wrap, TyCoVar
bndr_id) }
| Bool
otherwise
= do { (TcCoercionN
co, Type
bndr_ty) <- case Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
exp_pat_ty of
Check Type
pat_ty -> TcLevel
-> Type -> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
promoteTcType TcLevel
bind_lvl Type
pat_ty
Infer InferResult
infer_res -> Bool
-> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
-> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
forall a. HasCallStack => Bool -> a -> a
assert (TcLevel
bind_lvl TcLevel -> TcLevel -> Bool
forall a. Eq a => a -> a -> Bool
== InferResult -> TcLevel
ir_lvl InferResult
infer_res) (IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
-> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type))
-> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
-> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
forall a b. (a -> b) -> a -> b
$
do { Type
bndr_ty <- InferResult -> IOEnv (Env TcGblEnv TcLclEnv) Type
inferResultToType InferResult
infer_res
; (TcCoercionN, Type)
-> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (Type -> TcCoercionN
mkNomReflCo Type
bndr_ty, Type
bndr_ty) }
; let bndr_mult :: Type
bndr_mult = Scaled ExpSigmaTypeFRR -> Type
forall a. Scaled a -> Type
scaledMult Scaled ExpSigmaTypeFRR
exp_pat_ty
; TyCoVar
bndr_id <- LetBndrSpec -> Name -> Type -> Type -> TcM TyCoVar
newLetBndr LetBndrSpec
no_gen Name
bndr_name Type
bndr_mult Type
bndr_ty
; String -> SDoc -> TcRn ()
traceTc String
"tcPatBndr(nosig)" ([SDoc] -> SDoc
forall doc. IsDoc doc => [doc] -> doc
vcat [ TcLevel -> SDoc
forall a. Outputable a => a -> SDoc
ppr TcLevel
bind_lvl
, Scaled ExpSigmaTypeFRR -> SDoc
forall a. Outputable a => a -> SDoc
ppr Scaled ExpSigmaTypeFRR
exp_pat_ty, Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
bndr_ty, TcCoercionN -> SDoc
forall a. Outputable a => a -> SDoc
ppr TcCoercionN
co
, TyCoVar -> SDoc
forall a. Outputable a => a -> SDoc
ppr TyCoVar
bndr_id ])
; (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (TcCoercionN -> HsWrapper
mkWpCastN TcCoercionN
co, TyCoVar
bndr_id) }
tcPatBndr PatEnv
_ Name
bndr_name Scaled ExpSigmaTypeFRR
pat_ty
= do { let pat_mult :: Type
pat_mult = Scaled ExpSigmaTypeFRR -> Type
forall a. Scaled a -> Type
scaledMult Scaled ExpSigmaTypeFRR
pat_ty
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
expTypeToType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; String -> SDoc -> TcRn ()
traceTc String
"tcPatBndr(not let)" (Name -> SDoc
forall a. Outputable a => a -> SDoc
ppr Name
bndr_name SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
pat_ty)
; (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper
idHsWrapper, HasDebugCallStack => Name -> Type -> Type -> TyCoVar
Name -> Type -> Type -> TyCoVar
mkLocalIdOrCoVar Name
bndr_name Type
pat_mult Type
pat_ty) }
newLetBndr :: LetBndrSpec -> Name -> Mult -> TcType -> TcM TcId
newLetBndr :: LetBndrSpec -> Name -> Type -> Type -> TcM TyCoVar
newLetBndr LetBndrSpec
LetLclBndr Name
name Type
w Type
ty
= do { Name
mono_name <- Name -> TcM Name
cloneLocalName Name
name
; TyCoVar -> TcM TyCoVar
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HasDebugCallStack => Name -> Type -> Type -> TyCoVar
Name -> Type -> Type -> TyCoVar
mkLocalId Name
mono_name Type
w Type
ty) }
newLetBndr (LetGblBndr TcPragEnv
prags) Name
name Type
w Type
ty
= TyCoVar -> [LSig (GhcPass 'Renamed)] -> TcM TyCoVar
addInlinePrags (HasDebugCallStack => Name -> Type -> Type -> TyCoVar
Name -> Type -> Type -> TyCoVar
mkLocalId Name
name Type
w Type
ty) (TcPragEnv -> Name -> [LSig (GhcPass 'Renamed)]
lookupPragEnv TcPragEnv
prags Name
name)
tc_sub_type :: PatEnv -> ExpSigmaType -> TcSigmaType -> TcM HsWrapper
tc_sub_type :: PatEnv -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tc_sub_type PatEnv
penv ExpSigmaTypeFRR
t1 Type
t2 = CtOrigin
-> UserTypeCtxt -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tcSubTypePat (PatEnv -> CtOrigin
pe_orig PatEnv
penv) UserTypeCtxt
GenSigCtxt ExpSigmaTypeFRR
t1 Type
t2
type Checker inp out = forall r.
PatEnv
-> inp
-> TcM r
-> TcM ( out
, r
)
tcMultiple_ :: Checker inp () -> PatEnv -> [inp] -> TcM r -> TcM r
tcMultiple_ :: forall inp r. Checker inp () -> PatEnv -> [inp] -> TcM r -> TcM r
tcMultiple_ Checker inp ()
tc_pat PatEnv
penv [inp]
args TcM r
thing_inside
= do { ([()]
_, r
res) <- Checker inp () -> Checker [inp] [()]
forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple PatEnv -> inp -> TcM r -> TcM ((), r)
Checker inp ()
tc_pat PatEnv
penv [inp]
args TcM r
thing_inside
; r -> TcM r
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return r
res }
tcMultiple :: Checker inp out -> Checker [inp] [out]
tcMultiple :: forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple Checker inp out
tc_pat PatEnv
penv [inp]
args TcM r
thing_inside
= do { [ErrCtxt]
err_ctxt <- TcM [ErrCtxt]
getErrCtxt
; let loop :: [inp] -> TcM ([out], r)
loop []
= do { r
res <- TcM r
thing_inside
; ([out], r) -> TcM ([out], r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([], r
res) }
loop (inp
arg:[inp]
args)
= do { (out
p', ([out]
ps', r
res))
<- PatEnv -> inp -> TcM ([out], r) -> TcM (out, ([out], r))
Checker inp out
tc_pat PatEnv
penv inp
arg (TcM ([out], r) -> TcM (out, ([out], r)))
-> TcM ([out], r) -> TcM (out, ([out], r))
forall a b. (a -> b) -> a -> b
$
[ErrCtxt] -> TcM ([out], r) -> TcM ([out], r)
forall a. [ErrCtxt] -> TcM a -> TcM a
setErrCtxt [ErrCtxt]
err_ctxt (TcM ([out], r) -> TcM ([out], r))
-> TcM ([out], r) -> TcM ([out], r)
forall a b. (a -> b) -> a -> b
$
[inp] -> TcM ([out], r)
loop [inp]
args
; ([out], r) -> TcM ([out], r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (out
p'out -> [out] -> [out]
forall a. a -> [a] -> [a]
:[out]
ps', r
res) }
; [inp] -> TcM ([out], r)
loop [inp]
args }
tc_lpat :: Scaled ExpSigmaTypeFRR
-> Checker (LPat GhcRn) (LPat GhcTc)
tc_lpat :: Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv (L SrcSpanAnnA
span Pat (GhcPass 'Renamed)
pat) TcM r
thing_inside
= SrcSpanAnnA -> TcRn (LPat GhcTc, r) -> TcRn (LPat GhcTc, r)
forall ann a. EpAnn ann -> TcRn a -> TcRn a
setSrcSpanA SrcSpanAnnA
span (TcRn (LPat GhcTc, r) -> TcRn (LPat GhcTc, r))
-> TcRn (LPat GhcTc, r) -> TcRn (LPat GhcTc, r)
forall a b. (a -> b) -> a -> b
$
do { (Pat GhcTc
pat', r
res) <- Pat (GhcPass 'Renamed)
-> (TcM r -> TcM (Pat GhcTc, r)) -> TcM r -> TcM (Pat GhcTc, r)
forall a b.
Pat (GhcPass 'Renamed) -> (TcM a -> TcM b) -> TcM a -> TcM b
maybeWrapPatCtxt Pat (GhcPass 'Renamed)
pat (Scaled ExpSigmaTypeFRR
-> Checker (Pat (GhcPass 'Renamed)) (Pat GhcTc)
tc_pat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv Pat (GhcPass 'Renamed)
pat)
TcM r
thing_inside
; (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (SrcSpanAnnA -> Pat GhcTc -> GenLocated SrcSpanAnnA (Pat GhcTc)
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnA
span Pat GhcTc
pat', r
res) }
tc_lpats :: [Scaled ExpSigmaTypeFRR]
-> Checker [LPat GhcRn] [LPat GhcTc]
tc_lpats :: [Scaled ExpSigmaTypeFRR]
-> Checker [LPat (GhcPass 'Renamed)] [LPat GhcTc]
tc_lpats [Scaled ExpSigmaTypeFRR]
tys PatEnv
penv [LPat (GhcPass 'Renamed)]
pats
= Bool
-> SDoc
-> (TcM r -> TcM ([LPat GhcTc], r))
-> TcM r
-> TcM ([LPat GhcTc], r)
forall a. HasCallStack => Bool -> SDoc -> a -> a
assertPpr ([GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
-> [Scaled ExpSigmaTypeFRR] -> Bool
forall a b. [a] -> [b] -> Bool
equalLength [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats [Scaled ExpSigmaTypeFRR]
tys) ([GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ [Scaled ExpSigmaTypeFRR] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Scaled ExpSigmaTypeFRR]
tys) ((TcM r -> TcM ([LPat GhcTc], r))
-> TcM r -> TcM ([LPat GhcTc], r))
-> (TcM r -> TcM ([LPat GhcTc], r))
-> TcM r
-> TcM ([LPat GhcTc], r)
forall a b. (a -> b) -> a -> b
$
Checker
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)),
Scaled ExpSigmaTypeFRR)
(GenLocated SrcSpanAnnA (Pat GhcTc))
-> Checker
[(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)),
Scaled ExpSigmaTypeFRR)]
[GenLocated SrcSpanAnnA (Pat GhcTc)]
forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple (\ PatEnv
penv' (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p,Scaled ExpSigmaTypeFRR
t) -> Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
t PatEnv
penv' LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p)
PatEnv
penv
(String
-> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
-> [Scaled ExpSigmaTypeFRR]
-> [(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)),
Scaled ExpSigmaTypeFRR)]
forall a b. HasDebugCallStack => String -> [a] -> [b] -> [(a, b)]
zipEqual String
"tc_lpats" [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats [Scaled ExpSigmaTypeFRR]
tys)
checkManyPattern :: NonLinearPatternReason -> LPat GhcRn -> Scaled a -> TcM HsWrapper
checkManyPattern :: forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
reason LPat (GhcPass 'Renamed)
pat Scaled a
pat_ty = CtOrigin -> Type -> Type -> TcM HsWrapper
tcSubMult (NonLinearPatternReason -> LPat (GhcPass 'Renamed) -> CtOrigin
NonLinearPatternOrigin NonLinearPatternReason
reason LPat (GhcPass 'Renamed)
pat) Type
ManyTy (Scaled a -> Type
forall a. Scaled a -> Type
scaledMult Scaled a
pat_ty)
tc_forall_lpat :: TcTyVar -> Checker (LPat GhcRn) (LPat GhcTc)
tc_forall_lpat :: TyCoVar -> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_forall_lpat TyCoVar
tv PatEnv
penv (L SrcSpanAnnA
span Pat (GhcPass 'Renamed)
pat) TcM r
thing_inside
= SrcSpanAnnA -> TcRn (LPat GhcTc, r) -> TcRn (LPat GhcTc, r)
forall ann a. EpAnn ann -> TcRn a -> TcRn a
setSrcSpanA SrcSpanAnnA
span (TcRn (LPat GhcTc, r) -> TcRn (LPat GhcTc, r))
-> TcRn (LPat GhcTc, r) -> TcRn (LPat GhcTc, r)
forall a b. (a -> b) -> a -> b
$
do { (Pat GhcTc
pat', r
res) <- Pat (GhcPass 'Renamed)
-> (TcM r -> TcM (Pat GhcTc, r)) -> TcM r -> TcM (Pat GhcTc, r)
forall a b.
Pat (GhcPass 'Renamed) -> (TcM a -> TcM b) -> TcM a -> TcM b
maybeWrapPatCtxt Pat (GhcPass 'Renamed)
pat (TyCoVar -> Checker (Pat (GhcPass 'Renamed)) (Pat GhcTc)
tc_forall_pat TyCoVar
tv PatEnv
penv Pat (GhcPass 'Renamed)
pat)
TcM r
thing_inside
; (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (SrcSpanAnnA -> Pat GhcTc -> GenLocated SrcSpanAnnA (Pat GhcTc)
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnA
span Pat GhcTc
pat', r
res) }
tc_forall_pat :: TcTyVar -> Checker (Pat GhcRn) (Pat GhcTc)
tc_forall_pat :: TyCoVar -> Checker (Pat (GhcPass 'Renamed)) (Pat GhcTc)
tc_forall_pat TyCoVar
tv PatEnv
penv (ParPat XParPat (GhcPass 'Renamed)
x LPat (GhcPass 'Renamed)
lpat) TcM r
thing_inside
= do { (GenLocated SrcSpanAnnA (Pat GhcTc)
lpat', r
res) <- TyCoVar -> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_forall_lpat TyCoVar
tv PatEnv
penv LPat (GhcPass 'Renamed)
lpat TcM r
thing_inside
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (XParPat GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XParPat p -> LPat p -> Pat p
ParPat XParPat (GhcPass 'Renamed)
XParPat GhcTc
x LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
lpat', r
res) }
tc_forall_pat TyCoVar
tv PatEnv
_ (EmbTyPat XEmbTyPat (GhcPass 'Renamed)
_ HsTyPat (NoGhcTc (GhcPass 'Renamed))
tp) TcM r
thing_inside
= do { (Type
arg_ty, r
result) <- HsTyPat (GhcPass 'Renamed) -> TyCoVar -> TcM r -> TcM (Type, r)
forall r.
HsTyPat (GhcPass 'Renamed) -> TyCoVar -> TcM r -> TcM (Type, r)
tc_ty_pat HsTyPat (NoGhcTc (GhcPass 'Renamed))
HsTyPat (GhcPass 'Renamed)
tp TyCoVar
tv TcM r
thing_inside
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (XEmbTyPat GhcTc -> HsTyPat (NoGhcTc GhcTc) -> Pat GhcTc
forall p. XEmbTyPat p -> HsTyPat (NoGhcTc p) -> Pat p
EmbTyPat XEmbTyPat GhcTc
Type
arg_ty HsTyPat (NoGhcTc (GhcPass 'Renamed))
HsTyPat (NoGhcTc GhcTc)
tp, r
result) }
tc_forall_pat TyCoVar
tv PatEnv
_ Pat (GhcPass 'Renamed)
pat TcM r
thing_inside
= do { HsTyPat (GhcPass 'Renamed)
tp <- Pat (GhcPass 'Renamed) -> TcM (HsTyPat (GhcPass 'Renamed))
pat_to_type_pat Pat (GhcPass 'Renamed)
pat
; (Type
arg_ty, r
result) <- HsTyPat (GhcPass 'Renamed) -> TyCoVar -> TcM r -> TcM (Type, r)
forall r.
HsTyPat (GhcPass 'Renamed) -> TyCoVar -> TcM r -> TcM (Type, r)
tc_ty_pat HsTyPat (GhcPass 'Renamed)
tp TyCoVar
tv TcM r
thing_inside
; let pat' :: Pat GhcTc
pat' = XXPat GhcTc -> Pat GhcTc
forall p. XXPat p -> Pat p
XPat (XXPat GhcTc -> Pat GhcTc) -> XXPat GhcTc -> Pat GhcTc
forall a b. (a -> b) -> a -> b
$ Pat (GhcPass 'Renamed) -> Pat GhcTc -> XXPatGhcTc
ExpansionPat Pat (GhcPass 'Renamed)
pat (XEmbTyPat GhcTc -> HsTyPat (NoGhcTc GhcTc) -> Pat GhcTc
forall p. XEmbTyPat p -> HsTyPat (NoGhcTc p) -> Pat p
EmbTyPat XEmbTyPat GhcTc
Type
arg_ty HsTyPat (NoGhcTc GhcTc)
HsTyPat (GhcPass 'Renamed)
tp)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (Pat GhcTc
pat', r
result) }
pat_to_type_pat :: Pat GhcRn -> TcM (HsTyPat GhcRn)
pat_to_type_pat :: Pat (GhcPass 'Renamed) -> TcM (HsTyPat (GhcPass 'Renamed))
pat_to_type_pat Pat (GhcPass 'Renamed)
pat = do
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
ty, HsTyPatRnBuilder
x) <- WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
-> IOEnv
(Env TcGblEnv TcLclEnv)
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)),
HsTyPatRnBuilder)
forall w (m :: * -> *) a. Monoid w => WriterT w m a -> m (a, w)
runWriterT (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type Pat (GhcPass 'Renamed)
pat)
HsTyPat (GhcPass 'Renamed) -> TcM (HsTyPat (GhcPass 'Renamed))
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (XHsTP (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed) -> HsTyPat (GhcPass 'Renamed)
forall pass. XHsTP pass -> LHsType pass -> HsTyPat pass
HsTP (HsTyPatRnBuilder -> HsTyPatRn
buildHsTyPatRn HsTyPatRnBuilder
x) LHsType (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
ty)
pat_to_type :: Pat GhcRn -> WriterT HsTyPatRnBuilder TcM (LHsType GhcRn)
pat_to_type :: Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type (EmbTyPat XEmbTyPat (GhcPass 'Renamed)
_ (HsTP XHsTP (NoGhcTc (GhcPass 'Renamed))
x LHsType (NoGhcTc (GhcPass 'Renamed))
t)) =
do { HsTyPatRnBuilder
-> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) ()
forall w (m :: * -> *). (Monoid w, Monad m) => w -> WriterT w m ()
tell (HsTyPatRn -> HsTyPatRnBuilder
builderFromHsTyPatRn XHsTP (NoGhcTc (GhcPass 'Renamed))
HsTyPatRn
x)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (m :: * -> *) a. Monad m => a -> m a
return LHsType (NoGhcTc (GhcPass 'Renamed))
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t }
pat_to_type (VarPat XVarPat (GhcPass 'Renamed)
_ LIdP (GhcPass 'Renamed)
lname) =
do { HsTyPatRnBuilder
-> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) ()
forall w (m :: * -> *). (Monoid w, Monad m) => w -> WriterT w m ()
tell (Name -> HsTyPatRnBuilder
tpBuilderExplicitTV (GenLocated SrcSpanAnnN Name -> Name
forall l e. GenLocated l e -> e
unLoc LIdP (GhcPass 'Renamed)
GenLocated SrcSpanAnnN Name
lname))
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (m :: * -> *) a. Monad m => a -> m a
return GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
b }
where b :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
b = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XTyVar (GhcPass 'Renamed)
-> PromotionFlag
-> LIdP (GhcPass 'Renamed)
-> HsType (GhcPass 'Renamed)
forall pass.
XTyVar pass -> PromotionFlag -> LIdP pass -> HsType pass
HsTyVar XTyVar (GhcPass 'Renamed)
forall a. NoAnn a => a
noAnn PromotionFlag
NotPromoted LIdP (GhcPass 'Renamed)
lname)
pat_to_type (WildPat XWildPat (GhcPass 'Renamed)
_) = GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (m :: * -> *) a. Monad m => a -> m a
return GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
b
where b :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
b = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XWildCardTy (GhcPass 'Renamed) -> HsType (GhcPass 'Renamed)
forall pass. XWildCardTy pass -> HsType pass
HsWildCardTy XWildCardTy (GhcPass 'Renamed)
NoExtField
noExtField)
pat_to_type (SigPat XSigPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
pat HsPatSigType (NoGhcTc (GhcPass 'Renamed))
sig_ty)
= do { GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t <- Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
pat)
; let { !(HsPS XHsPS (NoGhcTc (GhcPass 'Renamed))
x_hsps LHsType (NoGhcTc (GhcPass 'Renamed))
k) = HsPatSigType (NoGhcTc (GhcPass 'Renamed))
sig_ty
; b :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
b = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XKindSig (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed)
-> HsType (GhcPass 'Renamed)
forall pass.
XKindSig pass -> LHsType pass -> LHsType pass -> HsType pass
HsKindSig [AddEpAnn]
XKindSig (GhcPass 'Renamed)
forall a. NoAnn a => a
noAnn LHsType (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t LHsType (NoGhcTc (GhcPass 'Renamed))
LHsType (GhcPass 'Renamed)
k) }
; HsTyPatRnBuilder
-> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) ()
forall w (m :: * -> *). (Monoid w, Monad m) => w -> WriterT w m ()
tell (HsPSRn -> HsTyPatRnBuilder
tpBuilderPatSig XHsPS (NoGhcTc (GhcPass 'Renamed))
HsPSRn
x_hsps)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (m :: * -> *) a. Monad m => a -> m a
return GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
b }
pat_to_type (ParPat XParPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
pat)
= do { GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t <- Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
pat)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XParTy (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed) -> HsType (GhcPass 'Renamed)
forall pass. XParTy pass -> LHsType pass -> HsType pass
HsParTy XParTy (GhcPass 'Renamed)
AnnParen
forall a. NoAnn a => a
noAnn LHsType (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t)) }
pat_to_type (SplicePat (HsUntypedSpliceTop ThModFinalizers
mod_finalizers Pat (GhcPass 'Renamed)
pat) HsUntypedSplice (GhcPass 'Renamed)
splice) = do
{ GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t <- Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type Pat (GhcPass 'Renamed)
pat
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XSpliceTy (GhcPass 'Renamed)
-> HsUntypedSplice (GhcPass 'Renamed) -> HsType (GhcPass 'Renamed)
forall pass. XSpliceTy pass -> HsUntypedSplice pass -> HsType pass
HsSpliceTy (ThModFinalizers
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> HsUntypedSpliceResult
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall thing.
ThModFinalizers -> thing -> HsUntypedSpliceResult thing
HsUntypedSpliceTop ThModFinalizers
mod_finalizers GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t) HsUntypedSplice (GhcPass 'Renamed)
splice)) }
pat_to_type (TuplePat XTuplePat (GhcPass 'Renamed)
_ [LPat (GhcPass 'Renamed)]
pats Boxity
Boxed)
= do { [GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
tys <- (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
[GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
forall (f :: * -> *) a b.
Applicative f =>
(a -> f b) -> [a] -> f [b]
traverse (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
pat_to_type (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc) [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats
; let t :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XExplicitTupleTy (GhcPass 'Renamed)
-> [LHsType (GhcPass 'Renamed)] -> HsType (GhcPass 'Renamed)
forall pass. XExplicitTupleTy pass -> [LHsType pass] -> HsType pass
HsExplicitTupleTy XExplicitTupleTy (GhcPass 'Renamed)
NoExtField
noExtField [LHsType (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
tys)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t }
pat_to_type (ListPat XListPat (GhcPass 'Renamed)
_ [LPat (GhcPass 'Renamed)]
pats)
= do { [GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
tys <- (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
[GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
forall (f :: * -> *) a b.
Applicative f =>
(a -> f b) -> [a] -> f [b]
traverse (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
pat_to_type (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc) [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats
; let t :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XExplicitListTy (GhcPass 'Renamed)
-> PromotionFlag
-> [LHsType (GhcPass 'Renamed)]
-> HsType (GhcPass 'Renamed)
forall pass.
XExplicitListTy pass
-> PromotionFlag -> [LHsType pass] -> HsType pass
HsExplicitListTy XExplicitListTy (GhcPass 'Renamed)
NoExtField
NoExtField PromotionFlag
NotPromoted [LHsType (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
tys)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t }
pat_to_type (LitPat XLitPat (GhcPass 'Renamed)
_ HsLit (GhcPass 'Renamed)
lit)
| Just HsTyLit (GhcPass 'Renamed)
ty_lit <- HsLit (GhcPass 'Renamed) -> Maybe (HsTyLit (GhcPass 'Renamed))
tyLitFromLit HsLit (GhcPass 'Renamed)
lit
= do { let t :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XTyLit (GhcPass 'Renamed)
-> HsTyLit (GhcPass 'Renamed) -> HsType (GhcPass 'Renamed)
forall pass. XTyLit pass -> HsTyLit pass -> HsType pass
HsTyLit XTyLit (GhcPass 'Renamed)
NoExtField
noExtField HsTyLit (GhcPass 'Renamed)
ty_lit)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t }
pat_to_type (NPat XNPat (GhcPass 'Renamed)
_ (L EpAnnCO
_ HsOverLit (GhcPass 'Renamed)
lit) Maybe (SyntaxExpr (GhcPass 'Renamed))
_ SyntaxExpr (GhcPass 'Renamed)
_)
| Just HsTyLit (GhcPass 'Renamed)
ty_lit <- OverLitVal -> Maybe (HsTyLit (GhcPass 'Renamed))
tyLitFromOverloadedLit (HsOverLit (GhcPass 'Renamed) -> OverLitVal
forall p. HsOverLit p -> OverLitVal
ol_val HsOverLit (GhcPass 'Renamed)
lit)
= do { let t :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XTyLit (GhcPass 'Renamed)
-> HsTyLit (GhcPass 'Renamed) -> HsType (GhcPass 'Renamed)
forall pass. XTyLit pass -> HsTyLit pass -> HsType pass
HsTyLit XTyLit (GhcPass 'Renamed)
NoExtField
noExtField HsTyLit (GhcPass 'Renamed)
ty_lit)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t}
pat_to_type (ConPat XConPat (GhcPass 'Renamed)
_ XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
lname (InfixCon LPat (GhcPass 'Renamed)
left LPat (GhcPass 'Renamed)
right))
= do { GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
lty <- Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
left)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
rty <- Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
pat_to_type (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
right)
; let { t :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XOpTy (GhcPass 'Renamed)
-> PromotionFlag
-> LHsType (GhcPass 'Renamed)
-> LIdP (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed)
-> HsType (GhcPass 'Renamed)
forall pass.
XOpTy pass
-> PromotionFlag
-> LHsType pass
-> LIdP pass
-> LHsType pass
-> HsType pass
HsOpTy [AddEpAnn]
XOpTy (GhcPass 'Renamed)
forall a. NoAnn a => a
noAnn PromotionFlag
NotPromoted LHsType (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
lty LIdP (GhcPass 'Renamed)
XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
lname LHsType (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
rty)}
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t }
pat_to_type (ConPat XConPat (GhcPass 'Renamed)
_ XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
lname (PrefixCon [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
invis_args [LPat (GhcPass 'Renamed)]
vis_args))
= do { let { appHead :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
appHead = HsType (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA (XTyVar (GhcPass 'Renamed)
-> PromotionFlag
-> LIdP (GhcPass 'Renamed)
-> HsType (GhcPass 'Renamed)
forall pass.
XTyVar pass -> PromotionFlag -> LIdP pass -> HsType pass
HsTyVar XTyVar (GhcPass 'Renamed)
forall a. NoAnn a => a
noAnn PromotionFlag
NotPromoted LIdP (GhcPass 'Renamed)
XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
lname)}
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
ty_invis <- (GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> HsConPatTyArg (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> [HsConPatTyArg (GhcPass 'Renamed)]
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall (t :: * -> *) (m :: * -> *) b a.
(Foldable t, Monad m) =>
(b -> a -> m b) -> b -> t a -> m b
foldM LHsType (GhcPass 'Renamed)
-> HsConPatTyArg (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> HsConPatTyArg (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
apply_invis_arg GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
appHead [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
[HsConPatTyArg (GhcPass 'Renamed)]
invis_args
; [GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
tys_vis <- (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
[GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
forall (f :: * -> *) a b.
Applicative f =>
(a -> f b) -> [a] -> f [b]
traverse (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
pat_to_type (Pat (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))))
-> (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
-> Pat (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc) [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
vis_args
; let t :: GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t = (GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> [GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall b a. (b -> a -> b) -> b -> [a] -> b
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl' LHsType (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed) -> LHsType (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
forall (p :: Pass).
LHsType (GhcPass p) -> LHsType (GhcPass p) -> LHsType (GhcPass p)
mkHsAppTy GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
ty_invis [GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))]
tys_vis
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
t }
where
apply_invis_arg :: LHsType GhcRn -> HsConPatTyArg GhcRn -> WriterT HsTyPatRnBuilder TcM (LHsType GhcRn)
apply_invis_arg :: LHsType (GhcPass 'Renamed)
-> HsConPatTyArg (GhcPass 'Renamed)
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
apply_invis_arg !LHsType (GhcPass 'Renamed)
t (HsConPatTyArg XConPatTyArg (GhcPass 'Renamed)
_ (HsTP XHsTP (GhcPass 'Renamed)
argx LHsType (GhcPass 'Renamed)
arg))
= do { HsTyPatRnBuilder
-> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) ()
forall w (m :: * -> *). (Monoid w, Monad m) => w -> WriterT w m ()
tell (HsTyPatRn -> HsTyPatRnBuilder
builderFromHsTyPatRn XHsTP (GhcPass 'Renamed)
HsTyPatRn
argx)
; GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(GenLocated SrcSpanAnnA (HsType (GhcPass 'Renamed)))
forall a.
a -> WriterT HsTyPatRnBuilder (IOEnv (Env TcGblEnv TcLclEnv)) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (XAppKindTy (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed)
-> LHsType (GhcPass 'Renamed)
forall (p :: Pass).
XAppKindTy (GhcPass p)
-> LHsType (GhcPass p)
-> LHsType (GhcPass p)
-> LHsType (GhcPass p)
mkHsAppKindTy XAppKindTy (GhcPass 'Renamed)
NoExtField
noExtField LHsType (GhcPass 'Renamed)
t LHsType (GhcPass 'Renamed)
arg)}
pat_to_type Pat (GhcPass 'Renamed)
pat = TcM (LHsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
forall (m :: * -> *) a.
Monad m =>
m a -> WriterT HsTyPatRnBuilder m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (TcM (LHsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed)))
-> TcM (LHsType (GhcPass 'Renamed))
-> WriterT
HsTyPatRnBuilder
(IOEnv (Env TcGblEnv TcLclEnv))
(LHsType (GhcPass 'Renamed))
forall a b. (a -> b) -> a -> b
$
TcRnMessage -> TcM (LHsType (GhcPass 'Renamed))
forall a. TcRnMessage -> TcRn a
failWith (TcRnMessage -> TcM (LHsType (GhcPass 'Renamed)))
-> TcRnMessage -> TcM (LHsType (GhcPass 'Renamed))
forall a b. (a -> b) -> a -> b
$ Pat (GhcPass 'Renamed) -> TcRnMessage
TcRnIllformedTypePattern Pat (GhcPass 'Renamed)
pat
tc_ty_pat :: HsTyPat GhcRn -> TcTyVar -> TcM r -> TcM (TcType, r)
tc_ty_pat :: forall r.
HsTyPat (GhcPass 'Renamed) -> TyCoVar -> TcM r -> TcM (Type, r)
tc_ty_pat HsTyPat (GhcPass 'Renamed)
tp TyCoVar
tv TcM r
thing_inside
= do { ([(Name, TyCoVar)]
sig_wcs, [(Name, TyCoVar)]
sig_ibs, Type
arg_ty) <- HsTyPat (GhcPass 'Renamed)
-> Type -> TcM ([(Name, TyCoVar)], [(Name, TyCoVar)], Type)
tcHsTyPat HsTyPat (GhcPass 'Renamed)
tp (TyCoVar -> Type
varType TyCoVar
tv)
; TcCoercionN
_ <- Maybe TypedThing -> Type -> Type -> TcM TcCoercionN
unifyType Maybe TypedThing
forall a. Maybe a
Nothing Type
arg_ty (TyCoVar -> Type
mkTyVarTy TyCoVar
tv)
; r
result <- [(Name, TyCoVar)] -> TcM r -> TcM r
forall r. [(Name, TyCoVar)] -> TcM r -> TcM r
tcExtendNameTyVarEnv [(Name, TyCoVar)]
sig_wcs (TcM r -> TcM r) -> TcM r -> TcM r
forall a b. (a -> b) -> a -> b
$
[(Name, TyCoVar)] -> TcM r -> TcM r
forall r. [(Name, TyCoVar)] -> TcM r -> TcM r
tcExtendNameTyVarEnv [(Name, TyCoVar)]
sig_ibs (TcM r -> TcM r) -> TcM r -> TcM r
forall a b. (a -> b) -> a -> b
$
TcM r
thing_inside
; (Type, r) -> TcM (Type, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (Type
arg_ty, r
result) }
tc_pat :: Scaled ExpSigmaTypeFRR
-> Checker (Pat GhcRn) (Pat GhcTc)
tc_pat :: Scaled ExpSigmaTypeFRR
-> Checker (Pat (GhcPass 'Renamed)) (Pat GhcTc)
tc_pat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv Pat (GhcPass 'Renamed)
ps_pat TcM r
thing_inside = case Pat (GhcPass 'Renamed)
ps_pat of
VarPat XVarPat (GhcPass 'Renamed)
x (L SrcSpanAnnN
l Name
name) -> do
{ (HsWrapper
wrap, TyCoVar
id) <- PatEnv
-> Name -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, TyCoVar)
tcPatBndr PatEnv
penv Name
name Scaled ExpSigmaTypeFRR
pat_ty
; (r
res, HsWrapper
mult_wrap) <- Name -> Type -> TcM r -> TcM (r, HsWrapper)
forall a. Name -> Type -> TcM a -> TcM (a, HsWrapper)
tcCheckUsage Name
name (Scaled ExpSigmaTypeFRR -> Type
forall a. Scaled a -> Type
scaledMult Scaled ExpSigmaTypeFRR
pat_ty) (TcM r -> TcM (r, HsWrapper)) -> TcM r -> TcM (r, HsWrapper)
forall a b. (a -> b) -> a -> b
$
Name -> TyCoVar -> TcM r -> TcM r
forall a. Name -> TyCoVar -> TcM a -> TcM a
tcExtendIdEnv1 Name
name TyCoVar
id TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat (HsWrapper
wrap HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
mult_wrap) (XVarPat GhcTc -> LIdP GhcTc -> Pat GhcTc
forall p. XVarPat p -> LIdP p -> Pat p
VarPat XVarPat (GhcPass 'Renamed)
XVarPat GhcTc
x (SrcSpanAnnN -> TyCoVar -> GenLocated SrcSpanAnnN TyCoVar
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnN
l TyCoVar
id)) Type
pat_ty, r
res) }
ParPat XParPat (GhcPass 'Renamed)
x LPat (GhcPass 'Renamed)
pat -> do
{ (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM r
thing_inside
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (XParPat GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XParPat p -> LPat p -> Pat p
ParPat XParPat (GhcPass 'Renamed)
XParPat GhcTc
x LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) }
BangPat XBangPat (GhcPass 'Renamed)
x LPat (GhcPass 'Renamed)
pat -> do
{ (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM r
thing_inside
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (XBangPat GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XBangPat p -> LPat p -> Pat p
BangPat XBangPat (GhcPass 'Renamed)
XBangPat GhcTc
x LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) }
LazyPat XLazyPat (GhcPass 'Renamed)
x LPat (GhcPass 'Renamed)
pat -> do
{ HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
LazyPatternReason (Pat (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat (GhcPass 'Renamed)
ps_pat) Scaled ExpSigmaTypeFRR
pat_ty
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', (r
res, WantedConstraints
pat_ct))
<- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat Scaled ExpSigmaTypeFRR
pat_ty (PatEnv -> PatEnv
makeLazy PatEnv
penv) LPat (GhcPass 'Renamed)
pat (TcM (r, WantedConstraints)
-> TcM (LPat GhcTc, (r, WantedConstraints)))
-> TcM (r, WantedConstraints)
-> TcM (LPat GhcTc, (r, WantedConstraints))
forall a b. (a -> b) -> a -> b
$
TcM r -> TcM (r, WantedConstraints)
forall a. TcM a -> TcM (a, WantedConstraints)
captureConstraints TcM r
thing_inside
; WantedConstraints -> TcRn ()
emitConstraints WantedConstraints
pat_ct
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; TcCoercionN
_ <- Maybe TypedThing -> Type -> Type -> TcM TcCoercionN
unifyType Maybe TypedThing
forall a. Maybe a
Nothing (HasDebugCallStack => Type -> Type
Type -> Type
typeKind Type
pat_ty) Type
liftedTypeKind
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
mult_wrap (XLazyPat GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XLazyPat p -> LPat p -> Pat p
LazyPat XLazyPat (GhcPass 'Renamed)
XLazyPat GhcTc
x LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat') Type
pat_ty, r
res) }
WildPat XWildPat (GhcPass 'Renamed)
_ -> do
{ HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
OtherPatternReason (Pat (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat (GhcPass 'Renamed)
ps_pat) Scaled ExpSigmaTypeFRR
pat_ty
; r
res <- TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
expTypeToType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
mult_wrap (XWildPat GhcTc -> Pat GhcTc
forall p. XWildPat p -> Pat p
WildPat XWildPat GhcTc
Type
pat_ty) Type
pat_ty, r
res) }
AsPat XAsPat (GhcPass 'Renamed)
x (L SrcSpanAnnN
nm_loc Name
name) LPat (GhcPass 'Renamed)
pat -> do
{ HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
OtherPatternReason (Pat (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat (GhcPass 'Renamed)
ps_pat) Scaled ExpSigmaTypeFRR
pat_ty
; (HsWrapper
wrap, TyCoVar
bndr_id) <- SrcSpanAnnN -> TcM (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar)
forall ann a. EpAnn ann -> TcRn a -> TcRn a
setSrcSpanA SrcSpanAnnN
nm_loc (PatEnv
-> Name -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, TyCoVar)
tcPatBndr PatEnv
penv Name
name Scaled ExpSigmaTypeFRR
pat_ty)
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- Name
-> TyCoVar
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall a. Name -> TyCoVar -> TcM a -> TcM a
tcExtendIdEnv1 Name
name TyCoVar
bndr_id (IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r))
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall a b. (a -> b) -> a -> b
$
Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Scaled ExpSigmaTypeFRR
pat_ty Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. Scaled a -> b -> Scaled b
`scaledSet`(Type -> ExpSigmaTypeFRR
mkCheckExpType (Type -> ExpSigmaTypeFRR) -> Type -> ExpSigmaTypeFRR
forall a b. (a -> b) -> a -> b
$ TyCoVar -> Type
idType TyCoVar
bndr_id))
PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat (HsWrapper
wrap HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
mult_wrap) (XAsPat GhcTc -> LIdP GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XAsPat p -> LIdP p -> LPat p -> Pat p
AsPat XAsPat (GhcPass 'Renamed)
XAsPat GhcTc
x (SrcSpanAnnN -> TyCoVar -> GenLocated SrcSpanAnnN TyCoVar
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnN
nm_loc TyCoVar
bndr_id) LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat') Type
pat_ty, r
res) }
ViewPat XViewPat (GhcPass 'Renamed)
_ LHsExpr (GhcPass 'Renamed)
expr LPat (GhcPass 'Renamed)
pat -> do
{ HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
ViewPatternReason (Pat (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat (GhcPass 'Renamed)
ps_pat) Scaled ExpSigmaTypeFRR
pat_ty
; (GenLocated SrcSpanAnnA (HsExpr GhcTc)
expr',Type
expr_ty) <- LHsExpr (GhcPass 'Renamed) -> TcM (LHsExpr GhcTc, Type)
tcInferRho LHsExpr (GhcPass 'Renamed)
expr
; let herald :: ExpectedFunTyOrigin
herald = HsExpr (GhcPass 'Renamed) -> ExpectedFunTyOrigin
ExpectedFunTyViewPat (HsExpr (GhcPass 'Renamed) -> ExpectedFunTyOrigin)
-> HsExpr (GhcPass 'Renamed) -> ExpectedFunTyOrigin
forall a b. (a -> b) -> a -> b
$ GenLocated SrcSpanAnnA (HsExpr (GhcPass 'Renamed))
-> HsExpr (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc LHsExpr (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsExpr (GhcPass 'Renamed))
expr
; (HsWrapper
expr_wrap1, Scaled Type
_mult Type
inf_arg_ty, Type
inf_res_sigma)
<- ExpectedFunTyOrigin
-> Maybe TypedThing
-> (Int, Type)
-> Type
-> TcM (HsWrapper, Scaled Type, Type)
matchActualFunTy ExpectedFunTyOrigin
herald (TypedThing -> Maybe TypedThing
forall a. a -> Maybe a
Just (TypedThing -> Maybe TypedThing)
-> (HsExpr (GhcPass 'Renamed) -> TypedThing)
-> HsExpr (GhcPass 'Renamed)
-> Maybe TypedThing
forall b c a. (b -> c) -> (a -> b) -> a -> c
. HsExpr (GhcPass 'Renamed) -> TypedThing
HsExprRnThing (HsExpr (GhcPass 'Renamed) -> Maybe TypedThing)
-> HsExpr (GhcPass 'Renamed) -> Maybe TypedThing
forall a b. (a -> b) -> a -> b
$ GenLocated SrcSpanAnnA (HsExpr (GhcPass 'Renamed))
-> HsExpr (GhcPass 'Renamed)
forall l e. GenLocated l e -> e
unLoc LHsExpr (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (HsExpr (GhcPass 'Renamed))
expr) (Int
1,Type
expr_ty) Type
expr_ty
; HsWrapper
expr_wrap2 <- PatEnv -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tc_sub_type PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty) Type
inf_arg_ty
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Scaled ExpSigmaTypeFRR
pat_ty Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. Scaled a -> b -> Scaled b
`scaledSet` Type -> ExpSigmaTypeFRR
mkCheckExpType Type
inf_res_sigma) PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM r
thing_inside
; let Scaled Type
w ExpSigmaTypeFRR
h_pat_ty = Scaled ExpSigmaTypeFRR
pat_ty
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType ExpSigmaTypeFRR
h_pat_ty
; let expr_wrap2' :: HsWrapper
expr_wrap2' = HsWrapper -> HsWrapper -> Scaled Type -> Type -> HsWrapper
mkWpFun HsWrapper
expr_wrap2 HsWrapper
idHsWrapper
(Type -> Type -> Scaled Type
forall a. Type -> a -> Scaled a
Scaled Type
w Type
pat_ty) Type
inf_res_sigma
; let
expr_wrap :: HsWrapper
expr_wrap = HsWrapper
expr_wrap2' HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
expr_wrap1 HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
mult_wrap
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ((Pat GhcTc, r) -> TcM (Pat GhcTc, r))
-> (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a b. (a -> b) -> a -> b
$ (XViewPat GhcTc -> LHsExpr GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XViewPat p -> LHsExpr p -> LPat p -> Pat p
ViewPat XViewPat GhcTc
Type
pat_ty (HsWrapper -> LHsExpr GhcTc -> LHsExpr GhcTc
mkLHsWrap HsWrapper
expr_wrap LHsExpr GhcTc
GenLocated SrcSpanAnnA (HsExpr GhcTc)
expr') LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) }
SigPat XSigPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
pat HsPatSigType (NoGhcTc (GhcPass 'Renamed))
sig_ty -> do
{ (Type
inner_ty, [(Name, TyCoVar)]
tv_binds, [(Name, TyCoVar)]
wcs, HsWrapper
wrap) <- Bool
-> HsPatSigType (GhcPass 'Renamed)
-> ExpSigmaTypeFRR
-> TcM (Type, [(Name, TyCoVar)], [(Name, TyCoVar)], HsWrapper)
tcPatSig (PatEnv -> Bool
inPatBind PatEnv
penv)
HsPatSigType (NoGhcTc (GhcPass 'Renamed))
HsPatSigType (GhcPass 'Renamed)
sig_ty (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- [(Name, TyCoVar)]
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall r. [(Name, TyCoVar)] -> TcM r -> TcM r
tcExtendNameTyVarEnv [(Name, TyCoVar)]
wcs (IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r))
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall a b. (a -> b) -> a -> b
$
[(Name, TyCoVar)]
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall r. [(Name, TyCoVar)] -> TcM r -> TcM r
tcExtendNameTyVarEnv [(Name, TyCoVar)]
tv_binds (IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r))
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
forall a b. (a -> b) -> a -> b
$
Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Scaled ExpSigmaTypeFRR
pat_ty Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. Scaled a -> b -> Scaled b
`scaledSet` Type -> ExpSigmaTypeFRR
mkCheckExpType Type
inner_ty) PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
wrap (XSigPat GhcTc
-> LPat GhcTc -> HsPatSigType (NoGhcTc GhcTc) -> Pat GhcTc
forall p. XSigPat p -> LPat p -> HsPatSigType (NoGhcTc p) -> Pat p
SigPat XSigPat GhcTc
Type
inner_ty LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat' HsPatSigType (NoGhcTc (GhcPass 'Renamed))
HsPatSigType (NoGhcTc GhcTc)
sig_ty) Type
pat_ty, r
res) }
ListPat XListPat (GhcPass 'Renamed)
_ [LPat (GhcPass 'Renamed)]
pats -> do
{ (HsWrapper
coi, Type
elt_ty) <- (Type -> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, Type)
forall a.
(Type -> TcM (TcCoercionN, a))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, a)
matchExpectedPatTy Type -> IOEnv (Env TcGblEnv TcLclEnv) (TcCoercionN, Type)
matchExpectedListTy PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; ([GenLocated SrcSpanAnnA (Pat GhcTc)]
pats', r
res) <- Checker
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat GhcTc))
-> Checker
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
[GenLocated SrcSpanAnnA (Pat GhcTc)]
forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple (Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Scaled ExpSigmaTypeFRR
pat_ty Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. Scaled a -> b -> Scaled b
`scaledSet` Type -> ExpSigmaTypeFRR
mkCheckExpType Type
elt_ty))
PatEnv
penv [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
coi
(XListPat GhcTc -> [LPat GhcTc] -> Pat GhcTc
forall p. XListPat p -> [LPat p] -> Pat p
ListPat XListPat GhcTc
Type
elt_ty [LPat GhcTc]
[GenLocated SrcSpanAnnA (Pat GhcTc)]
pats') Type
pat_ty, r
res)
}
TuplePat XTuplePat (GhcPass 'Renamed)
_ [LPat (GhcPass 'Renamed)]
pats Boxity
boxity -> do
{ let arity :: Int
arity = [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats
tc :: TyCon
tc = Boxity -> Int -> TyCon
tupleTyCon Boxity
boxity Int
arity
; Int -> TcRn ()
checkTupSize Int
arity
; (HsWrapper
coi, [Type]
arg_tys) <- (Type -> TcM (TcCoercionN, [Type]))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, [Type])
forall a.
(Type -> TcM (TcCoercionN, a))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, a)
matchExpectedPatTy (TyCon -> Type -> TcM (TcCoercionN, [Type])
matchExpectedTyConApp TyCon
tc)
PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; let con_arg_tys :: [Type]
con_arg_tys = case Boxity
boxity of Boxity
Unboxed -> Int -> [Type] -> [Type]
forall a. Int -> [a] -> [a]
drop Int
arity [Type]
arg_tys
Boxity
Boxed -> [Type]
arg_tys
; ([GenLocated SrcSpanAnnA (Pat GhcTc)]
pats', r
res) <- [Scaled ExpSigmaTypeFRR]
-> Checker [LPat (GhcPass 'Renamed)] [LPat GhcTc]
tc_lpats ((Type -> Scaled ExpSigmaTypeFRR)
-> [Type] -> [Scaled ExpSigmaTypeFRR]
forall a b. (a -> b) -> [a] -> [b]
map (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. Scaled a -> b -> Scaled b
scaledSet Scaled ExpSigmaTypeFRR
pat_ty (ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR)
-> (Type -> ExpSigmaTypeFRR) -> Type -> Scaled ExpSigmaTypeFRR
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Type -> ExpSigmaTypeFRR
mkCheckExpType) [Type]
con_arg_tys)
PatEnv
penv [LPat (GhcPass 'Renamed)]
pats TcM r
thing_inside
; DynFlags
dflags <- IOEnv (Env TcGblEnv TcLclEnv) DynFlags
forall (m :: * -> *). HasDynFlags m => m DynFlags
getDynFlags
; let
unmangled_result :: Pat GhcTc
unmangled_result = XTuplePat GhcTc -> [LPat GhcTc] -> Boxity -> Pat GhcTc
forall p. XTuplePat p -> [LPat p] -> Boxity -> Pat p
TuplePat [Type]
XTuplePat GhcTc
con_arg_tys [LPat GhcTc]
[GenLocated SrcSpanAnnA (Pat GhcTc)]
pats' Boxity
boxity
possibly_mangled_result :: Pat GhcTc
possibly_mangled_result
| GeneralFlag -> DynFlags -> Bool
gopt GeneralFlag
Opt_IrrefutableTuples DynFlags
dflags Bool -> Bool -> Bool
&&
Boxity -> Bool
isBoxed Boxity
boxity = XLazyPat GhcTc -> LPat GhcTc -> Pat GhcTc
forall p. XLazyPat p -> LPat p -> Pat p
LazyPat XLazyPat GhcTc
NoExtField
noExtField (Pat GhcTc -> GenLocated SrcSpanAnnA (Pat GhcTc)
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat GhcTc
unmangled_result)
| Bool
otherwise = Pat GhcTc
unmangled_result
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; Bool -> TcRn ()
forall (m :: * -> *). (HasCallStack, Applicative m) => Bool -> m ()
massert ([Type]
con_arg_tys [Type] -> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> Bool
forall a b. [a] -> [b] -> Bool
`equalLength` [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
pats)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
coi Pat GhcTc
possibly_mangled_result Type
pat_ty, r
res)
}
SumPat XSumPat (GhcPass 'Renamed)
_ LPat (GhcPass 'Renamed)
pat Int
alt Int
arity -> do
{ let tc :: TyCon
tc = Int -> TyCon
sumTyCon Int
arity
; (HsWrapper
coi, [Type]
arg_tys) <- (Type -> TcM (TcCoercionN, [Type]))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, [Type])
forall a.
(Type -> TcM (TcCoercionN, a))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, a)
matchExpectedPatTy (TyCon -> Type -> TcM (TcCoercionN, [Type])
matchExpectedTyConApp TyCon
tc)
PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
;
let con_arg_tys :: [Type]
con_arg_tys = Int -> [Type] -> [Type]
forall a. Int -> [a] -> [a]
drop Int
arity [Type]
arg_tys
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Scaled ExpSigmaTypeFRR
pat_ty Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. Scaled a -> b -> Scaled b
`scaledSet` Type -> ExpSigmaTypeFRR
mkCheckExpType ([Type]
con_arg_tys [Type] -> Int -> Type
forall a. Outputable a => [a] -> Int -> a
`getNth` (Int
alt Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
1)))
PatEnv
penv LPat (GhcPass 'Renamed)
pat TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
coi (XSumPat GhcTc -> LPat GhcTc -> Int -> Int -> Pat GhcTc
forall p. XSumPat p -> LPat p -> Int -> Int -> Pat p
SumPat [Type]
XSumPat GhcTc
con_arg_tys LPat GhcTc
GenLocated SrcSpanAnnA (Pat GhcTc)
pat' Int
alt Int
arity) Type
pat_ty
, r
res)
}
ConPat XConPat (GhcPass 'Renamed)
_ XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
con HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats ->
PatEnv
-> GenLocated SrcSpanAnnN Name
-> Scaled ExpSigmaTypeFRR
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> TcM r
-> TcM (Pat GhcTc, r)
forall a.
PatEnv
-> GenLocated SrcSpanAnnN Name
-> Scaled ExpSigmaTypeFRR
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> TcM a
-> TcM (Pat GhcTc, a)
tcConPat PatEnv
penv XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
GenLocated SrcSpanAnnN Name
con Scaled ExpSigmaTypeFRR
pat_ty HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM r
thing_inside
LitPat XLitPat (GhcPass 'Renamed)
x HsLit (GhcPass 'Renamed)
simple_lit -> do
{ let lit_ty :: Type
lit_ty = HsLit (GhcPass 'Renamed) -> Type
forall (p :: Pass). HsLit (GhcPass p) -> Type
hsLitType HsLit (GhcPass 'Renamed)
simple_lit
; HsWrapper
wrap <- PatEnv -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tc_sub_type PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty) Type
lit_ty
; r
res <- TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ( HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
wrap (XLitPat GhcTc -> HsLit GhcTc -> Pat GhcTc
forall p. XLitPat p -> HsLit p -> Pat p
LitPat XLitPat (GhcPass 'Renamed)
XLitPat GhcTc
x (HsLit (GhcPass 'Renamed) -> HsLit GhcTc
forall (p1 :: Pass) (p2 :: Pass).
HsLit (GhcPass p1) -> HsLit (GhcPass p2)
convertLit HsLit (GhcPass 'Renamed)
simple_lit)) Type
pat_ty
, r
res) }
NPat XNPat (GhcPass 'Renamed)
_ (L EpAnnCO
l HsOverLit (GhcPass 'Renamed)
over_lit) Maybe (SyntaxExpr (GhcPass 'Renamed))
mb_neg SyntaxExpr (GhcPass 'Renamed)
eq -> do
{ HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
OtherPatternReason (Pat (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat (GhcPass 'Renamed)
ps_pat) Scaled ExpSigmaTypeFRR
pat_ty
; let orig :: CtOrigin
orig = HsOverLit (GhcPass 'Renamed) -> CtOrigin
LiteralOrigin HsOverLit (GhcPass 'Renamed)
over_lit
; ((HsOverLit GhcTc
lit', Maybe SyntaxExprTc
mb_neg'), SyntaxExprTc
eq')
<- CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> ExpSigmaTypeFRR
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc, Maybe SyntaxExprTc))
-> TcM ((HsOverLit GhcTc, Maybe SyntaxExprTc), SyntaxExprTc)
forall a.
CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> ExpSigmaTypeFRR
-> ([Type] -> [Type] -> TcM a)
-> TcM (a, SyntaxExprTc)
tcSyntaxOp CtOrigin
orig SyntaxExpr (GhcPass 'Renamed)
SyntaxExprRn
eq [ExpSigmaTypeFRR -> SyntaxOpType
SynType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty), SyntaxOpType
SynAny]
(Type -> ExpSigmaTypeFRR
mkCheckExpType Type
boolTy) (([Type] -> [Type] -> TcM (HsOverLit GhcTc, Maybe SyntaxExprTc))
-> TcM ((HsOverLit GhcTc, Maybe SyntaxExprTc), SyntaxExprTc))
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc, Maybe SyntaxExprTc))
-> TcM ((HsOverLit GhcTc, Maybe SyntaxExprTc), SyntaxExprTc)
forall a b. (a -> b) -> a -> b
$
\ [Type
neg_lit_ty] [Type]
_ ->
let new_over_lit :: Type -> TcM (HsOverLit GhcTc)
new_over_lit Type
lit_ty = HsOverLit (GhcPass 'Renamed)
-> ExpSigmaTypeFRR -> TcM (HsOverLit GhcTc)
newOverloadedLit HsOverLit (GhcPass 'Renamed)
over_lit
(Type -> ExpSigmaTypeFRR
mkCheckExpType Type
lit_ty)
in case Maybe (SyntaxExpr (GhcPass 'Renamed))
mb_neg of
Maybe (SyntaxExpr (GhcPass 'Renamed))
Nothing -> (, Maybe SyntaxExprTc
forall a. Maybe a
Nothing) (HsOverLit GhcTc -> (HsOverLit GhcTc, Maybe SyntaxExprTc))
-> TcM (HsOverLit GhcTc)
-> TcM (HsOverLit GhcTc, Maybe SyntaxExprTc)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Type -> TcM (HsOverLit GhcTc)
new_over_lit Type
neg_lit_ty
Just SyntaxExpr (GhcPass 'Renamed)
neg ->
(SyntaxExprTc -> Maybe SyntaxExprTc)
-> (HsOverLit GhcTc, SyntaxExprTc)
-> (HsOverLit GhcTc, Maybe SyntaxExprTc)
forall b c d. (b -> c) -> (d, b) -> (d, c)
forall (a :: * -> * -> *) b c d.
Arrow a =>
a b c -> a (d, b) (d, c)
second SyntaxExprTc -> Maybe SyntaxExprTc
forall a. a -> Maybe a
Just ((HsOverLit GhcTc, SyntaxExprTc)
-> (HsOverLit GhcTc, Maybe SyntaxExprTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc)
-> TcM (HsOverLit GhcTc, Maybe SyntaxExprTc)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$>
(CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> ExpSigmaTypeFRR
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc)
forall a.
CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> ExpSigmaTypeFRR
-> ([Type] -> [Type] -> TcM a)
-> TcM (a, SyntaxExprTc)
tcSyntaxOp CtOrigin
orig SyntaxExpr (GhcPass 'Renamed)
SyntaxExprRn
neg [SyntaxOpType
SynRho] (Type -> ExpSigmaTypeFRR
mkCheckExpType Type
neg_lit_ty) (([Type] -> [Type] -> TcM (HsOverLit GhcTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc))
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc)
forall a b. (a -> b) -> a -> b
$
\ [Type
lit_ty] [Type]
_ -> Type -> TcM (HsOverLit GhcTc)
new_over_lit Type
lit_ty)
; r
res <- TcM r
thing_inside
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
mult_wrap (XNPat GhcTc
-> XRec GhcTc (HsOverLit GhcTc)
-> Maybe (SyntaxExpr GhcTc)
-> SyntaxExpr GhcTc
-> Pat GhcTc
forall p.
XNPat p
-> XRec p (HsOverLit p)
-> Maybe (SyntaxExpr p)
-> SyntaxExpr p
-> Pat p
NPat XNPat GhcTc
Type
pat_ty (EpAnnCO -> HsOverLit GhcTc -> GenLocated EpAnnCO (HsOverLit GhcTc)
forall l e. l -> e -> GenLocated l e
L EpAnnCO
l HsOverLit GhcTc
lit') Maybe (SyntaxExpr GhcTc)
Maybe SyntaxExprTc
mb_neg' SyntaxExpr GhcTc
SyntaxExprTc
eq') Type
pat_ty, r
res) }
NPlusKPat XNPlusKPat (GhcPass 'Renamed)
_ (L SrcSpanAnnN
nm_loc Name
name)
(L EpAnnCO
loc HsOverLit (GhcPass 'Renamed)
lit) HsOverLit (GhcPass 'Renamed)
_ SyntaxExpr (GhcPass 'Renamed)
ge SyntaxExpr (GhcPass 'Renamed)
minus -> do
{ HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
OtherPatternReason (Pat (GhcPass 'Renamed)
-> GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
forall e a. HasAnnotation e => a -> GenLocated e a
noLocA Pat (GhcPass 'Renamed)
ps_pat) Scaled ExpSigmaTypeFRR
pat_ty
; let pat_exp_ty :: ExpSigmaTypeFRR
pat_exp_ty = Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty
orig :: CtOrigin
orig = HsOverLit (GhcPass 'Renamed) -> CtOrigin
LiteralOrigin HsOverLit (GhcPass 'Renamed)
lit
; (HsOverLit GhcTc
lit1', SyntaxExprTc
ge')
<- CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> ExpSigmaTypeFRR
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc)
forall a.
CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> ExpSigmaTypeFRR
-> ([Type] -> [Type] -> TcM a)
-> TcM (a, SyntaxExprTc)
tcSyntaxOp CtOrigin
orig SyntaxExpr (GhcPass 'Renamed)
SyntaxExprRn
ge [ExpSigmaTypeFRR -> SyntaxOpType
SynType ExpSigmaTypeFRR
pat_exp_ty, SyntaxOpType
SynRho]
(Type -> ExpSigmaTypeFRR
mkCheckExpType Type
boolTy) (([Type] -> [Type] -> TcM (HsOverLit GhcTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc))
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsOverLit GhcTc, SyntaxExprTc)
forall a b. (a -> b) -> a -> b
$
\ [Type
lit1_ty] [Type]
_ ->
HsOverLit (GhcPass 'Renamed)
-> ExpSigmaTypeFRR -> TcM (HsOverLit GhcTc)
newOverloadedLit HsOverLit (GhcPass 'Renamed)
lit (Type -> ExpSigmaTypeFRR
mkCheckExpType Type
lit1_ty)
; ((HsOverLit GhcTc
lit2', HsWrapper
minus_wrap, TyCoVar
bndr_id), SyntaxExprTc
minus')
<- CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> SyntaxOpType
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc, HsWrapper, TyCoVar))
-> TcM ((HsOverLit GhcTc, HsWrapper, TyCoVar), SyntaxExprTc)
forall a.
CtOrigin
-> SyntaxExprRn
-> [SyntaxOpType]
-> SyntaxOpType
-> ([Type] -> [Type] -> TcM a)
-> TcM (a, SyntaxExprTc)
tcSyntaxOpGen CtOrigin
orig SyntaxExpr (GhcPass 'Renamed)
SyntaxExprRn
minus [ExpSigmaTypeFRR -> SyntaxOpType
SynType ExpSigmaTypeFRR
pat_exp_ty, SyntaxOpType
SynRho] SyntaxOpType
SynAny (([Type] -> [Type] -> TcM (HsOverLit GhcTc, HsWrapper, TyCoVar))
-> TcM ((HsOverLit GhcTc, HsWrapper, TyCoVar), SyntaxExprTc))
-> ([Type] -> [Type] -> TcM (HsOverLit GhcTc, HsWrapper, TyCoVar))
-> TcM ((HsOverLit GhcTc, HsWrapper, TyCoVar), SyntaxExprTc)
forall a b. (a -> b) -> a -> b
$
\ [Type
lit2_ty, Type
var_ty] [Type]
_ ->
do { HsOverLit GhcTc
lit2' <- HsOverLit (GhcPass 'Renamed)
-> ExpSigmaTypeFRR -> TcM (HsOverLit GhcTc)
newOverloadedLit HsOverLit (GhcPass 'Renamed)
lit (Type -> ExpSigmaTypeFRR
mkCheckExpType Type
lit2_ty)
; (HsWrapper
wrap, TyCoVar
bndr_id) <- SrcSpanAnnN -> TcM (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar)
forall ann a. EpAnn ann -> TcRn a -> TcRn a
setSrcSpanA SrcSpanAnnN
nm_loc (TcM (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar))
-> TcM (HsWrapper, TyCoVar) -> TcM (HsWrapper, TyCoVar)
forall a b. (a -> b) -> a -> b
$
PatEnv
-> Name -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, TyCoVar)
tcPatBndr PatEnv
penv Name
name (ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a. a -> Scaled a
unrestricted (ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR)
-> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a b. (a -> b) -> a -> b
$ Type -> ExpSigmaTypeFRR
mkCheckExpType Type
var_ty)
; (HsOverLit GhcTc, HsWrapper, TyCoVar)
-> TcM (HsOverLit GhcTc, HsWrapper, TyCoVar)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsOverLit GhcTc
lit2', HsWrapper
wrap, TyCoVar
bndr_id) }
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType ExpSigmaTypeFRR
pat_exp_ty
; IOEnv (Env TcGblEnv TcLclEnv) Bool -> TcRn () -> TcRn ()
forall (m :: * -> *). Monad m => m Bool -> m () -> m ()
unlessM (Extension -> IOEnv (Env TcGblEnv TcLclEnv) Bool
forall gbl lcl. Extension -> TcRnIf gbl lcl Bool
xoptM Extension
LangExt.RebindableSyntax) (TcRn () -> TcRn ()) -> TcRn () -> TcRn ()
forall a b. (a -> b) -> a -> b
$
do { Class
icls <- Name -> TcM Class
tcLookupClass Name
integralClassName
; CtOrigin -> [Type] -> TcRn ()
instStupidTheta CtOrigin
orig [Class -> [Type] -> Type
mkClassPred Class
icls [Type
pat_ty]] }
; r
res <- Name -> TyCoVar -> TcM r -> TcM r
forall a. Name -> TyCoVar -> TcM a -> TcM a
tcExtendIdEnv1 Name
name TyCoVar
bndr_id TcM r
thing_inside
; let minus'' :: SyntaxExprTc
minus'' = case SyntaxExprTc
minus' of
SyntaxExprTc
NoSyntaxExprTc -> String -> SDoc -> SyntaxExprTc
forall a. HasCallStack => String -> SDoc -> a
pprPanic String
"tc_pat NoSyntaxExprTc" (SyntaxExprTc -> SDoc
forall a. Outputable a => a -> SDoc
ppr SyntaxExprTc
minus')
SyntaxExprTc { syn_expr :: SyntaxExprTc -> HsExpr GhcTc
syn_expr = HsExpr GhcTc
minus'_expr
, syn_arg_wraps :: SyntaxExprTc -> [HsWrapper]
syn_arg_wraps = [HsWrapper]
minus'_arg_wraps
, syn_res_wrap :: SyntaxExprTc -> HsWrapper
syn_res_wrap = HsWrapper
minus'_res_wrap }
-> SyntaxExprTc { syn_expr :: HsExpr GhcTc
syn_expr = HsExpr GhcTc
minus'_expr
, syn_arg_wraps :: [HsWrapper]
syn_arg_wraps = [HsWrapper]
minus'_arg_wraps
, syn_res_wrap :: HsWrapper
syn_res_wrap = HsWrapper
minus_wrap HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
minus'_res_wrap }
pat' :: Pat GhcTc
pat' = XNPlusKPat GhcTc
-> LIdP GhcTc
-> XRec GhcTc (HsOverLit GhcTc)
-> HsOverLit GhcTc
-> SyntaxExpr GhcTc
-> SyntaxExpr GhcTc
-> Pat GhcTc
forall p.
XNPlusKPat p
-> LIdP p
-> XRec p (HsOverLit p)
-> HsOverLit p
-> SyntaxExpr p
-> SyntaxExpr p
-> Pat p
NPlusKPat XNPlusKPat GhcTc
Type
pat_ty (SrcSpanAnnN -> TyCoVar -> GenLocated SrcSpanAnnN TyCoVar
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnN
nm_loc TyCoVar
bndr_id) (EpAnnCO -> HsOverLit GhcTc -> GenLocated EpAnnCO (HsOverLit GhcTc)
forall l e. l -> e -> GenLocated l e
L EpAnnCO
loc HsOverLit GhcTc
lit1') HsOverLit GhcTc
lit2'
SyntaxExpr GhcTc
SyntaxExprTc
ge' SyntaxExpr GhcTc
SyntaxExprTc
minus''
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
mult_wrap Pat GhcTc
pat' Type
pat_ty, r
res) }
SplicePat (HsUntypedSpliceTop ThModFinalizers
mod_finalizers Pat (GhcPass 'Renamed)
pat) HsUntypedSplice (GhcPass 'Renamed)
_ -> do
{ ThModFinalizers -> TcRn ()
addModFinalizersWithLclEnv ThModFinalizers
mod_finalizers
; Scaled ExpSigmaTypeFRR
-> Checker (Pat (GhcPass 'Renamed)) (Pat GhcTc)
tc_pat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv Pat (GhcPass 'Renamed)
pat TcM r
thing_inside }
SplicePat (HsUntypedSpliceNested Name
_) HsUntypedSplice (GhcPass 'Renamed)
_ -> String -> TcM (Pat GhcTc, r)
forall a. HasCallStack => String -> a
panic String
"tc_pat: nested splice in splice pat"
EmbTyPat XEmbTyPat (GhcPass 'Renamed)
_ HsTyPat (NoGhcTc (GhcPass 'Renamed))
_ -> TcRnMessage -> TcM (Pat GhcTc, r)
forall a. TcRnMessage -> TcRn a
failWith TcRnMessage
TcRnIllegalTypePattern
InvisPat XInvisPat (GhcPass 'Renamed)
_ HsTyPat (NoGhcTc (GhcPass 'Renamed))
_ -> String -> TcM (Pat GhcTc, r)
forall a. HasCallStack => String -> a
panic String
"tc_pat: invisible pattern appears recursively in the pattern"
XPat (HsPatExpanded Pat (GhcPass 'Renamed)
lpat Pat (GhcPass 'Renamed)
rpat) -> do
{ (Pat GhcTc
rpat', r
res) <- Scaled ExpSigmaTypeFRR
-> Checker (Pat (GhcPass 'Renamed)) (Pat GhcTc)
tc_pat Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv Pat (GhcPass 'Renamed)
rpat TcM r
thing_inside
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (XXPat GhcTc -> Pat GhcTc
forall p. XXPat p -> Pat p
XPat (XXPat GhcTc -> Pat GhcTc) -> XXPat GhcTc -> Pat GhcTc
forall a b. (a -> b) -> a -> b
$ Pat (GhcPass 'Renamed) -> Pat GhcTc -> XXPatGhcTc
ExpansionPat Pat (GhcPass 'Renamed)
lpat Pat GhcTc
rpat', r
res) }
tcPatSig :: Bool
-> HsPatSigType GhcRn
-> ExpSigmaType
-> TcM (TcType,
[(Name,TcTyVar)],
[(Name,TcTyVar)],
HsWrapper)
tcPatSig :: Bool
-> HsPatSigType (GhcPass 'Renamed)
-> ExpSigmaTypeFRR
-> TcM (Type, [(Name, TyCoVar)], [(Name, TyCoVar)], HsWrapper)
tcPatSig Bool
in_pat_bind HsPatSigType (GhcPass 'Renamed)
sig ExpSigmaTypeFRR
res_ty
= do { ([(Name, TyCoVar)]
sig_wcs, [(Name, TyCoVar)]
sig_tvs, Type
sig_ty) <- UserTypeCtxt
-> HoleMode
-> HsPatSigType (GhcPass 'Renamed)
-> ContextKind
-> TcM ([(Name, TyCoVar)], [(Name, TyCoVar)], Type)
tcHsPatSigType UserTypeCtxt
PatSigCtxt HoleMode
HM_Sig HsPatSigType (GhcPass 'Renamed)
sig ContextKind
OpenKind
; case [(Name, TyCoVar)] -> Maybe (NonEmpty (Name, TyCoVar))
forall a. [a] -> Maybe (NonEmpty a)
NE.nonEmpty [(Name, TyCoVar)]
sig_tvs of
Maybe (NonEmpty (Name, TyCoVar))
Nothing -> do {
HsWrapper
wrap <- (TidyEnv -> ZonkM (TidyEnv, SDoc))
-> TcM HsWrapper -> TcM HsWrapper
forall a. (TidyEnv -> ZonkM (TidyEnv, SDoc)) -> TcM a -> TcM a
addErrCtxtM (Type -> TidyEnv -> ZonkM (TidyEnv, SDoc)
mk_msg Type
sig_ty) (TcM HsWrapper -> TcM HsWrapper) -> TcM HsWrapper -> TcM HsWrapper
forall a b. (a -> b) -> a -> b
$
CtOrigin
-> UserTypeCtxt -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tcSubTypePat CtOrigin
PatSigOrigin UserTypeCtxt
PatSigCtxt ExpSigmaTypeFRR
res_ty Type
sig_ty
; (Type, [(Name, TyCoVar)], [(Name, TyCoVar)], HsWrapper)
-> TcM (Type, [(Name, TyCoVar)], [(Name, TyCoVar)], HsWrapper)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (Type
sig_ty, [], [(Name, TyCoVar)]
sig_wcs, HsWrapper
wrap)
}
Just NonEmpty (Name, TyCoVar)
sig_tvs_ne -> do
Bool -> TcRn () -> TcRn ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when Bool
in_pat_bind
(TcRnMessage -> TcRn ()
addErr (NonEmpty (Name, TyCoVar) -> TcRnMessage
TcRnCannotBindScopedTyVarInPatSig NonEmpty (Name, TyCoVar)
sig_tvs_ne))
HsWrapper
wrap <- (TidyEnv -> ZonkM (TidyEnv, SDoc))
-> TcM HsWrapper -> TcM HsWrapper
forall a. (TidyEnv -> ZonkM (TidyEnv, SDoc)) -> TcM a -> TcM a
addErrCtxtM (Type -> TidyEnv -> ZonkM (TidyEnv, SDoc)
mk_msg Type
sig_ty) (TcM HsWrapper -> TcM HsWrapper) -> TcM HsWrapper -> TcM HsWrapper
forall a b. (a -> b) -> a -> b
$
CtOrigin
-> UserTypeCtxt -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tcSubTypePat CtOrigin
PatSigOrigin UserTypeCtxt
PatSigCtxt ExpSigmaTypeFRR
res_ty Type
sig_ty
(Type, [(Name, TyCoVar)], [(Name, TyCoVar)], HsWrapper)
-> TcM (Type, [(Name, TyCoVar)], [(Name, TyCoVar)], HsWrapper)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (Type
sig_ty, [(Name, TyCoVar)]
sig_tvs, [(Name, TyCoVar)]
sig_wcs, HsWrapper
wrap)
}
where
mk_msg :: Type -> TidyEnv -> ZonkM (TidyEnv, SDoc)
mk_msg Type
sig_ty TidyEnv
tidy_env
= do { (TidyEnv
tidy_env, Type
sig_ty) <- TidyEnv -> Type -> ZonkM (TidyEnv, Type)
zonkTidyTcType TidyEnv
tidy_env Type
sig_ty
; Type
res_ty <- ExpSigmaTypeFRR -> ZonkM Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType ExpSigmaTypeFRR
res_ty
; (TidyEnv
tidy_env, Type
res_ty) <- TidyEnv -> Type -> ZonkM (TidyEnv, Type)
zonkTidyTcType TidyEnv
tidy_env Type
res_ty
; let msg :: SDoc
msg = [SDoc] -> SDoc
forall doc. IsDoc doc => [doc] -> doc
vcat [ SDoc -> Int -> SDoc -> SDoc
hang (String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"When checking that the pattern signature:")
Int
4 (Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
sig_ty)
, Int -> SDoc -> SDoc
nest Int
2 (SDoc -> Int -> SDoc -> SDoc
hang (String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"fits the type of its context:")
Int
2 (Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
res_ty)) ]
; (TidyEnv, SDoc) -> ZonkM (TidyEnv, SDoc)
forall a. a -> ZonkM a
forall (m :: * -> *) a. Monad m => a -> m a
return (TidyEnv
tidy_env, SDoc
msg) }
tcConPat :: PatEnv -> LocatedN Name
-> Scaled ExpSigmaTypeFRR
-> HsConPatDetails GhcRn -> TcM a
-> TcM (Pat GhcTc, a)
tcConPat :: forall a.
PatEnv
-> GenLocated SrcSpanAnnN Name
-> Scaled ExpSigmaTypeFRR
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> TcM a
-> TcM (Pat GhcTc, a)
tcConPat PatEnv
penv con_lname :: GenLocated SrcSpanAnnN Name
con_lname@(L SrcSpanAnnN
_ Name
con_name) Scaled ExpSigmaTypeFRR
pat_ty HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM a
thing_inside
= do { ConLike
con_like <- Name -> TcM ConLike
tcLookupConLike Name
con_name
; case ConLike
con_like of
RealDataCon DataCon
data_con -> GenLocated SrcSpanAnnN Name
-> DataCon
-> Scaled ExpSigmaTypeFRR
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(Pat GhcTc)
tcDataConPat GenLocated SrcSpanAnnN Name
con_lname DataCon
data_con Scaled ExpSigmaTypeFRR
pat_ty
PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM a
thing_inside
PatSynCon PatSyn
pat_syn -> GenLocated SrcSpanAnnN Name
-> PatSyn
-> Scaled ExpSigmaTypeFRR
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(Pat GhcTc)
tcPatSynPat GenLocated SrcSpanAnnN Name
con_lname PatSyn
pat_syn Scaled ExpSigmaTypeFRR
pat_ty
PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM a
thing_inside
}
warnMonoLocalBinds :: TcM ()
warnMonoLocalBinds :: TcRn ()
warnMonoLocalBinds
= do { Bool
mono_local_binds <- Extension -> IOEnv (Env TcGblEnv TcLclEnv) Bool
forall gbl lcl. Extension -> TcRnIf gbl lcl Bool
xoptM Extension
LangExt.MonoLocalBinds
; Bool -> TcRn () -> TcRn ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless Bool
mono_local_binds (TcRn () -> TcRn ()) -> TcRn () -> TcRn ()
forall a b. (a -> b) -> a -> b
$
TcRnMessage -> TcRn ()
addDiagnostic TcRnMessage
TcRnGADTMonoLocalBinds
}
tcDataConPat :: LocatedN Name -> DataCon
-> Scaled ExpSigmaTypeFRR
-> Checker (HsConPatDetails GhcRn) (Pat GhcTc)
tcDataConPat :: GenLocated SrcSpanAnnN Name
-> DataCon
-> Scaled ExpSigmaTypeFRR
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(Pat GhcTc)
tcDataConPat (L SrcSpanAnnN
con_span Name
con_name) DataCon
data_con Scaled ExpSigmaTypeFRR
pat_ty_scaled
PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM r
thing_inside
= do { let tycon :: TyCon
tycon = DataCon -> TyCon
dataConTyCon DataCon
data_con
([TyCoVar]
univ_tvs, [TyCoVar]
ex_tvs, [EqSpec]
eq_spec, [Type]
theta, [Scaled Type]
arg_tys, Type
_)
= DataCon
-> ([TyCoVar], [TyCoVar], [EqSpec], [Type], [Scaled Type], Type)
dataConFullSig DataCon
data_con
header :: GenLocated SrcSpanAnnN ConLike
header = SrcSpanAnnN -> ConLike -> GenLocated SrcSpanAnnN ConLike
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnN
con_span (DataCon -> ConLike
RealDataCon DataCon
data_con)
; (HsWrapper
wrap, [Type]
ctxt_res_tys) <- PatEnv
-> TyCon -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, [Type])
matchExpectedConTy PatEnv
penv TyCon
tycon Scaled ExpSigmaTypeFRR
pat_ty_scaled
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty_scaled)
; SrcSpanAnnN -> TcRn () -> TcRn ()
forall ann a. EpAnn ann -> TcRn a -> TcRn a
setSrcSpanA SrcSpanAnnN
con_span (TcRn () -> TcRn ()) -> TcRn () -> TcRn ()
forall a b. (a -> b) -> a -> b
$ DataCon -> [Type] -> TcRn ()
addDataConStupidTheta DataCon
data_con [Type]
ctxt_res_tys
; let all_arg_tys :: [Type]
all_arg_tys = [EqSpec] -> [Type]
eqSpecPreds [EqSpec]
eq_spec [Type] -> [Type] -> [Type]
forall a. [a] -> [a] -> [a]
++ [Type]
theta [Type] -> [Type] -> [Type]
forall a. [a] -> [a] -> [a]
++ ((Scaled Type -> Type) -> [Scaled Type] -> [Type]
forall a b. (a -> b) -> [a] -> [b]
map Scaled Type -> Type
forall a. Scaled a -> a
scaledThing [Scaled Type]
arg_tys)
; ConLike -> [TyCoVar] -> [Type] -> PatEnv -> TcRn ()
checkGADT (DataCon -> ConLike
RealDataCon DataCon
data_con) [TyCoVar]
ex_tvs [Type]
all_arg_tys PatEnv
penv
; Subst
tenv1 <- CtOrigin -> [TyCoVar] -> [Type] -> TcM Subst
instTyVarsWith CtOrigin
PatOrigin [TyCoVar]
univ_tvs [Type]
ctxt_res_tys
; let mc :: HsMatchContextRn
mc = case PatEnv -> PatCtxt
pe_ctxt PatEnv
penv of
LamPat HsMatchContextRn
mc -> HsMatchContextRn
mc
LetPat {} -> HsMatchContextRn
HsMatchContext (GenLocated SrcSpanAnnN Name)
forall fn. HsMatchContext fn
PatBindRhs
; SkolemInfo
skol_info <- SkolemInfoAnon -> IOEnv (Env TcGblEnv TcLclEnv) SkolemInfo
forall (m :: * -> *). MonadIO m => SkolemInfoAnon -> m SkolemInfo
mkSkolemInfo (ConLike -> HsMatchContextRn -> SkolemInfoAnon
PatSkol (DataCon -> ConLike
RealDataCon DataCon
data_con) HsMatchContextRn
mc)
; (Subst
tenv, [TyCoVar]
ex_tvs') <- SkolemInfo -> Subst -> [TyCoVar] -> TcM (Subst, [TyCoVar])
tcInstSuperSkolTyVarsX SkolemInfo
skol_info Subst
tenv1 [TyCoVar]
ex_tvs
; let arg_tys' :: [Scaled Type]
arg_tys' = HasDebugCallStack => Subst -> [Scaled Type] -> [Scaled Type]
Subst -> [Scaled Type] -> [Scaled Type]
substScaledTys Subst
tenv [Scaled Type]
arg_tys
pat_mult :: Type
pat_mult = Scaled ExpSigmaTypeFRR -> Type
forall a. Scaled a -> Type
scaledMult Scaled ExpSigmaTypeFRR
pat_ty_scaled
arg_tys_scaled :: [Scaled Type]
arg_tys_scaled = (Scaled Type -> Scaled Type) -> [Scaled Type] -> [Scaled Type]
forall a b. (a -> b) -> [a] -> [b]
map (Type -> Scaled Type -> Scaled Type
forall a. Type -> Scaled a -> Scaled a
scaleScaled Type
pat_mult) [Scaled Type]
arg_tys'
con_like :: ConLike
con_like = DataCon -> ConLike
RealDataCon DataCon
data_con
; DataCon -> [Scaled Type] -> TcRn ()
checkFixedRuntimeRep DataCon
data_con [Scaled Type]
arg_tys'
; String -> SDoc -> TcRn ()
traceTc String
"tcConPat" ([SDoc] -> SDoc
forall doc. IsDoc doc => [doc] -> doc
vcat [ String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"con_name:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> Name -> SDoc
forall a. Outputable a => a -> SDoc
ppr Name
con_name
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"univ_tvs:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [TyCoVar] -> SDoc
pprTyVars [TyCoVar]
univ_tvs
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"ex_tvs:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [TyCoVar] -> SDoc
pprTyVars [TyCoVar]
ex_tvs
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"eq_spec:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [EqSpec] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [EqSpec]
eq_spec
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"theta:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Type]
theta
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"ex_tvs':" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [TyCoVar] -> SDoc
pprTyVars [TyCoVar]
ex_tvs'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"ctxt_res_tys:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Type]
ctxt_res_tys
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"pat_ty:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
pat_ty
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"arg_tys':" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Scaled Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Scaled Type]
arg_tys'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"arg_pats" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)))
(HsRecFields
(GhcPass 'Renamed)
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))))
-> SDoc
forall a. Outputable a => a -> SDoc
ppr HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)))
(HsRecFields
(GhcPass 'Renamed)
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))))
arg_pats ])
; ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
univ_ty_args, [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
ex_ty_args) <- ConLike
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
splitConTyArgs ConLike
con_like HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats
; if [TyCoVar] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [TyCoVar]
ex_tvs Bool -> Bool -> Bool
&& [EqSpec] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [EqSpec]
eq_spec Bool -> Bool -> Bool
&& [Type] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [Type]
theta
then do {
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
arg_pats', r
res) <- Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a.
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
tcConTyArgs Subst
tenv PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
univ_ty_args (TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a b. (a -> b) -> a -> b
$
ConLike
-> [Scaled Type]
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(HsConPatDetails GhcTc)
tcConValArgs ConLike
con_like [Scaled Type]
arg_tys_scaled
PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM r
thing_inside
; let res_pat :: Pat GhcTc
res_pat = ConPat { pat_con :: XRec GhcTc (ConLikeP GhcTc)
pat_con = XRec GhcTc (ConLikeP GhcTc)
GenLocated SrcSpanAnnN ConLike
header
, pat_args :: HsConPatDetails GhcTc
pat_args = HsConPatDetails GhcTc
HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
arg_pats'
, pat_con_ext :: XConPat GhcTc
pat_con_ext = ConPatTc
{ cpt_tvs :: [TyCoVar]
cpt_tvs = [], cpt_dicts :: [TyCoVar]
cpt_dicts = []
, cpt_binds :: TcEvBinds
cpt_binds = TcEvBinds
emptyTcEvBinds
, cpt_arg_tys :: [Type]
cpt_arg_tys = [Type]
ctxt_res_tys
, cpt_wrap :: HsWrapper
cpt_wrap = HsWrapper
idHsWrapper
}
}
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
wrap Pat GhcTc
res_pat Type
pat_ty, r
res) }
else do
{ let theta' :: [Type]
theta' = HasDebugCallStack => Subst -> [Type] -> [Type]
Subst -> [Type] -> [Type]
substTheta Subst
tenv ([EqSpec] -> [Type]
eqSpecPreds [EqSpec]
eq_spec [Type] -> [Type] -> [Type]
forall a. [a] -> [a] -> [a]
++ [Type]
theta)
; Bool -> TcRn () -> TcRn ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Bool -> Bool
not ([EqSpec] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [EqSpec]
eq_spec) Bool -> Bool -> Bool
|| (Type -> Bool) -> [Type] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any Type -> Bool
isEqPred [Type]
theta) TcRn ()
warnMonoLocalBinds
; [TyCoVar]
given <- [Type] -> TcM [TyCoVar]
newEvVars [Type]
theta'
; (TcEvBinds
ev_binds, (HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
arg_pats', r
res))
<-
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall a.
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
tcConTyArgs Subst
tenv PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
univ_ty_args (TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall a b. (a -> b) -> a -> b
$
SkolemInfoAnon
-> [TyCoVar]
-> [TyCoVar]
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall result.
SkolemInfoAnon
-> [TyCoVar] -> [TyCoVar] -> TcM result -> TcM (TcEvBinds, result)
checkConstraints (SkolemInfo -> SkolemInfoAnon
getSkolemInfo SkolemInfo
skol_info) [TyCoVar]
ex_tvs' [TyCoVar]
given (TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)))
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall a b. (a -> b) -> a -> b
$
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a.
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
tcConTyArgs Subst
tenv PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
ex_ty_args (TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a b. (a -> b) -> a -> b
$
ConLike
-> [Scaled Type]
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(HsConPatDetails GhcTc)
tcConValArgs ConLike
con_like [Scaled Type]
arg_tys_scaled PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM r
thing_inside
; let res_pat :: Pat GhcTc
res_pat = ConPat
{ pat_con :: XRec GhcTc (ConLikeP GhcTc)
pat_con = XRec GhcTc (ConLikeP GhcTc)
GenLocated SrcSpanAnnN ConLike
header
, pat_args :: HsConPatDetails GhcTc
pat_args = HsConPatDetails GhcTc
HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
arg_pats'
, pat_con_ext :: XConPat GhcTc
pat_con_ext = ConPatTc
{ cpt_tvs :: [TyCoVar]
cpt_tvs = [TyCoVar]
ex_tvs'
, cpt_dicts :: [TyCoVar]
cpt_dicts = [TyCoVar]
given
, cpt_binds :: TcEvBinds
cpt_binds = TcEvBinds
ev_binds
, cpt_arg_tys :: [Type]
cpt_arg_tys = [Type]
ctxt_res_tys
, cpt_wrap :: HsWrapper
cpt_wrap = HsWrapper
idHsWrapper
}
}
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat HsWrapper
wrap Pat GhcTc
res_pat Type
pat_ty, r
res)
} }
tcPatSynPat :: LocatedN Name -> PatSyn
-> Scaled ExpSigmaType
-> Checker (HsConPatDetails GhcRn) (Pat GhcTc)
tcPatSynPat :: GenLocated SrcSpanAnnN Name
-> PatSyn
-> Scaled ExpSigmaTypeFRR
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(Pat GhcTc)
tcPatSynPat (L SrcSpanAnnN
con_span Name
con_name) PatSyn
pat_syn Scaled ExpSigmaTypeFRR
pat_ty PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats TcM r
thing_inside
= do { let ([TyCoVar]
univ_tvs, [Type]
req_theta, [TyCoVar]
ex_tvs, [Type]
prov_theta, [Scaled Type]
arg_tys, Type
ty) = PatSyn
-> ([TyCoVar], [Type], [TyCoVar], [Type], [Scaled Type], Type)
patSynSig PatSyn
pat_syn
; (Subst
subst, [TyCoVar]
univ_tvs') <- [TyCoVar] -> TcM (Subst, [TyCoVar])
newMetaTyVars [TyCoVar]
univ_tvs
; let all_arg_tys :: [Type]
all_arg_tys = Type
ty Type -> [Type] -> [Type]
forall a. a -> [a] -> [a]
: [Type]
prov_theta [Type] -> [Type] -> [Type]
forall a. [a] -> [a] -> [a]
++ ((Scaled Type -> Type) -> [Scaled Type] -> [Type]
forall a b. (a -> b) -> [a] -> [b]
map Scaled Type -> Type
forall a. Scaled a -> a
scaledThing [Scaled Type]
arg_tys)
; ConLike -> [TyCoVar] -> [Type] -> PatEnv -> TcRn ()
checkGADT (PatSyn -> ConLike
PatSynCon PatSyn
pat_syn) [TyCoVar]
ex_tvs [Type]
all_arg_tys PatEnv
penv
; SkolemInfo
skol_info <- case PatEnv -> PatCtxt
pe_ctxt PatEnv
penv of
LamPat HsMatchContextRn
mc -> SkolemInfoAnon -> IOEnv (Env TcGblEnv TcLclEnv) SkolemInfo
forall (m :: * -> *). MonadIO m => SkolemInfoAnon -> m SkolemInfo
mkSkolemInfo (ConLike -> HsMatchContextRn -> SkolemInfoAnon
PatSkol (PatSyn -> ConLike
PatSynCon PatSyn
pat_syn) HsMatchContextRn
mc)
LetPat {} -> SkolemInfo -> IOEnv (Env TcGblEnv TcLclEnv) SkolemInfo
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return SkolemInfo
HasCallStack => SkolemInfo
unkSkol
; (Subst
tenv, [TyCoVar]
ex_tvs') <- SkolemInfo -> Subst -> [TyCoVar] -> TcM (Subst, [TyCoVar])
tcInstSuperSkolTyVarsX SkolemInfo
skol_info Subst
subst [TyCoVar]
ex_tvs
; let ty' :: Type
ty' = HasDebugCallStack => Subst -> Type -> Type
Subst -> Type -> Type
substTy Subst
tenv Type
ty
arg_tys' :: [Scaled Type]
arg_tys' = HasDebugCallStack => Subst -> [Scaled Type] -> [Scaled Type]
Subst -> [Scaled Type] -> [Scaled Type]
substScaledTys Subst
tenv [Scaled Type]
arg_tys
pat_mult :: Type
pat_mult = Scaled ExpSigmaTypeFRR -> Type
forall a. Scaled a -> Type
scaledMult Scaled ExpSigmaTypeFRR
pat_ty
arg_tys_scaled :: [Scaled Type]
arg_tys_scaled = (Scaled Type -> Scaled Type) -> [Scaled Type] -> [Scaled Type]
forall a b. (a -> b) -> [a] -> [b]
map (Type -> Scaled Type -> Scaled Type
forall a. Type -> Scaled a -> Scaled a
scaleScaled Type
pat_mult) [Scaled Type]
arg_tys'
prov_theta' :: [Type]
prov_theta' = HasDebugCallStack => Subst -> [Type] -> [Type]
Subst -> [Type] -> [Type]
substTheta Subst
tenv [Type]
prov_theta
req_theta' :: [Type]
req_theta' = HasDebugCallStack => Subst -> [Type] -> [Type]
Subst -> [Type] -> [Type]
substTheta Subst
tenv [Type]
req_theta
con_like :: ConLike
con_like = PatSyn -> ConLike
PatSynCon PatSyn
pat_syn
; Bool -> TcRn () -> TcRn ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when ((Type -> Bool) -> [Type] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any Type -> Bool
isEqPred [Type]
prov_theta) TcRn ()
warnMonoLocalBinds
; HsWrapper
mult_wrap <- NonLinearPatternReason
-> LPat (GhcPass 'Renamed)
-> Scaled ExpSigmaTypeFRR
-> TcM HsWrapper
forall a.
NonLinearPatternReason
-> LPat (GhcPass 'Renamed) -> Scaled a -> TcM HsWrapper
checkManyPattern NonLinearPatternReason
PatternSynonymReason LPat (GhcPass 'Renamed)
nlWildPatName Scaled ExpSigmaTypeFRR
pat_ty
; ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
univ_ty_args, [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
ex_ty_args) <- ConLike
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
splitConTyArgs ConLike
con_like HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats
; HsWrapper
wrap <- PatEnv -> ExpSigmaTypeFRR -> Type -> TcM HsWrapper
tc_sub_type PatEnv
penv (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty) Type
ty'
; String -> SDoc -> TcRn ()
traceTc String
"tcPatSynPat" (SDoc -> TcRn ()) -> SDoc -> TcRn ()
forall a b. (a -> b) -> a -> b
$
[SDoc] -> SDoc
forall doc. IsDoc doc => [doc] -> doc
vcat [ String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"Pat syn:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> PatSyn -> SDoc
forall a. Outputable a => a -> SDoc
ppr PatSyn
pat_syn
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"Expected type:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> Scaled ExpSigmaTypeFRR -> SDoc
forall a. Outputable a => a -> SDoc
ppr Scaled ExpSigmaTypeFRR
pat_ty
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"Pat res ty:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
ty'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"ex_tvs':" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [TyCoVar] -> SDoc
pprTyVars [TyCoVar]
ex_tvs'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"prov_theta':" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Type]
prov_theta'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"req_theta':" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Type]
req_theta'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"arg_tys':" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Scaled Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Scaled Type]
arg_tys'
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"univ_ty_args:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
univ_ty_args
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"ex_ty_args:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
ex_ty_args ]
; HsWrapper
req_wrap <- CtOrigin -> [Type] -> [Type] -> TcM HsWrapper
instCall (Name -> CtOrigin
OccurrenceOf Name
con_name) ([TyCoVar] -> [Type]
mkTyVarTys [TyCoVar]
univ_tvs') [Type]
req_theta'
; String -> SDoc -> TcRn ()
traceTc String
"instCall" (HsWrapper -> SDoc
forall a. Outputable a => a -> SDoc
ppr HsWrapper
req_wrap)
; let
bad_arg_tys :: [(Int, Scaled Type)]
bad_arg_tys :: [(Int, Scaled Type)]
bad_arg_tys = ((Int, Scaled Type) -> Bool)
-> [(Int, Scaled Type)] -> [(Int, Scaled Type)]
forall a. (a -> Bool) -> [a] -> [a]
filter (\ (Int
_, Scaled Type
_ Type
arg_ty) -> Bool -> Bool
not (HasDebugCallStack => Type -> Bool
Type -> Bool
typeHasFixedRuntimeRep Type
arg_ty))
([(Int, Scaled Type)] -> [(Int, Scaled Type)])
-> [(Int, Scaled Type)] -> [(Int, Scaled Type)]
forall a b. (a -> b) -> a -> b
$ [Int] -> [Scaled Type] -> [(Int, Scaled Type)]
forall a b. [a] -> [b] -> [(a, b)]
zip [Int
0..] [Scaled Type]
arg_tys'
; Bool -> SDoc -> TcRn ()
forall (m :: * -> *).
(HasCallStack, Applicative m) =>
Bool -> SDoc -> m ()
massertPpr ([(Int, Scaled Type)] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [(Int, Scaled Type)]
bad_arg_tys) (SDoc -> TcRn ()) -> SDoc -> TcRn ()
forall a b. (a -> b) -> a -> b
$
[SDoc] -> SDoc
forall doc. IsDoc doc => [doc] -> doc
vcat [ String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"tcPatSynPat: pattern arguments do not have a fixed RuntimeRep"
, String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"bad_arg_tys:" SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [(Int, Scaled Type)] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [(Int, Scaled Type)]
bad_arg_tys ]
; String -> SDoc -> TcRn ()
traceTc String
"checkConstraints {" SDoc
forall doc. IsOutput doc => doc
Outputable.empty
; [TyCoVar]
prov_dicts' <- [Type] -> TcM [TyCoVar]
newEvVars [Type]
prov_theta'
; (TcEvBinds
ev_binds, (HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
arg_pats', r
res))
<-
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall a.
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
tcConTyArgs Subst
tenv PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
univ_ty_args (TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall a b. (a -> b) -> a -> b
$
SkolemInfoAnon
-> [TyCoVar]
-> [TyCoVar]
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall result.
SkolemInfoAnon
-> [TyCoVar] -> [TyCoVar] -> TcM result -> TcM (TcEvBinds, result)
checkConstraints (SkolemInfo -> SkolemInfoAnon
getSkolemInfo SkolemInfo
skol_info) [TyCoVar]
ex_tvs' [TyCoVar]
prov_dicts' (TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)))
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(TcEvBinds,
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
forall a b. (a -> b) -> a -> b
$
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a.
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
tcConTyArgs Subst
tenv PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
ex_ty_args (TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r))
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> TcM
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a b. (a -> b) -> a -> b
$
ConLike
-> [Scaled Type]
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(HsConPatDetails GhcTc)
tcConValArgs ConLike
con_like [Scaled Type]
arg_tys_scaled PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
arg_pats (TcM r -> TcM (HsConPatDetails GhcTc, r))
-> TcM r -> TcM (HsConPatDetails GhcTc, r)
forall a b. (a -> b) -> a -> b
$
TcM r
thing_inside
; String -> SDoc -> TcRn ()
traceTc String
"checkConstraints }" (TcEvBinds -> SDoc
forall a. Outputable a => a -> SDoc
ppr TcEvBinds
ev_binds)
; let res_pat :: Pat GhcTc
res_pat = ConPat { pat_con :: XRec GhcTc (ConLikeP GhcTc)
pat_con = SrcSpanAnnN -> ConLike -> GenLocated SrcSpanAnnN ConLike
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnN
con_span (ConLike -> GenLocated SrcSpanAnnN ConLike)
-> ConLike -> GenLocated SrcSpanAnnN ConLike
forall a b. (a -> b) -> a -> b
$ PatSyn -> ConLike
PatSynCon PatSyn
pat_syn
, pat_args :: HsConPatDetails GhcTc
pat_args = HsConPatDetails GhcTc
HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
arg_pats'
, pat_con_ext :: XConPat GhcTc
pat_con_ext = ConPatTc
{ cpt_tvs :: [TyCoVar]
cpt_tvs = [TyCoVar]
ex_tvs'
, cpt_dicts :: [TyCoVar]
cpt_dicts = [TyCoVar]
prov_dicts'
, cpt_binds :: TcEvBinds
cpt_binds = TcEvBinds
ev_binds
, cpt_arg_tys :: [Type]
cpt_arg_tys = [TyCoVar] -> [Type]
mkTyVarTys [TyCoVar]
univ_tvs'
, cpt_wrap :: HsWrapper
cpt_wrap = HsWrapper
req_wrap
}
}
; Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
forall (m :: * -> *). MonadIO m => ExpSigmaTypeFRR -> m Type
readExpType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
pat_ty)
; (Pat GhcTc, r) -> TcM (Pat GhcTc, r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsWrapper -> Pat GhcTc -> Type -> Pat GhcTc
mkHsWrapPat (HsWrapper
wrap HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
mult_wrap) Pat GhcTc
res_pat Type
pat_ty, r
res) }
checkFixedRuntimeRep :: DataCon -> [Scaled TcSigmaTypeFRR] -> TcM ()
checkFixedRuntimeRep :: DataCon -> [Scaled Type] -> TcRn ()
checkFixedRuntimeRep DataCon
data_con [Scaled Type]
arg_tys
= (Int -> Scaled Type -> TcRn ())
-> [Int] -> [Scaled Type] -> TcRn ()
forall (m :: * -> *) a b c.
Applicative m =>
(a -> b -> m c) -> [a] -> [b] -> m ()
zipWithM_ Int -> Scaled Type -> TcRn ()
check_one [Int
1..] [Scaled Type]
arg_tys
where
check_one :: Int -> Scaled Type -> TcRn ()
check_one Int
i Scaled Type
arg_ty = HasDebugCallStack => FixedRuntimeRepContext -> Type -> TcRn ()
FixedRuntimeRepContext -> Type -> TcRn ()
hasFixedRuntimeRep_syntactic
(DataCon -> Int -> FixedRuntimeRepContext
FRRDataConPatArg DataCon
data_con Int
i)
(Scaled Type -> Type
forall a. Scaled a -> a
scaledThing Scaled Type
arg_ty)
matchExpectedPatTy :: (TcRhoType -> TcM (TcCoercionN, a))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, a)
matchExpectedPatTy :: forall a.
(Type -> TcM (TcCoercionN, a))
-> PatEnv -> ExpSigmaTypeFRR -> TcM (HsWrapper, a)
matchExpectedPatTy Type -> TcM (TcCoercionN, a)
inner_match (PE { pe_orig :: PatEnv -> CtOrigin
pe_orig = CtOrigin
orig }) ExpSigmaTypeFRR
pat_ty
= do { Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
expTypeToType ExpSigmaTypeFRR
pat_ty
; (HsWrapper
wrap, Type
pat_rho) <- CtOrigin -> Type -> TcM (HsWrapper, Type)
topInstantiate CtOrigin
orig Type
pat_ty
; (TcCoercionN
co, a
res) <- Type -> TcM (TcCoercionN, a)
inner_match Type
pat_rho
; String -> SDoc -> TcRn ()
traceTc String
"matchExpectedPatTy" (Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
pat_ty SDoc -> SDoc -> SDoc
forall doc. IsDoc doc => doc -> doc -> doc
$$ HsWrapper -> SDoc
forall a. Outputable a => a -> SDoc
ppr HsWrapper
wrap)
; (HsWrapper, a) -> TcM (HsWrapper, a)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (TcCoercionN -> HsWrapper
mkWpCastN (TcCoercionN -> TcCoercionN
mkSymCo TcCoercionN
co) HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
wrap, a
res) }
matchExpectedConTy :: PatEnv
-> TyCon
-> Scaled ExpSigmaTypeFRR
-> TcM (HsWrapper, [TcSigmaType])
matchExpectedConTy :: PatEnv
-> TyCon -> Scaled ExpSigmaTypeFRR -> TcM (HsWrapper, [Type])
matchExpectedConTy (PE { pe_orig :: PatEnv -> CtOrigin
pe_orig = CtOrigin
orig }) TyCon
data_tc Scaled ExpSigmaTypeFRR
exp_pat_ty
| Just (TyCon
fam_tc, [Type]
fam_args, CoAxiom Unbranched
co_tc) <- TyCon -> Maybe (TyCon, [Type], CoAxiom Unbranched)
tyConFamInstSig_maybe TyCon
data_tc
= do { Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
expTypeToType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
exp_pat_ty)
; (HsWrapper
wrap, Type
pat_rho) <- CtOrigin -> Type -> TcM (HsWrapper, Type)
topInstantiate CtOrigin
orig Type
pat_ty
; (Subst
subst, [TyCoVar]
tvs') <- [TyCoVar] -> TcM (Subst, [TyCoVar])
newMetaTyVars (TyCon -> [TyCoVar]
tyConTyVars TyCon
data_tc)
; String -> SDoc -> TcRn ()
traceTc String
"matchExpectedConTy" ([SDoc] -> SDoc
forall doc. IsDoc doc => [doc] -> doc
vcat [TyCon -> SDoc
forall a. Outputable a => a -> SDoc
ppr TyCon
data_tc,
[TyCoVar] -> SDoc
forall a. Outputable a => a -> SDoc
ppr (TyCon -> [TyCoVar]
tyConTyVars TyCon
data_tc),
TyCon -> SDoc
forall a. Outputable a => a -> SDoc
ppr TyCon
fam_tc, [Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Type]
fam_args,
Scaled ExpSigmaTypeFRR -> SDoc
forall a. Outputable a => a -> SDoc
ppr Scaled ExpSigmaTypeFRR
exp_pat_ty,
Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
pat_ty,
Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Type
pat_rho, HsWrapper -> SDoc
forall a. Outputable a => a -> SDoc
ppr HsWrapper
wrap])
; TcCoercionN
co1 <- Maybe TypedThing -> Type -> Type -> TcM TcCoercionN
unifyType Maybe TypedThing
forall a. Maybe a
Nothing (TyCon -> [Type] -> Type
mkTyConApp TyCon
fam_tc (HasDebugCallStack => Subst -> [Type] -> [Type]
Subst -> [Type] -> [Type]
substTys Subst
subst [Type]
fam_args)) Type
pat_rho
; let tys' :: [Type]
tys' = [TyCoVar] -> [Type]
mkTyVarTys [TyCoVar]
tvs'
co2 :: TcCoercionN
co2 = Role
-> CoAxiom Unbranched -> [Type] -> [TcCoercionN] -> TcCoercionN
mkUnbranchedAxInstCo Role
Representational CoAxiom Unbranched
co_tc [Type]
tys' []
full_co :: TcCoercionN
full_co = HasDebugCallStack => TcCoercionN -> TcCoercionN
TcCoercionN -> TcCoercionN
mkSubCo (TcCoercionN -> TcCoercionN
mkSymCo TcCoercionN
co1) TcCoercionN -> TcCoercionN -> TcCoercionN
`mkTransCo` TcCoercionN
co2
; (HsWrapper, [Type]) -> TcM (HsWrapper, [Type])
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ( TcCoercionN -> HsWrapper
mkWpCastR TcCoercionN
full_co HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
wrap, [Type]
tys') }
| Bool
otherwise
= do { Type
pat_ty <- ExpSigmaTypeFRR -> IOEnv (Env TcGblEnv TcLclEnv) Type
expTypeToType (Scaled ExpSigmaTypeFRR -> ExpSigmaTypeFRR
forall a. Scaled a -> a
scaledThing Scaled ExpSigmaTypeFRR
exp_pat_ty)
; (HsWrapper
wrap, Type
pat_rho) <- CtOrigin -> Type -> TcM (HsWrapper, Type)
topInstantiate CtOrigin
orig Type
pat_ty
; (TcCoercionN
coi, [Type]
tys) <- TyCon -> Type -> TcM (TcCoercionN, [Type])
matchExpectedTyConApp TyCon
data_tc Type
pat_rho
; (HsWrapper, [Type]) -> TcM (HsWrapper, [Type])
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (TcCoercionN -> HsWrapper
mkWpCastN (TcCoercionN -> TcCoercionN
mkSymCo TcCoercionN
coi) HsWrapper -> HsWrapper -> HsWrapper
<.> HsWrapper
wrap, [Type]
tys) }
tcConValArgs :: ConLike
-> [Scaled TcSigmaTypeFRR]
-> Checker (HsConPatDetails GhcRn) (HsConPatDetails GhcTc)
tcConValArgs :: ConLike
-> [Scaled Type]
-> Checker
(HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))))
(HsConPatDetails GhcTc)
tcConValArgs ConLike
con_like [Scaled Type]
arg_tys PatEnv
penv HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
con_args TcM r
thing_inside = case HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
con_args of
PrefixCon [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
type_args [LPat (GhcPass 'Renamed)]
arg_pats -> do
{ Bool -> TcRnMessage -> TcRn ()
checkTc (Int
con_arity Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
== Int
no_of_args)
(TyThing -> Int -> Int -> TcRnMessage
TcRnArityMismatch (ConLike -> TyThing
AConLike ConLike
con_like) Int
con_arity Int
no_of_args)
; let pats_w_tys :: [(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)]
pats_w_tys = String
-> [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
-> [Scaled Type]
-> [(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)]
forall a b. HasDebugCallStack => String -> [a] -> [b] -> [(a, b)]
zipEqual String
"tcConArgs" [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
arg_pats [Scaled Type]
arg_tys
; ([GenLocated SrcSpanAnnA (Pat GhcTc)]
arg_pats', r
res) <- Checker
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)
(GenLocated SrcSpanAnnA (Pat GhcTc))
-> Checker
[(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)]
[GenLocated SrcSpanAnnA (Pat GhcTc)]
forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple PatEnv
-> (LPat (GhcPass 'Renamed), Scaled Type)
-> TcM r
-> TcM (LPat GhcTc, r)
PatEnv
-> (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)
-> TcM r
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
Checker (LPat (GhcPass 'Renamed), Scaled Type) (LPat GhcTc)
Checker
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)
(GenLocated SrcSpanAnnA (Pat GhcTc))
tcConArg PatEnv
penv [(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)]
pats_w_tys TcM r
thing_inside
; (HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> IOEnv
(Env TcGblEnv TcLclEnv)
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([HsConPatTyArg (GhcPass 'Renamed)]
-> [GenLocated SrcSpanAnnA (Pat GhcTc)]
-> HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
forall tyarg arg rec.
[tyarg] -> [arg] -> HsConDetails tyarg arg rec
PrefixCon [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
[HsConPatTyArg (GhcPass 'Renamed)]
type_args [GenLocated SrcSpanAnnA (Pat GhcTc)]
arg_pats', r
res) }
where
con_arity :: Int
con_arity = ConLike -> Int
conLikeArity ConLike
con_like
no_of_args :: Int
no_of_args = [GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [LPat (GhcPass 'Renamed)]
[GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))]
arg_pats
InfixCon LPat (GhcPass 'Renamed)
p1 LPat (GhcPass 'Renamed)
p2 -> do
{ Bool -> TcRnMessage -> TcRn ()
checkTc (Int
con_arity Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
== Int
2)
(TyThing -> Int -> Int -> TcRnMessage
TcRnArityMismatch (ConLike -> TyThing
AConLike ConLike
con_like) Int
con_arity Int
2)
; let [Scaled Type
arg_ty1,Scaled Type
arg_ty2] = [Scaled Type]
arg_tys
; ([GenLocated SrcSpanAnnA (Pat GhcTc)
p1',GenLocated SrcSpanAnnA (Pat GhcTc)
p2'], r
res) <- Checker
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)
(GenLocated SrcSpanAnnA (Pat GhcTc))
-> Checker
[(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)]
[GenLocated SrcSpanAnnA (Pat GhcTc)]
forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple PatEnv
-> (LPat (GhcPass 'Renamed), Scaled Type)
-> TcM r
-> TcM (LPat GhcTc, r)
PatEnv
-> (GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)
-> TcM r
-> IOEnv
(Env TcGblEnv TcLclEnv) (GenLocated SrcSpanAnnA (Pat GhcTc), r)
Checker (LPat (GhcPass 'Renamed), Scaled Type) (LPat GhcTc)
Checker
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)), Scaled Type)
(GenLocated SrcSpanAnnA (Pat GhcTc))
tcConArg PatEnv
penv [(LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p1,Scaled Type
arg_ty1),(LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
p2,Scaled Type
arg_ty2)]
TcM r
thing_inside
; (HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> IOEnv
(Env TcGblEnv TcLclEnv)
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (GenLocated SrcSpanAnnA (Pat GhcTc)
-> GenLocated SrcSpanAnnA (Pat GhcTc)
-> HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
forall tyarg arg rec. arg -> arg -> HsConDetails tyarg arg rec
InfixCon GenLocated SrcSpanAnnA (Pat GhcTc)
p1' GenLocated SrcSpanAnnA (Pat GhcTc)
p2', r
res) }
where
con_arity :: Int
con_arity = ConLike -> Int
conLikeArity ConLike
con_like
RecCon (HsRecFields [LHsRecField (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))]
rpats Maybe (XRec (GhcPass 'Renamed) RecFieldsDotDot)
dd) -> do
{ ([GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc)))]
rpats', r
res) <- Checker
(GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)))))
(GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))))
-> Checker
[GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))))]
[GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc)))]
forall inp out. Checker inp out -> Checker [inp] [out]
tcMultiple PatEnv
-> LHsRecField (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))
-> TcM r
-> TcM (LHsRecField GhcTc (LPat GhcTc), r)
PatEnv
-> GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))))
-> TcM r
-> IOEnv
(Env TcGblEnv TcLclEnv)
(GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
Checker
(LHsRecField (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
(LHsRecField GhcTc (LPat GhcTc))
Checker
(GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)))))
(GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))))
tc_field PatEnv
penv [LHsRecField (GhcPass 'Renamed) (LPat (GhcPass 'Renamed))]
[GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))))]
rpats TcM r
thing_inside
; (HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> IOEnv
(Env TcGblEnv TcLclEnv)
(HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))
-> HsConDetails
(HsConPatTyArg (GhcPass 'Renamed))
(GenLocated SrcSpanAnnA (Pat GhcTc))
(HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc)))
forall tyarg arg rec. rec -> HsConDetails tyarg arg rec
RecCon ([LHsRecField GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))]
-> Maybe (XRec GhcTc RecFieldsDotDot)
-> HsRecFields GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))
forall p arg.
[LHsRecField p arg]
-> Maybe (XRec p RecFieldsDotDot) -> HsRecFields p arg
HsRecFields [LHsRecField GhcTc (GenLocated SrcSpanAnnA (Pat GhcTc))]
[GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc)))]
rpats' Maybe (XRec (GhcPass 'Renamed) RecFieldsDotDot)
Maybe (XRec GhcTc RecFieldsDotDot)
dd), r
res) }
where
tc_field :: Checker (LHsRecField GhcRn (LPat GhcRn))
(LHsRecField GhcTc (LPat GhcTc))
tc_field :: Checker
(LHsRecField (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
(LHsRecField GhcTc (LPat GhcTc))
tc_field PatEnv
penv
(L SrcSpanAnnA
l (HsFieldBind XHsFieldBind (GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
ann (L SrcSpanAnnA
loc (FieldOcc XCFieldOcc (GhcPass 'Renamed)
sel (L SrcSpanAnnN
lr RdrName
rdr))) GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
pat Bool
pun))
TcM r
thing_inside
= do { TyCoVar
sel' <- Name -> TcM TyCoVar
tcLookupId XCFieldOcc (GhcPass 'Renamed)
Name
sel
; Scaled Type
pat_ty <- SrcSpanAnnA -> TcRn (Scaled Type) -> TcRn (Scaled Type)
forall ann a. EpAnn ann -> TcRn a -> TcRn a
setSrcSpanA SrcSpanAnnA
loc (TcRn (Scaled Type) -> TcRn (Scaled Type))
-> TcRn (Scaled Type) -> TcRn (Scaled Type)
forall a b. (a -> b) -> a -> b
$ Name -> FastString -> TcRn (Scaled Type)
find_field_ty XCFieldOcc (GhcPass 'Renamed)
Name
sel
(OccName -> FastString
occNameFS (OccName -> FastString) -> OccName -> FastString
forall a b. (a -> b) -> a -> b
$ RdrName -> OccName
rdrNameOcc RdrName
rdr)
; (GenLocated SrcSpanAnnA (Pat GhcTc)
pat', r
res) <- PatEnv
-> (LPat (GhcPass 'Renamed), Scaled Type)
-> TcM r
-> TcM (LPat GhcTc, r)
Checker (LPat (GhcPass 'Renamed), Scaled Type) (LPat GhcTc)
tcConArg PatEnv
penv (LPat (GhcPass 'Renamed)
GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))
pat, Scaled Type
pat_ty) TcM r
thing_inside
; (GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
-> IOEnv
(Env TcGblEnv TcLclEnv)
(GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))),
r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (SrcSpanAnnA
-> HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))
-> GenLocated
SrcSpanAnnA
(HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc)))
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnA
l (XHsFieldBind (GenLocated SrcSpanAnnA (FieldOcc GhcTc))
-> GenLocated SrcSpanAnnA (FieldOcc GhcTc)
-> GenLocated SrcSpanAnnA (Pat GhcTc)
-> Bool
-> HsFieldBind
(GenLocated SrcSpanAnnA (FieldOcc GhcTc))
(GenLocated SrcSpanAnnA (Pat GhcTc))
forall lhs rhs.
XHsFieldBind lhs -> lhs -> rhs -> Bool -> HsFieldBind lhs rhs
HsFieldBind XHsFieldBind (GenLocated SrcSpanAnnA (FieldOcc (GhcPass 'Renamed)))
XHsFieldBind (GenLocated SrcSpanAnnA (FieldOcc GhcTc))
ann (SrcSpanAnnA
-> FieldOcc GhcTc -> GenLocated SrcSpanAnnA (FieldOcc GhcTc)
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnA
loc (XCFieldOcc GhcTc -> XRec GhcTc RdrName -> FieldOcc GhcTc
forall pass. XCFieldOcc pass -> XRec pass RdrName -> FieldOcc pass
FieldOcc XCFieldOcc GhcTc
TyCoVar
sel' (SrcSpanAnnN -> RdrName -> GenLocated SrcSpanAnnN RdrName
forall l e. l -> e -> GenLocated l e
L SrcSpanAnnN
lr RdrName
rdr))) GenLocated SrcSpanAnnA (Pat GhcTc)
pat'
Bool
pun), r
res) }
find_field_ty :: Name -> FastString -> TcM (Scaled TcType)
find_field_ty :: Name -> FastString -> TcRn (Scaled Type)
find_field_ty Name
sel FastString
lbl
= case [Scaled Type
ty | (FieldLabel
fl, Scaled Type
ty) <- [(FieldLabel, Scaled Type)]
field_tys, FieldLabel -> Name
flSelector FieldLabel
fl Name -> Name -> Bool
forall a. Eq a => a -> a -> Bool
== Name
sel ] of
[] -> TcRnMessage -> TcRn (Scaled Type)
forall a. TcRnMessage -> TcRn a
failWith (Name -> FieldLabelString -> TcRnMessage
badFieldConErr (ConLike -> Name
forall a. NamedThing a => a -> Name
getName ConLike
con_like) (FastString -> FieldLabelString
FieldLabelString FastString
lbl))
(Scaled Type
pat_ty : [Scaled Type]
extras) -> do
String -> SDoc -> TcRn ()
traceTc String
"find_field" (Scaled Type -> SDoc
forall a. Outputable a => a -> SDoc
ppr Scaled Type
pat_ty SDoc -> SDoc -> SDoc
forall doc. IsLine doc => doc -> doc -> doc
<+> [Scaled Type] -> SDoc
forall a. Outputable a => a -> SDoc
ppr [Scaled Type]
extras)
Bool -> TcRn (Scaled Type) -> TcRn (Scaled Type)
forall a. HasCallStack => Bool -> a -> a
assert ([Scaled Type] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [Scaled Type]
extras) (Scaled Type -> TcRn (Scaled Type)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return Scaled Type
pat_ty)
field_tys :: [(FieldLabel, Scaled TcType)]
field_tys :: [(FieldLabel, Scaled Type)]
field_tys = [FieldLabel] -> [Scaled Type] -> [(FieldLabel, Scaled Type)]
forall a b. [a] -> [b] -> [(a, b)]
zip (ConLike -> [FieldLabel]
conLikeFieldLabels ConLike
con_like) [Scaled Type]
arg_tys
splitConTyArgs :: ConLike -> HsConPatDetails GhcRn
-> TcM ( [(HsConPatTyArg GhcRn, TyVar)]
, [(HsConPatTyArg GhcRn, TyVar)] )
splitConTyArgs :: ConLike
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
splitConTyArgs ConLike
con_like (PrefixCon [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
type_args [LPat (GhcPass 'Renamed)]
_)
= do { Bool -> TcRnMessage -> TcRn ()
checkTc ([HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
[HsConPatTyArg (GhcPass 'Renamed)]
type_args [HsConPatTyArg (GhcPass 'Renamed)] -> [TyCoVar] -> Bool
forall a b. [a] -> [b] -> Bool
`leLength` [TyCoVar]
con_spec_bndrs)
(ConLike -> Int -> Int -> TcRnMessage
TcRnTooManyTyArgsInConPattern ConLike
con_like
([TyCoVar] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [TyCoVar]
con_spec_bndrs) ([HsConPatTyArg (GhcPass 'Renamed)] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
[HsConPatTyArg (GhcPass 'Renamed)]
type_args))
; if [TyCoVar] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [TyCoVar]
ex_tvs
then ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
bndr_ty_arg_prs, [])
else ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (((HsConPatTyArg (GhcPass 'Renamed), TyCoVar) -> Bool)
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
forall a. (a -> Bool) -> [a] -> ([a], [a])
partition (HsConPatTyArg (GhcPass 'Renamed), TyCoVar) -> Bool
is_universal [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
bndr_ty_arg_prs) }
where
ex_tvs :: [TyCoVar]
ex_tvs = ConLike -> [TyCoVar]
conLikeExTyCoVars ConLike
con_like
con_spec_bndrs :: [TyCoVar]
con_spec_bndrs = [ TyCoVar
tv | Bndr TyCoVar
tv Specificity
SpecifiedSpec <- ConLike -> [VarBndr TyCoVar Specificity]
conLikeUserTyVarBinders ConLike
con_like ]
bndr_ty_arg_prs :: [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
bndr_ty_arg_prs = [HsConPatTyArg (NoGhcTc (GhcPass 'Renamed))]
[HsConPatTyArg (GhcPass 'Renamed)]
type_args [HsConPatTyArg (GhcPass 'Renamed)]
-> [TyCoVar] -> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
forall a b. [a] -> [b] -> [(a, b)]
`zip` [TyCoVar]
con_spec_bndrs
is_universal :: (HsConPatTyArg (GhcPass 'Renamed), TyCoVar) -> Bool
is_universal (HsConPatTyArg (GhcPass 'Renamed)
_, TyCoVar
tv) = Bool -> Bool
not (TyCoVar
tv TyCoVar -> [TyCoVar] -> Bool
forall a. Eq a => a -> [a] -> Bool
forall (t :: * -> *) a. (Foldable t, Eq a) => a -> t a -> Bool
`elem` [TyCoVar]
ex_tvs)
splitConTyArgs ConLike
_ (RecCon {}) = ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([], [])
splitConTyArgs ConLike
_ (InfixCon {}) = ([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
-> TcM
([(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)],
[(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)])
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ([], [])
tcConTyArgs :: Subst -> PatEnv -> [(HsConPatTyArg GhcRn, TyVar)]
-> TcM a -> TcM a
tcConTyArgs :: forall a.
Subst
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
tcConTyArgs Subst
tenv PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
prs TcM a
thing_inside
= Checker (HsConPatTyArg (GhcPass 'Renamed), TyCoVar) ()
-> PatEnv
-> [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
-> TcM a
-> TcM a
forall inp r. Checker inp () -> PatEnv -> [inp] -> TcM r -> TcM r
tcMultiple_ (Subst -> Checker (HsConPatTyArg (GhcPass 'Renamed), TyCoVar) ()
tcConTyArg Subst
tenv) PatEnv
penv [(HsConPatTyArg (GhcPass 'Renamed), TyCoVar)]
prs TcM a
thing_inside
tcConTyArg :: Subst -> Checker (HsConPatTyArg GhcRn, TyVar) ()
tcConTyArg :: Subst -> Checker (HsConPatTyArg (GhcPass 'Renamed), TyCoVar) ()
tcConTyArg Subst
tenv PatEnv
penv (HsConPatTyArg XConPatTyArg (GhcPass 'Renamed)
_ HsTyPat (GhcPass 'Renamed)
rn_ty, TyCoVar
con_tv) TcM r
thing_inside
= do { ([(Name, TyCoVar)]
sig_wcs, [(Name, TyCoVar)]
sig_ibs, Type
arg_ty) <- HsTyPat (GhcPass 'Renamed)
-> Type -> TcM ([(Name, TyCoVar)], [(Name, TyCoVar)], Type)
tcHsTyPat HsTyPat (GhcPass 'Renamed)
rn_ty (HasDebugCallStack => Subst -> Type -> Type
Subst -> Type -> Type
substTy Subst
tenv (TyCoVar -> Type
varType TyCoVar
con_tv))
; case [(Name, TyCoVar)] -> Maybe (NonEmpty (Name, TyCoVar))
forall a. [a] -> Maybe (NonEmpty a)
NE.nonEmpty [(Name, TyCoVar)]
sig_ibs of
Just NonEmpty (Name, TyCoVar)
sig_ibs_ne | PatEnv -> Bool
inPatBind PatEnv
penv ->
TcRnMessage -> TcRn ()
addErr (NonEmpty (Name, TyCoVar) -> TcRnMessage
TcRnCannotBindTyVarsInPatBind NonEmpty (Name, TyCoVar)
sig_ibs_ne)
Maybe (NonEmpty (Name, TyCoVar))
_ -> () -> TcRn ()
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ()
; TcCoercionN
_ <- Maybe TypedThing -> Type -> Type -> TcM TcCoercionN
unifyType Maybe TypedThing
forall a. Maybe a
Nothing Type
arg_ty (Subst -> TyCoVar -> Type
substTyVar Subst
tenv TyCoVar
con_tv)
; r
result <- [(Name, TyCoVar)] -> TcM r -> TcM r
forall r. [(Name, TyCoVar)] -> TcM r -> TcM r
tcExtendNameTyVarEnv [(Name, TyCoVar)]
sig_wcs (TcM r -> TcM r) -> TcM r -> TcM r
forall a b. (a -> b) -> a -> b
$
[(Name, TyCoVar)] -> TcM r -> TcM r
forall r. [(Name, TyCoVar)] -> TcM r -> TcM r
tcExtendNameTyVarEnv [(Name, TyCoVar)]
sig_ibs (TcM r -> TcM r) -> TcM r -> TcM r
forall a b. (a -> b) -> a -> b
$
TcM r
thing_inside
; ((), r) -> TcM ((), r)
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ((), r
result) }
tcConArg :: Checker (LPat GhcRn, Scaled TcSigmaType) (LPat GhcTc)
tcConArg :: Checker (LPat (GhcPass 'Renamed), Scaled Type) (LPat GhcTc)
tcConArg PatEnv
penv (LPat (GhcPass 'Renamed)
arg_pat, Scaled Type
arg_mult Type
arg_ty)
= Scaled ExpSigmaTypeFRR
-> Checker (LPat (GhcPass 'Renamed)) (LPat GhcTc)
tc_lpat (Type -> ExpSigmaTypeFRR -> Scaled ExpSigmaTypeFRR
forall a. Type -> a -> Scaled a
Scaled Type
arg_mult (Type -> ExpSigmaTypeFRR
mkCheckExpType Type
arg_ty)) PatEnv
penv LPat (GhcPass 'Renamed)
arg_pat
addDataConStupidTheta :: DataCon -> [TcType] -> TcM ()
addDataConStupidTheta :: DataCon -> [Type] -> TcRn ()
addDataConStupidTheta DataCon
data_con [Type]
inst_tys
| [Type] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [Type]
stupid_theta = () -> TcRn ()
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
| Bool
otherwise = CtOrigin -> [Type] -> TcRn ()
instStupidTheta CtOrigin
origin [Type]
inst_theta
where
origin :: CtOrigin
origin = Name -> CtOrigin
OccurrenceOf (DataCon -> Name
dataConName DataCon
data_con)
stupid_theta :: [Type]
stupid_theta = DataCon -> [Type]
dataConStupidTheta DataCon
data_con
univ_tvs :: [TyCoVar]
univ_tvs = DataCon -> [TyCoVar]
dataConUnivTyVars DataCon
data_con
tenv :: Subst
tenv = [TyCoVar] -> [Type] -> Subst
HasDebugCallStack => [TyCoVar] -> [Type] -> Subst
zipTvSubst [TyCoVar]
univ_tvs ([TyCoVar] -> [Type] -> [Type]
forall b a. [b] -> [a] -> [a]
takeList [TyCoVar]
univ_tvs [Type]
inst_tys)
inst_theta :: [Type]
inst_theta = HasDebugCallStack => Subst -> [Type] -> [Type]
Subst -> [Type] -> [Type]
substTheta Subst
tenv [Type]
stupid_theta
maybeWrapPatCtxt :: Pat GhcRn -> (TcM a -> TcM b) -> TcM a -> TcM b
maybeWrapPatCtxt :: forall a b.
Pat (GhcPass 'Renamed) -> (TcM a -> TcM b) -> TcM a -> TcM b
maybeWrapPatCtxt Pat (GhcPass 'Renamed)
pat TcM a -> TcM b
tcm TcM a
thing_inside
| Bool -> Bool
not (Pat (GhcPass 'Renamed) -> Bool
forall p. Pat p -> Bool
worth_wrapping Pat (GhcPass 'Renamed)
pat) = TcM a -> TcM b
tcm TcM a
thing_inside
| Bool
otherwise = SDoc -> TcM b -> TcM b
forall a. SDoc -> TcM a -> TcM a
addErrCtxt SDoc
msg (TcM b -> TcM b) -> TcM b -> TcM b
forall a b. (a -> b) -> a -> b
$ TcM a -> TcM b
tcm (TcM a -> TcM b) -> TcM a -> TcM b
forall a b. (a -> b) -> a -> b
$ TcM a -> TcM a
forall a. TcM a -> TcM a
popErrCtxt TcM a
thing_inside
where
worth_wrapping :: Pat p -> Bool
worth_wrapping (VarPat {}) = Bool
False
worth_wrapping (ParPat {}) = Bool
False
worth_wrapping (AsPat {}) = Bool
False
worth_wrapping Pat p
_ = Bool
True
msg :: SDoc
msg = SDoc -> Int -> SDoc -> SDoc
hang (String -> SDoc
forall doc. IsLine doc => String -> doc
text String
"In the pattern:") Int
2 (Pat (GhcPass 'Renamed) -> SDoc
forall a. Outputable a => a -> SDoc
ppr Pat (GhcPass 'Renamed)
pat)
checkGADT :: ConLike
-> [TyVar]
-> [Type]
-> PatEnv
-> TcM ()
checkGADT :: ConLike -> [TyCoVar] -> [Type] -> PatEnv -> TcRn ()
checkGADT ConLike
conlike [TyCoVar]
ex_tvs [Type]
arg_tys = \case
PE { pe_ctxt :: PatEnv -> PatCtxt
pe_ctxt = LetPat {} }
-> () -> TcRn ()
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
PE { pe_ctxt :: PatEnv -> PatCtxt
pe_ctxt = LamPat (ArrowMatchCtxt {}) }
| Bool -> Bool
not (Bool -> Bool) -> Bool -> Bool
forall a b. (a -> b) -> a -> b
$ ConLike -> Bool
isVanillaConLike ConLike
conlike
-> TcRnMessage -> TcRn ()
forall a. TcRnMessage -> TcRn a
failWithTc TcRnMessage
TcRnArrowProcGADTPattern
PE { pe_lazy :: PatEnv -> Bool
pe_lazy = Bool
True }
| Bool
has_existentials
-> TcRnMessage -> TcRn ()
forall a. TcRnMessage -> TcRn a
failWithTc TcRnMessage
TcRnLazyGADTPattern
PatEnv
_ -> () -> TcRn ()
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
where
has_existentials :: Bool
has_existentials :: Bool
has_existentials = (TyCoVar -> Bool) -> [TyCoVar] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
any (TyCoVar -> VarSet -> Bool
`elemVarSet` [Type] -> VarSet
tyCoVarsOfTypes [Type]
arg_tys) [TyCoVar]
ex_tvs
isIrrefutableHsPatRnTcM :: Bool -> LPat GhcRn -> TcM Bool
isIrrefutableHsPatRnTcM :: Bool
-> LPat (GhcPass 'Renamed) -> IOEnv (Env TcGblEnv TcLclEnv) Bool
isIrrefutableHsPatRnTcM Bool
is_strict = LPatIrrefutableCheck
(IOEnv (Env TcGblEnv TcLclEnv)) (GhcPass 'Renamed)
forall (m :: * -> *) (p :: Pass).
(Monad m, OutputableBndrId p) =>
LPatIrrefutableCheck m (GhcPass p)
isIrrefutableHsPatHelperM Bool
is_strict Bool
-> XRec (GhcPass 'Renamed) (ConLikeP (GhcPass 'Renamed))
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass 'Renamed)))
(LPat (GhcPass 'Renamed))
(HsRecFields (GhcPass 'Renamed) (LPat (GhcPass 'Renamed)))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
Bool
-> GenLocated (Anno (ConLikeP (GhcPass 'Renamed))) Name
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass 'Renamed)))
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed)))
(HsRecFields
(GhcPass 'Renamed)
(GenLocated SrcSpanAnnA (Pat (GhcPass 'Renamed))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
forall {p :: Pass}.
(ConLikeP (GhcPass p) ~ Name, OutputableBndr (IdGhcP p),
OutputableBndr (IdGhcP (NoGhcTcPass p)), IsPass p,
Outputable (GenLocated (Anno (IdGhcP p)) (IdGhcP p)),
Outputable
(GenLocated
(Anno (IdGhcP (NoGhcTcPass p))) (IdGhcP (NoGhcTcPass p)))) =>
Bool
-> GenLocated (Anno (ConLikeP (GhcPass p))) Name
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
isConLikeIrr
where
doWork :: Bool
-> GenLocated SrcSpanAnnA (Pat (GhcPass p))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
doWork Bool
is_strict = LPatIrrefutableCheck (IOEnv (Env TcGblEnv TcLclEnv)) (GhcPass p)
forall (m :: * -> *) (p :: Pass).
(Monad m, OutputableBndrId p) =>
LPatIrrefutableCheck m (GhcPass p)
isIrrefutableHsPatHelperM Bool
is_strict Bool
-> XRec (GhcPass p) (ConLikeP (GhcPass p))
-> HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass p)))
(XRec (GhcPass p) (Pat (GhcPass p)))
(HsRecFields (GhcPass p) (XRec (GhcPass p) (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
Bool
-> GenLocated (Anno (ConLikeP (GhcPass p))) Name
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
isConLikeIrr
isConLikeIrr :: Bool
-> GenLocated (Anno (ConLikeP (GhcPass p))) Name
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
isConLikeIrr Bool
is_strict (L Anno (ConLikeP (GhcPass p))
_ Name
dcName) HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
details =
do { TyThing
tyth <- Name -> TcM TyThing
tcLookupGlobal Name
dcName
; case TyThing
tyth of
(ATyCon TyCon
tycon) -> Bool
-> TyCon
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
doCheck Bool
is_strict TyCon
tycon HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
details
(AConLike ConLike
cl) ->
case ConLike
cl of
RealDataCon DataCon
dc -> Bool
-> TyCon
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
doCheck Bool
is_strict (DataCon -> TyCon
dataConTyCon DataCon
dc) HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
details
PatSynCon PatSyn
_pat -> Bool -> IOEnv (Env TcGblEnv TcLclEnv) Bool
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return Bool
False
TyThing
_ -> Bool -> IOEnv (Env TcGblEnv TcLclEnv) Bool
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return Bool
False
}
doCheck :: Bool
-> TyCon
-> HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
doCheck Bool
is_strict TyCon
tycon HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
details = do { let b :: Bool
b = Maybe DataCon -> Bool
forall a. Maybe a -> Bool
isJust (TyCon -> Maybe DataCon
tyConSingleDataCon_maybe TyCon
tycon)
; [Bool]
bs <- (GenLocated SrcSpanAnnA (Pat (GhcPass p))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool)
-> [GenLocated SrcSpanAnnA (Pat (GhcPass p))]
-> IOEnv (Env TcGblEnv TcLclEnv) [Bool]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> [a] -> m [b]
mapM (Bool
-> GenLocated SrcSpanAnnA (Pat (GhcPass p))
-> IOEnv (Env TcGblEnv TcLclEnv) Bool
doWork Bool
is_strict) (HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass p)))
(XRec (GhcPass p) (Pat (GhcPass p)))
(HsRecFields (GhcPass p) (XRec (GhcPass p) (Pat (GhcPass p))))
-> [XRec (GhcPass p) (Pat (GhcPass p))]
forall p. UnXRec p => HsConPatDetails p -> [LPat p]
hsConPatArgs HsConDetails
(HsConPatTyArg (NoGhcTc (GhcPass p)))
(XRec (GhcPass p) (Pat (GhcPass p)))
(HsRecFields (GhcPass p) (XRec (GhcPass p) (Pat (GhcPass p))))
HsConDetails
(HsConPatTyArg (GhcPass (NoGhcTcPass p)))
(GenLocated SrcSpanAnnA (Pat (GhcPass p)))
(HsRecFields
(GhcPass p) (GenLocated SrcSpanAnnA (Pat (GhcPass p))))
details)
; Bool -> IOEnv (Env TcGblEnv TcLclEnv) Bool
forall a. a -> IOEnv (Env TcGblEnv TcLclEnv) a
forall (m :: * -> *) a. Monad m => a -> m a
return (Bool
b Bool -> Bool -> Bool
&& [Bool] -> Bool
forall (t :: * -> *). Foldable t => t Bool -> Bool
and [Bool]
bs) }