summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Greenman <dg@FreeBSD.org>1995-01-09 05:59:04 +0000
committerDavid Greenman <dg@FreeBSD.org>1995-01-09 05:59:04 +0000
commit96bccfd8b23b881d3b6281161ed32aa7ba757803 (patch)
tree33b7e494eaa588dcd85ae331639692844d0075c7
parentcfc22f90268457ebcf2d169b2c29ac03e9bc33ca (diff)
Notes
-rw-r--r--usr.bin/ranlib/build.c9
-rw-r--r--usr.bin/ranlib/touch.c1
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);
}