X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Fguile%2Fdolcon%2Futil.scm;h=5276ba8dfc9bfb41448f2d12e80b9ad9e5af5c97;hb=4070426d5489d98be7e2e2d7042562f80673c4b2;hp=506de8eaa6d3eba93e810c166ef3b7132ce589a1;hpb=c52332778b75b99ca95cd26cfe34a22dfa9cd18e;p=doldaconnect.git diff --git a/lib/guile/dolcon/util.scm b/lib/guile/dolcon/util.scm index 506de8e..5276ba8 100644 --- a/lib/guile/dolcon/util.scm +++ b/lib/guile/dolcon/util.scm @@ -58,12 +58,16 @@ (lambda () (dc-fn-update) (let* ((notify (lambda (event data) (for-each (lambda (o) (if (eq? event (car o)) ((cadr o) data))) fn-procs))) - (ua (lambda (r a) (let ((ires (dc-intresp r))) - (fn-updattr (car ires) a (cadr ires)) - (notify a (cdr (assq (car ires) fnetnodes))))))) - (dc-loop-reg ".notify" 601 (lambda (r er) (let ((ires (dc-intresp r))) - (fn-updattr (car ires) 'state (list-ref '(syn hs est dead) (cadr ires))) - (notify 'state (cdr (assq (car ires) fnetnodes)))))) + (ua (lambda (r a) (let* ((ires (dc-intresp r)) + (hubform (assq (car ires) fnetnodes))) + (if hubform + (begin (fn-updattr (car ires) a (cadr ires)) + (notify a (cdr (assq (car ires) fnetnodes))))))))) + (dc-loop-reg ".notify" 601 (lambda (r er) (let* ((ires (dc-intresp r)) + (hubform (assq (car ires) fnetnodes))) + (if hubform + (begin (fn-updattr (car ires) 'state (list-ref '(syn hs est dead) (cadr ires))) + (notify 'state (cdr hubform))))))) (dc-loop-reg ".notify" 602 (lambda (r er) (ua r 'name))) (dc-loop-reg ".notify" 605 (lambda (r er) (ua r 'users))) (dc-loop-reg ".notify" 604 (lambda (r er)