[GHC] #11700: pattern match bug

GHC ghc-devs at haskell.org
Mon May 2 06:57:20 UTC 2016


#11700: pattern match bug
-------------------------------------+-------------------------------------
        Reporter:  TobyGoodwin       |                Owner:
            Type:  bug               |               Status:  new
        Priority:  normal            |            Milestone:
       Component:  Compiler          |              Version:  7.10.3
      Resolution:                    |             Keywords:
Operating System:  Unknown/Multiple  |         Architecture:
                                     |  Unknown/Multiple
 Type of failure:  None/Unknown      |            Test Case:
                                     |  https://github.com/TobyGoodwin/odd-
                                     |  ghc-pattern-bug
      Blocked By:                    |             Blocking:
 Related Tickets:                    |  Differential Rev(s):
       Wiki Page:                    |
-------------------------------------+-------------------------------------

Comment (by osa1):

 Hm, this is a weird one. I still don't understand the typechecker so can't
 fix
 this myself, but I did some debugging. Here's a simpler function that
 fails:

 {{{#!haskell
 fn2 :: Key User -> (Entity Message, Entity Folder) -> IO ()
 fn2 usr cluster =
   let (Entity msgKey msg, Entity fldrKey fldr) = cluster
   in do
     print $ messageName msg
     print $ folderName fldr
 }}}

 Interestingly, the error message is about {{{Folder}}}, but if I replace
 {{{Message}}} with an empty tuple.

 {{{#!haskell
 fn2 :: Key User -> ((), Entity Folder) -> IO ()
 fn2 usr cluster =
   let ((), Entity fldrKey fldr) = cluster
   in do
     print $ folderName fldr
 }}}

 It works. I also tried swapping the tuple elements:

 {{{#!haskell
 fn2 :: Key User -> (Entity Folder, Entity Message) -> IO ()
 fn2 usr cluster =
   let (Entity fldrKey fldr, Entity msgKey msg) = cluster
   in do
     print $ messageName msg
     print $ folderName fldr
 }}}

 and it failed with an error message about {{{Message}}}:

 {{{
 Message.hs:45:25: error:
     • Couldn't match expected type ‘Message’ with actual type ‘Message’
     • In the first argument of ‘messageName’, namely ‘msg’
       In the second argument of ‘($)’, namely ‘messageName msg’
       In a stmt of a 'do' block: print $ messageName msg
 }}}

 It seems like some kind of side-effect is happening when type checking the
 first pattern.

 Oh, I also tried replacing the {{{in}}} part with {{{return ()}}}, and it
 worked:


 {{{#!haskell
 fn2 :: Key User -> (Entity Folder, Entity Message) -> IO ()
 fn2 usr cluster =
   let (Entity fldrKey fldr, Entity msgKey msg) = cluster
   in do
     return ()
 }}}

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


More information about the ghc-tickets mailing list