module FRP.Yampa.Conditional (
provided
, pause
) where
import Control.Arrow
import FRP.Yampa.Basic
import FRP.Yampa.InternalCore (SF(..), SF'(..), sfTF', Transition)
import FRP.Yampa.EventS
import FRP.Yampa.Switches
provided :: (a -> Bool) -> SF a b -> SF a b -> SF a b
provided p sft sff =
switch (constant undefined &&& snap) $ \a0 ->
if p a0 then stt else stf
where
stt = switch (sft &&& (not . p ^>> edge)) (const stf)
stf = switch (sff &&& (p ^>> edge)) (const stt)
pause :: b -> SF a Bool -> SF a b -> SF a b
pause b_init (SF { sfTF = tfP}) (SF {sfTF = tf10}) = SF {sfTF = tf0}
where
tf0 a0 = case tfP a0 of
(c, True) -> (pauseInit b_init tf10 c, b_init)
(c, False) -> let (k, b0) = tf10 a0
in (pause' b0 k c, b0)
pauseInit :: b -> (a -> Transition a b) -> SF' a Bool -> SF' a b
pauseInit b_init' tf10' c = SF' tf0'
where tf0' dt a =
case (sfTF' c) dt a of
(c', True) -> (pauseInit b_init' tf10' c', b_init')
(c', False) -> let (k, b0) = tf10' a
in (pause' b0 k c', b0)
pause' :: b -> SF' a b -> SF' a Bool -> SF' a b
pause' b_init' tf10' tfP' = SF' tf0'
where tf0' dt a =
case (sfTF' tfP') dt a of
(tfP'', True) -> (pause' b_init' tf10' tfP'', b_init')
(tfP'', False) -> let (tf10'', b0') = (sfTF' tf10') dt a
in (pause' b0' tf10'' tfP'', b0')