{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE UndecidableInstances #-}
module Data.Equality.Graph.Classes
( module Data.Equality.Graph.Classes
, module Data.Equality.Graph.Classes.Id
) where
import qualified Data.Set as S
import Data.Functor.Classes
import Data.Equality.Graph.Classes.Id
import Data.Equality.Graph.Nodes
import Data.Equality.Utils.SizedList
import Data.Equality.Analysis
data EClass l = EClass
{ forall (l :: * -> *). EClass l -> ClassId
eClassId :: {-# UNPACK #-} !ClassId
, forall (l :: * -> *). EClass l -> Set (ENode l)
eClassNodes :: !(S.Set (ENode l))
, forall (l :: * -> *). EClass l -> Domain l
eClassData :: Domain l
, forall (l :: * -> *). EClass l -> SList (ClassId, ENode l)
eClassParents :: !(SList (ClassId, ENode l))
}
instance (Show (Domain l), Show1 l) => Show (EClass l) where
show :: EClass l -> String
show (EClass ClassId
a Set (ENode l)
b Domain l
d (SList [(ClassId, ENode l)]
c ClassId
_)) = String
"Id: " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show ClassId
a forall a. Semigroup a => a -> a -> a
<> String
"\nNodes: " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Set (ENode l)
b forall a. Semigroup a => a -> a -> a
<> String
"\nParents: " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show [(ClassId, ENode l)]
c forall a. Semigroup a => a -> a -> a
<> String
"\nData: " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Domain l
d