From 96dcb4e9329ab0b64d747ce196651a38e182fa5c Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Sun, 8 Jan 1995 19:33:34 +0000 Subject: [PATCH] See log in textutils/lib/. --- lib/safe-read.c | 43 +++++++++++++++++++------------------------ 1 file changed, 19 insertions(+), 24 deletions(-) diff --git a/lib/safe-read.c b/lib/safe-read.c index 7fd4415bb..93d35e4fa 100644 --- a/lib/safe-read.c +++ b/lib/safe-read.c @@ -27,39 +27,34 @@ #endif #include -#ifndef STDC_HEADERS +#ifndef errno extern int errno; #endif -/* Read LEN bytes at PTR from descriptor DESC, for file FILENAME, - retrying if necessary. Return a negative value if an error occurs, - otherwise return the actual number of bytes read, - which must be LEN unless end-of-file was reached. */ +/* Read LEN bytes at PTR from descriptor DESC, retrying if interrupted. + Return the actual number of bytes read, zero for EOF, or negative + for an error. */ - The canonical source for this function is in the gcc distribution - in file cccp.c. So don't make any changes here. */ - -static int +int safe_read (desc, ptr, len) int desc; char *ptr; int len; { - int left = len; - while (left > 0) { - int nchars = read (desc, ptr, left); - if (nchars < 0) - { + int n_chars; + + if (len <= 0) + return len; + #ifdef EINTR - if (errno == EINTR) - continue; + do + { + n_chars = read (desc, ptr, len); + } + while (n_chars < 0 && errno == EINTR); +#else + n_chars = read (desc, ptr, len); #endif - return nchars; - } - if (nchars == 0) - break; - ptr += nchars; - left -= nchars; - } - return len - left; + + return n_chars; } -- 2.11.0