2016-04-01 23:53:46 +00:00
|
|
|
#lang syndicate/hll ;; -*- racket -*-
|
2015-11-10 00:07:29 +00:00
|
|
|
|
|
|
|
(actor (forever #:collect [(count 0)]
|
|
|
|
(assert `(parent-count ,count))
|
|
|
|
(on (asserted `(parent ,$p ,$c)) (+ count 1))
|
|
|
|
(on (retracted `(parent ,$p ,$c)) (- count 1))))
|
|
|
|
|
|
|
|
(define (insert-record record . monitors)
|
|
|
|
(actor (until (or (retracted (assertion-set-union* monitors))
|
|
|
|
(message `(retract ,record)))
|
|
|
|
(assert record))))
|
|
|
|
|
|
|
|
(insert-record `(parent john douglas))
|
|
|
|
(insert-record `(parent bob john))
|
|
|
|
(insert-record `(parent ebbon bob))
|
|
|
|
|
|
|
|
(actor (forever (on (asserted `(parent ,$p ,$c))
|
|
|
|
(insert-record `(ancestor ,p ,c)
|
|
|
|
`(parent ,p ,c)))))
|
|
|
|
|
|
|
|
(actor (forever (on (asserted `(parent ,$A ,$C))
|
|
|
|
(actor (until (retracted `(parent ,A ,C))
|
|
|
|
(on (asserted `(ancestor ,C ,$B))
|
|
|
|
(insert-record `(ancestor ,A ,B)
|
|
|
|
`(parent ,A ,C)
|
|
|
|
`(ancestor ,C ,B))))))))
|
|
|
|
|
|
|
|
(actor (forever (on (asserted `(ancestor ebbon douglas))
|
|
|
|
(printf "Proved (ancestor ebbon douglas)\n"))
|
|
|
|
(on (retracted `(ancestor ebbon douglas))
|
|
|
|
(printf "Proof of (ancestor ebbon douglas) invalidated\n"))))
|
|
|
|
|
|
|
|
(define (after msec thunk)
|
|
|
|
(define id (gensym 'after))
|
|
|
|
(if (zero? msec)
|
|
|
|
(thunk)
|
|
|
|
(actor (send! (set-timer id msec 'relative))
|
|
|
|
(until (message (timer-expired id ?)))
|
|
|
|
(thunk))))
|
|
|
|
|
|
|
|
(define use-delays? #t)
|
|
|
|
|
|
|
|
(after (if use-delays? 1000 0) (lambda ()
|
|
|
|
(printf "----- Retracting\n")
|
|
|
|
(message `(retract (parent bob john)))))
|
|
|
|
(after (if use-delays? 2000 0) (lambda ()
|
|
|
|
(printf "----- Asserting\n")
|
|
|
|
(list (insert-record `(parent bob mary))
|
|
|
|
(insert-record `(parent mary sue))
|
|
|
|
(insert-record `(parent sue john)))))
|