* ioext.c: further simplify scm_read_string_x_partial by defining
authorGary Houston <ghouston@arglist.com>
Thu, 18 Jan 2001 22:54:54 +0000 (22:54 +0000)
committerGary Houston <ghouston@arglist.com>
Thu, 18 Jan 2001 22:54:54 +0000 (22:54 +0000)
a macro SCM_EBLOCK.

libguile/ChangeLog
libguile/ioext.c

index 3bf635e..572ae53 100644 (file)
@@ -1,3 +1,8 @@
+2001-01-18  Gary Houston  <ghouston@arglist.com>
+
+       * ioext.c: further simplify scm_read_string_x_partial by defining
+       a macro SCM_EBLOCK.
+
 2001-01-18  Dirk Herrmann  <D.Herrmann@tu-bs.de>
 
        * gh_data.c (gh_ints2scm):  Simplified using SCM_FIXABLE.
index bf757c1..8949823 100644 (file)
 #endif
 \f
 
+#if defined (EAGAIN)
+#define SCM_MAYBE_EAGAIN || errno == EAGAIN
+#else
+#define SCM_MAYBE_EAGAIN
+#endif
+
+#if defined (EWOULDBLOCK)
+#define SCM_MAYBE_EWOULDBLOCK || errno == EWOULDBLOCK
+#else
+#define SCM_MAYBE_EWOULDBLOCK
+#endif
+
+/* MAYBE there is EAGAIN way of defining this macro but now I EWOULDBLOCK.  */
+#define SCM_EBLOCK(errno) \
+   (0 SCM_MAYBE_EAGAIN SCM_MAYBE_EWOULDBLOCK)
+
 SCM_DEFINE (scm_read_string_x_partial, "read-string!/partial", 1, 3, 0,
            (SCM str, SCM port_or_fdes, SCM start, SCM end),
            "Read characters from an fport or file descriptor into a\n"
@@ -140,17 +156,9 @@ SCM_DEFINE (scm_read_string_x_partial, "read-string!/partial", 1, 3, 0,
       SCM_SYSCALL (chars_read = read (fdes, dest, read_len));
       if (chars_read == -1)
        {
-#if defined (EWOULDBLOCK) || defined (EAGAIN)
-         if (
-#if defined (EWOULDBLOCK)
-             errno == EWOULDBLOCK
-#else
-             errno == EAGAIN
-#endif
-             )
+         if (SCM_EBLOCK (errno))
            chars_read = 0;
          else
-#endif
            SCM_SYSERROR;
         }
       else if (chars_read == 0)