X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Ffull-write.c;h=4e566f6e25f6c066522ad6dca85dc585cf31113a;hb=683f20f450976b4c99f616e7cb0b4217286cec56;hp=41f410d0a2609a6d2ed1270cd79517bc79d61826;hpb=811a26c818092d4888dafb6f07967b341ae7b8d6;p=gnulib.git diff --git a/lib/full-write.c b/lib/full-write.c index 41f410d0a..4e566f6e2 100644 --- a/lib/full-write.c +++ b/lib/full-write.c @@ -1,5 +1,7 @@ -/* safe-write.c -- an interface to write that retries after interrupts - Copyright (C) 1993 Free Software Foundation, Inc. +/* full-write.c -- an interface to write that retries after interrupts + + Copyright 1993, 1994, 1997, 1998, 1999, 2000, 2001 Free Software + Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -12,56 +14,54 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with this program; if not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - Copied largely from GNU C's cccp.c. - */ + Written by Paul Eggert. */ -#ifdef HAVE_CONFIG_H -#if defined (CONFIG_BROKETS) -/* We use instead of "config.h" so that a compilation - using -I. -I$srcdir will use ./config.h rather than $srcdir/config.h - (which it would do because it found this file in $srcdir). */ -#include -#else -#include "config.h" -#endif +#if HAVE_CONFIG_H +# include #endif #include -#ifdef HAVE_UNISTD_H -#include +#include "full-write.h" + +#if HAVE_UNISTD_H +# include #endif #include -#ifndef STDC_HEADERS +#ifndef errno extern int errno; #endif -/* Write LEN bytes at PTR to descriptor DESC, retrying if interrupted. - Return zero upon success, write's (negative) error code otherwise. */ +/* Write LEN bytes at PTR to descriptor DESC, retrying if interrupted + or if partial writes occur. Return the number of bytes successfully + written, setting errno if that is less than LEN. */ -int -full_write (desc, ptr, len) - int desc; - char *ptr; - int len; +size_t +full_write (int desc, const char *ptr, size_t len) { + size_t total_written = 0; + while (len > 0) { - int written = write (desc, ptr, len); - if (written < 0) + ssize_t written = write (desc, ptr, len); + if (written <= 0) { + /* Some buggy drivers return 0 when you fall off a device's end. */ + if (written == 0) + errno = ENOSPC; #ifdef EINTR if (errno == EINTR) continue; #endif - return written; + break; } + total_written += written; ptr += written; len -= written; } - return 0; + return total_written; }