diff options
| author | David Greenman <dg@FreeBSD.org> | 1995-01-09 05:59:04 +0000 |
|---|---|---|
| committer | David Greenman <dg@FreeBSD.org> | 1995-01-09 05:59:04 +0000 |
| commit | 96bccfd8b23b881d3b6281161ed32aa7ba757803 (patch) | |
| tree | 33b7e494eaa588dcd85ae331639692844d0075c7 | |
| parent | cfc22f90268457ebcf2d169b2c29ac03e9bc33ca (diff) | |
Notes
| -rw-r--r-- | usr.bin/ranlib/build.c | 9 | ||||
| -rw-r--r-- | usr.bin/ranlib/touch.c | 1 |
2 files changed, 8 insertions, 2 deletions
diff --git a/usr.bin/ranlib/build.c b/usr.bin/ranlib/build.c index 12a6dc694722..ff745bed3c28 100644 --- a/usr.bin/ranlib/build.c +++ b/usr.bin/ranlib/build.c @@ -220,7 +220,7 @@ bad1: (void)lseek(rfd, r_off, SEEK_SET); static void symobj() { - register RLIB *rp; + register RLIB *rp, *rpnext; struct ranlib rn; off_t ransize; long size, stroff; @@ -272,9 +272,14 @@ symobj() error(tname); /* Write out the string table. */ - for (rp = rhead; rp; rp = rp->next) + for (rp = rhead; rp; rp = rpnext) { if (!fwrite(rp->sym, rp->symlen, 1, fp)) error(tname); + rpnext = rp->next; + free(rp->sym); + free(rp); + } + rhead = NULL; if (pad && !fwrite(&pad, sizeof(pad), 1, fp)) error(tname); diff --git a/usr.bin/ranlib/touch.c b/usr.bin/ranlib/touch.c index 4cf4b12cad64..0dd91232c676 100644 --- a/usr.bin/ranlib/touch.c +++ b/usr.bin/ranlib/touch.c @@ -65,6 +65,7 @@ touch() return(1); } settime(afd); + close_archive(afd); return(0); } |
