| Portability | non-portable (requires STM) | 
|---|---|
| Stability | experimental | 
| Maintainer | Peter Robinson <robinson@ecs.tuwien.ac.at> | 
Control.Concurrent.AdvSTM.TVar
Contents
Description
- data TVar a
- newTVar :: MonadAdvSTM m => a -> m (TVar a)
- newTVarIO :: a -> IO (TVar a)
- readTVar :: MonadAdvSTM m => TVar a -> m a
- writeTVar :: MonadAdvSTM m => TVar a -> a -> m ()
- readTVarAsync :: MonadAdvSTM m => TVar a -> m a
- writeTVarAsync :: MonadAdvSTM m => TVar a -> a -> m ()
TVars
newTVar :: MonadAdvSTM m => a -> m (TVar a)Source
See newTVar
readTVar :: MonadAdvSTM m => TVar a -> m aSource
Reads a value from a TVar. Blocks until the IO onCommit action(s) of 
 the corresponding transaction are complete.
 See onCommit for a more detailed description of this behaviour.
writeTVar :: MonadAdvSTM m => TVar a -> a -> m ()Source
Writes a value to a TVar. Blocks until the onCommit IO-action(s) are
 complete. See onCommit for details.
readTVarAsync :: MonadAdvSTM m => TVar a -> m aSource
Reads a value directly from the TVar. Does not block when the onCommit actions aren't done yet. NOTE: Only use this function when you know what you're doing.
writeTVarAsync :: MonadAdvSTM m => TVar a -> a -> m ()Source
Writes a value directly to the TVar. Does not block when onCommit actions aren't done yet. This function comes in handy for error recovery of exceptions that occur in onCommit.