-
Notifications
You must be signed in to change notification settings - Fork 71
/
TwoCounters.hs
56 lines (43 loc) · 2.1 KB
/
TwoCounters.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
{-----------------------------------------------------------------------------
reactive-banana-wx
Example: Two Counters.
------------------------------------------------------------------------------}
{-# LANGUAGE ScopedTypeVariables #-} -- allows "forall t. Moment t"
import Control.Monad
import Graphics.UI.WX hiding (Event)
import Reactive.Banana
import Reactive.Banana.WX
{-----------------------------------------------------------------------------
Main
------------------------------------------------------------------------------}
main = start $ do
f <- frame [text := "Two Counters"]
bup <- button f [text := "Up"]
bdown <- button f [text := "Down"]
bswitch <- button f [text := "Switch Counters"]
out1 <- staticText f []
out2 <- staticText f []
set f [layout := margin 10 $
column 5 [row 5 [widget bup, widget bdown, widget bswitch],
grid 5 5 [[label "First Counter:" , widget out1]
,[label "Second Counter:", widget out2]]]]
let networkDescription :: forall t. Frameworks t => Moment t ()
networkDescription = do
eup <- event0 bup command
edown <- event0 bdown command
eswitch <- event0 bswitch command
let
-- do we act on the left button?
firstcounter :: Behavior t Bool
firstcounter = accumB True $ not <$ eswitch
-- joined state of the two counters
counters :: Behavior t (Int, Int)
counters = accumB (0,0) $
union ((increment <$> firstcounter) `apply` eup)
((decrement <$> firstcounter) `apply` edown)
increment left _ (x,y) = if left then (x+1,y) else (x,y+1)
decrement left _ (x,y) = if left then (x-1,y) else (x,y-1)
sink out1 [text :== show . fst <$> counters]
sink out2 [text :== show . snd <$> counters]
network <- compile networkDescription
actuate network