]> Dogcows Code - chaz/tar/commitdiff
Include full-write.h, not safe-read.h.
authorPaul Eggert <eggert@cs.ucla.edu>
Sat, 13 Jan 2001 05:59:29 +0000 (05:59 +0000)
committerPaul Eggert <eggert@cs.ucla.edu>
Sat, 13 Jan 2001 05:59:29 +0000 (05:59 +0000)
full_write returns size_t, with short writes meaning failure.
All callers changed.

lib/full-write.c

index f4c14e8062c3d3615d6d787a32f8f32662f5d229..1f5b78702931b4ed8b6a7fde11fd964bf0f9b81f 100644 (file)
@@ -1,5 +1,5 @@
 /* full-write.c -- an interface to write that retries after interrupts
-   Copyright 1993, 1994, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
+   Copyright 1993,94,97,98,99,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
@@ -24,7 +24,7 @@
 
 #include <sys/types.h>
 
-#include "safe-read.h"
+#include "full-write.h"
 
 #if HAVE_UNISTD_H
 # include <unistd.h>
 extern int errno;
 #endif
 
-/* Write LEN bytes at PTR to descriptor DESC, retrying if interrupted.
-   Return LEN upon success, -1 (setting errno) 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.  */
 
-ssize_t
+size_t
 full_write (int desc, const char *ptr, size_t len)
 {
-  ssize_t total_written = 0;
+  size_t total_written = 0;
 
   while (len > 0)
     {
@@ -55,7 +56,7 @@ full_write (int desc, const char *ptr, size_t len)
          if (errno == EINTR)
            continue;
 #endif
-         return -1;
+         break;
        }
       total_written += written;
       ptr += written;
This page took 0.023245 seconds and 4 git commands to generate.