Copyright | (C) 2014 Jan Stolarek |
---|---|
License | BSD-style (see LICENSE) |
Maintainer | Jan Stolarek (jan.stolarek@p.lodz.pl) |
Stability | experimental |
Portability | non-portable |
Safe Haskell | None |
Language | Haskell2010 |
Defines promoted functions and datatypes relating to Maybe
,
including a promoted version of all the definitions in Data.Maybe
.
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.Maybe
. Also, please excuse
the apparent repeated variable names. This is due to an interaction
between Template Haskell and Haddock.
- maybe_ :: forall b a. b -> (a -> b) -> Maybe a -> b
- type family Maybe_ a a a :: b
- type family IsJust a :: Bool
- type family IsNothing a :: Bool
- type family FromJust a :: a
- type family FromMaybe a a :: a
- type family MaybeToList a :: [] a
- type family ListToMaybe a :: Maybe a
- type family CatMaybes a :: [] a
- type family MapMaybe a a :: [] b
- type NothingSym0 = Nothing
- data JustSym0 l
- type JustSym1 t = Just t
- data Maybe_Sym0 l
- data Maybe_Sym1 l l
- data Maybe_Sym2 l l l
- type Maybe_Sym3 t t t = Maybe_ t t t
- data IsJustSym0 l
- type IsJustSym1 t = IsJust t
- data IsNothingSym0 l
- type IsNothingSym1 t = IsNothing t
- data FromJustSym0 l
- type FromJustSym1 t = FromJust t
- data FromMaybeSym0 l
- data FromMaybeSym1 l l
- type FromMaybeSym2 t t = FromMaybe t t
- data MaybeToListSym0 l
- type MaybeToListSym1 t = MaybeToList t
- data ListToMaybeSym0 l
- type ListToMaybeSym1 t = ListToMaybe t
- data CatMaybesSym0 l
- type CatMaybesSym1 t = CatMaybes t
- data MapMaybeSym0 l
- data MapMaybeSym1 l l
- type MapMaybeSym2 t t = MapMaybe t t
Promoted functions from Data.Maybe
The preceding two definitions is derived from the function maybe
in
Data.Maybe
. The extra underscore is to avoid name clashes with the type
Maybe
.
type family FromMaybe a a :: a Source
FromMaybe d x = Case_1628117042 d x (Let_1628117033Scrutinee_1628116954Sym2 d x) |
type family MaybeToList a :: [] a Source
MaybeToList Nothing = [] | |
MaybeToList (Just x) = Apply (Apply (:$) x) [] |
type family ListToMaybe a :: Maybe a Source
ListToMaybe [] = NothingSym0 | |
ListToMaybe ((:) a z) = Apply JustSym0 a |
Defunctionalization symbols
type NothingSym0 = Nothing Source
data Maybe_Sym0 l Source
SuppressUnusedWarnings (TyFun k (TyFun (TyFun k k -> *) (TyFun (Maybe k) k -> *) -> *) -> *) (Maybe_Sym0 k k) | |
type Apply (TyFun (TyFun k1 k -> *) (TyFun (Maybe k1) k -> *) -> *) k (Maybe_Sym0 k1 k) l0 = Maybe_Sym1 k k1 l0 |
data Maybe_Sym1 l l Source
SuppressUnusedWarnings (k -> TyFun (TyFun k k -> *) (TyFun (Maybe k) k -> *) -> *) (Maybe_Sym1 k k) | |
type Apply (TyFun (Maybe k) k1 -> *) (TyFun k k1 -> *) (Maybe_Sym1 k1 k l1) l0 = Maybe_Sym2 k1 k l1 l0 |
data Maybe_Sym2 l l l Source
SuppressUnusedWarnings (k -> (TyFun k k -> *) -> TyFun (Maybe k) k -> *) (Maybe_Sym2 k k) | |
type Apply k (Maybe k1) (Maybe_Sym2 k k1 l1 l2) l0 = Maybe_Sym3 k k1 l1 l2 l0 |
type Maybe_Sym3 t t t = Maybe_ t t t Source
data IsJustSym0 l Source
SuppressUnusedWarnings (TyFun (Maybe k) Bool -> *) (IsJustSym0 k) | |
type Apply Bool (Maybe k) (IsJustSym0 k) l0 = IsJustSym1 k l0 |
type IsJustSym1 t = IsJust t Source
data IsNothingSym0 l Source
SuppressUnusedWarnings (TyFun (Maybe k) Bool -> *) (IsNothingSym0 k) | |
type Apply Bool (Maybe k) (IsNothingSym0 k) l0 = IsNothingSym1 k l0 |
type IsNothingSym1 t = IsNothing t Source
data FromJustSym0 l Source
SuppressUnusedWarnings (TyFun (Maybe k) k -> *) (FromJustSym0 k) | |
type Apply k (Maybe k) (FromJustSym0 k) l0 = FromJustSym1 k l0 |
type FromJustSym1 t = FromJust t Source
data FromMaybeSym0 l Source
SuppressUnusedWarnings (TyFun k (TyFun (Maybe k) k -> *) -> *) (FromMaybeSym0 k) | |
type Apply (TyFun (Maybe k) k -> *) k (FromMaybeSym0 k) l0 = FromMaybeSym1 k l0 |
data FromMaybeSym1 l l Source
SuppressUnusedWarnings (k -> TyFun (Maybe k) k -> *) (FromMaybeSym1 k) | |
type Apply k (Maybe k) (FromMaybeSym1 k l1) l0 = FromMaybeSym2 k l1 l0 |
type FromMaybeSym2 t t = FromMaybe t t Source
data MaybeToListSym0 l Source
SuppressUnusedWarnings (TyFun (Maybe k) [k] -> *) (MaybeToListSym0 k) | |
type Apply [k] (Maybe k) (MaybeToListSym0 k) l0 = MaybeToListSym1 k l0 |
type MaybeToListSym1 t = MaybeToList t Source
data ListToMaybeSym0 l Source
SuppressUnusedWarnings (TyFun [k] (Maybe k) -> *) (ListToMaybeSym0 k) | |
type Apply (Maybe k) [k] (ListToMaybeSym0 k) l0 = ListToMaybeSym1 k l0 |
type ListToMaybeSym1 t = ListToMaybe t Source
data CatMaybesSym0 l Source
SuppressUnusedWarnings (TyFun [Maybe k] [k] -> *) (CatMaybesSym0 k) | |
type Apply [k] [Maybe k] (CatMaybesSym0 k) l0 = CatMaybesSym1 k l0 |
type CatMaybesSym1 t = CatMaybes t Source
data MapMaybeSym0 l Source
SuppressUnusedWarnings (TyFun (TyFun k (Maybe k) -> *) (TyFun [k] [k] -> *) -> *) (MapMaybeSym0 k k) | |
type Apply (TyFun [k1] [k] -> *) (TyFun k1 (Maybe k) -> *) (MapMaybeSym0 k k1) l0 = MapMaybeSym1 k k1 l0 |
data MapMaybeSym1 l l Source
SuppressUnusedWarnings ((TyFun k (Maybe k) -> *) -> TyFun [k] [k] -> *) (MapMaybeSym1 k k) | |
type Apply [k] [k1] (MapMaybeSym1 k k1 l1) l0 = MapMaybeSym2 k k1 l1 l0 |
type MapMaybeSym2 t t = MapMaybe t t Source