[GHC] #12724: Be lazier about reducing type-function applications

GHC ghc-devs at haskell.org
Fri Oct 21 16:16:17 UTC 2016


#12724: Be lazier about reducing type-function applications
-------------------------------------+-------------------------------------
        Reporter:  simonpj           |                Owner:
            Type:  bug               |               Status:  new
        Priority:  normal            |            Milestone:
       Component:  Compiler          |              Version:  8.0.1
      Resolution:                    |             Keywords:
Operating System:  Unknown/Multiple  |         Architecture:
                                     |  Unknown/Multiple
 Type of failure:  None/Unknown      |            Test Case:
      Blocked By:                    |             Blocking:
 Related Tickets:                    |  Differential Rev(s):
       Wiki Page:                    |
-------------------------------------+-------------------------------------

Comment (by Simon Peyton Jones <simonpj@…>):

 In [changeset:"1f09b246d377a0007a953e5a77545d81671d2e36/ghc"
 1f09b246/ghc]:
 {{{
 #!CommitTicketReference repository="ghc"
 revision="1f09b246d377a0007a953e5a77545d81671d2e36"
 Accept 20% dedgradation in Trac #5030 compile time

 In commit

   31621b12 * A collection of type-inference refactorings.

 I fixed a bug in the on-the-fly unifier.  Usually the
 on-the-fly unifier (TcUnify) defers type function
 applications to the constraint solver.  But in one situation
 it inconsistently did not defer, so a unification happened
 without reducing a type function.  By a fluke this makes
 T5030 (specifcially the definition of cnst) much better.

 It turns out that consistently non-deferring type functions
 makes the test for #3064 go bad.  So somehow the current,
 inconsistent situation was an accidental sweet spot.

 But it's a horrible sweet spot, relying on what was essentially
 a bug.  So I've accepted the worsening (it's an exotic case),
 and opened #12724 to deal with the underlying cause.
 }}}

--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/12724#comment:3>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler


More information about the ghc-tickets mailing list