commit a51858016570713a2aca623645aa3ec2ac1a3d6c
parent 43327506b697598bf565576f9f3a820cc87d79ed
Author: sin <sin@2f30.org>
Date: Sun, 22 Feb 2015 11:08:16 +0000
Sync concat() from sbase
Diffstat:
1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/libutil/concat.c b/libutil/concat.c
@@ -1,6 +1,5 @@
/* See LICENSE file for copyright and license details. */
#include <stdio.h>
-#include <unistd.h>
#include "../text.h"
#include "../util.h"
@@ -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);
}