Make dischargeFmv handle Deriveds
A Derived CFunEqCan does not "own" its FlatMetaTv (fmv), and should not update it. But one caller (canCFunEqCan) was failing to satisfy the precondition to dischargeFmv, which led to a crash (Trac #15170). I fixed this by making dischargeFmv handle Deriveds (to avoid forcing each caller to do so separately). NB: this does not completely fix the original #15170 bug, but I'll explain that on the ticket. The test case for this patch is actually the program in comment:1.
Showing
- compiler/typecheck/TcFlatten.hs 6 additions, 4 deletionscompiler/typecheck/TcFlatten.hs
- compiler/typecheck/TcInteract.hs 2 additions, 8 deletionscompiler/typecheck/TcInteract.hs
- compiler/typecheck/TcRnTypes.hs 2 additions, 2 deletionscompiler/typecheck/TcRnTypes.hs
- compiler/typecheck/TcSMonad.hs 15 additions, 4 deletionscompiler/typecheck/TcSMonad.hs
- testsuite/tests/polykinds/T15170.hs 26 additions, 0 deletionstestsuite/tests/polykinds/T15170.hs
- testsuite/tests/polykinds/all.T 1 addition, 0 deletionstestsuite/tests/polykinds/all.T
Loading
Please register or sign in to comment