From c7fd4536a16f5be404b1fdb6b37660895bc7de0b Mon Sep 17 00:00:00 2001 From: "Todd C. Miller" Date: Tue, 18 Dec 2001 16:55:07 +0000 Subject: We need to adjust where "dot" points when we realloc(message). Problem found by Mike Heffner of the FreeBSD project. --- usr.bin/mail/fio.c | 32 +++++++++++++++----------------- 1 file changed, 15 insertions(+), 17 deletions(-) (limited to 'usr.bin/mail') diff --git a/usr.bin/mail/fio.c b/usr.bin/mail/fio.c index 41f48a6a9b2..8974869ab72 100644 --- a/usr.bin/mail/fio.c +++ b/usr.bin/mail/fio.c @@ -1,4 +1,4 @@ -/* $OpenBSD: fio.c,v 1.20 2001/11/21 15:26:39 millert Exp $ */ +/* $OpenBSD: fio.c,v 1.21 2001/12/18 16:55:06 millert Exp $ */ /* $NetBSD: fio.c,v 1.8 1997/07/07 22:57:55 phil Exp $ */ /* @@ -38,7 +38,7 @@ #if 0 static const char sccsid[] = "@(#)fio.c 8.2 (Berkeley) 4/20/95"; #else -static const char rcsid[] = "$OpenBSD: fio.c,v 1.20 2001/11/21 15:26:39 millert Exp $"; +static const char rcsid[] = "$OpenBSD: fio.c,v 1.21 2001/12/18 16:55:06 millert Exp $"; #endif #endif /* not lint */ @@ -281,21 +281,19 @@ setinput(struct message *mp) void makemessage(FILE *f, int omsgCount) { - size_t size = (msgCount + 1) * sizeof(struct message); - - if (omsgCount) { - message = (struct message *)realloc(message, size); - if (message == 0) - errx(1, "Insufficient memory for %d messages\n", - msgCount); - } else { - if (message != 0) - (void)free(message); - if ((message = (struct message *)malloc(size)) == NULL) - errx(1, "Insufficient memory for %d messages", - msgCount); - dot = message; - } + size_t size; + struct message *nmessage; + + size = (msgCount + 1) * sizeof(struct message); + nmessage = (struct message *)realloc(message, size); + if (nmessage == 0) + errx(1, "Insufficient memory for %d messages\n", + msgCount); + if (omsgCount == 0 || message == NULL) + dot = nmessage; + else + dot = nmessage + (dot - message); + message = nmessage; size -= (omsgCount + 1) * sizeof(struct message); fflush(f); (void)lseek(fileno(f), (off_t)sizeof(*message), 0); -- cgit v1.2.3