X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;ds=sidebyside;f=8sync%2Fsystems%2Factors.scm;h=e2fd27eac767c1464d38e0fb31d8cd00659052e1;hb=de334e45354276124e0c58138f53c7ce1656c101;hp=270b25f452909e5a000780bd7de5e968d47d63d2;hpb=d3202269c645127c176cad41185fa0f95be34d89;p=8sync.git diff --git a/8sync/systems/actors.scm b/8sync/systems/actors.scm index 270b25f..e2fd27e 100644 --- a/8sync/systems/actors.scm +++ b/8sync/systems/actors.scm @@ -48,7 +48,7 @@ actor-id-string mlambda define-mhandler - make-action-dispatch + simple-dispatcher build-actions make-action-dispatch define-simple-actor @@ -352,6 +352,8 @@ Which is like doing manually: (let* ((action (message-action message)) (method (assoc-ref action-map action))) (if (not method) + ;; @@: There's every possibility this should be handled in + ;; hive-process-message instead. (throw 'action-not-found "No appropriate action handler found for actor" #:action action @@ -369,6 +371,15 @@ Which is like doing manually: ((_ (action-name handler)) (cons (quote action-name) handler)))) +(define-syntax-rule (build-actions action-item ...) + "Build a mapping of actions. Same syntax as make-action-dispatch +but this doesn't build the dispatcher for you (you probably want to +pass it to simple-dispatcher). + +The advantage here is that since this simply builds an alist, you can +compose it with other action maps." + (list (%expand-action-item action-item) ...)) + (define-syntax make-action-dispatch (syntax-rules () "Expand a list of action names and actions into an alist @@ -390,8 +401,7 @@ more compact following syntax: ((party actor message) (display \"Life of the party!\")))" ((make-action-dispatch action-item ...) - (simple-dispatcher - (list (%expand-action-item action-item) ...))))) + (simple-dispatcher (build-actions action-item ...))))) (define-syntax-rule (define-simple-actor class actions ...) (define-class class ()