| Copyright | (c) Ross Paterson 2013 | 
|---|---|
| License | BSD-style (see the file LICENSE) | 
| Maintainer | libraries@haskell.org | 
| Stability | experimental | 
| Portability | portable | 
| Safe Haskell | Safe | 
| Language | Haskell2010 | 
Data.Functor.Classes
Description
Liftings of the Prelude classes Eq, Ord, Read and Show to
 unary and binary type constructors.
These classes are needed to express the constraints on arguments of
 transformers in portable Haskell.  Thus for a new transformer T,
 one might write instances like
instance (Eq1 f) => Eq1 (T f) where ... instance (Ord1 f) => Ord1 (T f) where ... instance (Read1 f) => Read1 (T f) where ... instance (Show1 f) => Show1 (T f) where ...
If these instances can be defined, defining instances of the base classes is mechanical:
instance (Eq1 f, Eq a) => Eq (T f a) where (==) = eq1 instance (Ord1 f, Ord a) => Ord (T f a) where compare = compare1 instance (Read1 f, Read a) => Read (T f a) where readPrec = readPrec1 readListPrec = readListPrecDefault instance (Show1 f, Show a) => Show (T f a) where showsPrec = showsPrec1
Since: base-4.9.0.0
Synopsis
- class Eq1 f where
- eq1 :: (Eq1 f, Eq a) => f a -> f a -> Bool
- class Eq1 f => Ord1 f where- liftCompare :: (a -> b -> Ordering) -> f a -> f b -> Ordering
 
- compare1 :: (Ord1 f, Ord a) => f a -> f a -> Ordering
- class Read1 f where- liftReadsPrec :: (Int -> ReadS a) -> ReadS [a] -> Int -> ReadS (f a)
- liftReadList :: (Int -> ReadS a) -> ReadS [a] -> ReadS [f a]
- liftReadPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec (f a)
- liftReadListPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec [f a]
 
- readsPrec1 :: (Read1 f, Read a) => Int -> ReadS (f a)
- readPrec1 :: (Read1 f, Read a) => ReadPrec (f a)
- liftReadListDefault :: Read1 f => (Int -> ReadS a) -> ReadS [a] -> ReadS [f a]
- liftReadListPrecDefault :: Read1 f => ReadPrec a -> ReadPrec [a] -> ReadPrec [f a]
- class Show1 f where
- showsPrec1 :: (Show1 f, Show a) => Int -> f a -> ShowS
- class Eq2 f where
- eq2 :: (Eq2 f, Eq a, Eq b) => f a b -> f a b -> Bool
- class Eq2 f => Ord2 f where- liftCompare2 :: (a -> b -> Ordering) -> (c -> d -> Ordering) -> f a c -> f b d -> Ordering
 
- compare2 :: (Ord2 f, Ord a, Ord b) => f a b -> f a b -> Ordering
- class Read2 f where- liftReadsPrec2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> Int -> ReadS (f a b)
- liftReadList2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [f a b]
- liftReadPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec (f a b)
- liftReadListPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [f a b]
 
