- (let* ((s (network-stream c))
- (log (logging-stream c))
- (line (read-line s)))
- (format log "< ~a~%" line)
- (multiple-value-bind (message type) (parse-server-line line)
- (let ((handler (lookup-handler type))
- (mode (connection-mode c)))
- (if handler
- (funcall handler mode message)
- (error 'no-handler :mode mode :type type))))
- line))
+ (handler-case
+ (let* ((s (network-stream c))
+ (log (logging-stream c))
+ (line (read-line s)))
+ (format log "< ~a~%" line)
+ (multiple-value-bind (message type) (parse-server-line line)
+ (let ((handler (lookup-handler type))
+ (mode (connection-mode c)))
+ (if handler
+ (funcall handler mode message)
+ (error 'no-handler :mode mode :type type))))
+ line)
+ (sb-int:closed-stream-error () nil)))