[GHC] #14179: "Conflicting family instance" error pretty prints data family instances poorly

GHC ghc-devs at haskell.org
Fri Sep 1 14:13:11 UTC 2017


#14179: "Conflicting family instance" error pretty prints data family instances
poorly
-------------------------------------+-------------------------------------
           Reporter:  RyanGlScott    |             Owner:  (none)
               Type:  bug            |            Status:  new
           Priority:  normal         |         Milestone:
          Component:  Compiler       |           Version:  8.2.1
  (Type checker)                     |
           Keywords:  TypeFamilies   |  Operating System:  Unknown/Multiple
       Architecture:                 |   Type of failure:  Poor/confusing
  Unknown/Multiple                   |  error message
          Test Case:                 |        Blocked By:
           Blocking:                 |   Related Tickets:
Differential Rev(s):                 |         Wiki Page:
-------------------------------------+-------------------------------------
 This can be observed on GHC 8.0.1 or later:

 {{{#!hs
 {-# LANGUAGE TypeFamilies #-}
 module Bug where

 data family   Fam a
 data instance Fam Int
 data instance Fam Int
 }}}

 {{{
 $ /opt/ghc/8.2.1/bin/ghci Bug.hs
 GHCi, version 8.2.1: http://www.haskell.org/ghc/  :? for help
 Loaded GHCi configuration from /home/rgscott/.ghci
 [1 of 1] Compiling Bug              ( Bug.hs, interpreted )

 Bug.hs:5:15: error:
     Conflicting family instance declarations:
       Fam Int = -- Defined at Bug.hs:5:15
       Fam Int = -- Defined at Bug.hs:6:15
   |
 5 | data instance Fam Int
   |               ^^^
 }}}

 Notice how GHC attempts to pretty-print the RHS by using a `=` symbol, but
 there is no RHS!

 This gets even more confusing with this program, which requires GHC HEAD:

 {{{#!hs
 {-# LANGUAGE PolyKinds #-}
 {-# LANGUAGE TypeFamilies #-}
 module Bug where

 data family   Fam :: k -> *
 data instance Fam :: * -> *
 data instance Fam :: * -> *
 }}}
 {{{
 $ ghc5/inplace/bin/ghc-stage2 --interactive Bug.hs
 GHCi, version 8.3.20170818: http://www.haskell.org/ghc/  :? for help
 Loaded GHCi configuration from /home/rgscott/.ghci
 [1 of 1] Compiling Bug              ( Bug.hs, interpreted )

 Bug.hs:6:15: error:
     Conflicting family instance declarations:
       Fam = -- Defined at Bug.hs:6:15
       Fam = -- Defined at Bug.hs:7:15
   |
 6 | data instance Fam :: * -> *
   |               ^^^
 }}}

 Not only is there no RHS, but the kind signatures of each instance aren't
 printed either. This is an issue, since the entire reason why the two
 instances conflict are because of their kinds!

 We should rethink how data family instances are pretty printer here to
 avoid this issue.

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


More information about the ghc-tickets mailing list