diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 2010-10-29 14:47:16 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 2010-10-29 14:47:16 +0000 |
commit | 91ab9dfe70f8e3d260a6946c62b8243fa733c73a (patch) | |
tree | 31e28087fb5ba79d3685f81111689cf43f9ded82 | |
parent | fd985a9a91482b967b27f84105751c290e3da3c5 (diff) |
Remove colcrt and checknr. colcrt is only useful on very old
terminals and checknr has been subsumed by "mandoc -Tlint".
OK deraadt@ jmc@ schwarze@
-rw-r--r-- | usr.bin/Makefile | 4 | ||||
-rw-r--r-- | usr.bin/checknr/Makefile | 5 | ||||
-rw-r--r-- | usr.bin/checknr/checknr.1 | 156 | ||||
-rw-r--r-- | usr.bin/checknr/checknr.c | 600 | ||||
-rw-r--r-- | usr.bin/colcrt/Makefile | 5 | ||||
-rw-r--r-- | usr.bin/colcrt/colcrt.1 | 108 | ||||
-rw-r--r-- | usr.bin/colcrt/colcrt.c | 250 |
7 files changed, 2 insertions, 1126 deletions
diff --git a/usr.bin/Makefile b/usr.bin/Makefile index 4bbe1761ab5..5bb2601c9a5 100644 --- a/usr.bin/Makefile +++ b/usr.bin/Makefile @@ -1,10 +1,10 @@ -# $OpenBSD: Makefile,v 1.118 2010/10/18 20:01:54 deraadt Exp $ +# $OpenBSD: Makefile,v 1.119 2010/10/29 14:47:14 millert Exp $ .include <bsd.own.mk> SUBDIR= apply apropos ar arch asa asn1_compile at aucat audioctl awk banner \ basename bc bdes bgplg \ - biff cal calendar cap_mkdb cdio checknr chpass cmp col colcrt colrm \ + biff cal calendar cap_mkdb cdio chpass cmp col colrm \ column comm compile_et compress cpp crontab csplit ctags cut \ dc deroff diff diff3 dirname du encrypt env expand false file \ file2c find fgen finger fmt fold from fsplit fstat ftp gencat getcap \ diff --git a/usr.bin/checknr/Makefile b/usr.bin/checknr/Makefile deleted file mode 100644 index a2fdf7a64b4..00000000000 --- a/usr.bin/checknr/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.3 1997/09/21 11:48:34 deraadt Exp $ - -PROG= checknr - -.include <bsd.prog.mk> diff --git a/usr.bin/checknr/checknr.1 b/usr.bin/checknr/checknr.1 deleted file mode 100644 index af492d03173..00000000000 --- a/usr.bin/checknr/checknr.1 +++ /dev/null @@ -1,156 +0,0 @@ -.\" $OpenBSD: checknr.1,v 1.14 2007/05/31 19:20:08 jmc Exp $ -.\" $NetBSD: checknr.1,v 1.5 1995/03/26 04:10:14 glass Exp $ -.\" -.\" Copyright (c) 1980, 1990, 1993 -.\" The Regents of the University of California. All rights reserved. -.\" -.\" 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. -.\" -.\" @(#)checknr.1 8.1 (Berkeley) 6/6/93 -.\" -.Dd $Mdocdate: May 31 2007 $ -.Dt CHECKNR 1 -.Os -.Sh NAME -.Nm checknr -.Nd check nroff/troff files -.Sh SYNOPSIS -.Nm checknr -.Op Fl fs -.Op Fl a Ns Ar \&.x1.y1.x2.y2. ... \&.xn.yn -.Op Fl c Ns Ar \&.x1.x2.x3. ... \&.xn -.Op Ar file -.Sh DESCRIPTION -.Nm -checks a list of -.Xr nroff 1 -or -.Xr troff 1 -input files for certain kinds of errors -involving mismatched opening and closing delimiters -and unknown commands. -If no files are specified, -.Nm -checks the standard input. -.Pp -The options are as follows: -.Bl -tag -width Ds -.It Fl a -Add additional pairs of macros to the list of known macros. -This must be followed by groups of six characters, each group defining -a pair of macros. -The six characters are -a period, -the first macro name, -another period, -and the second macro name. -For example, to define a pair .BS and .ES, use -.Dq Li \-a.BS.ES -.It Fl c -Define commands which would otherwise be complained about -as undefined. -.It Fl f -Request -.Nm -to ignore -.Ql \ef -font changes. -.It Fl s -Ignore -.Ql \es -size changes. -.El -.Pp -Delimiters checked are: -.Bl -enum -.It -Font changes using \efx ... \efP. -.It -Size changes using \esx ... \es0. -.It -Macros that come in open ... close forms, for example, -the .TS and .TE macros which must always come in pairs. -.El -.Pp -.Nm -is intended for use on documents that are prepared with -.Nm -in mind, much the same as -.Xr lint 1 . -It expects a certain document writing style for -.Ql \ef -and -.Ql \es -commands, -in that each -.Ql \efx -must be terminated with -.Ql \efP -and -each -.Ql \esx -must be terminated with -.Ql \es0 . -While it will work to directly go into the next font or explicitly -specify the original font or point size, -and many existing documents actually do this, -such a practice will produce complaints from -.Nm checknr . -Since it is probably better to use the -.Ql \efP -and -.Ql \es0 -forms anyway, -you should think of this as a contribution to your document -preparation style. -.Pp -.Nm -knows about the -.Xr ms 7 -and -.Xr me 7 -macro packages. -.Sh DIAGNOSTICS -.Bd -unfilled -Complaints about unmatched delimiters. -Complaints about unrecognized commands. -Various complaints about the syntax of commands. -.Ed -.Sh SEE ALSO -.Xr nroff 1 , -.Xr troff 1 , -.Xr me 7 , -.Xr ms 7 -.Sh HISTORY -The -.Nm -command appeared in -.Bx 4.0 . -.Sh BUGS -There is no way to define a 1 character macro name using -.Fl a . -.Pp -Does not correctly recognize certain reasonable constructs, -such as conditionals. diff --git a/usr.bin/checknr/checknr.c b/usr.bin/checknr/checknr.c deleted file mode 100644 index 1012d5cf876..00000000000 --- a/usr.bin/checknr/checknr.c +++ /dev/null @@ -1,600 +0,0 @@ -/* $OpenBSD: checknr.c,v 1.16 2009/10/27 23:59:36 deraadt Exp $ */ -/* $NetBSD: checknr.c,v 1.4 1995/03/26 04:10:19 glass Exp $ */ - -/* - * Copyright (c) 1980, 1993 - * The Regents of the University of California. All rights reserved. - * - * 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. - */ - -/* - * checknr: check an nroff/troff input file for matching macro calls. - * we also attempt to match size and font changes, but only the embedded - * kind. These must end in \s0 and \fP resp. Maybe more sophistication - * later but for now think of these restrictions as contributions to - * structured typesetting. - */ -#include <stdio.h> -#include <string.h> -#include <stdlib.h> -#include <unistd.h> -#include <ctype.h> -#include <err.h> - -#define MAXSTK 100 /* Stack size */ -#define MAXBR 100 /* Max number of bracket pairs known */ -#define MAXCMDS 500 /* Max number of commands known */ - -/* - * The stack on which we remember what we've seen so far. - */ -struct stkstr { - int opno; /* number of opening bracket */ - int pl; /* '+', '-', ' ' for \s, 1 for \f, 0 for .ft */ - int parm; /* parm to size, font, etc */ - int lno; /* line number the thing came in in */ -} stk[MAXSTK]; -int stktop; - -void usage(void); -void addmac(char *); -void process(FILE *); -void pe(int); -int eq(char *, char *); -void complain(int); -void prop(int); -void chkcmd(char *, char *); -void addcmd(char *); -void nomatch(char *); -void checkknown(char *); -int binsrch(char *); - -/* - * The kinds of opening and closing brackets. - */ -struct brstr { - char *opbr; - char *clbr; -} br[MAXBR] = { - /* A few bare bones troff commands */ -#define SZ 0 - { "sz", "sz" }, /* also \s */ -#define FT 1 - { "ft", "ft" }, /* also \f */ - /* the -mm package */ - { "AL", "LE" }, - { "AS", "AE" }, - { "BL", "LE" }, - { "BS", "BE" }, - { "DF", "DE" }, - { "DL", "LE" }, - { "DS", "DE" }, - { "FS", "FE" }, - { "ML", "LE" }, - { "NS", "NE" }, - { "RL", "LE" }, - { "VL", "LE" }, - /* the -ms package */ - { "AB", "AE" }, - { "BD", "DE" }, - { "CD", "DE" }, - { "DS", "DE" }, - { "FS", "FE" }, - { "ID", "DE" }, - { "KF", "KE" }, - { "KS", "KE" }, - { "LD", "DE" }, - { "LG", "NL" }, - { "QS", "QE" }, - { "RS", "RE" }, - { "SM", "NL" }, - { "XA", "XE" }, - { "XS", "XE" }, - /* The -me package */ - { "(b", ")b" }, - { "(c", ")c" }, - { "(d", ")d" }, - { "(f", ")f" }, - { "(l", ")l" }, - { "(q", ")q" }, - { "(x", ")x" }, - { "(z", ")z" }, - /* Things needed by preprocessors */ - { "EQ", "EN" }, - { "TS", "TE" }, - /* Refer */ - { "[", "]" }, - { 0, } -}; - -/* - * All commands known to nroff, plus macro packages. - * Used so we can complain about unrecognized commands. - */ -char *knowncmds[MAXCMDS] = { -"$c", "$f", "$h", "$p", "$s", "(b", "(c", "(d", "(f", "(l", "(q", "(t", -"(x", "(z", ")b", ")c", ")d", ")f", ")l", ")q", ")t", ")x", ")z", "++", -"+c", "1C", "1c", "2C", "2c", "@(", "@)", "@C", "@D", "@F", "@I", "@M", -"@c", "@e", "@f", "@h", "@m", "@n", "@o", "@p", "@r", "@t", "@z", "AB", -"AE", "AF", "AI", "AL", "AM", "AS", "AT", "AU", "AX", "B", "B1", "B2", -"BD", "BE", "BG", "BL", "BS", "BT", "BX", "C1", "C2", "CD", "CM", "CT", -"D", "DA", "DE", "DF", "DL", "DS", "DT", "EC", "EF", "EG", "EH", "EM", -"EN", "EQ", "EX", "FA", "FD", "FE", "FG", "FJ", "FK", "FL", "FN", "FO", -"FQ", "FS", "FV", "FX", "H", "HC", "HD", "HM", "HO", "HU", "I", "ID", -"IE", "IH", "IM", "IP", "IX", "IZ", "KD", "KE", "KF", "KQ", "KS", "LB", -"LC", "LD", "LE", "LG", "LI", "LP", "MC", "ME", "MF", "MH", "ML", "MR", -"MT", "ND", "NE", "NH", "NL", "NP", "NS", "OF", "OH", "OK", "OP", "P", -"P1", "PF", "PH", "PP", "PT", "PX", "PY", "QE", "QP", "QS", "R", "RA", -"RC", "RE", "RL", "RP", "RQ", "RS", "RT", "S", "S0", "S2", "S3", "SA", -"SG", "SH", "SK", "SM", "SP", "SY", "T&", "TA", "TB", "TC", "TD", "TE", -"TH", "TL", "TM", "TP", "TQ", "TR", "TS", "TX", "UL", "US", "UX", "VL", -"WC", "WH", "XA", "XD", "XE", "XF", "XK", "XP", "XS", "[", "[-", "[0", -"[1", "[2", "[3", "[4", "[5", "[<", "[>", "[]", "]", "]-", "]<", "]>", -"][", "ab", "ac", "ad", "af", "am", "ar", "as", "b", "ba", "bc", "bd", -"bi", "bl", "bp", "br", "bx", "c.", "c2", "cc", "ce", "cf", "ch", "cs", -"ct", "cu", "da", "de", "di", "dl", "dn", "ds", "dt", "dw", "dy", "ec", -"ef", "eh", "el", "em", "eo", "ep", "ev", "ex", "fc", "fi", "fl", "fo", -"fp", "ft", "fz", "hc", "he", "hl", "hp", "ht", "hw", "hx", "hy", "i", -"ie", "if", "ig", "in", "ip", "it", "ix", "lc", "lg", "li", "ll", "ln", -"lo", "lp", "ls", "lt", "m1", "m2", "m3", "m4", "mc", "mk", "mo", "n1", -"n2", "na", "ne", "nf", "nh", "nl", "nm", "nn", "np", "nr", "ns", "nx", -"of", "oh", "os", "pa", "pc", "pi", "pl", "pm", "pn", "po", "pp", "ps", -"q", "r", "rb", "rd", "re", "rm", "rn", "ro", "rr", "rs", "rt", "sb", -"sc", "sh", "sk", "so", "sp", "ss", "st", "sv", "sz", "ta", "tc", "th", -"ti", "tl", "tm", "tp", "tr", "u", "uf", "uh", "ul", "vs", "wh", "xp", -"yr", 0 -}; - -int lineno; /* current line number in input file */ -char line[256]; /* the current line */ -char *cfilename; /* name of current file */ -int nfiles; /* number of files to process */ -int fflag; /* -f: ignore \f */ -int sflag; /* -s: ignore \s */ -int ncmds; /* size of knowncmds */ -int slot; /* slot in knowncmds found by binsrch */ - -int -main(int argc, char *argv[]) -{ - FILE *f; - int i; - char *cp; - char b1[4]; - - /* Figure out how many known commands there are */ - while (knowncmds[ncmds]) - ncmds++; - while (argc > 1 && argv[1][0] == '-') { - switch(argv[1][1]) { - - /* -a: add pairs of macros */ - case 'a': - i = strlen(argv[1]) - 2; - if (i == 0 || i % 6 != 0) - usage(); - /* look for empty macro slots */ - for (i=0; br[i].opbr; i++) - ; - for (cp=argv[1]+3; cp[-1]; cp += 6) { - if (i >= MAXBR) - errx(1, "too many pairs"); - if ((br[i].opbr = malloc(3)) == NULL) - err(1, "malloc"); - strlcpy(br[i].opbr, cp, 3); - if ((br[i].clbr = malloc(3)) == NULL) - err(1, "malloc"); - strlcpy(br[i].clbr, cp+3, 3); - addmac(br[i].opbr); /* knows pairs are also known cmds */ - addmac(br[i].clbr); - i++; - } - break; - - /* -c: add known commands */ - case 'c': - i = strlen(argv[1]) - 2; - if (i == 0 || i % 3 != 0) - usage(); - for (cp=argv[1]+3; cp[-1]; cp += 3) { - if (cp[2] && cp[2] != '.') - usage(); - strncpy(b1, cp, 2); - addmac(b1); - } - break; - - /* -f: ignore font changes */ - case 'f': - fflag = 1; - break; - - /* -s: ignore size changes */ - case 's': - sflag = 1; - break; - default: - usage(); - } - argc--; argv++; - } - - nfiles = argc - 1; - - if (nfiles > 0) { - for (i=1; i<argc; i++) { - cfilename = argv[i]; - f = fopen(cfilename, "r"); - if (f == NULL) - warn("%s", cfilename); - else { - process(f); - fclose(f); - } - } - } else { - cfilename = "stdin"; - process(stdin); - } - exit(0); -} - -void -usage(void) -{ - extern char *__progname; - (void)fprintf(stderr, - "usage: %s [-fs] [-a.x1.y1.x2.y2. ... .xn.yn] " - "[-c.x1.x2.x3. ... .xn] [file]\n", __progname); - exit(1); -} - -void -process(FILE *f) -{ - int i, n; - char mac[5]; /* The current macro or nroff command */ - int pl; - - stktop = -1; - for (lineno = 1; fgets(line, sizeof line, f); lineno++) { - if (line[0] == '.') { - /* - * find and isolate the macro/command name. - */ - strncpy(mac, line+1, 4); - if (isspace(mac[0])) { - pe(lineno); - printf("Empty command\n"); - } else if (isspace(mac[1])) { - mac[1] = 0; - } else if (isspace(mac[2])) { - mac[2] = 0; - } else if (mac[0] != '\\' || mac[1] != '\"') { - pe(lineno); - printf("Command too long\n"); - } - - /* - * Is it a known command? - */ - checkknown(mac); - - /* - * Should we add it? - */ - if (eq(mac, "de")) - addcmd(line); - - chkcmd(line, mac); - } - - /* - * At this point we process the line looking - * for \s and \f. - */ - for (i=0; line[i]; i++) - if (line[i]=='\\' && (i==0 || line[i-1]!='\\')) { - if (!sflag && line[++i]=='s') { - pl = line[++i]; - if (isdigit(pl)) { - n = pl - '0'; - pl = ' '; - } else - n = 0; - while (isdigit(line[++i])) - n = 10 * n + line[i] - '0'; - i--; - if (n == 0) { - if (stk[stktop].opno == SZ) { - stktop--; - } else { - pe(lineno); - printf("unmatched \\s0\n"); - } - } else { - stk[++stktop].opno = SZ; - stk[stktop].pl = pl; - stk[stktop].parm = n; - stk[stktop].lno = lineno; - } - } else if (!fflag && line[i]=='f') { - n = line[++i]; - if (n == 'P') { - if (stk[stktop].opno == FT) { - stktop--; - } else { - pe(lineno); - printf("unmatched \\fP\n"); - } - } else { - stk[++stktop].opno = FT; - stk[stktop].pl = 1; - stk[stktop].parm = n; - stk[stktop].lno = lineno; - } - } - } - } - /* - * We've hit the end and look at all this stuff that hasn't been - * matched yet! Complain, complain. - */ - for (i=stktop; i>=0; i--) { - complain(i); - } -} - -void -complain(int i) -{ - pe(stk[i].lno); - printf("Unmatched "); - prop(i); - printf("\n"); -} - -void -prop(int i) -{ - if (stk[i].pl == 0) - printf(".%s", br[stk[i].opno].opbr); - else switch(stk[i].opno) { - case SZ: - printf("\\s%c%d", stk[i].pl, stk[i].parm); - break; - case FT: - printf("\\f%c", stk[i].parm); - break; - default: - printf("Bug: stk[%d].opno = %d = .%s, .%s", - i, stk[i].opno, br[stk[i].opno].opbr, br[stk[i].opno].clbr); - } -} - -void -chkcmd(char *line, char *mac) -{ - int i; - - /* - * Check to see if it matches top of stack. - */ - if (stktop >= 0 && eq(mac, br[stk[stktop].opno].clbr)) - stktop--; /* OK. Pop & forget */ - else { - /* No. Maybe it's an opener */ - for (i=0; br[i].opbr; i++) { - if (eq(mac, br[i].opbr)) { - /* Found. Push it. */ - stktop++; - stk[stktop].opno = i; - stk[stktop].pl = 0; - stk[stktop].parm = 0; - stk[stktop].lno = lineno; - break; - } - /* - * Maybe it's an unmatched closer. - * NOTE: this depends on the fact - * that none of the closers can be - * openers too. - */ - if (eq(mac, br[i].clbr)) { - nomatch(mac); - break; - } - } - } -} - -void -nomatch(char *mac) -{ - int i, j; - - /* - * Look for a match further down on stack - * If we find one, it suggests that the stuff in - * between is supposed to match itself. - */ - for (j=stktop; j>=0; j--) - if (eq(mac,br[stk[j].opno].clbr)) { - /* Found. Make a good diagnostic. */ - if (j == stktop-2) { - /* - * Check for special case \fx..\fR and don't - * complain. - */ - if (stk[j+1].opno==FT && stk[j+1].parm!='R' - && stk[j+2].opno==FT && stk[j+2].parm=='R') { - stktop = j -1; - return; - } - /* - * We have two unmatched frobs. Chances are - * they were intended to match, so we mention - * them together. - */ - pe(stk[j+1].lno); - prop(j+1); - printf(" does not match %d: ", stk[j+2].lno); - prop(j+2); - printf("\n"); - } else for (i=j+1; i <= stktop; i++) { - complain(i); - } - stktop = j-1; - return; - } - /* Didn't find one. Throw this away. */ - pe(lineno); - printf("Unmatched .%s\n", mac); -} - -/* eq: are two strings equal? */ -int -eq(char *s1, char *s2) -{ - return (strcmp(s1, s2) == 0); -} - -/* print the first part of an error message, given the line number */ -void -pe(int lineno) -{ - if (nfiles > 1) - printf("%s: ", cfilename); - printf("%d: ", lineno); -} - -void -checkknown(char *mac) -{ - - if (eq(mac, ".")) - return; - if (binsrch(mac) >= 0) - return; - if (mac[0] == '\\' && mac[1] == '"') /* comments */ - return; - - pe(lineno); - printf("Unknown command: .%s\n", mac); -} - -/* - * We have a .de xx line in "line". Add xx to the list of known commands. - */ -void -addcmd(char *line) -{ - char *mac; - - /* grab the macro being defined */ - mac = line+4; - while (isspace(*mac)) - mac++; - if (*mac == 0) { - pe(lineno); - printf("illegal define: %s\n", line); - return; - } - mac[2] = 0; - if (isspace(mac[1]) || mac[1] == '\\') - mac[1] = 0; - if (ncmds >= MAXCMDS) { - printf("Only %d known commands allowed\n", MAXCMDS); - exit(1); - } - addmac(mac); -} - -/* - * Add mac to the list. We should really have some kind of tree - * structure here but this is a quick-and-dirty job and I just don't - * have time to mess with it. (I wonder if this will come back to haunt - * me someday?) Anyway, I claim that .de is fairly rare in user - * nroff programs, and the register loop below is pretty fast. - */ -void -addmac(char *mac) -{ - char **src, **dest, **loc; - - if (binsrch(mac) >= 0){ /* it's OK to redefine something */ -#ifdef DEBUG - printf("binsrch(%s) -> already in table\n", mac); -#endif /* DEBUG */ - return; - } - /* binsrch sets slot as a side effect */ -#ifdef DEBUG -printf("binsrch(%s) -> %d\n", mac, slot); -#endif - loc = &knowncmds[slot]; - src = &knowncmds[ncmds-1]; - dest = src+1; - while (dest > loc) - *dest-- = *src--; - if ((*loc = strdup(mac)) == NULL) - err(1, "strdup"); - ncmds++; -#ifdef DEBUG -printf("after: %s %s %s %s %s, %d cmds\n", knowncmds[slot-2], knowncmds[slot-1], knowncmds[slot], knowncmds[slot+1], knowncmds[slot+2], ncmds); -#endif -} - -/* - * Do a binary search in knowncmds for mac. - * If found, return the index. If not, return -1. - */ -int -binsrch(char *mac) -{ - char *p; /* pointer to current cmd in list */ - int d; /* difference if any */ - int mid; /* mid point in binary search */ - int top, bot; /* boundaries of bin search, inclusive */ - - top = ncmds-1; - bot = 0; - while (top >= bot) { - mid = (top+bot)/2; - p = knowncmds[mid]; - d = p[0] - mac[0]; - if (d == 0) - d = p[1] - mac[1]; - if (d == 0) - return mid; - if (d < 0) - bot = mid + 1; - else - top = mid - 1; - } - slot = bot; /* place it would have gone */ - return -1; -} diff --git a/usr.bin/colcrt/Makefile b/usr.bin/colcrt/Makefile deleted file mode 100644 index 4d2f45bd850..00000000000 --- a/usr.bin/colcrt/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# $OpenBSD: Makefile,v 1.3 1997/09/21 11:48:43 deraadt Exp $ - -PROG= colcrt - -.include <bsd.prog.mk> diff --git a/usr.bin/colcrt/colcrt.1 b/usr.bin/colcrt/colcrt.1 deleted file mode 100644 index f26615458d7..00000000000 --- a/usr.bin/colcrt/colcrt.1 +++ /dev/null @@ -1,108 +0,0 @@ -.\" $OpenBSD: colcrt.1,v 1.13 2007/05/31 19:20:08 jmc Exp $ -.\" $NetBSD: colcrt.1,v 1.3 1995/03/26 05:30:59 glass Exp $ -.\" -.\" Copyright (c) 1980, 1990, 1993 -.\" The Regents of the University of California. All rights reserved. -.\" -.\" 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. -.\" -.\" @(#)colcrt.1 8.1 (Berkeley) 6/30/93 -.\" -.Dd $Mdocdate: May 31 2007 $ -.Dt COLCRT 1 -.Os -.Sh NAME -.Nm colcrt -.Nd filter nroff output -.Sh SYNOPSIS -.Nm colcrt -.Op Fl -.Op Fl 2 -.Op Ar -.Sh DESCRIPTION -.Nm -provides virtual half-line and reverse line feed sequences -for terminals without such capability, and on which overstriking -is destructive. -Half-line characters and underlining (changed to dashing -.Sq - ) -are placed on new lines in between the normal output lines. -.Pp -The options are as follows: -.Bl -tag -width Ds -.It Fl -Suppress all underlining. -This option is especially useful for previewing -.Em allboxed -tables from -.Xr tbl 1 . -.It Fl 2 -Causes all half-lines to be printed, effectively double spacing the output. -Normally, a minimal space output format is used which will suppress empty -lines. -The program never suppresses two consecutive empty lines, however. -The -.Fl 2 -option is useful for sending output to the line printer when the output -contains superscripts and subscripts which would otherwise be invisible. -.El -.Sh EXAMPLES -A typical use of -.Nm -would be: -.Bd -literal -offset indent -$ tbl exum2.n | nroff -ms | colcrt - | more -.Ed -.Sh SEE ALSO -.Xr col 1 , -.Xr more 1 , -.Xr nroff 1 , -.Xr troff 1 , -.Xr ul 1 -.Sh HISTORY -The -.Nm -command appeared in -.Bx 3.0 . -.Sh BUGS -Should fold underlines onto blanks even with the -.Sq Fl -option so that -a true underline character would show. -.Pp -Can't back up more than 102 lines. -.Pp -General overstriking is lost; -as a special case -.Ql | -overstruck with -.Ql - -or underline becomes -.Ql + . -.Pp -Lines are trimmed to 132 characters. -.Pp -Some provision should be made for processing superscripts and subscripts -in documents which are already double-spaced. diff --git a/usr.bin/colcrt/colcrt.c b/usr.bin/colcrt/colcrt.c deleted file mode 100644 index dc0108c9578..00000000000 --- a/usr.bin/colcrt/colcrt.c +++ /dev/null @@ -1,250 +0,0 @@ -/* $OpenBSD: colcrt.c,v 1.10 2009/10/27 23:59:36 deraadt Exp $ */ -/* $NetBSD: colcrt.c,v 1.3 1995/03/26 05:31:00 glass Exp $ */ - -/* - * Copyright (c) 1980, 1993 - * The Regents of the University of California. All rights reserved. - * - * 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. - */ - -#include <sys/types.h> -#include <unistd.h> -#include <stdlib.h> -#include <string.h> -#include <stdio.h> -#include <err.h> - -/* - * colcrt - replaces col for crts with new nroff esp. when using tbl. - * Bill Joy UCB July 14, 1977 - * - * This filter uses a screen buffer, 267 half-lines by 132 columns. - * It interprets the up and down sequences generated by the new - * nroff when used with tbl and by \u \d and \r. - * General overstriking doesn't work correctly. - * Underlining is split onto multiple lines, etc. - * - * Option - suppresses all underlining. - * Option -2 forces printing of all half lines. - */ - -char page[267][132]; - -int outline = 1; -int outcol; - -char suppresul; -char printall; - -FILE *f; - -void pflush(int); -int plus(char, char); -void move(int, int); - -int -main(int argc, char *argv[]) -{ - extern char *__progname; - char *cp, *dp; - int c; - - argc--; - argv++; - while (argc > 0 && argv[0][0] == '-') { - switch (argv[0][1]) { - case 0: - suppresul = 1; - break; - case '2': - printall = 1; - break; - default: - fprintf(stderr, - "usage: %s [-] [-2] [file ...]\n", - __progname); - fflush(stdout); - exit(1); - } - argc--; - argv++; - } - do { - if (argc > 0) { - close(0); - if (!(f = fopen(argv[0], "r"))) { - fflush(stdout); - err(1, "fopen: %s", argv[0]); - } - argc--; - argv++; - } - for (;;) { - c = getc(stdin); - if (c == -1) { - pflush(outline); - fflush(stdout); - break; - } - switch (c) { - case '\n': - if (outline >= 265) - pflush(62); - outline += 2; - outcol = 0; - continue; - case '\016': - case '\017': - continue; - case 033: - c = getc(stdin); - switch (c) { - case '9': - if (outline >= 266) - pflush(62); - outline++; - continue; - case '8': - if (outline >= 1) - outline--; - continue; - case '7': - outline -= 2; - if (outline < 0) - outline = 0; - continue; - default: - continue; - } - case '\b': - if (outcol) - outcol--; - continue; - case '\t': - outcol += 8; - outcol &= ~7; - outcol--; - c = ' '; - default: - if (outcol >= 132) { - outcol++; - continue; - } - cp = &page[outline][outcol]; - outcol++; - if (c == '_') { - if (suppresul) - continue; - cp += 132; - c = '-'; - } - if (*cp == 0) { - *cp = c; - dp = cp - outcol; - for (cp--; cp >= dp && *cp == 0; cp--) - *cp = ' '; - } else - if (plus(c, *cp) || plus(*cp, c)) - *cp = '+'; - else if (*cp == ' ' || *cp == 0) - *cp = c; - continue; - } - } - } while (argc > 0); - fflush(stdout); - exit(0); -} - -int -plus(char c, char d) -{ - - return ((c == '|' && d == '-') || d == '_'); -} - -int first; - -void -pflush(int ol) -{ - int i; - char *cp; - char lastomit; - int l; - - l = ol; - lastomit = 0; - if (l > 266) - l = 266; - else - l |= 1; - for (i = first | 1; i < l; i++) { - move(i, i - 1); - move(i, i + 1); - } - for (i = first; i < l; i++) { - cp = page[i]; - if (printall == 0 && lastomit == 0 && *cp == 0) { - lastomit = 1; - continue; - } - lastomit = 0; - printf("%s\n", cp); - } - bcopy(page[ol], page, (267 - ol) * 132); - bzero(page[267- ol], ol * 132); - outline -= ol; - outcol = 0; - first = 1; -} - -void -move(int l, int m) -{ - char *cp, *dp; - - for (cp = page[l], dp = page[m]; *cp; cp++, dp++) { - switch (*cp) { - case '|': - if (*dp != ' ' && *dp != '|' && *dp != 0) - return; - break; - case ' ': - break; - default: - return; - } - } - if (*cp == 0) { - for (cp = page[l], dp = page[m]; *cp; cp++, dp++) - if (*cp == '|') - *dp = '|'; - else if (*dp == 0) - *dp = ' '; - page[l][0] = 0; - } -} |