Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Pack/unpack newtypes.
Warning
This is an internal module: it is not subject to any versioning policy, breaking changes can happen at any time.
If something here seems useful, please report it or create a pull request to export it from an external module.
Synopsis
- class (Generic a, Coercible a (Old a), Newtype' a) => Newtype a
- type Old a = GOld (Rep a)
- type family GOld (f :: Type -> Type) where ...
- type Newtype' a = NewtypeErr a (MetaDataNewtype (MetaOf (Rep a)))
- type family NewtypeErr a (b :: Bool) :: Constraint where ...
- unpack :: Newtype a => a -> Old a
- pack :: Newtype a => Old a -> a
Documentation
class (Generic a, Coercible a (Old a), Newtype' a) => Newtype a Source #
type Old a = GOld (Rep a) Source #
The type wrapped by a newtype.
newtype Foo = Foo { bar :: Bar } deriving Generic
-- Old Foo ~ Bar
type Newtype' a = NewtypeErr a (MetaDataNewtype (MetaOf (Rep a))) Source #
Use Newtype
instead.
type family NewtypeErr a (b :: Bool) :: Constraint where ... Source #
NewtypeErr a 'True = () | |
NewtypeErr a 'False = TypeError (('Text "The type " ':<>: 'ShowType a) ':<>: 'Text " is not a newtype.") |