guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

01/02: ssh: Work around 'select' bug in Guile.


From: Ludovic Courtès
Subject: 01/02: ssh: Work around 'select' bug in Guile.
Date: Fri, 9 Feb 2018 05:23:33 -0500 (EST)

civodul pushed a commit to branch master
in repository guix.

commit 8446dc5a360e3a13fecea870f86efdbd893e3905
Author: Ludovic Courtès <address@hidden>
Date:   Wed Feb 7 22:31:48 2018 +0100

    ssh: Work around 'select' bug in Guile.
    
    Fixes <https://bugs.gnu.org/30365>.
    
    * guix/ssh.scm (remote-daemon-channel)[redirect]: Define 'select*' and
    use it.
---
 guix/ssh.scm | 17 +++++++++++++----
 1 file changed, 13 insertions(+), 4 deletions(-)

diff --git a/guix/ssh.scm b/guix/ssh.scm
index 5e44202..9e90216 100644
--- a/guix/ssh.scm
+++ b/guix/ssh.scm
@@ -108,9 +108,18 @@ Throw an error on failure."
        (use-modules (ice-9 match) (rnrs io ports)
                     (rnrs bytevectors))
 
-       (let ((sock   (socket AF_UNIX SOCK_STREAM 0))
-             (stdin  (current-input-port))
-             (stdout (current-output-port)))
+       (let ((sock    (socket AF_UNIX SOCK_STREAM 0))
+             (stdin   (current-input-port))
+             (stdout  (current-output-port))
+             (select* (lambda (read write except)
+                        ;; This is a workaround for
+                        ;; <https://bugs.gnu.org/30365> in Guile < 2.2.4:
+                        ;; since 'select' sometimes returns non-empty sets for
+                        ;; no good reason, call 'select' a second time with a
+                        ;; zero timeout to filter out incorrect replies.
+                        (match (select read write except)
+                          ((read write except)
+                           (select read write except 0))))))
          (setvbuf stdout _IONBF)
 
          ;; Use buffered ports so that 'get-bytevector-some' returns up to the
@@ -121,7 +130,7 @@ Throw an error on failure."
          (connect sock AF_UNIX ,socket-name)
 
          (let loop ()
-           (match (select (list stdin sock) '() '())
+           (match (select* (list stdin sock) '() '())
              ((reads () ())
               (when (memq stdin reads)
                 (match (get-bytevector-some stdin)



reply via email to

[Prev in Thread] Current Thread [Next in Thread]