[hackers] [sbase] Switch concat() to use fread() and fwrite() || sin

From: <git_AT_suckless.org>
Date: Mon, 9 Feb 2015 16:25:08 +0100 (CET)

commit 6f85c05e57afaf0cb60b76e717d38ec6a34ce1c8
Author: sin <sin_AT_2f30.org>
Date: Mon Feb 9 15:22:03 2015 +0000

    Switch concat() to use fread() and fwrite()
    
    We should never mix FILE I/O with raw I/O. Going from raw I/O
    to FILE I/O is fine but doing the opposite is extremely tricky and
    only works under certain conditions (unbuffered stream + no call
    to ungetc()).

diff --git a/libutil/concat.c b/libutil/concat.c
index a276fbb..ef1e5b9 100644
--- a/libutil/concat.c
+++ b/libutil/concat.c
_AT_@ -1,6 +1,5 @@
 /* See LICENSE file for copyright and license details. */
 #include <stdio.h>
-#include <unistd.h>
 
 #include "../text.h"
 #include "../util.h"
_AT_@ -9,12 +8,14 @@ void
 concat(FILE *fp1, const char *s1, FILE *fp2, const char *s2)
 {
         char buf[BUFSIZ];
- ssize_t n;
+ size_t n;
 
- while ((n = read(fileno(fp1), buf, sizeof buf)) > 0) {
- if (write(fileno(fp2), buf, n) != n)
+ while ((n = fread(buf, 1, sizeof(buf), fp1)) > 0) {
+ if (fwrite(buf, 1, n, fp2) != n)
                         eprintf("%s: write error:", s2);
+ if (feof(fp1))
+ break;
         }
- if (n < 0)
+ if (ferror(fp1))
                 eprintf("%s: read error:", s1);
 }
Received on Mon Feb 09 2015 - 16:25:08 CET

This archive was generated by hypermail 2.3.0 : Mon Feb 09 2015 - 16:36:18 CET