diff options
author | Ryan Scott <ryan.gl.scott@gmail.com> | 2019-01-15 16:02:07 -0500 |
---|---|---|
committer | Ryan Scott <ryan.gl.scott@gmail.com> | 2019-01-15 16:02:07 -0500 |
commit | e63518f5d6a93be111f9108c0990a1162f88d615 (patch) | |
tree | 884e3f0e82ac213b7263fd9142453a0a0b9f52c1 /compiler | |
parent | 83a22066fbe136e4a984e8c90c1d3fd72b6ec4b9 (diff) | |
download | haskell-e63518f5d6a93be111f9108c0990a1162f88d615.tar.gz |
Fix #16116 by removing badAssocRhs
Diffstat (limited to 'compiler')
-rw-r--r-- | compiler/rename/RnSource.hs | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/compiler/rename/RnSource.hs b/compiler/rename/RnSource.hs index e5fe3a3a31..0699f80858 100644 --- a/compiler/rename/RnSource.hs +++ b/compiler/rename/RnSource.hs @@ -784,14 +784,6 @@ rnFamInstEqn doc mb_cls rhs_kvars ++ map hsLTyVarName bndrs' ; warnUnusedTypePatterns all_nms nms_used - -- See Note [Renaming associated types] - ; let bad_tvs = maybe [] (filter is_bad . snd) mb_cls - var_name_set = mkNameSet (map hsLTyVarName bndrs' - ++ all_imp_var_names) - is_bad cls_tkv = cls_tkv `elemNameSet` rhs_fvs - && not (cls_tkv `elemNameSet` var_name_set) - ; unless (null bad_tvs) (badAssocRhs bad_tvs) - ; return ((bndrs', pats', payload'), rhs_fvs `plusFV` pat_fvs) } ; let all_fvs = fvs `addOneFV` unLoc tycon' @@ -999,6 +991,21 @@ can all be in scope (Trac #5862): id :: Ob x a => x a a (.) :: (Ob x a, Ob x b, Ob x c) => x b c -> x a b -> x a c Here 'k' is in scope in the kind signature, just like 'x'. + +Although type family equations can bind type variables with explicit foralls, +it need not be the case that all variables that appear on the RHS must be bound +by a forall. For instance, the following is acceptable: + + class C a where + type T a b + instance C (Maybe a) where + type forall b. T (Maybe a) b = Either a b + +Even though `a` is not bound by the forall, this is still accepted because `a` +was previously bound by the `instance C (Maybe a)` part. (see Trac #16116). + +In each case, the function which detects improperly bound variables on the RHS +is TcValidity.checkValidFamPats. -} @@ -2078,13 +2085,6 @@ are no data constructors we allow h98_style = True ***************************************************** -} --------------- -badAssocRhs :: [Name] -> RnM () -badAssocRhs ns - = addErr (hang (text "The RHS of an associated type declaration mentions" - <+> text "out-of-scope variable" <> plural ns - <+> pprWithCommas (quotes . ppr) ns) - 2 (text "All such variables must be bound on the LHS")) - wrongTyFamName :: Name -> Name -> SDoc wrongTyFamName fam_tc_name eqn_tc_name = hang (text "Mismatched type name in type family instance.") |