{-# LANGUAGE GADTs, TypeFamilies #-}
module Data.Machine.Is
  ( Is(..)
  ) where
import Control.Category
import Data.Semigroup
import Prelude
data Is a b where
  Refl :: Is a a
instance Show (Is a b) where
  showsPrec _ Refl = showString "Refl"
instance Eq (Is a b) where
  Refl == Refl = True
  {-# INLINE (==) #-}
instance Ord (Is a b) where
  Refl `compare` Refl = EQ
  {-# INLINE compare #-}
instance (a ~ b) => Semigroup (Is a b) where
  Refl <> Refl = Refl
  {-# INLINE (<>) #-}
instance (a ~ b) => Monoid (Is a b) where
  mempty = Refl
  {-# INLINE mempty #-}
  mappend = (<>)
  {-# INLINE mappend #-}
instance (a ~ b) => Read (Is a b) where
  readsPrec d = readParen (d > 10) (\r -> [(Refl,s) | ("Refl",s) <- lex r ])
instance Category Is where
  id = Refl
  {-# INLINE id #-}
  Refl . Refl = Refl
  {-# INLINE (.) #-}