[GHC] #12235: Wrong compilation of bang patterns
GHC
ghc-devs at haskell.org
Mon Jun 27 15:34:50 UTC 2016
#12235: Wrong compilation of bang patterns
-------------------------------------+-------------------------------------
Reporter: osa1 | Owner:
Type: bug | Status: closed
Priority: normal | Milestone:
Component: Compiler | Version: 8.1
Resolution: invalid | 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 nomeata):
I agree with rwbarton. When matching `(undefined, [C])` against the
patterns, it will match it against `(i, [])` and fail, and then against
`(i, (A : ts))` and fail. Now it will be matched against `(!i, (B :
ts))`. Comparing a tuple requires matching the individual components, from
left to right. So it matches `undefined` against `!i`.
According to the docs for bang patterns, as you quote them, this is done
by first evaluating the expression to WHNF, which triggers the
`undefined`, and this happens before `[C]` is matched against `(B:ts)`.
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/12235#comment:7>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list