From: Juho Snellman Date: Wed, 15 Mar 2006 17:48:25 +0000 (+0000) Subject: 0.9.10.37: X-Git-Url: http://repo.macrolet.net/gitweb/?a=commitdiff_plain;h=df677c367a27b9d8cedd6371b7646567a972d4b3;p=sbcl.git 0.9.10.37: The recent changes to LISTEN caused it to sometimes return NIL even when there was data already in the input buffer. Fix it. --- diff --git a/src/code/fd-stream.lisp b/src/code/fd-stream.lisp index 3edf77e..efa1d05 100644 --- a/src/code/fd-stream.lisp +++ b/src/code/fd-stream.lisp @@ -1591,23 +1591,29 @@ #!-win32 (setf (fd-stream-listen fd-stream) (if (sysread-may-block-p fd-stream) - nil - ;; select(2) and CL:LISTEN have slightly different - ;; semantics. The former returns that an FD is - ;; readable when a read operation wouldn't block. - ;; That includes EOF. However, LISTEN must return - ;; NIL at EOF. - (progn (catch 'eof-input-catcher - ;; r-b/f too calls select, but it shouldn't - ;; block as long as read can return once w/o - ;; blocking - (refill-buffer/fd fd-stream)) - (fd-stream-listen fd-stream)))))) + nil + ;; select(2) and CL:LISTEN have slightly different + ;; semantics. The former returns that an FD is + ;; readable when a read operation wouldn't block. + ;; That includes EOF. However, LISTEN must return + ;; NIL at EOF. + (progn (catch 'eof-input-catcher + ;; r-b/f too calls select, but it shouldn't + ;; block as long as read can return once w/o + ;; blocking + (refill-buffer/fd fd-stream)) + ;; If REFILL-BUFFER/FD set the FD-STREAM-LISTEN + ;; slot to a non-nil value (i.e. :EOF), keep + ;; that value. + (or (fd-stream-listen fd-stream) + ;; Otherwise we have data -> set the slot + ;; to T. + t)))))) (:unread (setf (fd-stream-unread fd-stream) arg1) (setf (fd-stream-listen fd-stream) t)) (:close - (cond (arg1 ; We got us an abort on our hands. + (cond (arg1 ; We got us an abort on our hands. (when (fd-stream-handler fd-stream) (sb!sys:remove-fd-handler (fd-stream-handler fd-stream)) (setf (fd-stream-handler fd-stream) nil)) @@ -1688,11 +1694,11 @@ (setf (fd-stream-listen fd-stream) nil)) #!-win32 (catch 'eof-input-catcher - (loop - until (sysread-may-block-p fd-stream) - do (refill-buffer/fd fd-stream) - (setf (fd-stream-ibuf-head fd-stream) 0) - (setf (fd-stream-ibuf-tail fd-stream) 0)) + (loop until (sysread-may-block-p fd-stream) + do + (refill-buffer/fd fd-stream) + (setf (fd-stream-ibuf-head fd-stream) 0) + (setf (fd-stream-ibuf-tail fd-stream) 0)) t)) (:force-output (flush-output-buffer fd-stream)) @@ -1724,7 +1730,7 @@ :format-control "~S is not a stream associated with a file." :format-arguments (list fd-stream))) (multiple-value-bind (okay dev ino mode nlink uid gid rdev size - atime mtime ctime blksize blocks) + atime mtime ctime blksize blocks) (sb!unix:unix-fstat (fd-stream-fd fd-stream)) (declare (ignore ino nlink uid gid rdev atime mtime ctime blksize blocks)) diff --git a/version.lisp-expr b/version.lisp-expr index 36dcbc3..7bdcb65 100644 --- a/version.lisp-expr +++ b/version.lisp-expr @@ -17,4 +17,4 @@ ;;; checkins which aren't released. (And occasionally for internal ;;; versions, especially for internal versions off the main CVS ;;; branch, it gets hairier, e.g. "0.pre7.14.flaky4.13".) -"0.9.10.36" +"0.9.10.37"