2017-08-10 19:17:28 +00:00
|
|
|
#lang syndicate
|
2015-12-11 07:25:52 +00:00
|
|
|
;; Toy file system, based on the example in the ESOP2016 submission.
|
2016-04-01 23:53:46 +00:00
|
|
|
;; syndicate/actor implementation.
|
2015-12-11 07:25:52 +00:00
|
|
|
|
2016-07-31 16:17:12 +00:00
|
|
|
(require/activate "fs-shell.rkt")
|
|
|
|
(require/activate "fs-protocol.rkt")
|
2015-12-11 07:25:52 +00:00
|
|
|
|
2017-02-15 23:18:19 +00:00
|
|
|
(spawn (field [files (hash)])
|
2016-08-24 16:35:38 +00:00
|
|
|
(on (asserted (observe (file $name _)))
|
|
|
|
(printf "At least one reader exists for ~v\n" name)
|
|
|
|
(until (retracted (observe (file name _)))
|
|
|
|
(field [content (hash-ref (files) name #f)])
|
|
|
|
(assert (file name (content)))
|
|
|
|
(on (message (save (file name $new-content))) (content new-content))
|
|
|
|
(on (message (delete name)) (content #f)))
|
|
|
|
(printf "No remaining readers exist for ~v\n" name))
|
|
|
|
(on (message (save (file $name $content))) (files (hash-set (files) name content)))
|
|
|
|
(on (message (delete $name)) (files (hash-remove (files) name))))
|