module Pandora.Paradigm.Primary.Functor.Edges where

import Pandora.Pattern.Category (($))
import Pandora.Pattern.Functor.Covariant (Covariant ((<$>)))
import Pandora.Pattern.Functor.Pointable (Pointable (point))
import Pandora.Pattern.Functor.Traversable (Traversable ((->>)))


data Edges a = Empty | Leap a | Connect a | Overlay a

instance Covariant Edges where
        _ <$> Empty = Empty
        f <$> Connect x = Connect $ f x
        f <$> Overlay x = Overlay $ f x
        f <$> Leap x = Leap $ f x

instance Traversable Edges where
        Empty ->> _ = point Empty
        Connect x ->> f = Connect <$> f x
        Overlay x ->> f = Overlay <$> f x
        Leap x ->> f = Leap <$> f x

edges :: r -> (a -> r) -> (a -> r) -> (a -> r) -> Edges a -> r
edges r _ _ _ Empty = r
edges _ f _ _ (Connect x) = f x
edges _ _ g _ (Overlay y) = g y
edges _ _ _ h (Leap z) = h z