xref: /illumos-gate/usr/src/cmd/eqn/lookup.c (revision c81d47afd05baeb768e2f032636019b717899efd)
1 /*
2  * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
3  * Use is subject to license terms.
4  */
5 
6 /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
7 /*	  All Rights Reserved  	*/
8 
9 /*
10  * Copyright (c) 1980 Regents of the University of California.
11  * All rights reserved. The Berkeley software License Agreement
12  * specifies the terms and conditions for redistribution.
13  */
14 
15 #pragma ident	"%Z%%M%	%I%	%E% SMI"
16 
17 #include "e.h"
18 #include "e.def"
19 #include <locale.h>
20 
21 #define	TBLSIZE	100
22 
23 tbl	*keytbl[TBLSIZE];	/* key words */
24 tbl	*restbl[TBLSIZE];	/* reserved words */
25 tbl	*deftbl[TBLSIZE];	/* user-defined names */
26 
27 struct {
28 	char	*key;
29 	int	keyval;
30 } keyword[]	= {
31 	"sub", 	SUB,
32 	"sup", 	SUP,
33 	".EN", 	EOF,
34 	"from", 	FROM,
35 	"to", 	TO,
36 	"sum", 	SUM,
37 	"hat", 	HAT,
38 	"vec", VEC,
39 	"dyad", DYAD,
40 	"dot", 	DOT,
41 	"dotdot", 	DOTDOT,
42 	"bar", 	BAR,
43 	"tilde", 	TILDE,
44 	"under", 	UNDER,
45 	"prod", 	PROD,
46 	"int", 	INT,
47 	"integral", 	INT,
48 	"union", 	UNION,
49 	"inter", 	INTER,
50 	"pile", 	PILE,
51 	"lpile", 	LPILE,
52 	"cpile", 	CPILE,
53 	"rpile", 	RPILE,
54 	"over", 	OVER,
55 	"sqrt", 	SQRT,
56 	"above", 	ABOVE,
57 	"size", 	SIZE,
58 	"font", 	FONT,
59 	"fat", FAT,
60 	"roman", 	ROMAN,
61 	"italic", 	ITALIC,
62 	"bold", 	BOLD,
63 	"left", 	LEFT,
64 	"right", 	RIGHT,
65 	"delim", 	DELIM,
66 	"define", 	DEFINE,
67 
68 #ifdef	NEQN	/* make ndefine synonym for define, tdefine a no-op */
69 
70 	"tdefine",	TDEFINE,
71 	"ndefine",	DEFINE,
72 
73 #else		/* tdefine = define, ndefine = no-op */
74 
75 	"tdefine", 	DEFINE,
76 	"ndefine", 	NDEFINE,
77 
78 #endif
79 
80 	"gsize", 	GSIZE,
81 	".gsize", 	GSIZE,
82 	"gfont", 	GFONT,
83 	"include", 	INCLUDE,
84 	"up", 	UP,
85 	"down", 	DOWN,
86 	"fwd", 	FWD,
87 	"back", 	BACK,
88 	"mark", 	MARK,
89 	"lineup", 	LINEUP,
90 	"matrix", 	MATRIX,
91 	"col", 	COL,
92 	"lcol", 	LCOL,
93 	"ccol", 	CCOL,
94 	"rcol", 	RCOL,
95 	0, 	0
96 };
97 
98 struct {
99 	char	*res;
100 	char	*resval;
101 } resword[]	= {
102 	">=",	"\\(>=",
103 	"<=",	"\\(<=",
104 	"==",	"\\(==",
105 	"!=",	"\\(!=",
106 	"+-",	"\\(+-",
107 	"->",	"\\(->",
108 	"<-",	"\\(<-",
109 	"inf",	"\\(if",
110 	"infinity",	"\\(if",
111 	"partial",	"\\(pd",
112 	"half",	"\\f1\\(12\\fP",
113 	"prime",	"\\f1\\(fm\\fP",
114 	"dollar",	"\\f1$\\fP",
115 	"nothing",	"",
116 	"times",	"\\(mu",
117 	"del",	"\\(gr",
118 	"grad",	"\\(gr",
119 #ifdef	NEQN
120 	"<<",	"<<",
121 	">>",	">>",
122 	"approx",	"~\b\\d~\\u",
123 	"cdot",	"\\v'-.5'.\\v'.5'",
124 	"...",	"...",
125 	",...,",	",...,",
126 #else
127 	"<<",	"<\\h'-.3m'<",
128 	">>",	">\\h'-.3m'>",
129 	"approx",	"\\v'-.2m'\\z\\(ap\\v'.25m'\\(ap\\v'-.05m'",
130 	"cdot",	"\\v'-.3m'.\\v'.3m'",
131 	"...",	"\\v'-.3m'\\ .\\ .\\ .\\ \\v'.3m'",
132 	",...,",	",\\ .\\ .\\ .\\ ,\\|",
133 #endif
134 
135 	"alpha",	"\\(*a",
136 	"beta",	"\\(*b",
137 	"gamma",	"\\(*g",
138 	"GAMMA",	"\\(*G",
139 	"delta",	"\\(*d",
140 	"DELTA",	"\\(*D",
141 	"epsilon",	"\\(*e",
142 	"EPSILON",	"\\f1E\\fP",
143 	"omega",	"\\(*w",
144 	"OMEGA",	"\\(*W",
145 	"lambda",	"\\(*l",
146 	"LAMBDA",	"\\(*L",
147 	"mu",	"\\(*m",
148 	"nu",	"\\(*n",
149 	"theta",	"\\(*h",
150 	"THETA",	"\\(*H",
151 	"phi",	"\\(*f",
152 	"PHI",	"\\(*F",
153 	"pi",	"\\(*p",
154 	"PI",	"\\(*P",
155 	"sigma",	"\\(*s",
156 	"SIGMA",	"\\(*S",
157 	"xi",	"\\(*c",
158 	"XI",	"\\(*C",
159 	"zeta",	"\\(*z",
160 	"iota",	"\\(*i",
161 	"eta",	"\\(*y",
162 	"kappa",	"\\(*k",
163 	"rho",	"\\(*r",
164 	"tau",	"\\(*t",
165 	"omicron",	"\\(*o",
166 	"upsilon",	"\\(*u",
167 	"UPSILON",	"\\(*U",
168 	"psi",	"\\(*q",
169 	"PSI",	"\\(*Q",
170 	"chi",	"\\(*x",
171 	"and",	"\\f1and\\fP",
172 	"for",	"\\f1for\\fP",
173 	"if",	"\\f1if\\fP",
174 	"Re",	"\\f1Re\\fP",
175 	"Im",	"\\f1Im\\fP",
176 	"sin",	"\\f1sin\\fP",
177 	"cos",	"\\f1cos\\fP",
178 	"tan",	"\\f1tan\\fP",
179 	"sec",  "\\f1sec\\fP",
180 	"csc",  "\\f1csc\\fP",
181 	"arc",	"\\f1arc\\fP",
182 	"asin", "\\f1asin\\fP",
183 	"acos", "\\f1acos\\fP",
184 	"atan", "\\f1atan\\fP",
185 	"asec", "\\f1asec\\fP",
186 	"acsc", "\\f1acsc\\fP",
187 	"sinh",	"\\f1sinh\\fP",
188 	"coth",	"\\f1coth\\fP",
189 	"tanh",	"\\f1tanh\\fP",
190 	"cosh",	"\\f1cosh\\fP",
191 	"lim",	"\\f1lim\\fP",
192 	"log",	"\\f1log\\fP",
193 	"max",	"\\f1max\\fP",
194 	"min",	"\\f1min\\fP",
195 	"ln",	"\\f1ln\\fP",
196 	"exp",	"\\f1exp\\fP",
197 	"det",	"\\f1det\\fP",
198 	0,	0
199 };
200 
201 /* find name in tbl. if defn non-null, install */
202 tbl *
203 lookup(tbl *tblp[], char *name, char *defn)
204 {
205 	tbl *p;
206 	int h;
207 	unsigned char *s = (unsigned char *)name;
208 	char *malloc();
209 
210 	for (h = 0; *s != '\0'; )
211 		h += *s++;
212 	h %= TBLSIZE;
213 
214 	for (p = tblp[h]; p != NULL; p = p->next)
215 		if (strcmp(name, p->name) == 0) {	/* found it */
216 			if (defn != NULL)
217 				p->defn = defn;
218 			return (p);
219 		}
220 	/* didn't find it */
221 	if (defn == NULL)
222 		return (NULL);
223 	p = (tbl *) malloc(sizeof (tbl));
224 	if (p == NULL)
225 		error(FATAL, gettext("out of space in lookup"), NULL);
226 	p->name = name;
227 	p->defn = defn;
228 	p->next = tblp[h];
229 	tblp[h] = p;
230 	return (p);
231 }
232 
233 void
234 init_tbl(void)	/* initialize all tables */
235 {
236 	int i;
237 
238 	for (i = 0; keyword[i].key != NULL; i++)
239 		lookup(keytbl, keyword[i].key, (char *)keyword[i].keyval);
240 	for (i = 0; resword[i].res != NULL; i++)
241 		lookup(restbl, resword[i].res, resword[i].resval);
242 }
243