| SigPatOut (LPat id) -- Pattern with a type signature
Type
- ------------ Dictionary patterns (translation only) ---------------
- | DictPat -- Used when destructing Dictionaries with an explicit case
- [id] -- Superclass dicts
- [id] -- Methods
-
------------ Pattern coercions (translation only) ---------------
| CoPat HsWrapper -- If co::t1 -> t2, p::t2,
-- then (CoPat co p) :: t1
pprPat (CoPat co pat _) = parens (pprHsWrapper (ppr pat) co)
pprPat (SigPatIn pat ty) = ppr pat <+> dcolon <+> ppr ty
pprPat (SigPatOut pat ty) = ppr pat <+> dcolon <+> ppr ty
-pprPat (DictPat ds ms) = parens (sep [ptext SLIT("{-dict-}"),
- brackets (interpp'SP ds),
- brackets (interpp'SP ms)])
pprUserCon c (InfixCon p1 p2) = ppr p1 <+> ppr c <+> ppr p2
pprUserCon c details = ppr c <+> pprConArgs details
isConPat (ListPat {}) = True
isConPat (PArrPat {}) = True
isConPat (TuplePat {}) = True
-isConPat (DictPat ds ms) = (length ds + length ms) > 1
isConPat other = False
isSigPat (SigPatIn _ _) = True
go1 (NPlusKPat _ _ _ _) = False
go1 (TypePat _) = panic "isIrrefutableHsPat: type pattern"
- go1 (DictPat _ _) = panic "isIrrefutableHsPat: type pattern"
\end{code}