2014-11-20 02:42:58 +00:00
|
|
|
#lang racket/base
|
|
|
|
(require racket/generic
|
|
|
|
racket/match
|
|
|
|
racket/sequence
|
|
|
|
racket/contract/base
|
|
|
|
lux/chaos)
|
|
|
|
|
|
|
|
(struct pair (l r)
|
|
|
|
#:methods gen:chaos
|
2014-11-26 22:21:55 +00:00
|
|
|
[(define/generic super-start! chaos-start!)
|
|
|
|
(define/generic super-yield chaos-yield)
|
2014-11-22 18:54:08 +00:00
|
|
|
(define/generic super-event chaos-event)
|
2014-11-20 02:42:58 +00:00
|
|
|
(define/generic super-output! chaos-output!)
|
|
|
|
(define/generic super-label! chaos-label!)
|
|
|
|
(define/generic super-swap! chaos-swap!)
|
2014-11-26 22:21:55 +00:00
|
|
|
(define/generic super-stop! chaos-stop!)
|
|
|
|
(define (chaos-start! c)
|
|
|
|
(match-define (pair l r) c)
|
|
|
|
(super-start! l)
|
|
|
|
(super-start! r))
|
2014-11-20 02:42:58 +00:00
|
|
|
(define (chaos-yield c e)
|
|
|
|
(match-define (pair l r) c)
|
|
|
|
(super-yield l
|
|
|
|
(handle-evt always-evt
|
|
|
|
(λ (_)
|
|
|
|
(super-yield r e)))))
|
2014-11-22 18:54:08 +00:00
|
|
|
(define (chaos-event c)
|
2014-11-20 02:42:58 +00:00
|
|
|
(match-define (pair l r) c)
|
2014-11-22 18:54:08 +00:00
|
|
|
(choice-evt (super-event l)
|
|
|
|
(super-event r)))
|
2014-11-20 02:42:58 +00:00
|
|
|
(define (chaos-output! c o)
|
|
|
|
(match-define (pair l r) c)
|
|
|
|
(match-define (cons l.o r.o) o)
|
|
|
|
(super-output! l l.o)
|
|
|
|
(super-output! r r.o))
|
|
|
|
(define (chaos-label! c lab)
|
|
|
|
(match-define (pair l r) c)
|
|
|
|
(super-label! l lab)
|
|
|
|
(super-label! r lab))
|
|
|
|
(define (chaos-swap! c t)
|
|
|
|
(match-define (pair l r) c)
|
2014-11-26 22:21:55 +00:00
|
|
|
(super-swap! l (λ () (super-swap! r t))))
|
|
|
|
(define (chaos-stop! c)
|
|
|
|
(match-define (pair l r) c)
|
|
|
|
(super-stop! l)
|
|
|
|
(super-stop! r))])
|
2014-11-20 02:42:58 +00:00
|
|
|
|
|
|
|
(define (make-pair l r)
|
|
|
|
(pair l r))
|
|
|
|
(provide
|
|
|
|
(contract-out
|
|
|
|
[make-pair
|
|
|
|
(-> chaos? chaos?
|
|
|
|
chaos?)]))
|