{-# LANGUAGE RankNTypes #-} -- | -- Copyright: (c) 2022 Bodigrim -- License: BSD3 module Data.List.Infinite.Internal ( Infinite (..), build, ) where -- | Type of infinite lists. -- -- In terms of recursion schemes, 'Infinite' @a@ is a fix point of the base functor @(a,)@, -- 'Data.List.Infinite.foldr' is a catamorphism and 'Data.List.Infinite.unfoldr' is an anamorphism. data Infinite a = a :< Infinite a infixr 5 :< build :: forall a. (forall b. (a -> b -> b) -> b) -> Infinite a build :: forall a. (forall b. (a -> b -> b) -> b) -> Infinite a build forall b. (a -> b -> b) -> b g = (a -> Infinite a -> Infinite a) -> Infinite a forall b. (a -> b -> b) -> b g a -> Infinite a -> Infinite a forall a. a -> Infinite a -> Infinite a (:<) {-# INLINE [1] build #-}