[GHC] #12199: GHC is oblivious to injectivity when a type family is used in a GADT type

GHC ghc-devs at haskell.org
Fri Jun 17 00:41:46 UTC 2016


#12199: GHC is oblivious to injectivity when a type family is used in a GADT type
-------------------------------------+-------------------------------------
           Reporter:  RyanGlScott    |             Owner:
               Type:  bug            |            Status:  new
           Priority:  normal         |         Milestone:
          Component:  Compiler       |           Version:  8.0.1
  (Type checker)                     |
           Keywords:  TypeFamilies,  |  Operating System:  Unknown/Multiple
  Injective                          |
       Architecture:                 |   Type of failure:  GHC rejects
  Unknown/Multiple                   |  valid program
          Test Case:                 |        Blocked By:
           Blocking:                 |   Related Tickets:
Differential Rev(s):                 |         Wiki Page:
-------------------------------------+-------------------------------------
 [https://www.reddit.com/r/haskell/comments/4oeidw/type_family_dependencies_and_gadts/
 A reddit post] points out a limitation of injective type families:

 {{{#!hs
 {-# LANGUAGE GADTs                  #-}
 {-# LANGUAGE KindSignatures         #-}
 {-# LANGUAGE TypeFamilyDependencies #-}

 type family Foo a = b | b -> a where
   Foo Int = Bool

 data Bar :: * -> * where
   Bar :: a -> Bar (Foo a)

 oink :: Bar Bool -> Int
 oink (Bar x) = x  -- type error
 }}}

 Compiling this fails with:

 {{{
 Could not deduce: a ~ Int
 from the context: Bool ~ Foo a
 }}}

 Which seems odd, given that `Bool ~ Foo a` should imply `a ~ Int` by
 injectivity. Even if you change the type signature of `oink` to `Bar (Foo
 Int) -> Int`, it fails with:

 {{{
 Could not deduce: a ~ Int
 from the context: Foo Int ~ Foo a
 }}}

 which makes it even more apparent that it isn't aware of the fact that
 `Foo` is injective.

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


More information about the ghc-tickets mailing list