multirec-0.7: Generic programming for families of recursive datatypes

Portabilitynon-portable
Stabilityexperimental
Maintainergenerics@haskell.org

Generics.MultiRec.FoldK

Contents

Description

Variant of Generics.MultiRec.Fold where the result type is independent of the index.

Synopsis

Generic fold and unfold

type Algebra' phi f r = forall ix. phi ix -> f (K0 r) ix -> rSource

type Algebra phi r = Algebra' phi (PF phi) rSource

type AlgebraF' phi f g r = forall ix. phi ix -> f (K0 r) ix -> g rSource

type AlgebraF phi g r = AlgebraF' phi (PF phi) g rSource

fold :: (Fam phi, HFunctor phi (PF phi)) => Algebra phi r -> phi ix -> ix -> rSource

foldM :: (Fam phi, HFunctor phi (PF phi), Monad m) => AlgebraF phi m r -> phi ix -> ix -> m rSource

type CoAlgebra' phi f r = forall ix. phi ix -> r -> f (K0 r) ixSource

type CoAlgebra phi r = CoAlgebra' phi (PF phi) rSource

type CoAlgebraF' phi f g r = forall ix. phi ix -> r -> g (f (K0 r) ix)Source

type CoAlgebraF phi g r = CoAlgebraF' phi (PF phi) g rSource

unfold :: (Fam phi, HFunctor phi (PF phi)) => CoAlgebra phi r -> phi ix -> r -> ixSource

unfoldM :: (Fam phi, HFunctor phi (PF phi), Monad m) => CoAlgebraF phi m r -> phi ix -> r -> m ixSource

type ParaAlgebra' phi f r = forall ix. phi ix -> f (K0 r) ix -> ix -> rSource

type ParaAlgebra phi r = ParaAlgebra' phi (PF phi) rSource

type ParaAlgebraF' phi f g r = forall ix. phi ix -> f (K0 r) ix -> ix -> g rSource

type ParaAlgebraF phi g r = ParaAlgebraF' phi (PF phi) g rSource

para :: (Fam phi, HFunctor phi (PF phi)) => ParaAlgebra phi r -> phi ix -> ix -> rSource

paraM :: (Fam phi, HFunctor phi (PF phi), Monad m) => ParaAlgebraF phi m r -> phi ix -> ix -> m rSource

Creating an algebra

type AlgPart f b ix = f (K0 b) ix -> bSource

type :-> f g b ix = f b ix -> g b ixSource

(&) :: (AlgPart a :-> (AlgPart b :-> AlgPart (a :+: b))) c ixSource

tag :: AlgPart a c ix -> AlgPart (a :>: ix) c ix'Source

con :: AlgPart a b ix -> AlgPart (C c a) b ixSource