diff options
| author | Simon Peyton Jones <simonpj@microsoft.com> | 2017-07-27 14:45:54 +0100 | 
|---|---|---|
| committer | Simon Peyton Jones <simonpj@microsoft.com> | 2017-07-28 09:31:55 +0100 | 
| commit | 6b77914cd37b697354611bcd87897885c1e5b4a6 (patch) | |
| tree | f52b7bd7e2cea8bf63decb5b6d943cdda1f49fdc /compiler/deSugar/Check.hs | |
| parent | 7af0b906116e13fbd90f43f2f6c6b826df2dca77 (diff) | |
| download | haskell-6b77914cd37b697354611bcd87897885c1e5b4a6.tar.gz | |
Fix instantiation of pattern synonyms
In Check.hs (pattern match ovelap checking) we to figure out the
instantiation of a pattern synonym from the type of the pattern. We
were doing this utterly wrongly.  Trac #13768 demonstrated this
bogosity.
The fix is easy; and is described in PatSyn.hs
  Note [Pattern synonym result type]
Diffstat (limited to 'compiler/deSugar/Check.hs')
| -rw-r--r-- | compiler/deSugar/Check.hs | 17 | 
1 files changed, 9 insertions, 8 deletions
| diff --git a/compiler/deSugar/Check.hs b/compiler/deSugar/Check.hs index cb9837ed0c..ce114e727b 100644 --- a/compiler/deSugar/Check.hs +++ b/compiler/deSugar/Check.hs @@ -18,7 +18,7 @@ module Check (  #include "HsVersions.h"  import TmOracle - +import Unify( tcMatchTy )  import BasicTypes  import DynFlags  import HsSyn @@ -45,6 +45,7 @@ import Var           (EvVar)  import Type  import UniqSupply  import DsGRHSs       (isTrueLHsExpr) +import Maybes        ( expectJust )  import Data.List     (find)  import Data.Maybe    (isJust, fromMaybe) @@ -971,14 +972,14 @@ mkOneConFull :: Id -> ConLike -> DsM (ValAbs, ComplexEq, Bag EvVar)  --          ComplexEq:       x ~ K y1..yn  --          [EvVar]:         Q  mkOneConFull x con = do -  let -- res_ty == TyConApp (ConLikeTyCon cabs_con) cabs_arg_tys -      res_ty  = idType x -      (univ_tvs, ex_tvs, eq_spec, thetas, _req_theta , arg_tys, _) +  let res_ty  = idType x +      (univ_tvs, ex_tvs, eq_spec, thetas, _req_theta , arg_tys, con_res_ty)          = conLikeFullSig con -      tc_args = case splitTyConApp_maybe res_ty of -                  Just (_, tys) -> tys -                  Nothing -> pprPanic "mkOneConFull: Not TyConApp:" (ppr res_ty) -      subst1  = zipTvSubst univ_tvs tc_args +      tc_args = tyConAppArgs res_ty +      subst1  = case con of +                  RealDataCon {} -> zipTvSubst univ_tvs tc_args +                  PatSynCon {}   -> expectJust "mkOneConFull" (tcMatchTy con_res_ty res_ty) +                                    -- See Note [Pattern synonym result type] in PatSyn    (subst, ex_tvs') <- cloneTyVarBndrs subst1 ex_tvs <$> getUniqueSupplyM | 
