Home | History | Annotate | Line # | Download | only in mkindex
mkindex.c revision 1.6.4.1
      1  1.6.4.1  wrstuden /*	$NetBSD: mkindex.c,v 1.6.4.1 1999/12/27 18:28:59 wrstuden Exp $	*/
      2      1.2       cgd 
      3      1.1       jtc /*-
      4      1.1       jtc  * Copyright (c) 1993
      5      1.1       jtc  *	The Regents of the University of California.  All rights reserved.
      6      1.1       jtc  *
      7      1.1       jtc  * This code is derived from software contributed to Berkeley by
      8      1.1       jtc  * Barry Brachman.
      9      1.1       jtc  *
     10      1.1       jtc  * Redistribution and use in source and binary forms, with or without
     11      1.1       jtc  * modification, are permitted provided that the following conditions
     12      1.1       jtc  * are met:
     13      1.1       jtc  * 1. Redistributions of source code must retain the above copyright
     14      1.1       jtc  *    notice, this list of conditions and the following disclaimer.
     15      1.1       jtc  * 2. Redistributions in binary form must reproduce the above copyright
     16      1.1       jtc  *    notice, this list of conditions and the following disclaimer in the
     17      1.1       jtc  *    documentation and/or other materials provided with the distribution.
     18      1.1       jtc  * 3. All advertising materials mentioning features or use of this software
     19      1.1       jtc  *    must display the following acknowledgement:
     20      1.1       jtc  *	This product includes software developed by the University of
     21      1.1       jtc  *	California, Berkeley and its contributors.
     22      1.1       jtc  * 4. Neither the name of the University nor the names of its contributors
     23      1.1       jtc  *    may be used to endorse or promote products derived from this software
     24      1.1       jtc  *    without specific prior written permission.
     25      1.1       jtc  *
     26      1.1       jtc  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     27      1.1       jtc  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     28      1.1       jtc  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     29      1.1       jtc  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     30      1.1       jtc  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     31      1.1       jtc  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     32      1.1       jtc  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     33      1.1       jtc  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     34      1.1       jtc  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     35      1.1       jtc  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     36      1.1       jtc  * SUCH DAMAGE.
     37      1.1       jtc  */
     38      1.1       jtc 
     39      1.6       jsm #include <sys/cdefs.h>
     40      1.1       jtc #ifndef lint
     41      1.6       jsm __COPYRIGHT("@(#) Copyright (c) 1993\n\
     42      1.6       jsm 	The Regents of the University of California.  All rights reserved.\n");
     43      1.1       jtc #endif /* not lint */
     44      1.1       jtc 
     45      1.1       jtc #ifndef lint
     46      1.2       cgd #if 0
     47      1.1       jtc static char sccsid[] = "@(#)mkindex.c	8.1 (Berkeley) 6/11/93";
     48      1.2       cgd #else
     49  1.6.4.1  wrstuden __RCSID("$NetBSD: mkindex.c,v 1.6.4.1 1999/12/27 18:28:59 wrstuden Exp $");
     50      1.2       cgd #endif
     51      1.1       jtc #endif /* not lint */
     52      1.1       jtc 
     53      1.5       jsm #include <err.h>
     54      1.1       jtc #include <stdio.h>
     55      1.6       jsm #include <stdlib.h>
     56      1.1       jtc 
     57      1.1       jtc #include "bog.h"
     58      1.1       jtc 
     59      1.6       jsm int main __P((void));
     60      1.1       jtc char *nextword __P((FILE *, char *, int *, int *));
     61      1.1       jtc 
     62      1.1       jtc int
     63      1.4   hubertf main(void)
     64      1.1       jtc {
     65  1.6.4.1  wrstuden 	int clen, rlen, prev, i;
     66      1.1       jtc 	long off, start;
     67      1.1       jtc 	char buf[MAXWORDLEN + 1];
     68      1.1       jtc 
     69      1.1       jtc 	prev = '\0';
     70      1.1       jtc 	off = start = 0L;
     71      1.1       jtc 	while (nextword(stdin, buf, &clen, &rlen) != NULL) {
     72      1.1       jtc 		if (*buf != prev) {
     73  1.6.4.1  wrstuden 			/*
     74  1.6.4.1  wrstuden 			 * Boggle expects a full index even if the dictionary
     75  1.6.4.1  wrstuden 			 * had no words beginning with some letters.
     76  1.6.4.1  wrstuden 			 * So we write out entries for every letter from prev
     77  1.6.4.1  wrstuden 			 * to *buf.
     78  1.6.4.1  wrstuden 			 */
     79      1.1       jtc 			if (prev != '\0')
     80      1.1       jtc 				printf("%c %6ld %6ld\n", prev, start, off - 1);
     81  1.6.4.1  wrstuden 			for (i = (prev ? prev + 1 : 'a'); i < *buf; i++)
     82  1.6.4.1  wrstuden 				printf("%c %6ld %6ld\n", i, off, off - 1);
     83      1.1       jtc 			prev = *buf;
     84      1.1       jtc 			start = off;
     85      1.1       jtc 		}
     86      1.1       jtc 		off += clen + 1;
     87      1.1       jtc 	}
     88      1.1       jtc 	printf("%c %6ld %6ld\n", prev, start, off - 1);
     89  1.6.4.1  wrstuden 	for (i = prev + 1; i <= 'z'; i++)
     90  1.6.4.1  wrstuden 		printf("%c %6ld %6ld\n", i, off, off - 1);
     91      1.5       jsm 	fflush(stdout);
     92      1.5       jsm 	if (ferror(stdout))
     93      1.5       jsm 		err(1, "writing standard output");
     94      1.1       jtc 	exit(0);
     95      1.1       jtc }
     96      1.1       jtc 
     97      1.1       jtc /*
     98      1.1       jtc  * Return the next word in the compressed dictionary in 'buffer' or
     99      1.1       jtc  * NULL on end-of-file
    100      1.1       jtc  * Also set clen to the length of the compressed word (for mkindex) and
    101      1.1       jtc  * rlen to the strlen() of the real word
    102      1.1       jtc  */
    103      1.1       jtc char *
    104      1.1       jtc nextword(fp, buffer, clen, rlen)
    105      1.1       jtc 	FILE *fp;
    106      1.1       jtc 	char *buffer;
    107      1.1       jtc 	int *clen, *rlen;
    108      1.1       jtc {
    109      1.3     lukem 	int ch, pcount;
    110      1.3     lukem 	char *p, *q;
    111      1.1       jtc 	static char buf[MAXWORDLEN + 1];
    112      1.1       jtc 	static int first = 1;
    113      1.1       jtc 	static int lastch = 0;
    114      1.1       jtc 
    115      1.1       jtc    	if (first) {
    116      1.1       jtc 		if ((pcount = getc(fp)) == EOF)
    117      1.1       jtc 			return (NULL);
    118      1.1       jtc 		first = 0;
    119      1.1       jtc 	}
    120      1.1       jtc 	else if ((pcount = lastch) == EOF)
    121      1.1       jtc 		return (NULL);
    122      1.1       jtc 
    123      1.1       jtc 	p = buf + (*clen = pcount);
    124      1.1       jtc 
    125      1.1       jtc 	while ((ch = getc(fp)) != EOF && ch >= 'a')
    126      1.1       jtc 			*p++ = ch;
    127      1.1       jtc 		lastch = ch;
    128      1.1       jtc 	*p = '\0';
    129      1.1       jtc 
    130      1.1       jtc 	*rlen = (int) (p - buf);
    131      1.1       jtc 	*clen = *rlen - *clen;
    132      1.1       jtc 
    133      1.1       jtc 	p = buf;
    134      1.1       jtc 	q = buffer;
    135      1.1       jtc 	while ((*q++ = *p) != '\0') {
    136      1.1       jtc 		if (*p++ == 'q')
    137      1.1       jtc 			*q++ = 'u';
    138      1.1       jtc 	}
    139      1.1       jtc 	return (buffer);
    140      1.1       jtc }
    141