ppt.c revision 1.14 1 1.14 atatat /* $NetBSD: ppt.c,v 1.14 2002/11/26 23:07:36 atatat Exp $ */
2 1.4 cgd
3 1.1 cgd /*
4 1.4 cgd * Copyright (c) 1988, 1993
5 1.4 cgd * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.1 cgd * 3. All advertising materials mentioning features or use of this software
16 1.1 cgd * must display the following acknowledgement:
17 1.1 cgd * This product includes software developed by the University of
18 1.1 cgd * California, Berkeley and its contributors.
19 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
20 1.1 cgd * may be used to endorse or promote products derived from this software
21 1.1 cgd * without specific prior written permission.
22 1.1 cgd *
23 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 cgd * SUCH DAMAGE.
34 1.1 cgd */
35 1.1 cgd
36 1.5 lukem #include <sys/cdefs.h>
37 1.1 cgd #ifndef lint
38 1.5 lukem __COPYRIGHT("@(#) Copyright (c) 1988, 1993\n\
39 1.5 lukem The Regents of the University of California. All rights reserved.\n");
40 1.1 cgd #endif /* not lint */
41 1.1 cgd
42 1.1 cgd #ifndef lint
43 1.4 cgd #if 0
44 1.4 cgd static char sccsid[] = "@(#)ppt.c 8.1 (Berkeley) 5/31/93";
45 1.4 cgd #else
46 1.14 atatat __RCSID("$NetBSD: ppt.c,v 1.14 2002/11/26 23:07:36 atatat Exp $");
47 1.4 cgd #endif
48 1.1 cgd #endif /* not lint */
49 1.1 cgd
50 1.11 kim #include <err.h>
51 1.1 cgd #include <stdio.h>
52 1.9 matt #include <stdlib.h>
53 1.10 kim #include <string.h>
54 1.6 jsm #include <unistd.h>
55 1.1 cgd
56 1.10 kim #define EDGE "___________"
57 1.10 kim
58 1.11 kim void usage __P((void));
59 1.5 lukem int main __P((int, char *[]));
60 1.5 lukem static void putppt __P((int));
61 1.10 kim int getppt __P((const char *));
62 1.10 kim
63 1.10 kim void
64 1.10 kim usage(void)
65 1.10 kim {
66 1.10 kim extern char *__progname;
67 1.10 kim fprintf(stderr, "usage: %s [-d] [string ...]\n", __progname);
68 1.10 kim exit(1);
69 1.10 kim }
70 1.1 cgd
71 1.5 lukem int
72 1.1 cgd main(argc, argv)
73 1.1 cgd int argc;
74 1.1 cgd char **argv;
75 1.1 cgd {
76 1.10 kim char *p, buf[132];
77 1.14 atatat int c, start, neednl, dflag;
78 1.6 jsm
79 1.6 jsm /* Revoke setgid privileges */
80 1.8 mycroft setgid(getgid());
81 1.1 cgd
82 1.12 kim dflag = 0;
83 1.10 kim while ((c = getopt(argc, argv, "dh")) != -1)
84 1.10 kim switch(c) {
85 1.10 kim case 'd':
86 1.10 kim dflag = 1;
87 1.10 kim break;
88 1.12 kim case 'h':
89 1.12 kim case '?':
90 1.10 kim default:
91 1.10 kim usage();
92 1.10 kim }
93 1.10 kim argc -= optind;
94 1.10 kim argv += optind;
95 1.10 kim
96 1.10 kim if (dflag) {
97 1.10 kim if (argc > 0)
98 1.10 kim usage();
99 1.10 kim
100 1.10 kim start = 0;
101 1.14 atatat neednl = 0;
102 1.10 kim while (fgets(buf, sizeof(buf), stdin) != NULL) {
103 1.10 kim c = getppt(buf);
104 1.10 kim if (c < 0) {
105 1.10 kim if (start) {
106 1.14 atatat /* lost sync? */
107 1.14 atatat if (neednl)
108 1.14 atatat putchar('\n');
109 1.10 kim exit(0);
110 1.10 kim } else
111 1.10 kim continue;
112 1.10 kim }
113 1.10 kim start = 1;
114 1.10 kim putchar(c);
115 1.14 atatat neednl = (c != '\n');
116 1.7 jsm }
117 1.10 kim if (!feof(stdin))
118 1.10 kim err(1, "fgets");
119 1.14 atatat if (neednl)
120 1.14 atatat putchar('\n');
121 1.10 kim } else {
122 1.10 kim (void) puts(EDGE);
123 1.14 atatat if (argc > 0)
124 1.13 kim while ((p = *argv++)) {
125 1.10 kim for (; *p; ++p)
126 1.10 kim putppt((int)*p);
127 1.13 kim if ((*(argv)))
128 1.10 kim putppt((int)' ');
129 1.10 kim }
130 1.10 kim else while ((c = getchar()) != EOF)
131 1.10 kim putppt(c);
132 1.10 kim (void) puts(EDGE);
133 1.10 kim }
134 1.1 cgd exit(0);
135 1.1 cgd }
136 1.1 cgd
137 1.1 cgd static void
138 1.1 cgd putppt(c)
139 1.5 lukem int c;
140 1.1 cgd {
141 1.5 lukem int i;
142 1.1 cgd
143 1.1 cgd (void) putchar('|');
144 1.1 cgd for (i = 7; i >= 0; i--) {
145 1.1 cgd if (i == 2)
146 1.1 cgd (void) putchar('.'); /* feed hole */
147 1.1 cgd if ((c&(1<<i)) != 0)
148 1.1 cgd (void) putchar('o');
149 1.1 cgd else
150 1.1 cgd (void) putchar(' ');
151 1.1 cgd }
152 1.1 cgd (void) putchar('|');
153 1.1 cgd (void) putchar('\n');
154 1.10 kim }
155 1.10 kim
156 1.10 kim int
157 1.10 kim getppt(const char *buf)
158 1.10 kim {
159 1.10 kim const char *p = strchr(buf, '.');
160 1.10 kim int c;
161 1.10 kim
162 1.10 kim if (p == NULL)
163 1.10 kim return (-1);
164 1.10 kim
165 1.10 kim c = 0;
166 1.10 kim if (p[ 3] != ' ')
167 1.10 kim c |= 0001;
168 1.10 kim if (p[ 2] != ' ')
169 1.10 kim c |= 0002;
170 1.10 kim if (p[ 1] != ' ')
171 1.10 kim c |= 0004;
172 1.10 kim if (p[-1] != ' ')
173 1.10 kim c |= 0010;
174 1.10 kim if (p[-2] != ' ')
175 1.10 kim c |= 0020;
176 1.10 kim if (p[-3] != ' ')
177 1.10 kim c |= 0040;
178 1.10 kim if (p[-4] != ' ')
179 1.10 kim c |= 0100;
180 1.10 kim if (p[-5] != ' ')
181 1.10 kim c |= 0200;
182 1.10 kim
183 1.10 kim return (c);
184 1.1 cgd }
185