X-Git-Url: https://jxself.org/git/?p=8sync.git;a=blobdiff_plain;f=8sync%2Fsystems%2Factors.scm;h=e2fd27eac767c1464d38e0fb31d8cd00659052e1;hp=c33240f309cc181dcf030b905a43b989e4cec186;hb=de334e45354276124e0c58138f53c7ce1656c101;hpb=e8a99d0a22f93676617c1d7d0f45cb675ed852ee diff --git a/8sync/systems/actors.scm b/8sync/systems/actors.scm index c33240f..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 @@ -370,6 +372,12 @@ Which is like doing manually: (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