Skip to content
Snippets Groups Projects
Commit 9cfef01a authored by Jens Nolte's avatar Jens Nolte
Browse files

Add MonadSTM variants for TVar operations

parent 598207f8
No related branches found
No related tags found
No related merge requests found
......@@ -4,9 +4,29 @@ module Quasar.PreludeSTM (
atomically,
newUniqueSTM,
module Control.Concurrent.STM,
newTVar,
newTVarIO,
readTVar,
readTVarIO,
writeTVar,
modifyTVar,
modifyTVar',
stateTVar,
swapTVar,
) where
import Control.Concurrent.STM hiding (atomically)
import Control.Concurrent.STM hiding (
atomically,
newTVar,
newTVarIO,
readTVar,
readTVarIO,
writeTVar,
modifyTVar,
modifyTVar',
stateTVar,
swapTVar,
)
import Control.Concurrent.STM qualified as STM
import Control.Monad.Base
import Control.Monad.IO.Class
......@@ -24,3 +44,30 @@ atomically t = liftIO (STM.atomically t)
newUniqueSTM :: MonadSTM m => m Unique
newUniqueSTM = liftSTM (unsafeIOToSTM newUnique)
newTVar :: MonadSTM m => a -> m (TVar a)
newTVar = liftSTM . STM.newTVar
newTVarIO :: MonadIO m => a -> m (TVar a)
newTVarIO = liftIO . STM.newTVarIO
readTVar :: MonadSTM m => TVar a -> m a
readTVar = liftSTM . STM.readTVar
readTVarIO :: MonadIO m => TVar a -> m a
readTVarIO = liftIO . STM.readTVarIO
writeTVar :: MonadSTM m => TVar a -> a -> m ()
writeTVar var = liftSTM . STM.writeTVar var
modifyTVar :: MonadSTM m => TVar a -> (a -> a) -> m ()
modifyTVar var = liftSTM . STM.modifyTVar var
modifyTVar' :: MonadSTM m => TVar a -> (a -> a) -> m ()
modifyTVar' var = liftSTM . STM.modifyTVar' var
stateTVar :: MonadSTM m => TVar s -> (s -> (a, s)) -> m a
stateTVar var = liftSTM . STM.stateTVar var
swapTVar :: MonadSTM m => TVar a -> a -> m a
swapTVar var = liftSTM . STM.swapTVar var
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment