[hackers] [sbase] remove unnecessary calls to realloc from tee || Jakob Kramer

From: <git_AT_suckless.org>
Date: Wed, 04 Jun 2014 00:46:22 +0200

commit 2e1580ed2dd9dd81e1c63ff52d906fdeafbb1fe6
Author: Jakob Kramer <jakob.kramer_AT_gmx.de>
Date: Tue Jun 3 00:15:52 2014 +0200

    remove unnecessary calls to realloc from tee

diff --git a/tee.c b/tee.c
index d78602b..d88e49c 100644
--- a/tee.c
+++ b/tee.c
_AT_@ -16,7 +16,7 @@ main(int argc, char *argv[])
 {
         bool aflag = false;
         char buf[BUFSIZ];
- int i, nfps = 1;
+ int i, nfps;
         size_t n;
         FILE **fps = NULL;
 
_AT_@ -28,16 +28,15 @@ main(int argc, char *argv[])
                 usage();
         } ARGEND;
 
- if(!(fps = malloc(sizeof *fps)))
- eprintf("malloc:");
- fps[nfps-1] = stdout;
+ nfps = argc + 1;
+ if(!(fps = calloc(nfps, sizeof *fps)))
+ eprintf("calloc:");
+
+ for(i = 0; argc > 0; argc--, argv++, i++)
+ if(!(fps[i] = fopen(*argv, aflag ? "a" : "w")))
+ eprintf("fopen %s:", *argv);
+ fps[i] = stdout;
 
- for(; argc > 0; argc--, argv++) {
- if(!(fps = realloc(fps, ++nfps * sizeof *fps)))
- eprintf("realloc:");
- if(!(fps[nfps-1] = fopen(argv[0], aflag ? "a" : "w")))
- eprintf("fopen %s:", argv[0]);
- }
         while((n = fread(buf, 1, sizeof buf, stdin)) > 0) {
                 for(i = 0; i < nfps; i++) {
                         if(fwrite(buf, 1, n, fps[i]) != n)
Received on Wed Jun 04 2014 - 00:46:22 CEST

This archive was generated by hypermail 2.3.0 : Wed Jun 04 2014 - 00:48:07 CEST