Make error when deriving an instance for a typeclass less misleading
Before, when you attempted to derive an instance for a typeclass, e.g., ``` class C1 (a :: Constraint) where class C2 where deriving instance C1 C2 ``` GHC would complain that `C2`'s data constructors aren't in scope. But that makes no sense, since typeclasses don't have constructors! By refining the checks that GHC performs when deriving, we can make the error message a little more sensible. This also cleans up a related `DeriveAnyClass` infelicity. Before, you wouldn't have been able to compile code like this: ``` import System.IO (Handle) class C a deriving instance C Handle ``` Since GHC was requiring that all data constructors of `Handle` be in scope. But `DeriveAnyClass` doesn't even generate code that mentions any data constructors, so this requirement is silly! Fixes #11509. Test Plan: make test TEST=T11509 Reviewers: simonpj, austin, bgamari Reviewed By: simonpj, bgamari Subscribers: thomie, simonpj Differential Revision: https://phabricator.haskell.org/D2558 GHC Trac Issues: #11509
Showing
- compiler/typecheck/TcDeriv.hs 100 additions, 34 deletionscompiler/typecheck/TcDeriv.hs
- compiler/typecheck/TcDerivUtils.hs 32 additions, 9 deletionscompiler/typecheck/TcDerivUtils.hs
- docs/users_guide/8.2.1-notes.rst 15 additions, 1 deletiondocs/users_guide/8.2.1-notes.rst
- docs/users_guide/glasgow_exts.rst 11 additions, 0 deletionsdocs/users_guide/glasgow_exts.rst
- testsuite/tests/deriving/should_compile/T11509_2.hs 13 additions, 0 deletionstestsuite/tests/deriving/should_compile/T11509_2.hs
- testsuite/tests/deriving/should_compile/T11509_3.hs 9 additions, 0 deletionstestsuite/tests/deriving/should_compile/T11509_3.hs
- testsuite/tests/deriving/should_compile/all.T 2 additions, 0 deletionstestsuite/tests/deriving/should_compile/all.T
- testsuite/tests/deriving/should_fail/T11509_1.hs 52 additions, 0 deletionstestsuite/tests/deriving/should_fail/T11509_1.hs
- testsuite/tests/deriving/should_fail/T11509_1.stderr 7 additions, 0 deletionstestsuite/tests/deriving/should_fail/T11509_1.stderr
- testsuite/tests/deriving/should_fail/all.T 2 additions, 0 deletionstestsuite/tests/deriving/should_fail/all.T
Loading
Please register or sign in to comment