]> granicus.if.org Git - musl/commitdiff
putgrent: Stop writing output on first failure
authorMichael Forney <mforney@mforney.org>
Tue, 5 Nov 2013 07:34:20 +0000 (23:34 -0800)
committerRich Felker <dalias@aerifal.cx>
Sat, 23 Nov 2013 21:20:51 +0000 (16:20 -0500)
This way, if an fprintf fails, we get an incomplete group entry rather
than a corrupted one.

src/passwd/putgrent.c

index d7847b15dbb112339b0ff2bead939fb9b612ddcc..b34f3254ba16b1a2e985d0d79cbf64ed5481aba2 100644 (file)
@@ -6,9 +6,10 @@ int putgrent(const struct group *gr, FILE *f)
        int r;
        size_t i;
        flockfile(f);
-       r = fprintf(f, "%s:%s:%d:", gr->gr_name, gr->gr_passwd, gr->gr_gid);
+       if ((r = fprintf(f, "%s:%s:%d:", gr->gr_name, gr->gr_passwd, gr->gr_gid))<0) goto done;
        if (gr->gr_mem) for (i=0; gr->gr_mem[i]; i++)
-               if (fprintf(f, "%s%s", i?",":"", gr->gr_mem[i])<0) r = -1;
+               if ((r = fprintf(f, "%s%s", i?",":"", gr->gr_mem[i]))<0) goto done;
+done:
        funlockfile(f);
        return r<0 ? -1 : 0;
 }