[GHC] #8745: GeneralizedNewtypeDeriving is still not Safe
GHC
ghc-devs at haskell.org
Wed Feb 12 03:05:26 UTC 2014
#8745: GeneralizedNewtypeDeriving is still not Safe
-------------------------------------+------------------------------------
Reporter: goldfire | Owner:
Type: bug | Status: new
Priority: normal | Milestone:
Component: Compiler | Version: 7.8.1-rc1
Resolution: | Keywords: Safe
Operating System: Unknown/Multiple | Architecture: Unknown/Multiple
Type of failure: None/Unknown | Difficulty: Unknown
Test Case: | Blocked By:
Blocking: | Related Tickets:
-------------------------------------+------------------------------------
Comment (by goldfire):
I've found a weird corner case that is very relevant.
Consider
{{{
class Foo a where ...
type role Foo representational
data PackFoo a where
MkPF :: Foo a => PackFoo a
instance Foo Int where ...
newtype Age = MkAge Int
instance Foo Age where ...
incoherent :: PackFoo Age
incoherent = coerce (MkPF :: PackFoo Int)
useIncoherent = case incoherent of MkPF -> {- here, we two incompatible
instances of Foo Age available! -}
}}}
The problem, as I see it, boils down to the role annotation on `Foo`,
which allows users to create incoherence. Should we perhaps disallow role
annotations on classes in Safe Haskell? It would be analogous to the
restrictions on overlapping instances, I think.
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/8745#comment:5>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list