{-# LANGUAGE TemplateHaskell #-} -- | Unification variables binding in the 'Control.Monad.ST.ST' monad module Hyper.Unify.Binding.ST ( STUVar(..), _STUVar , stBinding ) where import Control.Monad.ST.Class (MonadST(..)) import Data.STRef (STRef, newSTRef, readSTRef, writeSTRef) import Hyper.Class.Unify (BindingDict(..)) import Hyper.Unify.Term (UTerm(..)) import Hyper.Internal.Prelude -- | A unification variable in the 'Control.Monad.ST.ST' monad newtype STUVar s t = STUVar (STRef s (UTerm (STUVar s) t)) deriving stock Eq makePrisms ''STUVar -- | A 'BindingDict' for 'STUVar's {-# INLINE stBinding #-} stBinding :: MonadST m => BindingDict (STUVar (World m)) m t stBinding = BindingDict { lookupVar = liftST . readSTRef . (^. _STUVar) , newVar = \t -> newSTRef t & liftST <&> STUVar , bindVar = \v t -> writeSTRef (v ^. _STUVar) t & liftST }