{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE FunctionalDependencies #-}
{-# LANGUAGE KindSignatures #-}
module Data.JoinSemilattice.Class.Lifting where
import Data.Hashable (Hashable)
import Data.JoinSemilattice.Defined (Defined (..))
import Data.JoinSemilattice.Intersect (Intersect)
import qualified Data.JoinSemilattice.Intersect as Intersect
import Data.Kind (Constraint, Type)
class Lifting (f :: Type -> Type) (c :: Type -> Constraint) | f -> c where
lift' :: c x => x -> f x
class Trivial (x :: Type)
instance Trivial x
instance Lifting Defined Trivial where
lift' = Exactly
instance Lifting Intersect Hashable where
lift' = Intersect.singleton