- readsPrec2 :: (Read2 f, Read a, Read b) => Int -> ReadS (f a b)
- readPrec2 :: (Read2 f, Read a, Read b) => ReadPrec (f a b)
- liftReadList2Default :: Read2 f => (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [f a b]
- liftReadListPrec2Default :: Read2 f => ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [f a b]
- class Show2 f where
- showsPrec2 :: (Show2 f, Show a, Show b) => Int -> f a b -> ShowS
- readsData :: (String -> ReadS a) -> Int -> ReadS a
- readData :: ReadPrec a -> ReadPrec a
- readsUnaryWith :: (Int -> ReadS a) -> String -> (a -> t) -> String -> ReadS t
- readUnaryWith :: ReadPrec a -> String -> (a -> t) -> ReadPrec t
- readsBinaryWith :: (Int -> ReadS a) -> (Int -> ReadS b) -> String -> (a -> b -> t) -> String -> ReadS t
- readBinaryWith :: ReadPrec a -> ReadPrec b -> String -> (a -> b -> t) -> ReadPrec t
- showsUnaryWith :: (Int -> a -> ShowS) -> String -> Int -> a -> ShowS
- showsBinaryWith :: (Int -> a -> ShowS) -> (Int -> b -> ShowS) -> String -> Int -> a -> b -> ShowS
- readsUnary :: Read a => String -> (a -> t) -> String -> ReadS t
- readsUnary1 :: (Read1 f, Read a) => String -> (f a -> t) -> String -> ReadS t
- readsBinary1 :: (Read1 f, Read1 g, Read a) => String -> (f a -> g a -> t) -> String -> ReadS t
- showsUnary :: Show a => String -> Int -> a -> ShowS
- showsUnary1 :: (Show1 f, Show a) => String -> Int -> f a -> ShowS
- showsBinary1 :: (Show1 f, Show1 g, Show a) => String -> Int -> f a -> g a -> ShowS
Liftings of Prelude classes
For unary constructors
Lifting of the Eq class to unary type constructors.
Since: base-4.9.0.0
Methods
liftEq :: (a -> b -> Bool) -> f a -> f b -> Bool #
Lift an equality test through the type constructor.
The function will usually be applied to an equality function, but the more general type ensures that the implementation uses it to compare elements of the first container with elements of the second.
Since: base-4.9.0.0
Instances
| Eq1 Complex # | 
 
 Since: base-4.16.0.0 | 
| Eq1 Identity # | Since: base-4.9.0.0 | 
| Eq1 Down # | Since: base-4.12.0.0 | 
| Eq1 NonEmpty # | Since: base-4.10.0.0 | 
| Eq1 Maybe # | Since: base-4.9.0.0 | 
| Eq1 Solo # | Since: base-4.15 | 
| Eq1 [] # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Eq a => Eq1 (Either a) # | Since: base-4.9.0.0 | 
| Eq1 (Proxy :: Type -> Type) # | Since: base-4.9.0.0 | 
| Eq a => Eq1 ((,) a) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Eq a => Eq1 (Const a :: Type -> Type) # | Since: base-4.9.0.0 | 
| (Eq a, Eq b) => Eq1 ((,,) a b) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
| (Eq1 f, Eq1 g) => Eq1 (Product f g) # | Since: base-4.9.0.0 | 
| (Eq1 f, Eq1 g) => Eq1 (Sum f g) # | Since: base-4.9.0.0 | 
| (Eq a, Eq b, Eq c) => Eq1 ((,,,) a b c) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
| (Eq1 f, Eq1 g) => Eq1 (Compose f g) # | Since: base-4.9.0.0 | 
eq1 :: (Eq1 f, Eq a) => f a -> f a -> Bool #
Lift the standard ( function through the type constructor.==)
Since: base-4.9.0.0
Lifting of the Ord class to unary type constructors.
Since: base-4.9.0.0
Methods
liftCompare :: (a -> b -> Ordering) -> f a -> f b -> Ordering #
Lift a compare function through the type constructor.
The function will usually be applied to a comparison function, but the more general type ensures that the implementation uses it to compare elements of the first container with elements of the second.
Since: base-4.9.0.0
Instances
| Ord1 Identity # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord1 Down # | Since: base-4.12.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord1 NonEmpty # | Since: base-4.10.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord1 Maybe # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord1 Solo # | Since: base-4.15 | 
| Defined in Data.Functor.Classes | |
| Ord1 [] # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare :: (a -> b -> Ordering) -> [a] -> [b] -> Ordering # | |
| Ord a => Ord1 (Either a) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord1 (Proxy :: Type -> Type) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord a => Ord1 ((,) a) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare :: (a0 -> b -> Ordering) -> (a, a0) -> (a, b) -> Ordering # | |
| Ord a => Ord1 (Const a :: Type -> Type) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| (Ord a, Ord b) => Ord1 ((,,) a b) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare :: (a0 -> b0 -> Ordering) -> (a, b, a0) -> (a, b, b0) -> Ordering # | |
| (Ord1 f, Ord1 g) => Ord1 (Product f g) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Product | |
| (Ord1 f, Ord1 g) => Ord1 (Sum f g) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Sum | |
| (Ord a, Ord b, Ord c) => Ord1 ((,,,) a b c) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare :: (a0 -> b0 -> Ordering) -> (a, b, c, a0) -> (a, b, c, b0) -> Ordering # | |
| (Ord1 f, Ord1 g) => Ord1 (Compose f g) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Compose | |
compare1 :: (Ord1 f, Ord a) => f a -> f a -> Ordering #
Lift the standard compare function through the type constructor.
Since: base-4.9.0.0
Lifting of the Read class to unary type constructors.
Both liftReadsPrec and liftReadPrec exist to match the interface
 provided in the Read type class, but it is recommended to implement
 Read1 instances using liftReadPrec as opposed to liftReadsPrec, since
 the former is more efficient than the latter. For example:
instanceRead1T whereliftReadPrec= ...liftReadListPrec=liftReadListPrecDefault
For more information, refer to the documentation for the Read class.
Since: base-4.9.0.0
Minimal complete definition
Methods
liftReadsPrec :: (Int -> ReadS a) -> ReadS [a] -> Int -> ReadS (f a) #
readsPrec function for an application of the type constructor
 based on readsPrec and readList functions for the argument type.
Since: base-4.9.0.0
liftReadList :: (Int -> ReadS a) -> ReadS [a] -> ReadS [f a] #
readList function for an application of the type constructor
 based on readsPrec and readList functions for the argument type.
 The default implementation using standard list syntax is correct
 for most types.
Since: base-4.9.0.0
liftReadPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec (f a) #
readPrec function for an application of the type constructor
 based on readPrec and readListPrec functions for the argument type.
Since: base-4.10.0.0
liftReadListPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec [f a] #
readListPrec function for an application of the type constructor
 based on readPrec and readListPrec functions for the argument type.
The default definition uses liftReadList. Instances that define
 liftReadPrec should also define liftReadListPrec as
 liftReadListPrecDefault.
Since: base-4.10.0.0
Instances
| Read1 Complex # | 
 Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
| Read1 Identity # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Read1 Down # | Since: base-4.12.0.0 | 
| Defined in Data.Functor.Classes | |
| Read1 NonEmpty # | Since: base-4.10.0.0 | 
| Defined in Data.Functor.Classes | |
| Read1 Maybe # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Read1 Solo # | Since: base-4.15 | 
| Defined in Data.Functor.Classes | |
| Read1 [] # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Read a => Read1 (Either a) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec :: (Int -> ReadS a0) -> ReadS [a0] -> Int -> ReadS (Either a a0) # liftReadList :: (Int -> ReadS a0) -> ReadS [a0] -> ReadS [Either a a0] # liftReadPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec (Either a a0) # liftReadListPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec [Either a a0] # | |
| Read1 (Proxy :: Type -> Type) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Read a => Read1 ((,) a) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Read a => Read1 (Const a :: Type -> Type) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec :: (Int -> ReadS a0) -> ReadS [a0] -> Int -> ReadS (Const a a0) # liftReadList :: (Int -> ReadS a0) -> ReadS [a0] -> ReadS [Const a a0] # liftReadPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec (Const a a0) # liftReadListPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec [Const a a0] # | |
| (Read a, Read b) => Read1 ((,,) a b) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
| (Read1 f, Read1 g) => Read1 (Product f g) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Product Methods liftReadsPrec :: (Int -> ReadS a) -> ReadS [a] -> Int -> ReadS (Product f g a) # liftReadList :: (Int -> ReadS a) -> ReadS [a] -> ReadS [Product f g a] # liftReadPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec (Product f g a) # liftReadListPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec [Product f g a] # | |
| (Read1 f, Read1 g) => Read1 (Sum f g) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Sum | |
| (Read a, Read b, Read c) => Read1 ((,,,) a b c) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec :: (Int -> ReadS a0) -> ReadS [a0] -> Int -> ReadS (a, b, c, a0) # liftReadList :: (Int -> ReadS a0) -> ReadS [a0] -> ReadS [(a, b, c, a0)] # liftReadPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec (a, b, c, a0) # liftReadListPrec :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec [(a, b, c, a0)] # | |
| (Read1 f, Read1 g) => Read1 (Compose f g) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Compose Methods liftReadsPrec :: (Int -> ReadS a) -> ReadS [a] -> Int -> ReadS (Compose f g a) # liftReadList :: (Int -> ReadS a) -> ReadS [a] -> ReadS [Compose f g a] # liftReadPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec (Compose f g a) # liftReadListPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec [Compose f g a] # | |
readPrec1 :: (Read1 f, Read a) => ReadPrec (f a) #
Lift the standard readPrec and readListPrec functions through the
 type constructor.
Since: base-4.10.0.0
liftReadListDefault :: Read1 f => (Int -> ReadS a) -> ReadS [a] -> ReadS [f a] #
A possible replacement definition for the liftReadList method.
 This is only needed for Read1 instances where liftReadListPrec isn't
 defined as liftReadListPrecDefault.
Since: base-4.10.0.0
liftReadListPrecDefault :: Read1 f => ReadPrec a -> ReadPrec [a] -> ReadPrec [f a] #
A possible replacement definition for the liftReadListPrec method,
 defined using liftReadPrec.
Since: base-4.10.0.0
Lifting of the Show class to unary type constructors.
Since: base-4.9.0.0
Minimal complete definition
Methods
liftShowsPrec :: (Int -> a -> ShowS) -> ([a] -> ShowS) -> Int -> f a -> ShowS #
showsPrec function for an application of the type constructor
 based on showsPrec and showList functions for the argument type.
Since: base-4.9.0.0
liftShowList :: (Int -> a -> ShowS) -> ([a] -> ShowS) -> [f a] -> ShowS #
Instances
| Show1 Complex # | 
 Since: base-4.16.0.0 | 
| Show1 Identity # | Since: base-4.9.0.0 | 
| Show1 Down # | Since: base-4.12.0.0 | 
| Show1 NonEmpty # | Since: base-4.10.0.0 | 
| Show1 Maybe # | Since: base-4.9.0.0 | 
| Show1 Solo # | Since: base-4.15 | 
| Show1 [] # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Show a => Show1 (Either a) # | Since: base-4.9.0.0 | 
| Show1 (Proxy :: TYPE LiftedRep -> Type) # | Since: base-4.9.0.0 | 
| Show a => Show1 ((,) a) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Show a => Show1 (Const a :: TYPE LiftedRep -> Type) # | Since: base-4.9.0.0 | 
| (Show a, Show b) => Show1 ((,,) a b) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
| (Show1 f, Show1 g) => Show1 (Product f g) # | Since: base-4.9.0.0 | 
| (Show1 f, Show1 g) => Show1 (Sum f g) # | Since: base-4.9.0.0 | 
| (Show a, Show b, Show c) => Show1 ((,,,) a b c) # | Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
| (Show1 f, Show1 g) => Show1 (Compose f g) # | Since: base-4.9.0.0 | 
For binary constructors
Lifting of the Eq class to binary type constructors.
Since: base-4.9.0.0
Methods
liftEq2 :: (a -> b -> Bool) -> (c -> d -> Bool) -> f a c -> f b d -> Bool #
Lift equality tests through the type constructor.
The function will usually be applied to equality functions, but the more general type ensures that the implementation uses them to compare elements of the first container with elements of the second.
Since: base-4.9.0.0
Instances
| Eq2 Either # | Since: base-4.9.0.0 | 
| Eq2 (,) # | Since: base-4.9.0.0 | 
| Eq2 (Const :: Type -> Type -> Type) # | Since: base-4.9.0.0 | 
| Eq a => Eq2 ((,,) a) # | 
 Since: base-4.16.0.0 | 
| (Eq a, Eq b) => Eq2 ((,,,) a b) # | 
 Since: base-4.16.0.0 | 
eq2 :: (Eq2 f, Eq a, Eq b) => f a b -> f a b -> Bool #
Lift the standard ( function through the type constructor.==)
Since: base-4.9.0.0
Lifting of the Ord class to binary type constructors.
Since: base-4.9.0.0
Methods
liftCompare2 :: (a -> b -> Ordering) -> (c -> d -> Ordering) -> f a c -> f b d -> Ordering #
Lift compare functions through the type constructor.
The function will usually be applied to comparison functions, but the more general type ensures that the implementation uses them to compare elements of the first container with elements of the second.
Since: base-4.9.0.0
Instances
| Ord2 Either # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord2 (,) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare2 :: (a -> b -> Ordering) -> (c -> d -> Ordering) -> (a, c) -> (b, d) -> Ordering # | |
| Ord2 (Const :: Type -> Type -> Type) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes | |
| Ord a => Ord2 ((,,) a) # | 
 Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare2 :: (a0 -> b -> Ordering) -> (c -> d -> Ordering) -> (a, a0, c) -> (a, b, d) -> Ordering # | |
| (Ord a, Ord b) => Ord2 ((,,,) a b) # | 
 Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftCompare2 :: (a0 -> b0 -> Ordering) -> (c -> d -> Ordering) -> (a, b, a0, c) -> (a, b, b0, d) -> Ordering # | |
compare2 :: (Ord2 f, Ord a, Ord b) => f a b -> f a b -> Ordering #
Lift the standard compare function through the type constructor.
Since: base-4.9.0.0
Lifting of the Read class to binary type constructors.
Both liftReadsPrec2 and liftReadPrec2 exist to match the interface
 provided in the Read type class, but it is recommended to implement
 Read2 instances using liftReadPrec2 as opposed to liftReadsPrec2,
 since the former is more efficient than the latter. For example:
instanceRead2T whereliftReadPrec2= ...liftReadListPrec2=liftReadListPrec2Default
For more information, refer to the documentation for the Read class.
Since: base-4.9.0.0
Minimal complete definition
Methods
liftReadsPrec2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> Int -> ReadS (f a b) #
readsPrec function for an application of the type constructor
 based on readsPrec and readList functions for the argument types.
Since: base-4.9.0.0
liftReadList2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [f a b] #
readList function for an application of the type constructor
 based on readsPrec and readList functions for the argument types.
 The default implementation using standard list syntax is correct
 for most types.
Since: base-4.9.0.0
liftReadPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec (f a b) #
readPrec function for an application of the type constructor
 based on readPrec and readListPrec functions for the argument types.
Since: base-4.10.0.0
liftReadListPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [f a b] #
readListPrec function for an application of the type constructor
 based on readPrec and readListPrec functions for the argument types.
The default definition uses liftReadList2. Instances that define
 liftReadPrec2 should also define liftReadListPrec2 as
 liftReadListPrec2Default.
Since: base-4.10.0.0
Instances
| Read2 Either # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> Int -> ReadS (Either a b) # liftReadList2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [Either a b] # liftReadPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec (Either a b) # liftReadListPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [Either a b] # | |
| Read2 (,) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> Int -> ReadS (a, b) # liftReadList2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [(a, b)] # liftReadPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec (a, b) # liftReadListPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [(a, b)] # | |
| Read2 (Const :: Type -> Type -> Type) # | Since: base-4.9.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> Int -> ReadS (Const a b) # liftReadList2 :: (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [Const a b] # liftReadPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec (Const a b) # liftReadListPrec2 :: ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [Const a b] # | |
| Read a => Read2 ((,,) a) # | 
 Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec2 :: (Int -> ReadS a0) -> ReadS [a0] -> (Int -> ReadS b) -> ReadS [b] -> Int -> ReadS (a, a0, b) # liftReadList2 :: (Int -> ReadS a0) -> ReadS [a0] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [(a, a0, b)] # liftReadPrec2 :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec b -> ReadPrec [b] -> ReadPrec (a, a0, b) # liftReadListPrec2 :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [(a, a0, b)] # | |
| (Read a, Read b) => Read2 ((,,,) a b) # | 
 Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes Methods liftReadsPrec2 :: (Int -> ReadS a0) -> ReadS [a0] -> (Int -> ReadS b0) -> ReadS [b0] -> Int -> ReadS (a, b, a0, b0) # liftReadList2 :: (Int -> ReadS a0) -> ReadS [a0] -> (Int -> ReadS b0) -> ReadS [b0] -> ReadS [(a, b, a0, b0)] # liftReadPrec2 :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec b0 -> ReadPrec [b0] -> ReadPrec (a, b, a0, b0) # liftReadListPrec2 :: ReadPrec a0 -> ReadPrec [a0] -> ReadPrec b0 -> ReadPrec [b0] -> ReadPrec [(a, b, a0, b0)] # | |
readsPrec2 :: (Read2 f, Read a, Read b) => Int -> ReadS (f a b) #
Lift the standard readsPrec function through the type constructor.
Since: base-4.9.0.0
readPrec2 :: (Read2 f, Read a, Read b) => ReadPrec (f a b) #
Lift the standard readPrec function through the type constructor.
Since: base-4.10.0.0
liftReadList2Default :: Read2 f => (Int -> ReadS a) -> ReadS [a] -> (Int -> ReadS b) -> ReadS [b] -> ReadS [f a b] #
A possible replacement definition for the liftReadList2 method.
 This is only needed for Read2 instances where liftReadListPrec2 isn't
 defined as liftReadListPrec2Default.
Since: base-4.10.0.0
liftReadListPrec2Default :: Read2 f => ReadPrec a -> ReadPrec [a] -> ReadPrec b -> ReadPrec [b] -> ReadPrec [f a b] #
A possible replacement definition for the liftReadListPrec2 method,
 defined using liftReadPrec2.
Since: base-4.10.0.0
Lifting of the Show class to binary type constructors.
Since: base-4.9.0.0
Minimal complete definition
Methods
liftShowsPrec2 :: (Int -> a -> ShowS) -> ([a] -> ShowS) -> (Int -> b -> ShowS) -> ([b] -> ShowS) -> Int -> f a b -> ShowS #
showsPrec function for an application of the type constructor
 based on showsPrec and showList functions for the argument types.
Since: base-4.9.0.0
liftShowList2 :: (Int -> a -> ShowS) -> ([a] -> ShowS) -> (Int -> b -> ShowS) -> ([b] -> ShowS) -> [f a b] -> ShowS #
Instances
| Show2 Either # | Since: base-4.9.0.0 | 
| Show2 (,) # | Since: base-4.9.0.0 | 
| Show2 (Const :: Type -> TYPE LiftedRep -> Type) # | Since: base-4.9.0.0 | 
| Show a => Show2 ((,,) a) # | 
 Since: base-4.16.0.0 | 
| (Show a, Show b) => Show2 ((,,,) a b) # | 
 Since: base-4.16.0.0 | 
| Defined in Data.Functor.Classes | |
showsPrec2 :: (Show2 f, Show a, Show b) => Int -> f a b -> ShowS #
Lift the standard showsPrec function through the type constructor.
Since: base-4.9.0.0
Helper functions
These functions can be used to assemble Read and Show instances for
new algebraic types.  For example, given the definition
data T f a = Zero a | One (f a) | Two a (f a)
a standard Read1 instance may be defined as
instance (Read1 f) => Read1 (T f) where
    liftReadPrec rp rl = readData $
        readUnaryWith rp "Zero" Zero <|>
        readUnaryWith (liftReadPrec rp rl) "One" One <|>
        readBinaryWith rp (liftReadPrec rp rl) "Two" Two
    liftReadListPrec = liftReadListPrecDefaultand the corresponding Show1 instance as
instance (Show1 f) => Show1 (T f) where
    liftShowsPrec sp _ d (Zero x) =
        showsUnaryWith sp "Zero" d x
    liftShowsPrec sp sl d (One x) =
        showsUnaryWith (liftShowsPrec sp sl) "One" d x
    liftShowsPrec sp sl d (Two x y) =
        showsBinaryWith sp (liftShowsPrec sp sl) "Two" d x yreadsData :: (String -> ReadS a) -> Int -> ReadS a #
readsData p dp.  Parsers for various constructors can be constructed
 with readsUnary, readsUnary1 and readsBinary1, and combined with
 mappend from the Monoid class.
Since: base-4.9.0.0
readData :: ReadPrec a -> ReadPrec a #
readData pp.  Parsers for various constructors can be constructed
 with readUnaryWith and readBinaryWith, and combined with
 (<|>) from the Alternative class.
Since: base-4.10.0.0
readsUnaryWith :: (Int -> ReadS a) -> String -> (a -> t) -> String -> ReadS t #
readsUnaryWith rp n c n'rp.
Since: base-4.9.0.0
readUnaryWith :: ReadPrec a -> String -> (a -> t) -> ReadPrec t #
readUnaryWith rp n c'rp.
Since: base-4.10.0.0
readsBinaryWith :: (Int -> ReadS a) -> (Int -> ReadS b) -> String -> (a -> b -> t) -> String -> ReadS t #
readsBinaryWith rp1 rp2 n c n'rp1 and rp2
 respectively.
Since: base-4.9.0.0
readBinaryWith :: ReadPrec a -> ReadPrec b -> String -> (a -> b -> t) -> ReadPrec t #
readBinaryWith rp1 rp2 n c'rp1 and rp2
 respectively.
Since: base-4.10.0.0
showsUnaryWith :: (Int -> a -> ShowS) -> String -> Int -> a -> ShowS #
showsUnaryWith sp n d xn and argument x, in precedence
 context d.
Since: base-4.9.0.0
showsBinaryWith :: (Int -> a -> ShowS) -> (Int -> b -> ShowS) -> String -> Int -> a -> b -> ShowS #
showsBinaryWith sp1 sp2 n d x yn and arguments
 x and y, in precedence context d.
Since: base-4.9.0.0
Obsolete helpers
readsUnary :: Read a => String -> (a -> t) -> String -> ReadS t #
Deprecated: Use readsUnaryWith to define liftReadsPrec
readsUnary n c n'readsPrec.
Since: base-4.9.0.0
readsUnary1 :: (Read1 f, Read a) => String -> (f a -> t) -> String -> ReadS t #
Deprecated: Use readsUnaryWith to define liftReadsPrec
readsUnary1 n c n'readsPrec1.
Since: base-4.9.0.0
readsBinary1 :: (Read1 f, Read1 g, Read a) => String -> (f a -> g a -> t) -> String -> ReadS t #
Deprecated: Use readsBinaryWith to define liftReadsPrec
readsBinary1 n c n'readsPrec1.
Since: base-4.9.0.0
showsUnary :: Show a => String -> Int -> a -> ShowS #
Deprecated: Use showsUnaryWith to define liftShowsPrec
showsUnary n d xn and argument x, in precedence context d.
Since: base-4.9.0.0
showsUnary1 :: (Show1 f, Show a) => String -> Int -> f a -> ShowS #
Deprecated: Use showsUnaryWith to define liftShowsPrec
showsUnary1 n d xn and argument x, in precedence context d.
Since: base-4.9.0.0
showsBinary1 :: (Show1 f, Show1 g, Show a) => String -> Int -> f a -> g a -> ShowS #
Deprecated: Use showsBinaryWith to define liftShowsPrec
showsBinary1 n d x yn and arguments x and y, in precedence
 context d.
Since: base-4.9.0.0