From bbfa36aadf207c615cbe7960cb4d4ba5b7628a1f Mon Sep 17 00:00:00 2001 From: Michael Walker Date: Thu, 11 Feb 2016 14:05:28 +0000 Subject: [PATCH] Add comment about free monads vs continuations. --- dejafu/Test/DejaFu/Deterministic/Internal/Common.hs | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/dejafu/Test/DejaFu/Deterministic/Internal/Common.hs b/dejafu/Test/DejaFu/Deterministic/Internal/Common.hs index 3412ee5..f137317 100755 --- a/dejafu/Test/DejaFu/Deterministic/Internal/Common.hs +++ b/dejafu/Test/DejaFu/Deterministic/Internal/Common.hs @@ -22,7 +22,15 @@ import Control.Applicative (Applicative(..)) -------------------------------------------------------------------------------- -- * The @Conc@ Monad --- | The underlying monad is based on continuations over Actions. +-- | The underlying monad is based on continuations over 'Action's. +-- +-- One might wonder why the return type isn't reflected in 'Action', +-- and a free monad formulation used. This would remove the need for a +-- @Lift@ action as the penultimate action of thread 0 used to +-- communicate back the result, and be more pleasing in a +-- sense. However, this makes the current expression of threads and +-- exception handlers very difficult (perhaps even not possible +-- without significant reworking), so I abandoned the attempt. newtype M n r s a = M { runM :: (a -> Action n r s) -> Action n r s } instance Functor (M n r s) where