{-# LANGUAGE UndecidableInstances #-} module Pandora.Paradigm.Primary.Transformer.Jet where import Pandora.Pattern.Functor.Covariant (Covariant ((<-|-)), (<-|-|-), (<-|-)) import Pandora.Pattern.Functor.Traversable (Traversable ((<<-)), (<<-<<-)) import Pandora.Paradigm.Primary.Algebraic ((<-*-)) data Jet t a = Jet a (Jet t (t a)) instance Covariant (->) (->) t => Covariant (->) (->) (Jet t) where f <-|- Jet x xs = Jet (f x) (f <-|-|- xs) instance Traversable (->) (->) t => Traversable (->) (->) (Jet t) where f <<- Jet x xs = Jet <-|- f x <-*- (f <<-<<- xs)