Skip to content

Commit

Permalink
WIP: first step. Remove FutContents and HasPut constraints from par-c…
Browse files Browse the repository at this point in the history
…lasses pkg only. CC #120 and #108
  • Loading branch information
rrnewton committed Jul 29, 2015
1 parent d8f519c commit 7cf638a
Showing 1 changed file with 14 additions and 14 deletions.
28 changes: 14 additions & 14 deletions haskell/par-classes/Control/Par/Class.hs
Original file line number Diff line number Diff line change
Expand Up @@ -94,11 +94,12 @@ class ParMonad m => ParFuture (m :: EffectSig -> * -> * -> *) where
-- monad the user chooses. The future is parameterized by the 's' param as well.
type Future m :: * -> * -> *

-- | Different implementations may place different constraints on
-- what is allowable inside a Future. For example, some
-- implementations require an Eq Constraint.
type FutContents m a :: Constraint
type FutContents m a = () -- By default, no constraints.

-- -- | Different implementations may place different constraints on
-- -- what is allowable inside a Future. For example, some
-- -- implementations require an Eq Constraint.
-- type FutContents m a :: Constraint
-- type FutContents m a = () -- By default, no constraints.

-- | Create a potentially-parallel computation, and return a /future/
-- (or /promise/) that can be used to query the result of the forked
Expand All @@ -109,20 +110,19 @@ class ParMonad m => ParFuture (m :: EffectSig -> * -> * -> *) where
-- > fork (p >>= put r)
-- > return r
--
spawn :: (NFData a, HasPut e, FutContents m a) =>
spawn :: (NFData a) =>
m e s a -> m e s (Future m s a)

-- | Like 'spawn', but the result is only head-strict, not fully-strict.
spawn_ :: (HasPut e, FutContents m a) =>
m e s a -> m e s (Future m s a)
spawn_ :: m e s a -> m e s (Future m s a)

-- | Wait for the result of a future, and then return it.
get :: (HasGet e) => Future m s a -> m e s a

-- | Spawn a pure (rather than monadic) computation. Fully-strict.
--
-- > spawnP = spawn . return
spawnP :: (NFData a, HasPut e, FutContents m a) => a -> m e s (Future m s a)
spawnP :: (NFData a) => a -> m e s (Future m s a)

-- FIXME: We could conceivably elide the HasPut constraints, because spawn does not
-- have any possibility of doing a write to memory outside its scope (already allocated).
Expand Down Expand Up @@ -160,12 +160,12 @@ class ParFuture m => ParIVar (m :: EffectSig -> * -> * -> *) where
--
-- Sometimes partial strictness is more appropriate: see 'put_'.
--
put :: forall a e s . (FutContents m a, HasPut e, NFData a) =>
put :: forall a e s . (HasPut e, NFData a) =>
IVar m s a -> a -> m e s ()
put v a = deepseq a (put_ v a)

-- | like 'put', but only head-strict rather than fully-strict.
put_ :: forall a e s . (FutContents m a, HasPut e) =>
put_ :: forall a e s . (HasPut e) =>
IVar m s a -> a -> m e s ()

-- | NonIdem version of put. This version does not have the same constraint
Expand All @@ -176,11 +176,11 @@ class ParFuture m => ParIVar (m :: EffectSig -> * -> * -> *) where
-- Extra API routines that have default implementations:

-- | creates a new @IVar@ that contains a value
newFull :: (HasPut e, FutContents m a, NFData a) => a -> m e s (IVar m s a)
newFull :: (HasPut e, NFData a) => a -> m e s (IVar m s a)
newFull a = deepseq a (newFull_ a)

-- | creates a new @IVar@ that contains a value (head-strict only)
newFull_ :: (HasPut e, FutContents m a) => a -> m e s (IVar m s a)
newFull_ :: (HasPut e) => a -> m e s (IVar m s a)
newFull_ a = do v <- new
-- This is usually inefficient!
put_ v a
Expand Down Expand Up @@ -377,7 +377,7 @@ instance Generator [a] where
-- | Collection types which can be consumed in parallel.
class Generator c => ParFoldable c where
pmapFold :: forall m e s a .
(ParFuture m, HasGet e, HasPut e, FutContents m a)
(ParFuture m, HasGet e, HasPut e)
=> (ElemOf c -> m e s a) -- ^ compute one result
-> (a -> a -> m e s a) -- ^ combine two results
-> a -- ^ initial accumulator value
Expand Down

0 comments on commit 7cf638a

Please sign in to comment.