From owner-freebsd-bugs Mon Apr 22 05:45:02 1996 Return-Path: owner-bugs Received: (from root@localhost) by freefall.freebsd.org (8.7.3/8.7.3) id FAA02328 for bugs-outgoing; Mon, 22 Apr 1996 05:45:02 -0700 (PDT) Received: from neon.Glock.COM (neon.glock.com [198.82.228.159]) by freefall.freebsd.org (8.7.3/8.7.3) with ESMTP id FAA02316 Mon, 22 Apr 1996 05:44:59 -0700 (PDT) Received: (from mmead@localhost) by neon.Glock.COM (8.7.5/8.7.3) id IAA04738; Mon, 22 Apr 1996 08:44:51 -0400 (EDT) From: "matthew c. mead" Message-Id: <199604221244.IAA04738@neon.Glock.COM> Subject: Re: bin/1153: fmt segfaults To: mmead@Glock.COM Date: Mon, 22 Apr 1996 08:44:51 -0400 (EDT) Cc: FreeBSD-gnats-submit@freebsd.org, bugs@freebsd.org In-Reply-To: <199604220503.BAA01235@neon.Glock.COM> from "mmead@Glock.COM" at Apr 22, 96 01:03:08 am X-Mailer: ELM [version 2.4 PL24 ME8a] MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-bugs@freebsd.org X-Loop: FreeBSD.org Precedence: bulk The patch in the previous report would not work fully. I failed to test it on blank lines preceeding a the first line with text. The patch I sent in will cause blank lines preceeding the first line with text to be eaten. This patch corrects this behavior. This patch is against the *original* /usr/src/usr.bin/fmt/fmt.c, *not* the one obtained after using my first patch. --- /usr/src/usr.bin/fmt/fmt.c-dist Mon Apr 22 00:43:43 1996 +++ /usr/src/usr.bin/fmt/fmt.c Mon Apr 22 08:40:06 1996 @@ -172,7 +172,9 @@ *cp++ = c; c = getc(fi); } - *cp = '\0'; + if (cp != NULL) { + *cp = '\0'; + } /* * Toss anything remaining on the input line. @@ -186,7 +188,7 @@ col = 0; cp = linebuf; cp2 = canonb; - while (cc = *cp++) { + while ((cp != NULL) && (cc = *cp++)) { if (cc != '\t') { col++; if (cp2 - canonb >= cbufsize) { @@ -217,12 +219,17 @@ /* * Swipe trailing blanks from the line. */ - for (cp2--; cp2 >= canonb && *cp2 == ' '; cp2--) - ; - *++cp2 = '\0'; - prefix(canonb); - if (c != EOF) + if (cp != NULL) { + for (cp2--; cp2 >= canonb && *cp2 == ' '; cp2--) + ; + *++cp2 = '\0'; + prefix(canonb); + if (c != EOF) + c = getc(fi); + } else { + putchar('\n'); c = getc(fi); + } } } -matt -- Matthew C. Mead mmead@Glock.COM http://www.Glock.COM/~mmead/