From owner-svn-ports-all@freebsd.org Tue Sep 13 20:58:27 2016 Return-Path: Delivered-To: svn-ports-all@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id EE6B1BD971C; Tue, 13 Sep 2016 20:58:27 +0000 (UTC) (envelope-from marino@FreeBSD.org) Received: from repo.freebsd.org (repo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id BBDC51DB2; Tue, 13 Sep 2016 20:58:27 +0000 (UTC) (envelope-from marino@FreeBSD.org) Received: from repo.freebsd.org ([127.0.1.37]) by repo.freebsd.org (8.15.2/8.15.2) with ESMTP id u8DKwRLg056097; Tue, 13 Sep 2016 20:58:27 GMT (envelope-from marino@FreeBSD.org) Received: (from marino@localhost) by repo.freebsd.org (8.15.2/8.15.2/Submit) id u8DKwQn9056092; Tue, 13 Sep 2016 20:58:26 GMT (envelope-from marino@FreeBSD.org) Message-Id: <201609132058.u8DKwQn9056092@repo.freebsd.org> X-Authentication-Warning: repo.freebsd.org: marino set sender to marino@FreeBSD.org using -f From: John Marino Date: Tue, 13 Sep 2016 20:58:26 +0000 (UTC) To: ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org Subject: svn commit: r422086 - in head/misc: . fortune_strfile fortune_strfile/files X-SVN-Group: ports-head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-ports-all@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: SVN commit messages for the ports tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 13 Sep 2016 20:58:28 -0000 Author: marino Date: Tue Sep 13 20:58:26 2016 New Revision: 422086 URL: https://svnweb.freebsd.org/changeset/ports/422086 Log: Add new port misc/fortune_strfile This is a copy of strfile(8) with a "fortune_" prefix. It's intended to replace the /usr/games/strfile runtime dependency for fortune ports that require the games distribution to be installed. Added: head/misc/fortune_strfile/ head/misc/fortune_strfile/Makefile (contents, props changed) head/misc/fortune_strfile/files/ head/misc/fortune_strfile/files/strfile.c (contents, props changed) head/misc/fortune_strfile/files/strfile.h (contents, props changed) head/misc/fortune_strfile/pkg-descr (contents, props changed) Modified: head/misc/Makefile Modified: head/misc/Makefile ============================================================================== --- head/misc/Makefile Tue Sep 13 20:54:45 2016 (r422085) +++ head/misc/Makefile Tue Sep 13 20:58:26 2016 (r422086) @@ -98,6 +98,7 @@ SUBDIR += fortune-mod-ferengi_rules_of_acquisition SUBDIR += fortune-mod-futurama SUBDIR += fortune-mod-psalms + SUBDIR += fortune_strfile SUBDIR += fortuneit SUBDIR += fpc-chm SUBDIR += freebsd-doc-all Added: head/misc/fortune_strfile/Makefile ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/misc/fortune_strfile/Makefile Tue Sep 13 20:58:26 2016 (r422086) @@ -0,0 +1,24 @@ +# Created by: marino@FreeBSD.org +# $FreeBSD$ + +PORTNAME= fortune_strfile +PORTVERSION= 1.0 +CATEGORIES= misc +MASTER_SITES= # none +DISTFILES= # none + +MAINTAINER= marino@FreeBSD.org +COMMENT= Duplicate of strfile(8) + +PROGRAM= fortune_strfile +PLIST_FILES= bin/${PROGRAM} + +do-build: + ${MKDIR} ${WRKSRC} + ${CC} ${CFLAGS} -o ${WRKSRC}/${PROGRAM} ${FILESDIR}/strfile.c + +do-install: + ${MKDIR} ${STAGEDIR}${PREFIX}/bin + ${INSTALL_PROGRAM} ${WRKSRC}/${PROGRAM} ${STAGEDIR}${PREFIX}/bin + +.include Added: head/misc/fortune_strfile/files/strfile.c ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/misc/fortune_strfile/files/strfile.c Tue Sep 13 20:58:26 2016 (r422086) @@ -0,0 +1,441 @@ +/*- + * Copyright (c) 1989, 1993 + * The Regents of the University of California. All rights reserved. + * + * This code is derived from software contributed to Berkeley by + * Ken Arnold. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * @(#) Copyright (c) 1989, 1993 The Regents of the University of California. All rights reserved. + * @(#)strfile.c 8.1 (Berkeley) 5/31/93 + * $FreeBSD: src/games/fortune/strfile/strfile.c,v 1.15.2.2 2001/03/05 11:52:37 kris Exp $ + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "strfile.h" + +/* + * This program takes a file composed of strings separated by + * lines starting with two consecutive delimiting character (default + * character is '%') and creates another file which consists of a table + * describing the file (structure from "strfile.h"), a table of seek + * pointers to the start of the strings, and the strings, each terminated + * by a null byte. Usage: + * + * % strfile [-iorsx] [ -cC ] sourcefile [ datafile ] + * + * C - Allow comments marked by a double delimiter at line's beginning + * c - Change delimiting character from '%' to 'C' + * s - Silent. Give no summary of data processed at the end of + * the run. + * o - order the strings in alphabetic order + * i - if ordering, ignore case + * r - randomize the order of the strings + * x - set rotated bit + * + * Ken Arnold Sept. 7, 1978 -- + * + * Added ordering options. + */ + +#define STORING_PTRS (Oflag || Rflag) +#define CHUNKSIZE 512 + +#define ALLOC(ptr, sz) do { \ + if (ptr == NULL) \ + ptr = malloc((unsigned int)(CHUNKSIZE * sizeof(*ptr))); \ + else if (((sz) + 1) % CHUNKSIZE == 0) \ + ptr = realloc(ptr, ((unsigned int)((sz) + CHUNKSIZE) * sizeof(*ptr))); \ + if (ptr == NULL) { \ + fprintf(stderr, "out of space\n"); \ + exit(1); \ + } \ + } while (0) + +typedef struct { + char first; + long pos; +} STR; + +static char *Infile = NULL; /* input file name */ +static char Outfile[MAXPATHLEN] = ""; /* output file name */ +static char Delimch = '%'; /* delimiting character */ + +static int Cflag = false; /* embedded comments */ +static int Sflag = false; /* silent run flag */ +static int Oflag = false; /* ordering flag */ +static int Iflag = false; /* ignore case flag */ +static int Rflag = false; /* randomize order flag */ +static int Xflag = false; /* set rotated bit */ +static long Num_pts = 0; /* number of pointers/strings */ + +static long *Seekpts; + +static FILE *Sort_1, *Sort_2; /* pointers for sorting */ + +static STRFILE Tbl; /* statistics table */ + +static STR *Firstch; /* first chars of each string */ + +static void add_offset(FILE *, long); +static int cmp_str(const void *, const void *); +static int collate_range_cmp(int, int); +static void do_order(void); +static void getargs(int, char **); +static void randomize(void); +static void usage(void); + +/* + * main: + * Drive the sucker. There are two main modes -- either we store + * the seek pointers, if the table is to be sorted or randomized, + * or we write the pointer directly to the file, if we are to stay + * in file order. If the former, we allocate and re-allocate in + * CHUNKSIZE blocks; if the latter, we just write each pointer, + * and then seek back to the beginning to write in the table. + */ +int +main(int argc, char *argv[]) +{ + char *sp, *nsp, dc; + FILE *inf, *outf; + long last_off, length, pos, *p; + int first, cnt; + STR *fp; + static char string[257]; + + setlocale(LC_ALL, ""); + + getargs(argc, argv); /* evalute arguments */ + dc = Delimch; + if ((inf = fopen(Infile, "r")) == NULL) { + perror(Infile); + exit(1); + } + + if ((outf = fopen(Outfile, "w")) == NULL) { + perror(Outfile); + exit(1); + } + if (!STORING_PTRS) + fseek(outf, sizeof(Tbl), SEEK_SET); + + /* + * Write the strings onto the file + */ + + Tbl.str_longlen = 0; + Tbl.str_shortlen = ~((unsigned long)0); + Tbl.str_delim = dc; + Tbl.str_version = VERSION; + first = Oflag; + add_offset(outf, ftell(inf)); + last_off = 0; + do { + sp = fgets(string, 256, inf); + if (sp == NULL || (sp[0] == dc && sp[1] == '\n')) { + pos = ftell(inf); + length = pos - last_off - (sp ? strlen(sp) : 0); + last_off = pos; + if (!length) + continue; + add_offset(outf, pos); + if (Tbl.str_longlen < (unsigned long)length) + Tbl.str_longlen = length; + if (Tbl.str_shortlen > (unsigned long)length) + Tbl.str_shortlen = length; + first = Oflag; + } + else if (first) { + for (nsp = sp; !isalnum((unsigned char)*nsp); nsp++) + continue; + ALLOC(Firstch, Num_pts); + fp = &Firstch[Num_pts - 1]; + if (Iflag && isupper((unsigned char)*nsp)) + fp->first = tolower((unsigned char)*nsp); + else + fp->first = *nsp; + fp->pos = Seekpts[Num_pts - 1]; + first = false; + } + } while (sp != NULL); + + /* + * write the tables in + */ + + fclose(inf); + Tbl.str_numstr = Num_pts - 1; + + if (Cflag) + Tbl.str_flags |= STR_COMMENTS; + + if (Oflag) + do_order(); + else if (Rflag) + randomize(); + + if (Xflag) + Tbl.str_flags |= STR_ROTATED; + + if (!Sflag) { + printf("\"%s\" created\n", Outfile); + if (Num_pts == 2) + puts("There was 1 string"); + else + printf("There were %ld strings\n", Num_pts - 1); + printf("Longest string: %lu byte%s\n", Tbl.str_longlen, + Tbl.str_longlen == 1 ? "" : "s"); + printf("Shortest string: %lu byte%s\n", Tbl.str_shortlen, + Tbl.str_shortlen == 1 ? "" : "s"); + } + + rewind(outf); + Tbl.str_version = htonl(Tbl.str_version); + Tbl.str_numstr = htonl(Tbl.str_numstr); + Tbl.str_longlen = htonl(Tbl.str_longlen); + Tbl.str_shortlen = htonl(Tbl.str_shortlen); + Tbl.str_flags = htonl(Tbl.str_flags); + fwrite((char *)&Tbl, sizeof(Tbl), 1, outf); + if (STORING_PTRS) { + for (p = Seekpts, cnt = Num_pts; cnt--; ++p) + *p = htonl(*p); + fwrite((char *)Seekpts, sizeof(*Seekpts), (int)Num_pts, outf); + } + fclose(outf); + exit(0); +} + +/* + * This routine evaluates arguments from the command line + */ +void +getargs(int argc, char **argv) +{ + int ch; + + while ((ch = getopt(argc, argv, "Cc:iorsx")) != -1) + switch(ch) { + case 'C': /* embedded comments */ + Cflag++; + break; + case 'c': /* new delimiting char */ + Delimch = *optarg; + if (!isascii(Delimch)) { + printf("bad delimiting character: '\\%o\n'", + (unsigned char)Delimch); + } + break; + case 'i': /* ignore case in ordering */ + Iflag++; + break; + case 'o': /* order strings */ + Oflag++; + break; + case 'r': /* randomize pointers */ + Rflag++; + break; + case 's': /* silent */ + Sflag++; + break; + case 'x': /* set the rotated bit */ + Xflag++; + break; + case '?': + default: + usage(); + } + argv += optind; + + if (*argv) { + Infile = *argv; + if (*++argv) + strcpy(Outfile, *argv); + } + if (!Infile) { + puts("No input file name"); + usage(); + } + if (*Outfile == '\0') { + strcpy(Outfile, Infile); + strcat(Outfile, ".dat"); + } +} + +void +usage(void) +{ + fprintf(stderr, + "strfile [-Ciorsx] [-c char] source_file [output_file]\n"); + exit(1); +} + +/* + * add_offset: + * Add an offset to the list, or write it out, as appropriate. + */ +void +add_offset(FILE *fp, long off) +{ + long net; + + if (!STORING_PTRS) { + net = htonl(off); + fwrite(&net, 1, sizeof(net), fp); + } else { + ALLOC(Seekpts, Num_pts + 1); + Seekpts[Num_pts] = off; + } + Num_pts++; +} + +/* + * do_order: + * Order the strings alphabetically (possibly ignoring case). + */ +void +do_order(void) +{ + int i; + long *lp; + STR *fp; + + Sort_1 = fopen(Infile, "r"); + Sort_2 = fopen(Infile, "r"); + qsort((char *)Firstch, (int)Tbl.str_numstr, sizeof(*Firstch), cmp_str); + i = Tbl.str_numstr; + lp = Seekpts; + fp = Firstch; + while (i--) + *lp++ = fp++->pos; + fclose(Sort_1); + fclose(Sort_2); + Tbl.str_flags |= STR_ORDERED; +} + +static int +collate_range_cmp (int c1, int c2) +{ + static char s1[2], s2[2]; + int ret; + + s1[0] = c1; + s2[0] = c2; + if ((ret = strcoll(s1, s2)) != 0) + return (ret); + return (c1 - c2); +} + +/* + * cmp_str: + * Compare two strings in the file + */ +int +cmp_str(const void *s1, const void *s2) +{ + const STR *p1, *p2; + int c1, c2, n1, n2, r; + +#define SET_N(nf,ch) (nf = (ch == '\n')) +#define IS_END(ch,nf) (ch == EOF || (ch == (unsigned char)Delimch && nf)) + + p1 = (const STR *)s1; + p2 = (const STR *)s2; + + c1 = (unsigned char)p1->first; + c2 = (unsigned char)p2->first; + if ((r = collate_range_cmp(c1, c2)) != 0) + return r; + + fseek(Sort_1, p1->pos, SEEK_SET); + fseek(Sort_2, p2->pos, SEEK_SET); + + n1 = false; + n2 = false; + while (!isalnum(c1 = getc(Sort_1)) && c1 != '\0' && c1 != EOF) + SET_N(n1, c1); + while (!isalnum(c2 = getc(Sort_2)) && c2 != '\0' && c2 != EOF) + SET_N(n2, c2); + + while (!IS_END(c1, n1) && !IS_END(c2, n2)) { + if (Iflag) { + if (isupper(c1)) + c1 = tolower(c1); + if (isupper(c2)) + c2 = tolower(c2); + } + if ((r = collate_range_cmp(c1, c2)) != 0) + return r; + SET_N(n1, c1); + SET_N(n2, c2); + c1 = getc(Sort_1); + c2 = getc(Sort_2); + } + if (IS_END(c1, n1)) + c1 = 0; + if (IS_END(c2, n2)) + c2 = 0; + + return (collate_range_cmp(c1, c2)); +} + +/* + * randomize: + * Randomize the order of the string table. We must be careful + * not to randomize across delimiter boundaries. All + * randomization is done within each block. + */ +void +randomize(void) +{ + uint32_t cnt, i; + long tmp; + long *sp; + + Tbl.str_flags |= STR_RANDOM; + cnt = Tbl.str_numstr; + + /* + * move things around randomly + */ + + for (sp = Seekpts; cnt > 0; cnt--, sp++) { + i = arc4random_uniform(cnt); + tmp = sp[0]; + sp[0] = sp[i]; + sp[i] = tmp; + } +} Added: head/misc/fortune_strfile/files/strfile.h ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/misc/fortune_strfile/files/strfile.h Tue Sep 13 20:58:26 2016 (r422086) @@ -0,0 +1,52 @@ +/*- + * Copyright (c) 1991, 1993 + * The Regents of the University of California. All rights reserved. + * + * This code is derived from software contributed to Berkeley by + * Ken Arnold. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * @(#)strfile.h 8.1 (Berkeley) 5/31/93 + */ +/* $FreeBSD: src/games/fortune/strfile/strfile.h,v 1.3 1999/10/02 12:33:37 dcs Exp $ */ + +#define STR_ENDSTRING(line,tbl) \ + (((unsigned char)(line)[0]) == (tbl).str_delim && (line)[1] == '\n') + +typedef struct { /* information table */ +#define VERSION 1 + unsigned long str_version; /* version number */ + unsigned long str_numstr; /* # of strings in the file */ + unsigned long str_longlen; /* length of longest string */ + unsigned long str_shortlen; /* length of shortest string */ +#define STR_RANDOM 0x1 /* randomized pointers */ +#define STR_ORDERED 0x2 /* ordered pointers */ +#define STR_ROTATED 0x4 /* rot-13'd text */ +#define STR_COMMENTS 0x8 /* embedded comments */ + unsigned long str_flags; /* bit field for flags */ + unsigned char stuff[4]; /* long aligned space */ +#define str_delim stuff[0] /* delimiting character */ +} STRFILE; Added: head/misc/fortune_strfile/pkg-descr ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/misc/fortune_strfile/pkg-descr Tue Sep 13 20:58:26 2016 (r422086) @@ -0,0 +1,4 @@ +This is a duplicate of strfile(8). + +It exists to make it possible to have fortune ports without first having +to install the games distribution.