Copyright | (c) 2017--2019 Michael Walker |
---|---|
License | MIT |
Maintainer | Michael Walker <mike@barrucadu.co.uk> |
Stability | experimental |
Portability | CPP, ExistentialQuantification, NoMonoLocalBinds, RecordWildCards, TypeFamilies |
Safe Haskell | None |
Language | Haskell2010 |
MonadSTM
testing implementation, internal types and definitions.
This module is NOT considered to form part of the public interface
of this library.
Synopsis
- newtype ModelSTM (n :: Type -> Type) a = ModelSTM {
- runModelSTM :: (a -> STMAction n) -> STMAction n
- data STMAction (n :: Type -> Type)
- = Exception e => SCatch (e -> ModelSTM n a) (ModelSTM n a) (a -> STMAction n)
- | SRead (ModelTVar n a) (a -> STMAction n)
- | SWrite (ModelTVar n a) a (STMAction n)
- | SOrElse (ModelSTM n a) (ModelSTM n a) (a -> STMAction n)
- | SNew String a (ModelTVar n a -> STMAction n)
- | Exception e => SThrow e
- | SRetry
- | SStop (n ())
- data ModelTVar (n :: Type -> Type) a = ModelTVar {}
- data Result a
- runTransaction :: MonadDejaFu n => ModelSTM n a -> IdSource -> n (Result a, n (), IdSource, [TAction])
- doTransaction :: MonadDejaFu n => ModelSTM n a -> IdSource -> n (Result a, n (), n (), IdSource, [TAction])
- stepTrans :: MonadDejaFu n => STMAction n -> IdSource -> n (STMAction n, n (), n (), IdSource, [TVarId], [TVarId], TAction)
The ModelSTM
monad
newtype ModelSTM (n :: Type -> Type) a Source #
The underlying monad is based on continuations over primitive actions.
This is not Cont
because we want to give it a custom MonadFail
instance.
ModelSTM | |
|
Instances
MonadFail (ModelSTM n) Source # | |||||
Defined in Test.DejaFu.Conc.Internal.STM | |||||
Alternative (ModelSTM n) Source # | |||||
Applicative (ModelSTM n) Source # | |||||
Defined in Test.DejaFu.Conc.Internal.STM | |||||
Functor (ModelSTM n) Source # | |||||
Monad (ModelSTM n) Source # | |||||
MonadPlus (ModelSTM n) Source # | |||||
MonadSTM (ModelSTM n) Source # | |||||
Defined in Test.DejaFu.Conc.Internal.STM
| |||||
MonadCatch (ModelSTM n) Source # | |||||
Defined in Test.DejaFu.Conc.Internal.STM | |||||
MonadThrow (ModelSTM n) Source # | |||||
Defined in Test.DejaFu.Conc.Internal.STM throwM :: (HasCallStack, Exception e) => e -> ModelSTM n a # | |||||
type TVar (ModelSTM n) Source # | |||||
Defined in Test.DejaFu.Conc.Internal.STM |
Primitive actions
data STMAction (n :: Type -> Type) Source #
STM transactions are represented as a sequence of primitive actions.
Exception e => SCatch (e -> ModelSTM n a) (ModelSTM n a) (a -> STMAction n) | |
SRead (ModelTVar n a) (a -> STMAction n) | |
SWrite (ModelTVar n a) a (STMAction n) | |
SOrElse (ModelSTM n a) (ModelSTM n a) (a -> STMAction n) | |
SNew String a (ModelTVar n a -> STMAction n) | |
Exception e => SThrow e | |
SRetry | |
SStop (n ()) |
TVar
s
data ModelTVar (n :: Type -> Type) a Source #
A TVar
is modelled as a unique ID and a reference holding a
value.
Output
The result of an STM transaction, along with which TVar
s it
touched whilst executing.
Success [TVarId] [TVarId] a | The transaction completed successfully, reading the first list
|
Retry [TVarId] | The transaction aborted by calling |
Exception SomeException | The transaction aborted by throwing an exception. |
Execution
runTransaction :: MonadDejaFu n => ModelSTM n a -> IdSource -> n (Result a, n (), IdSource, [TAction]) Source #
Run a transaction, returning the result and new initial TVarId
.
If the transaction failed, any effects are undone.
doTransaction :: MonadDejaFu n => ModelSTM n a -> IdSource -> n (Result a, n (), n (), IdSource, [TAction]) Source #
Run a STM transaction, returning an action to undo its effects.
If the transaction fails, its effects will automatically be undone,
so the undo action returned will be pure ()
.