Safe Haskell | Safe |
---|---|
Language | Haskell2010 |
Synopsis
- class GShow t where
- gshowsPrec :: Int -> t a -> ShowS
- gshows :: GShow t => t a -> ShowS
- gshow :: GShow t => t a -> String
- class GRead t where
- greadsPrec :: Int -> GReadS t
- type GReadS t = String -> [(Some t, String)]
- greads :: GRead t => GReadS t
- gread :: GRead t => String -> (forall a. t a -> b) -> b
- greadMaybe :: GRead t => String -> (forall a. t a -> b) -> Maybe b
- getGReadResult :: Some tag -> (forall a. tag a -> b) -> b
- mkGReadResult :: tag a -> Some tag
Showing
Show
-like class for 1-type-parameter GADTs. GShow t => ...
is equivalent to something
like (forall a. Show (t a)) => ...
. The easiest way to create instances would probably be
to write (or derive) an instance Show (T a)
, and then simply say:
instance GShow t where gshowsPrec = showsPrec
gshowsPrec :: Int -> t a -> ShowS Source #
Instances
GShow (TypeRep :: k -> Type) Source # | |
Defined in Data.GADT.Internal | |
GShow ((:~:) a :: k -> Type) Source # | |
Defined in Data.GADT.Internal | |
GShow (GOrdering a :: k -> Type) Source # | |
Defined in Data.GADT.Internal | |
(GShow a, GShow b) => GShow (Product a b :: k -> Type) Source # |
|
Defined in Data.GADT.Internal | |
(GShow a, GShow b) => GShow (Sum a b :: k -> Type) Source # |
|
Defined in Data.GADT.Internal |
Reading
Read
-like class for 1-type-parameter GADTs. Unlike GShow
, this one cannot be
mechanically derived from a Read
instance because greadsPrec
must choose the phantom
type based on the String
being parsed.
greadsPrec :: Int -> GReadS t Source #
type GReadS t = String -> [(Some t, String)] Source #
GReadS t
is equivalent to ReadS (forall b. (forall a. t a -> b) -> b)
, which is
in turn equivalent to ReadS (Exists t)
(with data Exists t where Exists :: t a -> Exists t
)
greadMaybe :: GRead t => String -> (forall a. t a -> b) -> Maybe b Source #
>>>
greadMaybe "InL Refl" mkSome :: Maybe (Some (Sum ((:~:) Int) ((:~:) Bool)))
Just (mkSome (InL Refl))
>>>
greadMaybe "garbage" mkSome :: Maybe (Some ((:~:) Int))
Nothing
getGReadResult :: Some tag -> (forall a. tag a -> b) -> b Source #
mkGReadResult :: tag a -> Some tag Source #