Added effectful Kleisli composition to Prelude. 15/2815/1
authorReino Ruusu <reino.ruusu@semantum.fi>
Fri, 22 Mar 2019 12:51:03 +0000 (14:51 +0200)
committerReino Ruusu <reino.ruusu@semantum.fi>
Fri, 22 Mar 2019 12:51:03 +0000 (14:51 +0200)
gitlab #280

Change-Id: If7a721ef2508b84490304a8353b31e8de9f25d27

bundles/org.simantics.scl.runtime/scl/Prelude.md
bundles/org.simantics.scl.runtime/scl/Prelude.scl

index df91f29..531a635 100644 (file)
 ## Monads
 
 ::class[Monad]
-::value[>>]
+::value[>>, >=>]
 ::class[FunctorM]
 ::value[repeatForever]
 ::class[MonadZero]
 ::value[guard]
 ::class[MonadPlus, MonadOr]
 ::value[ignoreM]
+::class[MonadE]
+::value[compE]
+::class[MonadZeroE]
 
 # Side-effects 
 
index e92603b..f983251 100644 (file)
@@ -1096,6 +1096,7 @@ class (FunctorE f) => FunctorM f where
 /// MonadE ///
 
 class (FunctorE m, Monad m) => MonadE m where
+    "An effectful version of the bind operator `(>>=)`"
     bindE :: m a -> (a -> <e> m b) -> <e> m b
 
 instance MonadE Maybe where
@@ -1109,6 +1110,11 @@ instance MonadE (Either a) where
 instance MonadE [] where
     bindE l f = concatMap f l
 
+@inline
+"An effectful version of the Kleisli composition operator `(>=>)`"
+compE :: MonadE m => (a -> <e> m b) -> (b -> <f> m c) -> a -> <e,f> m c
+compE f g x = (f x) `bindE` g
+
 /// MZeroE ///
 
 class (MonadE m, MonadZero m) => MonadZeroE m where