{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE Safe #-}
{-# LANGUAGE TypeOperators #-}
module Data.Parameterized.ClassesC
  ( TestEqualityC(..)
  , OrdC(..)
  ) where
import Data.Type.Equality ((:~:)(..))
import Data.Kind
import Data.Maybe (isJust)
import Data.Parameterized.Classes (OrderingF, toOrdering)
import Data.Parameterized.Some (Some(..))
class TestEqualityC (t :: (k -> Type) -> Type) where
  testEqualityC :: (forall x y. f x -> f y -> Maybe (x :~: y))
                -> t f
                -> t f
                -> Bool
class TestEqualityC t => OrdC (t :: (k -> Type) -> Type) where
  compareC :: (forall x y. f x -> g y -> OrderingF x y)
           -> t f
           -> t g
           -> Ordering
instance TestEqualityC Some where
  testEqualityC :: (forall (x :: k) (y :: k). f x -> f y -> Maybe (x :~: y))
-> Some f -> Some f -> Bool
testEqualityC forall (x :: k) (y :: k). f x -> f y -> Maybe (x :~: y)
subterms (Some f x
someone) (Some f x
something) =
    Maybe (x :~: x) -> Bool
forall a. Maybe a -> Bool
isJust (f x -> f x -> Maybe (x :~: x)
forall (x :: k) (y :: k). f x -> f y -> Maybe (x :~: y)
subterms f x
someone f x
something)
instance OrdC Some where
  compareC :: (forall (x :: k) (y :: k). f x -> g y -> OrderingF x y)
-> Some f -> Some g -> Ordering
compareC forall (x :: k) (y :: k). f x -> g y -> OrderingF x y
subterms (Some f x
someone) (Some g x
something) =
    OrderingF x x -> Ordering
forall k (x :: k) (y :: k). OrderingF x y -> Ordering
toOrdering (f x -> g x -> OrderingF x x
forall (x :: k) (y :: k). f x -> g y -> OrderingF x y
subterms f x
someone g x
something)