[GHC] #9111: base should export Typeable instances of its promoted data constructors

GHC ghc-devs at haskell.org
Thu May 15 12:06:55 UTC 2014


#9111: base should export Typeable instances of its promoted data constructors
-------------------------------------+------------------------------------
        Reporter:  goldfire          |            Owner:
            Type:  feature request   |           Status:  new
        Priority:  normal            |        Milestone:
       Component:  Compiler          |          Version:  7.8.2
      Resolution:                    |         Keywords:
Operating System:  Unknown/Multiple  |     Architecture:  Unknown/Multiple
 Type of failure:  None/Unknown      |       Difficulty:  Unknown
       Test Case:                    |       Blocked By:
        Blocking:                    |  Related Tickets:
-------------------------------------+------------------------------------

Comment (by dreixel):

 Replying to [comment:11 goldfire]:
 > Would universally deriving `Typeable` break some abstraction guarantees?
 That is, if a library wanted to hide some types, could they be gotten
 through their (unhideable) `Typeable` instances? Template Haskell can
 surely do this, but I might be willing to ignore that particular attack.
 Are there others? What if a type is known but not the constructors? (I
 don't think `Typeable` can do this.) What about if a type synonym is known
 but the RHS isn't exported? (I bet it can do this.)

 `Typeable` knows nothing about the RHS of its type, so constructors are
 safe. Also, if you don't export a type nor any of its constructors, I
 don't see how you could use its |typeRep|, so I guess you're safe too
 (ignoring Template Haskell, of course).

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


More information about the ghc-tickets mailing list