| Copyright | (C) 2013-2014 Richard Eisenberg Jan Stolarek |
|---|---|
| License | BSD-style (see LICENSE) |
| Maintainer | Ryan Scott |
| Stability | experimental |
| Portability | non-portable |
| Safe Haskell | None |
| Language | Haskell2010 |
Data.Singletons.Prelude.Either
Description
Defines functions and datatypes relating to the singleton for Either,
including a singletons version of all the definitions in Data.Either.
Because many of these definitions are produced by Template Haskell,
it is not possible to create proper Haddock documentation. Please look
up the corresponding operation in Data.Either. Also, please excuse
the apparent repeated variable names. This is due to an interaction
between Template Haskell and Haddock.
Synopsis
- data family Sing :: k -> Type
- type SEither = (Sing :: Either a b -> Type)
- either_ :: (a -> c) -> (b -> c) -> Either a b -> c
- type family Either_ (a :: (~>) a c) (a :: (~>) b c) (a :: Either a b) :: c where ...
- sEither_ :: forall a c b (t :: (~>) a c) (t :: (~>) b c) (t :: Either a b). Sing t -> Sing t -> Sing t -> Sing (Apply (Apply (Apply Either_Sym0 t) t) t :: c)
- type family Lefts (a :: [Either a b]) :: [a] where ...
- sLefts :: forall a b (t :: [Either a b]). Sing t -> Sing (Apply LeftsSym0 t :: [a])
- type family Rights (a :: [Either a b]) :: [b] where ...
- sRights :: forall a b (t :: [Either a b]). Sing t -> Sing (Apply RightsSym0 t :: [b])
- type family PartitionEithers (a :: [Either a b]) :: ([a], [b]) where ...
- sPartitionEithers :: forall a b (t :: [Either a b]). Sing t -> Sing (Apply PartitionEithersSym0 t :: ([a], [b]))
- type family IsLeft (a :: Either a b) :: Bool where ...
- sIsLeft :: forall a b (t :: Either a b). Sing t -> Sing (Apply IsLeftSym0 t :: Bool)
- type family IsRight (a :: Either a b) :: Bool where ...
- sIsRight :: forall a b (t :: Either a b). Sing t -> Sing (Apply IsRightSym0 t :: Bool)
- data LeftSym0 :: forall (a6989586621679089505 :: Type) (b6989586621679089506 :: Type). (~>) a6989586621679089505 (Either (a6989586621679089505 :: Type) (b6989586621679089506 :: Type))
- type LeftSym1 (t6989586621679312485 :: a6989586621679089505) = Left t6989586621679312485
- data RightSym0 :: forall (a6989586621679089505 :: Type) (b6989586621679089506 :: Type). (~>) b6989586621679089506 (Either (a6989586621679089505 :: Type) (b6989586621679089506 :: Type))
- type RightSym1 (t6989586621679312487 :: b6989586621679089506) = Right t6989586621679312487
- data Either_Sym0 :: forall a6989586621680465967 b6989586621680465969 c6989586621680465968. (~>) ((~>) a6989586621680465967 c6989586621680465968) ((~>) ((~>) b6989586621680465969 c6989586621680465968) ((~>) (Either a6989586621680465967 b6989586621680465969) c6989586621680465968))
- data Either_Sym1 (a6989586621680466003 :: (~>) a6989586621680465967 c6989586621680465968) :: forall b6989586621680465969. (~>) ((~>) b6989586621680465969 c6989586621680465968) ((~>) (Either a6989586621680465967 b6989586621680465969) c6989586621680465968)
- data Either_Sym2 (a6989586621680466003 :: (~>) a6989586621680465967 c6989586621680465968) (a6989586621680466004 :: (~>) b6989586621680465969 c6989586621680465968) :: (~>) (Either a6989586621680465967 b6989586621680465969) c6989586621680465968
- type Either_Sym3 (a6989586621680466003 :: (~>) a6989586621680465967 c6989586621680465968) (a6989586621680466004 :: (~>) b6989586621680465969 c6989586621680465968) (a6989586621680466005 :: Either a6989586621680465967 b6989586621680465969) = Either_ a6989586621680466003 a6989586621680466004 a6989586621680466005
- data LeftsSym0 :: forall a6989586621680467445 b6989586621680467446. (~>) [Either a6989586621680467445 b6989586621680467446] [a6989586621680467445]
- type LeftsSym1 (a6989586621680467835 :: [Either a6989586621680467445 b6989586621680467446]) = Lefts a6989586621680467835
- data RightsSym0 :: forall a6989586621680467443 b6989586621680467444. (~>) [Either a6989586621680467443 b6989586621680467444] [b6989586621680467444]
- type RightsSym1 (a6989586621680467830 :: [Either a6989586621680467443 b6989586621680467444]) = Rights a6989586621680467830
- data IsLeftSym0 :: forall a6989586621680467439 b6989586621680467440. (~>) (Either a6989586621680467439 b6989586621680467440) Bool
- type IsLeftSym1 (a6989586621680467806 :: Either a6989586621680467439 b6989586621680467440) = IsLeft a6989586621680467806
- data IsRightSym0 :: forall a6989586621680467437 b6989586621680467438. (~>) (Either a6989586621680467437 b6989586621680467438) Bool
- type IsRightSym1 (a6989586621680467804 :: Either a6989586621680467437 b6989586621680467438) = IsRight a6989586621680467804
The Either singleton
data family Sing :: k -> Type #
The singleton kind-indexed data family.
Instances
| SDecide k => TestCoercion (Sing :: k -> Type) # | |
Defined in Data.Singletons.Decide | |
| SDecide k => TestEquality (Sing :: k -> Type) # | |
Defined in Data.Singletons.Decide | |
| Show (SSymbol s) # | |
| Show (SNat n) # | |
| Eq (Sing a) # | |
| Ord (Sing a) # | |
| Show (Sing z) # | |
| (ShowSing a, ShowSing [a]) => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| Show (Sing z) # | |
| (ShowSing a, ShowSing b) => Show (Sing z) # | |
| Show (Sing a) # | |
| Show (Sing z) # | |
| (ShowSing a, ShowSing b) => Show (Sing z) # | |
| (ShowSing a, ShowSing b, ShowSing c) => Show (Sing z) # | |
| (ShowSing a, ShowSing b, ShowSing c, ShowSing d) => Show (Sing z) # | |
| (ShowSing a, ShowSing b, ShowSing c, ShowSing d, ShowSing e) => Show (Sing z) # | |
| (ShowSing a, ShowSing b, ShowSing c, ShowSing d, ShowSing e, ShowSing f) => Show (Sing z) # | |
| (ShowSing a, ShowSing b, ShowSing c, ShowSing d, ShowSing e, ShowSing f, ShowSing g) => Show (Sing z) # | |
| Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| (ShowSing a, ShowSing b) => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| ShowSing m => Show (Sing z) # | |
| ShowSing (Maybe a) => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| ShowSing (Maybe a) => Show (Sing z) # | |
| ShowSing (Maybe a) => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| ShowSing Bool => Show (Sing z) # | |
| ShowSing Bool => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| ShowSing a => Show (Sing z) # | |
| (ShowSing a, ShowSing [a]) => Show (Sing z) # | |
| data Sing (a :: Bool) # | |
| data Sing (a :: Ordering) # | |
| data Sing (n :: Nat) # | |
| data Sing (n :: Symbol) # | |
Defined in Data.Singletons.TypeLits.Internal | |
| data Sing (a :: ()) # | |
Defined in Data.Singletons.Prelude.Instances | |
| data Sing (a :: Void) # | |
Defined in Data.Singletons.Prelude.Instances | |
| data Sing (a :: All) # | |
| data Sing (a :: Any) # | |
| data Sing (a :: PErrorMessage) # | |
Defined in Data.Singletons.TypeError data Sing (a :: PErrorMessage) where
| |
| data Sing (b :: [a]) # | |
| data Sing (b :: Maybe a) # | |
| newtype Sing (a :: TYPE rep) # | A choice of singleton for the kind Conceivably, one could generalize this instance to `Sing :: k -> Type` for
any kind We cannot produce explicit singleton values for everything in |
Defined in Data.Singletons.TypeRepTYPE | |
| data Sing (b :: Min a) # | |
| data Sing (b :: Max a) # | |
| data Sing (b :: First a) # | |
| data Sing (b :: Last a) # | |
| data Sing (a :: WrappedMonoid m) # | |
Defined in Data.Singletons.Prelude.Semigroup.Internal data Sing (a :: WrappedMonoid m) where
| |
| data Sing (b :: Option a) # | |
| data Sing (b :: Identity a) # | |
| data Sing (b :: First a) # | |
| data Sing (b :: Last a) # | |
| data Sing (b :: Dual a) # | |
| data Sing (b :: Sum a) # | |
| data Sing (b :: Product a) # | |
| data Sing (b :: Down a) # | |
| data Sing (b :: NonEmpty a) # | |
| data Sing (c :: Either a b) # | |
| data Sing (c :: (a, b)) # | |
| data Sing (c :: Arg a b) # | |
| newtype Sing (f :: k1 ~> k2) # | |
| data Sing (d :: (a, b, c)) # | |
| data Sing (c :: Const a b) # | |
| data Sing (e :: (a, b, c, d)) # | |
| data Sing (f :: (a, b, c, d, e)) # | |
| data Sing (g :: (a, b, c, d, e, f)) # | |
| data Sing (h :: (a, b, c, d, e, f, g)) # | |
Defined in Data.Singletons.Prelude.Instances | |
Though Haddock doesn't show it, the Sing instance above declares
constructors
SLeft :: Sing a -> Sing (Left a) SRight :: Sing b -> Sing (Right b)
Singletons from Data.Either
sEither_ :: forall a c b (t :: (~>) a c) (t :: (~>) b c) (t :: Either a b). Sing t -> Sing t -> Sing t -> Sing (Apply (Apply (Apply Either_Sym0 t) t) t :: c) #
The preceding two definitions are derived from the function either in
Data.Either. The extra underscore is to avoid name clashes with the type
Either.
type family PartitionEithers (a :: [Either a b]) :: ([a], [b]) where ... #
Equations
| PartitionEithers a_6989586621680467808 = Apply (Apply (Apply FoldrSym0 (Apply (Apply Either_Sym0 (Let6989586621680467813LeftSym1 a_6989586621680467808)) (Let6989586621680467813RightSym1 a_6989586621680467808))) (Apply (Apply Tuple2Sym0 '[]) '[])) a_6989586621680467808 |
sPartitionEithers :: forall a b (t :: [Either a b]). Sing t -> Sing (Apply PartitionEithersSym0 t :: ([a], [b])) #
Defunctionalization symbols
data LeftSym0 :: forall (a6989586621679089505 :: Type) (b6989586621679089506 :: Type). (~>) a6989586621679089505 (Either (a6989586621679089505 :: Type) (b6989586621679089506 :: Type)) #
Instances
| SingI (LeftSym0 :: TyFun a (Either a b) -> Type) # | |
Defined in Data.Singletons.Prelude.Instances | |
| SuppressUnusedWarnings (LeftSym0 :: TyFun a6989586621679089505 (Either a6989586621679089505 b6989586621679089506) -> Type) # | |
Defined in Data.Singletons.Prelude.Instances Methods suppressUnusedWarnings :: () # | |
| type Apply (LeftSym0 :: TyFun a (Either a b6989586621679089506) -> Type) (t6989586621679312485 :: a) # | |
data RightSym0 :: forall (a6989586621679089505 :: Type) (b6989586621679089506 :: Type). (~>) b6989586621679089506 (Either (a6989586621679089505 :: Type) (b6989586621679089506 :: Type)) #
Instances
| SingI (RightSym0 :: TyFun b (Either a b) -> Type) # | |
Defined in Data.Singletons.Prelude.Instances | |
| SuppressUnusedWarnings (RightSym0 :: TyFun b6989586621679089506 (Either a6989586621679089505 b6989586621679089506) -> Type) # | |
Defined in Data.Singletons.Prelude.Instances Methods suppressUnusedWarnings :: () # | |
| type Apply (RightSym0 :: TyFun b (Either a6989586621679089505 b) -> Type) (t6989586621679312487 :: b) # | |
data Either_Sym0 :: forall a6989586621680465967 b6989586621680465969 c6989586621680465968. (~>) ((~>) a6989586621680465967 c6989586621680465968) ((~>) ((~>) b6989586621680465969 c6989586621680465968) ((~>) (Either a6989586621680465967 b6989586621680465969) c6989586621680465968)) #
Instances
| SingI (Either_Sym0 :: TyFun (a ~> c) ((b ~> c) ~> (Either a b ~> c)) -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods sing :: Sing Either_Sym0 # | |
| SuppressUnusedWarnings (Either_Sym0 :: TyFun (a6989586621680465967 ~> c6989586621680465968) ((b6989586621680465969 ~> c6989586621680465968) ~> (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968)) -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (Either_Sym0 :: TyFun (a6989586621680465967 ~> c6989586621680465968) ((b6989586621680465969 ~> c6989586621680465968) ~> (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968)) -> Type) (a6989586621680466003 :: a6989586621680465967 ~> c6989586621680465968) # | |
Defined in Data.Singletons.Prelude.Either type Apply (Either_Sym0 :: TyFun (a6989586621680465967 ~> c6989586621680465968) ((b6989586621680465969 ~> c6989586621680465968) ~> (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968)) -> Type) (a6989586621680466003 :: a6989586621680465967 ~> c6989586621680465968) = (Either_Sym1 a6989586621680466003 b6989586621680465969 :: TyFun (b6989586621680465969 ~> c6989586621680465968) (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968) -> Type) | |
data Either_Sym1 (a6989586621680466003 :: (~>) a6989586621680465967 c6989586621680465968) :: forall b6989586621680465969. (~>) ((~>) b6989586621680465969 c6989586621680465968) ((~>) (Either a6989586621680465967 b6989586621680465969) c6989586621680465968) #
Instances
| SingI d => SingI (Either_Sym1 d b :: TyFun (b ~> c) (Either a b ~> c) -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods sing :: Sing (Either_Sym1 d b) # | |
| SuppressUnusedWarnings (Either_Sym1 a6989586621680466003 b6989586621680465969 :: TyFun (b6989586621680465969 ~> c6989586621680465968) (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968) -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (Either_Sym1 a6989586621680466003 b6989586621680465969 :: TyFun (b6989586621680465969 ~> c6989586621680465968) (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968) -> Type) (a6989586621680466004 :: b6989586621680465969 ~> c6989586621680465968) # | |
Defined in Data.Singletons.Prelude.Either type Apply (Either_Sym1 a6989586621680466003 b6989586621680465969 :: TyFun (b6989586621680465969 ~> c6989586621680465968) (Either a6989586621680465967 b6989586621680465969 ~> c6989586621680465968) -> Type) (a6989586621680466004 :: b6989586621680465969 ~> c6989586621680465968) = Either_Sym2 a6989586621680466003 a6989586621680466004 | |
data Either_Sym2 (a6989586621680466003 :: (~>) a6989586621680465967 c6989586621680465968) (a6989586621680466004 :: (~>) b6989586621680465969 c6989586621680465968) :: (~>) (Either a6989586621680465967 b6989586621680465969) c6989586621680465968 #
Instances
| (SingI d1, SingI d2) => SingI (Either_Sym2 d1 d2 :: TyFun (Either a b) c -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods sing :: Sing (Either_Sym2 d1 d2) # | |
| SuppressUnusedWarnings (Either_Sym2 a6989586621680466004 a6989586621680466003 :: TyFun (Either a6989586621680465967 b6989586621680465969) c6989586621680465968 -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (Either_Sym2 a6989586621680466004 a6989586621680466003 :: TyFun (Either a b) c -> Type) (a6989586621680466005 :: Either a b) # | |
Defined in Data.Singletons.Prelude.Either | |
type Either_Sym3 (a6989586621680466003 :: (~>) a6989586621680465967 c6989586621680465968) (a6989586621680466004 :: (~>) b6989586621680465969 c6989586621680465968) (a6989586621680466005 :: Either a6989586621680465967 b6989586621680465969) = Either_ a6989586621680466003 a6989586621680466004 a6989586621680466005 #
data LeftsSym0 :: forall a6989586621680467445 b6989586621680467446. (~>) [Either a6989586621680467445 b6989586621680467446] [a6989586621680467445] #
Instances
| SingI (LeftsSym0 :: TyFun [Either a b] [a] -> Type) # | |
Defined in Data.Singletons.Prelude.Either | |
| SuppressUnusedWarnings (LeftsSym0 :: TyFun [Either a6989586621680467445 b6989586621680467446] [a6989586621680467445] -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (LeftsSym0 :: TyFun [Either a b] [a] -> Type) (a6989586621680467835 :: [Either a b]) # | |
type LeftsSym1 (a6989586621680467835 :: [Either a6989586621680467445 b6989586621680467446]) = Lefts a6989586621680467835 #
data RightsSym0 :: forall a6989586621680467443 b6989586621680467444. (~>) [Either a6989586621680467443 b6989586621680467444] [b6989586621680467444] #
Instances
| SingI (RightsSym0 :: TyFun [Either a b] [b] -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods sing :: Sing RightsSym0 # | |
| SuppressUnusedWarnings (RightsSym0 :: TyFun [Either a6989586621680467443 b6989586621680467444] [b6989586621680467444] -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (RightsSym0 :: TyFun [Either a b] [b] -> Type) (a6989586621680467830 :: [Either a b]) # | |
Defined in Data.Singletons.Prelude.Either | |
type RightsSym1 (a6989586621680467830 :: [Either a6989586621680467443 b6989586621680467444]) = Rights a6989586621680467830 #
data IsLeftSym0 :: forall a6989586621680467439 b6989586621680467440. (~>) (Either a6989586621680467439 b6989586621680467440) Bool #
Instances
| SingI (IsLeftSym0 :: TyFun (Either a b) Bool -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods sing :: Sing IsLeftSym0 # | |
| SuppressUnusedWarnings (IsLeftSym0 :: TyFun (Either a6989586621680467439 b6989586621680467440) Bool -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (IsLeftSym0 :: TyFun (Either a b) Bool -> Type) (a6989586621680467806 :: Either a b) # | |
Defined in Data.Singletons.Prelude.Either | |
type IsLeftSym1 (a6989586621680467806 :: Either a6989586621680467439 b6989586621680467440) = IsLeft a6989586621680467806 #
data IsRightSym0 :: forall a6989586621680467437 b6989586621680467438. (~>) (Either a6989586621680467437 b6989586621680467438) Bool #
Instances
| SingI (IsRightSym0 :: TyFun (Either a b) Bool -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods sing :: Sing IsRightSym0 # | |
| SuppressUnusedWarnings (IsRightSym0 :: TyFun (Either a6989586621680467437 b6989586621680467438) Bool -> Type) # | |
Defined in Data.Singletons.Prelude.Either Methods suppressUnusedWarnings :: () # | |
| type Apply (IsRightSym0 :: TyFun (Either a b) Bool -> Type) (a6989586621680467804 :: Either a b) # | |
Defined in Data.Singletons.Prelude.Either | |
type IsRightSym1 (a6989586621680467804 :: Either a6989586621680467437 b6989586621680467438) = IsRight a6989586621680467804 #