From f4b40701897248744c931eb09d28023185fc437d Mon Sep 17 00:00:00 2001 From: jsm Date: Tue, 7 Dec 1999 07:47:08 +0000 Subject: If the dictionary for boggle does not include words beginning with every letter, add appropriate index lines. Problem reported by Mike Castle against the Linux port of the NetBSD games collection. --- boggle/mkindex/mkindex.c | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'boggle') diff --git a/boggle/mkindex/mkindex.c b/boggle/mkindex/mkindex.c index 2951486c..25d8af98 100644 --- a/boggle/mkindex/mkindex.c +++ b/boggle/mkindex/mkindex.c @@ -1,4 +1,4 @@ -/* $NetBSD: mkindex.c,v 1.6 1999/09/18 20:50:29 jsm Exp $ */ +/* $NetBSD: mkindex.c,v 1.7 1999/12/07 07:47:08 jsm Exp $ */ /*- * Copyright (c) 1993 @@ -46,7 +46,7 @@ __COPYRIGHT("@(#) Copyright (c) 1993\n\ #if 0 static char sccsid[] = "@(#)mkindex.c 8.1 (Berkeley) 6/11/93"; #else -__RCSID("$NetBSD: mkindex.c,v 1.6 1999/09/18 20:50:29 jsm Exp $"); +__RCSID("$NetBSD: mkindex.c,v 1.7 1999/12/07 07:47:08 jsm Exp $"); #endif #endif /* not lint */ @@ -62,7 +62,7 @@ char *nextword __P((FILE *, char *, int *, int *)); int main(void) { - int clen, rlen, prev; + int clen, rlen, prev, i; long off, start; char buf[MAXWORDLEN + 1]; @@ -70,14 +70,24 @@ main(void) off = start = 0L; while (nextword(stdin, buf, &clen, &rlen) != NULL) { if (*buf != prev) { + /* + * Boggle expects a full index even if the dictionary + * had no words beginning with some letters. + * So we write out entries for every letter from prev + * to *buf. + */ if (prev != '\0') printf("%c %6ld %6ld\n", prev, start, off - 1); + for (i = (prev ? prev + 1 : 'a'); i < *buf; i++) + printf("%c %6ld %6ld\n", i, off, off - 1); prev = *buf; start = off; } off += clen + 1; } printf("%c %6ld %6ld\n", prev, start, off - 1); + for (i = prev + 1; i <= 'z'; i++) + printf("%c %6ld %6ld\n", i, off, off - 1); fflush(stdout); if (ferror(stdout)) err(1, "writing standard output"); -- cgit v1.2.3-56-ge451