Copyright | (C) 2013-2014 Richard Eisenberg Jan Stolarek |
---|---|
License | BSD-style (see LICENSE) |
Maintainer | Ryan Scott |
Stability | experimental |
Portability | non-portable |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
Defines functions and datatypes relating to the singleton for Either
,
including singled versions 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
- type family Sing :: k -> Type
- data SEither :: forall (a :: Type) (b :: Type). Either a b -> Type where
- 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 :: (~>) a (Either (a :: Type) (b :: Type))
- type family LeftSym1 (a6989586621679042156 :: a) :: Either (a :: Type) (b :: Type) where ...
- data RightSym0 :: (~>) b (Either (a :: Type) (b :: Type))
- type family RightSym1 (a6989586621679042158 :: b) :: Either (a :: Type) (b :: Type) where ...
- data Either_Sym0 :: (~>) ((~>) a c) ((~>) ((~>) b c) ((~>) (Either a b) c))
- data Either_Sym1 (a6989586621679322752 :: (~>) a c) :: (~>) ((~>) b c) ((~>) (Either a b) c)
- data Either_Sym2 (a6989586621679322752 :: (~>) a c) (a6989586621679322753 :: (~>) b c) :: (~>) (Either a b) c
- type family Either_Sym3 (a6989586621679322752 :: (~>) a c) (a6989586621679322753 :: (~>) b c) (a6989586621679322754 :: Either a b) :: c where ...
- data LeftsSym0 :: (~>) [Either a b] [a]
- type family LeftsSym1 (a6989586621679325035 :: [Either a b]) :: [a] where ...
- data RightsSym0 :: (~>) [Either a b] [b]
- type family RightsSym1 (a6989586621679325029 :: [Either a b]) :: [b] where ...
- data IsLeftSym0 :: (~>) (Either a b) Bool
- type family IsLeftSym1 (a6989586621679325007 :: Either a b) :: Bool where ...
- data IsRightSym0 :: (~>) (Either a b) Bool
- type family IsRightSym1 (a6989586621679325004 :: Either a b) :: Bool where ...
The Either
singleton
type family Sing :: k -> Type #
Instances
data SEither :: forall (a :: Type) (b :: Type). Either a b -> Type where Source #
SLeft :: forall (a :: Type) (b :: Type) (n :: a). (Sing n) -> SEither ('Left n :: Either (a :: Type) (b :: Type)) | |
SRight :: forall (a :: Type) (b :: Type) (n :: b). (Sing n) -> SEither ('Right n :: Either (a :: Type) (b :: Type)) |
Instances
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) Source #
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 Rights (a :: [Either a b]) :: [b] where ... Source #
Rights '[] = NilSym0 | |
Rights ('(:) ('Left _) xs) = Apply RightsSym0 xs | |
Rights ('(:) ('Right x) xs) = Apply (Apply (:@#@$) x) (Apply RightsSym0 xs) |
type family PartitionEithers (a :: [Either a b]) :: ([a], [b]) where ... Source #
PartitionEithers a_6989586621679325008 = Apply (Apply (Apply FoldrSym0 (Apply (Apply Either_Sym0 (Let6989586621679325014LeftSym1 a_6989586621679325008)) (Let6989586621679325014RightSym1 a_6989586621679325008))) (Apply (Apply Tuple2Sym0 NilSym0) NilSym0)) a_6989586621679325008 |
sPartitionEithers :: forall a b (t :: [Either a b]). Sing t -> Sing (Apply PartitionEithersSym0 t :: ([a], [b])) Source #
Defunctionalization symbols
data LeftSym0 :: (~>) a (Either (a :: Type) (b :: Type)) Source #
Instances
SingI (LeftSym0 :: TyFun a (Either a b) -> Type) Source # | |
Defined in Data.Singletons.Base.Instances | |
SuppressUnusedWarnings (LeftSym0 :: TyFun a (Either a b) -> Type) Source # | |
Defined in Data.Singletons.Base.Instances suppressUnusedWarnings :: () # | |
type Apply (LeftSym0 :: TyFun a (Either a b) -> Type) (a6989586621679042156 :: a) Source # | |
type family LeftSym1 (a6989586621679042156 :: a) :: Either (a :: Type) (b :: Type) where ... Source #
data RightSym0 :: (~>) b (Either (a :: Type) (b :: Type)) Source #
Instances
SingI (RightSym0 :: TyFun b (Either a b) -> Type) Source # | |
Defined in Data.Singletons.Base.Instances | |
SuppressUnusedWarnings (RightSym0 :: TyFun b (Either a b) -> Type) Source # | |
Defined in Data.Singletons.Base.Instances suppressUnusedWarnings :: () # | |
type Apply (RightSym0 :: TyFun b (Either a b) -> Type) (a6989586621679042158 :: b) Source # | |
type family RightSym1 (a6989586621679042158 :: b) :: Either (a :: Type) (b :: Type) where ... Source #
data Either_Sym0 :: (~>) ((~>) a c) ((~>) ((~>) b c) ((~>) (Either a b) c)) Source #
Instances
SingI (Either_Sym0 :: TyFun (a ~> c) ((b ~> c) ~> (Either a b ~> c)) -> Type) Source # | |
Defined in Data.Either.Singletons sing :: Sing Either_Sym0 | |
SuppressUnusedWarnings (Either_Sym0 :: TyFun (a ~> c) ((b ~> c) ~> (Either a b ~> c)) -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (Either_Sym0 :: TyFun (a ~> c) ((b ~> c) ~> (Either a b ~> c)) -> Type) (a6989586621679322752 :: a ~> c) Source # | |
Defined in Data.Either.Singletons type Apply (Either_Sym0 :: TyFun (a ~> c) ((b ~> c) ~> (Either a b ~> c)) -> Type) (a6989586621679322752 :: a ~> c) = Either_Sym1 a6989586621679322752 :: TyFun (b ~> c) (Either a b ~> c) -> Type |
data Either_Sym1 (a6989586621679322752 :: (~>) a c) :: (~>) ((~>) b c) ((~>) (Either a b) c) Source #
Instances
SingI1 (Either_Sym1 :: (a ~> c) -> TyFun (b ~> c) (Either a b ~> c) -> Type) Source # | |
Defined in Data.Either.Singletons liftSing :: forall (x :: k1). Sing x -> Sing (Either_Sym1 x) | |
SingI d => SingI (Either_Sym1 d :: TyFun (b ~> c) (Either a b ~> c) -> Type) Source # | |
Defined in Data.Either.Singletons sing :: Sing (Either_Sym1 d) | |
SuppressUnusedWarnings (Either_Sym1 a6989586621679322752 :: TyFun (b ~> c) (Either a b ~> c) -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (Either_Sym1 a6989586621679322752 :: TyFun (b ~> c) (Either a b ~> c) -> Type) (a6989586621679322753 :: b ~> c) Source # | |
Defined in Data.Either.Singletons type Apply (Either_Sym1 a6989586621679322752 :: TyFun (b ~> c) (Either a b ~> c) -> Type) (a6989586621679322753 :: b ~> c) = Either_Sym2 a6989586621679322752 a6989586621679322753 |
data Either_Sym2 (a6989586621679322752 :: (~>) a c) (a6989586621679322753 :: (~>) b c) :: (~>) (Either a b) c Source #
Instances
SingI2 (Either_Sym2 :: (a ~> c) -> (b ~> c) -> TyFun (Either a b) c -> Type) Source # | |
Defined in Data.Either.Singletons liftSing2 :: forall (x :: k1) (y :: k2). Sing x -> Sing y -> Sing (Either_Sym2 x y) | |
SingI d => SingI1 (Either_Sym2 d :: (b ~> c) -> TyFun (Either a b) c -> Type) Source # | |
Defined in Data.Either.Singletons liftSing :: forall (x :: k1). Sing x -> Sing (Either_Sym2 d x) | |
(SingI d1, SingI d2) => SingI (Either_Sym2 d1 d2 :: TyFun (Either a b) c -> Type) Source # | |
Defined in Data.Either.Singletons sing :: Sing (Either_Sym2 d1 d2) | |
SuppressUnusedWarnings (Either_Sym2 a6989586621679322752 a6989586621679322753 :: TyFun (Either a b) c -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (Either_Sym2 a6989586621679322752 a6989586621679322753 :: TyFun (Either a b) c -> Type) (a6989586621679322754 :: Either a b) Source # | |
Defined in Data.Either.Singletons type Apply (Either_Sym2 a6989586621679322752 a6989586621679322753 :: TyFun (Either a b) c -> Type) (a6989586621679322754 :: Either a b) = Either_ a6989586621679322752 a6989586621679322753 a6989586621679322754 |
type family Either_Sym3 (a6989586621679322752 :: (~>) a c) (a6989586621679322753 :: (~>) b c) (a6989586621679322754 :: Either a b) :: c where ... Source #
Either_Sym3 a6989586621679322752 a6989586621679322753 a6989586621679322754 = Either_ a6989586621679322752 a6989586621679322753 a6989586621679322754 |
data LeftsSym0 :: (~>) [Either a b] [a] Source #
Instances
SingI (LeftsSym0 :: TyFun [Either a b] [a] -> Type) Source # | |
Defined in Data.Either.Singletons | |
SuppressUnusedWarnings (LeftsSym0 :: TyFun [Either a b] [a] -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (LeftsSym0 :: TyFun [Either a b] [a] -> Type) (a6989586621679325035 :: [Either a b]) Source # | |
data RightsSym0 :: (~>) [Either a b] [b] Source #
Instances
SingI (RightsSym0 :: TyFun [Either a b] [b] -> Type) Source # | |
Defined in Data.Either.Singletons sing :: Sing RightsSym0 | |
SuppressUnusedWarnings (RightsSym0 :: TyFun [Either a b] [b] -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (RightsSym0 :: TyFun [Either a b] [b] -> Type) (a6989586621679325029 :: [Either a b]) Source # | |
Defined in Data.Either.Singletons type Apply (RightsSym0 :: TyFun [Either a b] [b] -> Type) (a6989586621679325029 :: [Either a b]) = Rights a6989586621679325029 |
type family RightsSym1 (a6989586621679325029 :: [Either a b]) :: [b] where ... Source #
RightsSym1 a6989586621679325029 = Rights a6989586621679325029 |
data IsLeftSym0 :: (~>) (Either a b) Bool Source #
Instances
SingI (IsLeftSym0 :: TyFun (Either a b) Bool -> Type) Source # | |
Defined in Data.Either.Singletons sing :: Sing IsLeftSym0 | |
SuppressUnusedWarnings (IsLeftSym0 :: TyFun (Either a b) Bool -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (IsLeftSym0 :: TyFun (Either a b) Bool -> Type) (a6989586621679325007 :: Either a b) Source # | |
Defined in Data.Either.Singletons |
type family IsLeftSym1 (a6989586621679325007 :: Either a b) :: Bool where ... Source #
IsLeftSym1 a6989586621679325007 = IsLeft a6989586621679325007 |
data IsRightSym0 :: (~>) (Either a b) Bool Source #
Instances
SingI (IsRightSym0 :: TyFun (Either a b) Bool -> Type) Source # | |
Defined in Data.Either.Singletons sing :: Sing IsRightSym0 | |
SuppressUnusedWarnings (IsRightSym0 :: TyFun (Either a b) Bool -> Type) Source # | |
Defined in Data.Either.Singletons suppressUnusedWarnings :: () # | |
type Apply (IsRightSym0 :: TyFun (Either a b) Bool -> Type) (a6989586621679325004 :: Either a b) Source # | |
Defined in Data.Either.Singletons |
type family IsRightSym1 (a6989586621679325004 :: Either a b) :: Bool where ... Source #
IsRightSym1 a6989586621679325004 = IsRight a6989586621679325004 |