X-Git-Url: https://jxself.org/git/?p=8sync.git;a=blobdiff_plain;f=8sync%2Fsystems%2Firc.scm;h=f8e01b43c02a0f94309538a368be54cb6b966a8f;hp=1333c3c5868424a19f12ee1812c06063dfd3554a;hb=c931d867f132da7c45f4f22b879433e07d2b463b;hpb=520e853306905c9d7978eae03ce082d4561b656b diff --git a/8sync/systems/irc.scm b/8sync/systems/irc.scm index 1333c3c..f8e01b4 100755 --- a/8sync/systems/irc.scm +++ b/8sync/systems/irc.scm @@ -229,7 +229,9 @@ (define (reset-buffer) (set! buffer '())) (define (should-read-char socket) - (and (char-ready? socket) (not (eof-object? (peek-char socket))))) + (and (not (port-closed? socket)) + (char-ready? socket) + (not (eof-object? (peek-char socket))))) (define (irc-handler socket) (while (should-read-char socket) (set! buffer (cons (read-char socket) buffer)) @@ -239,11 +241,21 @@ ;; reset buffer (set! buffer '()) ;; run it - (%8sync-run (handle-line - socket - ready-line - username)))) - (_ #f)))) + (%8sync (handle-line + socket + ready-line + username)))) + (_ #f))) + ;; I need to shut things down on EOF object + (cond + ((port-closed? socket) + (display "port closed time\n") + (port-remove-request socket)) + ((and (char-ready? socket) + (eof-object? (peek-char socket))) + (display "port eof time\n") + (close socket) + (port-remove-request socket)))) irc-handler)) (define default-line-handler (make-handle-line))