rpc_util.c revision 1.4 1 1.1 glass /* @(#)rpc_util.c 2.1 88/08/01 4.0 RPCSRC */
2 1.1 glass /*
3 1.1 glass * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
4 1.1 glass * unrestricted use provided that this legend is included on all tape
5 1.1 glass * media and as a part of the software program in whole or part. Users
6 1.1 glass * may copy or modify Sun RPC without charge, but are not authorized
7 1.1 glass * to license or distribute it to anyone else except as part of a product or
8 1.1 glass * program developed by the user.
9 1.1 glass *
10 1.1 glass * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
11 1.1 glass * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
12 1.1 glass * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
13 1.1 glass *
14 1.1 glass * Sun RPC is provided with no support and without any obligation on the
15 1.1 glass * part of Sun Microsystems, Inc. to assist in its use, correction,
16 1.1 glass * modification or enhancement.
17 1.1 glass *
18 1.1 glass * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
19 1.1 glass * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
20 1.1 glass * OR ANY PART THEREOF.
21 1.1 glass *
22 1.1 glass * In no event will Sun Microsystems, Inc. be liable for any lost revenue
23 1.1 glass * or profits or other special, indirect and consequential damages, even if
24 1.1 glass * Sun has been advised of the possibility of such damages.
25 1.1 glass *
26 1.1 glass * Sun Microsystems, Inc.
27 1.1 glass * 2550 Garcia Avenue
28 1.1 glass * Mountain View, California 94043
29 1.1 glass */
30 1.1 glass #ifndef lint
31 1.3 mycroft /*static char sccsid[] = "from: @(#)rpc_util.c 1.5 87/06/24 (C) 1987 SMI";*/
32 1.4 cgd static char rcsid[] = "$Id: rpc_util.c,v 1.4 1995/03/06 04:59:37 cgd Exp $";
33 1.1 glass #endif
34 1.1 glass
35 1.1 glass /*
36 1.1 glass * rpc_util.c, Utility routines for the RPC protocol compiler
37 1.1 glass * Copyright (C) 1987, Sun Microsystems, Inc.
38 1.1 glass */
39 1.1 glass #include <stdio.h>
40 1.1 glass #include "rpc_scan.h"
41 1.1 glass #include "rpc_parse.h"
42 1.1 glass #include "rpc_util.h"
43 1.1 glass
44 1.1 glass char curline[MAXLINESIZE]; /* current read line */
45 1.1 glass char *where = curline; /* current point in line */
46 1.1 glass int linenum = 0; /* current line number */
47 1.1 glass
48 1.1 glass char *infilename; /* input filename */
49 1.1 glass
50 1.1 glass #define NFILES 4
51 1.1 glass char *outfiles[NFILES]; /* output file names */
52 1.1 glass int nfiles;
53 1.1 glass
54 1.1 glass FILE *fout; /* file pointer of current output */
55 1.1 glass FILE *fin; /* file pointer of current input */
56 1.1 glass
57 1.1 glass list *defined; /* list of defined things */
58 1.1 glass
59 1.2 mycroft static int printwhere();
60 1.1 glass
61 1.1 glass /*
62 1.1 glass * Reinitialize the world
63 1.1 glass */
64 1.1 glass reinitialize()
65 1.1 glass {
66 1.4 cgd memset(curline, 0, MAXLINESIZE);
67 1.1 glass where = curline;
68 1.1 glass linenum = 0;
69 1.1 glass defined = NULL;
70 1.1 glass }
71 1.1 glass
72 1.1 glass /*
73 1.1 glass * string equality
74 1.1 glass */
75 1.1 glass streq(a, b)
76 1.1 glass char *a;
77 1.1 glass char *b;
78 1.1 glass {
79 1.1 glass return (strcmp(a, b) == 0);
80 1.1 glass }
81 1.1 glass
82 1.1 glass /*
83 1.1 glass * find a value in a list
84 1.1 glass */
85 1.1 glass char *
86 1.1 glass findval(lst, val, cmp)
87 1.1 glass list *lst;
88 1.1 glass char *val;
89 1.1 glass int (*cmp) ();
90 1.1 glass
91 1.1 glass {
92 1.1 glass for (; lst != NULL; lst = lst->next) {
93 1.1 glass if ((*cmp) (lst->val, val)) {
94 1.1 glass return (lst->val);
95 1.1 glass }
96 1.1 glass }
97 1.1 glass return (NULL);
98 1.1 glass }
99 1.1 glass
100 1.1 glass /*
101 1.1 glass * store a value in a list
102 1.1 glass */
103 1.1 glass void
104 1.1 glass storeval(lstp, val)
105 1.1 glass list **lstp;
106 1.1 glass char *val;
107 1.1 glass {
108 1.1 glass list **l;
109 1.1 glass list *lst;
110 1.1 glass
111 1.1 glass for (l = lstp; *l != NULL; l = (list **) & (*l)->next);
112 1.1 glass lst = ALLOC(list);
113 1.1 glass lst->val = val;
114 1.1 glass lst->next = NULL;
115 1.1 glass *l = lst;
116 1.1 glass }
117 1.1 glass
118 1.1 glass
119 1.1 glass static
120 1.1 glass findit(def, type)
121 1.1 glass definition *def;
122 1.1 glass char *type;
123 1.1 glass {
124 1.1 glass return (streq(def->def_name, type));
125 1.1 glass }
126 1.1 glass
127 1.1 glass
128 1.1 glass static char *
129 1.1 glass fixit(type, orig)
130 1.1 glass char *type;
131 1.1 glass char *orig;
132 1.1 glass {
133 1.1 glass definition *def;
134 1.1 glass
135 1.1 glass def = (definition *) FINDVAL(defined, type, findit);
136 1.1 glass if (def == NULL || def->def_kind != DEF_TYPEDEF) {
137 1.1 glass return (orig);
138 1.1 glass }
139 1.1 glass switch (def->def.ty.rel) {
140 1.1 glass case REL_VECTOR:
141 1.1 glass return (def->def.ty.old_type);
142 1.1 glass case REL_ALIAS:
143 1.1 glass return (fixit(def->def.ty.old_type, orig));
144 1.1 glass default:
145 1.1 glass return (orig);
146 1.1 glass }
147 1.1 glass }
148 1.1 glass
149 1.1 glass char *
150 1.1 glass fixtype(type)
151 1.1 glass char *type;
152 1.1 glass {
153 1.1 glass return (fixit(type, type));
154 1.1 glass }
155 1.1 glass
156 1.1 glass char *
157 1.1 glass stringfix(type)
158 1.1 glass char *type;
159 1.1 glass {
160 1.1 glass if (streq(type, "string")) {
161 1.1 glass return ("wrapstring");
162 1.1 glass } else {
163 1.1 glass return (type);
164 1.1 glass }
165 1.1 glass }
166 1.1 glass
167 1.1 glass void
168 1.1 glass ptype(prefix, type, follow)
169 1.1 glass char *prefix;
170 1.1 glass char *type;
171 1.1 glass int follow;
172 1.1 glass {
173 1.1 glass if (prefix != NULL) {
174 1.1 glass if (streq(prefix, "enum")) {
175 1.1 glass f_print(fout, "enum ");
176 1.1 glass } else {
177 1.1 glass f_print(fout, "struct ");
178 1.1 glass }
179 1.1 glass }
180 1.1 glass if (streq(type, "bool")) {
181 1.1 glass f_print(fout, "bool_t ");
182 1.1 glass } else if (streq(type, "string")) {
183 1.1 glass f_print(fout, "char *");
184 1.1 glass } else {
185 1.1 glass f_print(fout, "%s ", follow ? fixtype(type) : type);
186 1.1 glass }
187 1.1 glass }
188 1.1 glass
189 1.1 glass
190 1.1 glass static
191 1.1 glass typedefed(def, type)
192 1.1 glass definition *def;
193 1.1 glass char *type;
194 1.1 glass {
195 1.1 glass if (def->def_kind != DEF_TYPEDEF || def->def.ty.old_prefix != NULL) {
196 1.1 glass return (0);
197 1.1 glass } else {
198 1.1 glass return (streq(def->def_name, type));
199 1.1 glass }
200 1.1 glass }
201 1.1 glass
202 1.1 glass isvectordef(type, rel)
203 1.1 glass char *type;
204 1.1 glass relation rel;
205 1.1 glass {
206 1.1 glass definition *def;
207 1.1 glass
208 1.1 glass for (;;) {
209 1.1 glass switch (rel) {
210 1.1 glass case REL_VECTOR:
211 1.1 glass return (!streq(type, "string"));
212 1.1 glass case REL_ARRAY:
213 1.1 glass return (0);
214 1.1 glass case REL_POINTER:
215 1.1 glass return (0);
216 1.1 glass case REL_ALIAS:
217 1.1 glass def = (definition *) FINDVAL(defined, type, typedefed);
218 1.1 glass if (def == NULL) {
219 1.1 glass return (0);
220 1.1 glass }
221 1.1 glass type = def->def.ty.old_type;
222 1.1 glass rel = def->def.ty.rel;
223 1.1 glass }
224 1.1 glass }
225 1.1 glass }
226 1.1 glass
227 1.1 glass
228 1.1 glass static char *
229 1.1 glass locase(str)
230 1.1 glass char *str;
231 1.1 glass {
232 1.1 glass char c;
233 1.1 glass static char buf[100];
234 1.1 glass char *p = buf;
235 1.1 glass
236 1.1 glass while (c = *str++) {
237 1.1 glass *p++ = (c >= 'A' && c <= 'Z') ? (c - 'A' + 'a') : c;
238 1.1 glass }
239 1.1 glass *p = 0;
240 1.1 glass return (buf);
241 1.1 glass }
242 1.1 glass
243 1.1 glass
244 1.1 glass void
245 1.1 glass pvname(pname, vnum)
246 1.1 glass char *pname;
247 1.1 glass char *vnum;
248 1.1 glass {
249 1.1 glass f_print(fout, "%s_%s", locase(pname), vnum);
250 1.1 glass }
251 1.1 glass
252 1.1 glass
253 1.1 glass /*
254 1.1 glass * print a useful (?) error message, and then die
255 1.1 glass */
256 1.1 glass void
257 1.1 glass error(msg)
258 1.1 glass char *msg;
259 1.1 glass {
260 1.1 glass printwhere();
261 1.1 glass f_print(stderr, "%s, line %d: ", infilename, linenum);
262 1.1 glass f_print(stderr, "%s\n", msg);
263 1.1 glass crash();
264 1.1 glass }
265 1.1 glass
266 1.1 glass /*
267 1.1 glass * Something went wrong, unlink any files that we may have created and then
268 1.1 glass * die.
269 1.1 glass */
270 1.1 glass crash()
271 1.1 glass {
272 1.1 glass int i;
273 1.1 glass
274 1.1 glass for (i = 0; i < nfiles; i++) {
275 1.1 glass (void) unlink(outfiles[i]);
276 1.1 glass }
277 1.1 glass exit(1);
278 1.1 glass }
279 1.1 glass
280 1.1 glass
281 1.1 glass void
282 1.1 glass record_open(file)
283 1.1 glass char *file;
284 1.1 glass {
285 1.1 glass if (nfiles < NFILES) {
286 1.1 glass outfiles[nfiles++] = file;
287 1.1 glass } else {
288 1.1 glass f_print(stderr, "too many files!\n");
289 1.1 glass crash();
290 1.1 glass }
291 1.1 glass }
292 1.1 glass
293 1.1 glass static char expectbuf[100];
294 1.1 glass static char *toktostr();
295 1.1 glass
296 1.1 glass /*
297 1.1 glass * error, token encountered was not the expected one
298 1.1 glass */
299 1.1 glass void
300 1.1 glass expected1(exp1)
301 1.1 glass tok_kind exp1;
302 1.1 glass {
303 1.1 glass s_print(expectbuf, "expected '%s'",
304 1.1 glass toktostr(exp1));
305 1.1 glass error(expectbuf);
306 1.1 glass }
307 1.1 glass
308 1.1 glass /*
309 1.1 glass * error, token encountered was not one of two expected ones
310 1.1 glass */
311 1.1 glass void
312 1.1 glass expected2(exp1, exp2)
313 1.1 glass tok_kind exp1, exp2;
314 1.1 glass {
315 1.1 glass s_print(expectbuf, "expected '%s' or '%s'",
316 1.1 glass toktostr(exp1),
317 1.1 glass toktostr(exp2));
318 1.1 glass error(expectbuf);
319 1.1 glass }
320 1.1 glass
321 1.1 glass /*
322 1.1 glass * error, token encountered was not one of 3 expected ones
323 1.1 glass */
324 1.1 glass void
325 1.1 glass expected3(exp1, exp2, exp3)
326 1.1 glass tok_kind exp1, exp2, exp3;
327 1.1 glass {
328 1.1 glass s_print(expectbuf, "expected '%s', '%s' or '%s'",
329 1.1 glass toktostr(exp1),
330 1.1 glass toktostr(exp2),
331 1.1 glass toktostr(exp3));
332 1.1 glass error(expectbuf);
333 1.1 glass }
334 1.1 glass
335 1.1 glass void
336 1.1 glass tabify(f, tab)
337 1.1 glass FILE *f;
338 1.1 glass int tab;
339 1.1 glass {
340 1.1 glass while (tab--) {
341 1.1 glass (void) fputc('\t', f);
342 1.1 glass }
343 1.1 glass }
344 1.1 glass
345 1.1 glass
346 1.1 glass
347 1.1 glass static token tokstrings[] = {
348 1.1 glass {TOK_IDENT, "identifier"},
349 1.1 glass {TOK_CONST, "const"},
350 1.1 glass {TOK_RPAREN, ")"},
351 1.1 glass {TOK_LPAREN, "("},
352 1.1 glass {TOK_RBRACE, "}"},
353 1.1 glass {TOK_LBRACE, "{"},
354 1.1 glass {TOK_LBRACKET, "["},
355 1.1 glass {TOK_RBRACKET, "]"},
356 1.1 glass {TOK_STAR, "*"},
357 1.1 glass {TOK_COMMA, ","},
358 1.1 glass {TOK_EQUAL, "="},
359 1.1 glass {TOK_COLON, ":"},
360 1.1 glass {TOK_SEMICOLON, ";"},
361 1.1 glass {TOK_UNION, "union"},
362 1.1 glass {TOK_STRUCT, "struct"},
363 1.1 glass {TOK_SWITCH, "switch"},
364 1.1 glass {TOK_CASE, "case"},
365 1.1 glass {TOK_DEFAULT, "default"},
366 1.1 glass {TOK_ENUM, "enum"},
367 1.1 glass {TOK_TYPEDEF, "typedef"},
368 1.1 glass {TOK_INT, "int"},
369 1.1 glass {TOK_SHORT, "short"},
370 1.1 glass {TOK_LONG, "long"},
371 1.1 glass {TOK_UNSIGNED, "unsigned"},
372 1.1 glass {TOK_DOUBLE, "double"},
373 1.1 glass {TOK_FLOAT, "float"},
374 1.1 glass {TOK_CHAR, "char"},
375 1.1 glass {TOK_STRING, "string"},
376 1.1 glass {TOK_OPAQUE, "opaque"},
377 1.1 glass {TOK_BOOL, "bool"},
378 1.1 glass {TOK_VOID, "void"},
379 1.1 glass {TOK_PROGRAM, "program"},
380 1.1 glass {TOK_VERSION, "version"},
381 1.1 glass {TOK_EOF, "??????"}
382 1.1 glass };
383 1.1 glass
384 1.1 glass static char *
385 1.1 glass toktostr(kind)
386 1.1 glass tok_kind kind;
387 1.1 glass {
388 1.1 glass token *sp;
389 1.1 glass
390 1.1 glass for (sp = tokstrings; sp->kind != TOK_EOF && sp->kind != kind; sp++);
391 1.1 glass return (sp->str);
392 1.1 glass }
393 1.1 glass
394 1.1 glass
395 1.1 glass
396 1.1 glass static
397 1.1 glass printbuf()
398 1.1 glass {
399 1.1 glass char c;
400 1.1 glass int i;
401 1.1 glass int cnt;
402 1.1 glass
403 1.1 glass # define TABSIZE 4
404 1.1 glass
405 1.1 glass for (i = 0; c = curline[i]; i++) {
406 1.1 glass if (c == '\t') {
407 1.1 glass cnt = 8 - (i % TABSIZE);
408 1.1 glass c = ' ';
409 1.1 glass } else {
410 1.1 glass cnt = 1;
411 1.1 glass }
412 1.1 glass while (cnt--) {
413 1.1 glass (void) fputc(c, stderr);
414 1.1 glass }
415 1.1 glass }
416 1.1 glass }
417 1.1 glass
418 1.1 glass
419 1.1 glass static
420 1.1 glass printwhere()
421 1.1 glass {
422 1.1 glass int i;
423 1.1 glass char c;
424 1.1 glass int cnt;
425 1.1 glass
426 1.1 glass printbuf();
427 1.1 glass for (i = 0; i < where - curline; i++) {
428 1.1 glass c = curline[i];
429 1.1 glass if (c == '\t') {
430 1.1 glass cnt = 8 - (i % TABSIZE);
431 1.1 glass } else {
432 1.1 glass cnt = 1;
433 1.1 glass }
434 1.1 glass while (cnt--) {
435 1.1 glass (void) fputc('^', stderr);
436 1.1 glass }
437 1.1 glass }
438 1.1 glass (void) fputc('\n', stderr);
439 1.1 glass }
440