{-# language UnboxedTuples #-}
{-# language MagicHash #-}
{-# language UnliftedNewtypes #-}
{-# language ScopedTypeVariables #-}
{-# language RoleAnnotations #-}
{-# language KindSignatures #-}
module Data.Primitive.Unlifted.MutVar.Primops
( UnliftedMutVar#
, newUnliftedMutVar#
, readUnliftedMutVar#
, writeUnliftedMutVar#
, sameUnliftedMutVar#
, casUnliftedMutVar#
, atomicSwapUnliftedMutVar#
) where
import GHC.Exts
newtype UnliftedMutVar# s (a :: TYPE 'UnliftedRep) = UnliftedMutVar# (MutVar# s Any)
type role UnliftedMutVar# nominal representational
newUnliftedMutVar# :: a -> State# s -> (# State# s, UnliftedMutVar# s a #)
{-# NOINLINE newUnliftedMutVar# #-}
newUnliftedMutVar# :: a -> State# s -> (# State# s, UnliftedMutVar# s a #)
newUnliftedMutVar# a
a State# s
s = case Any -> State# s -> (# State# s, MutVar# s Any #)
forall a d. a -> State# d -> (# State# d, MutVar# d a #)
newMutVar# (a -> Any
unsafeCoerce# a
a) State# s
s of
(# State# s
s', MutVar# s Any
mv #) -> (# State# s
s', MutVar# s Any -> UnliftedMutVar# s a
forall s (a :: TYPE 'UnliftedRep).
MutVar# s Any -> UnliftedMutVar# s a
UnliftedMutVar# MutVar# s Any
mv #)
readUnliftedMutVar# :: UnliftedMutVar# s a -> State# s -> (# State# s, a #)
{-# NOINLINE readUnliftedMutVar# #-}
readUnliftedMutVar# :: UnliftedMutVar# s a -> State# s -> (# State# s, a #)
readUnliftedMutVar# (UnliftedMutVar# MutVar# s Any
mv) State# s
s
= (# State# s, Any #) -> (# State# s, a #)
unsafeCoerce# (MutVar# s Any -> State# s -> (# State# s, Any #)
forall d a. MutVar# d a -> State# d -> (# State# d, a #)
readMutVar# MutVar# s Any
mv State# s
s)
writeUnliftedMutVar# :: UnliftedMutVar# s a -> a -> State# s -> State# s
{-# NOINLINE writeUnliftedMutVar# #-}
writeUnliftedMutVar# :: UnliftedMutVar# s a -> a -> State# s -> State# s
writeUnliftedMutVar# (UnliftedMutVar# MutVar# s Any
mv) a
a State# s
s
= MutVar# s Any -> Any -> State# s -> State# s
forall d a. MutVar# d a -> a -> State# d -> State# d
writeMutVar# MutVar# s Any
mv (a -> Any
unsafeCoerce# a
a) State# s
s
sameUnliftedMutVar# :: UnliftedMutVar# s a -> UnliftedMutVar# s a -> Int#
{-# INLINE sameUnliftedMutVar# #-}
sameUnliftedMutVar# :: UnliftedMutVar# s a -> UnliftedMutVar# s a -> Int#
sameUnliftedMutVar# (UnliftedMutVar# MutVar# s Any
mv1) (UnliftedMutVar# MutVar# s Any
mv2)
= MutVar# s Any -> MutVar# s Any -> Int#
forall d a. MutVar# d a -> MutVar# d a -> Int#
sameMutVar# MutVar# s Any
mv1 MutVar# s Any
mv2
casUnliftedMutVar#
:: UnliftedMutVar# s a
-> a
-> a
-> State# s -> (# State# s, Int#, a #)
{-# NOINLINE casUnliftedMutVar# #-}
casUnliftedMutVar# :: UnliftedMutVar# s a
-> a -> a -> State# s -> (# State# s, Int#, a #)
casUnliftedMutVar# (UnliftedMutVar# MutVar# s Any
mv) a
old a
new State# s
s
= (# State# s, Int#, Any #) -> (# State# s, Int#, a #)
unsafeCoerce# (MutVar# s Any
-> Any -> Any -> State# s -> (# State# s, Int#, Any #)
forall d a.
MutVar# d a -> a -> a -> State# d -> (# State# d, Int#, a #)
casMutVar# MutVar# s Any
mv (a -> Any
unsafeCoerce# a
old) (a -> Any
unsafeCoerce# a
new) State# s
s)
atomicSwapUnliftedMutVar#
:: UnliftedMutVar# s a -> a -> State# s -> (# State# s, a #)
{-# NOINLINE atomicSwapUnliftedMutVar# #-}
atomicSwapUnliftedMutVar# :: UnliftedMutVar# s a -> a -> State# s -> (# State# s, a #)
atomicSwapUnliftedMutVar# (UnliftedMutVar# MutVar# s Any
mv) a
a State# s
s
= (# State# s, Any #) -> (# State# s, a #)
unsafeCoerce# (MutVar# s Any -> Any -> State# s -> (# State# s, Any #)
forall s a. MutVar# s a -> a -> State# s -> (# State# s, a #)
atomicSwapMutVar# MutVar# s Any
mv (a -> Any
unsafeCoerce# a
a) State# s
s)
atomicSwapMutVar#
:: MutVar# s a -> a -> State# s -> (# State# s, a #)
atomicSwapMutVar# :: MutVar# s a -> a -> State# s -> (# State# s, a #)
atomicSwapMutVar# MutVar# s a
mv a
a State# s
s
= case MutVar# s a -> State# s -> (# State# s, a #)
forall d a. MutVar# d a -> State# d -> (# State# d, a #)
readMutVar# MutVar# s a
mv State# s
s of { (# State# s
s', a
old #) ->
case MutVar# s a -> a -> a -> State# s -> (# State# s, Int#, a #)
forall d a.
MutVar# d a -> a -> a -> State# d -> (# State# d, Int#, a #)
casMutVar# MutVar# s a
mv a
old a
a State# s
s' of
(# State# s
s'', Int#
0#, a
_ #) -> MutVar# s a -> a -> State# s -> (# State# s, a #)
forall s a. MutVar# s a -> a -> State# s -> (# State# s, a #)
atomicSwapMutVar# MutVar# s a
mv a
a State# s
s''
(# State# s
s'', Int#
_, a
_ #) -> (# State# s
s'', a
old #) }