37 lines
1.2 KiB
Racket
37 lines
1.2 KiB
Racket
|
#lang prospect
|
||
|
;; Demonstrates quit-world.
|
||
|
|
||
|
(require (only-in racket/port read-bytes-line-evt))
|
||
|
|
||
|
(define (spawn-command-listener)
|
||
|
(spawn (lambda (e s)
|
||
|
(match e
|
||
|
[(message (at-meta (at-meta (external-event _ (list #"quit")))))
|
||
|
(printf "Quitting just the leaf actor.\n")
|
||
|
(quit)]
|
||
|
[(message (at-meta (at-meta (external-event _ (list #"quit-world")))))
|
||
|
(printf "Terminating the whole network.\n")
|
||
|
(transition s (quit-world))]
|
||
|
[_ #f]))
|
||
|
(void)
|
||
|
(sub (external-event (read-bytes-line-evt (current-input-port) 'any) ?)
|
||
|
#:meta-level 2)))
|
||
|
|
||
|
(define (spawn-ticker)
|
||
|
(define (sub-to-alarm)
|
||
|
(sub (external-event (alarm-evt (+ (current-inexact-milliseconds) 1000)) ?) #:meta-level 2))
|
||
|
(spawn (lambda (e s)
|
||
|
(match e
|
||
|
[(message (at-meta (at-meta (external-event _ _))))
|
||
|
(printf "Tick!\n")
|
||
|
(transition s
|
||
|
(list (retract ?)
|
||
|
(sub-to-alarm)))]
|
||
|
[_ #f]))
|
||
|
(void)
|
||
|
(sub-to-alarm)))
|
||
|
|
||
|
(printf "Type 'quit' or 'quit-world'.\n")
|
||
|
(spawn-world (spawn-command-listener)
|
||
|
(spawn-ticker))
|