GCC Code Coverage Report
Directory: ./ Exec Total Coverage
File: usr.bin/rpcgen/rpc_cout.c Lines: 292 337 86.6 %
Date: 2017-11-07 Branches: 163 197 82.7 %

Line Branch Exec Source
1
/*	$OpenBSD: rpc_cout.c,v 1.28 2016/12/22 16:42:55 krw Exp $	*/
2
/*	$NetBSD: rpc_cout.c,v 1.6 1996/10/01 04:13:53 cgd Exp $	*/
3
4
/*
5
 * Copyright (c) 2010, Oracle America, Inc.
6
 *
7
 * Redistribution and use in source and binary forms, with or without
8
 * modification, are permitted provided that the following conditions are
9
 * met:
10
 *
11
 *     * Redistributions of source code must retain the above copyright
12
 *       notice, this list of conditions and the following disclaimer.
13
 *     * Redistributions in binary form must reproduce the above
14
 *       copyright notice, this list of conditions and the following
15
 *       disclaimer in the documentation and/or other materials
16
 *       provided with the distribution.
17
 *     * Neither the name of the "Oracle America, Inc." nor the names of its
18
 *       contributors may be used to endorse or promote products derived
19
 *       from this software without specific prior written permission.
20
 *
21
 *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
 *   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23
 *   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24
 *   FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
 *   COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
26
 *   INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27
 *   DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
28
 *   GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29
 *   INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
30
 *   WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
31
 *   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32
 *   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33
 */
34
35
/*
36
 * rpc_cout.c, XDR routine outputter for the RPC protocol compiler
37
 */
38
#include <stdio.h>
39
#include <stdlib.h>
40
#include <string.h>
41
#include <ctype.h>
42
#include "rpc_parse.h"
43
#include "rpc_util.h"
44
45
static int findtype(definition *, char *);
46
static int undefined(char *);
47
static void print_generic_header(char *, int);
48
static void print_header(definition *);
49
static void print_prog_header(proc_list *);
50
static void print_trailer(void);
51
static void print_ifopen(int, char *);
52
static void print_ifarg(char *);
53
static void print_ifsizeof(char *, char *);
54
static void print_ifclose(int);
55
static void print_ifstat(int, char *, char *, relation, char *, char *, char *);
56
static void emit_program(definition *);
57
static void emit_enum(definition *);
58
static void emit_union(definition *);
59
static void emit_struct(definition *);
60
static void emit_typedef(definition *);
61
static void print_stat(int, declaration *);
62
void emit_inline(declaration *, int);
63
void emit_single_in_line(declaration *, int, relation);
64
65
/*
66
 * Emit the C-routine for the given definition
67
 */
68
void
69
emit(def)
70
	definition *def;
71
{
72
1164
	if (def->def_kind == DEF_CONST) {
73
		return;
74
	}
75
322
	if (def->def_kind == DEF_PROGRAM) {
76
32
		emit_program(def);
77
32
		return;
78
	}
79
290
	if (def->def_kind == DEF_TYPEDEF) {
80
		/* now we need to handle declarations like struct typedef foo
81
		 * foo; since we dont want this to be expanded into 2 calls to
82
		 * xdr_foo */
83
84
40
		if (strcmp(def->def.ty.old_type, def->def_name) == 0)
85
			return;
86
	}
87
88
580
	print_header(def);
89

580
	switch (def->def_kind) {
90
	case DEF_UNION:
91
28
		emit_union(def);
92
28
		break;
93
	case DEF_ENUM:
94
26
		emit_enum(def);
95
26
		break;
96
	case DEF_STRUCT:
97
196
		emit_struct(def);
98
196
		break;
99
	case DEF_TYPEDEF:
100
40
		emit_typedef(def);
101
40
		break;
102
	default:
103
		break;
104
	}
105
290
	print_trailer();
106
872
}
107
108
static int
109
findtype(def, type)
110
	definition *def;
111
	char	*type;
112
{
113
114

1722
	if (def->def_kind == DEF_PROGRAM || def->def_kind == DEF_CONST) {
115
208
		return (0);
116
	} else {
117
366
		return (streq(def->def_name, type));
118
	}
119
574
}
120
121
static int
122
undefined(type)
123
	char	*type;
124
{
125
	definition *def;
126
127
152
	def = (definition *) FINDVAL(defined, type, findtype);
128
76
	return (def == NULL);
129
}
130
131
static void
132
print_generic_header(procname, pointerp)
133
	char	*procname;
134
	int	pointerp;
135
{
136
580
	fprintf(fout, "\n");
137
290
	fprintf(fout, "bool_t\n");
138
290
	if (Cflag) {
139
290
		fprintf(fout, "xdr_%s(", procname);
140
290
		fprintf(fout, "XDR *xdrs, ");
141
290
		fprintf(fout, "%s ", procname);
142
290
		if (pointerp)
143
286
			fprintf(fout, "*");
144
290
		fprintf(fout, "objp)\n{\n");
145
290
	} else {
146
		fprintf(fout, "xdr_%s(xdrs, objp)\n", procname);
147
		fprintf(fout, "\tXDR *xdrs;\n");
148
		fprintf(fout, "\t%s ", procname);
149
		if (pointerp)
150
			fprintf(fout, "*");
151
		fprintf(fout, "objp;\n{\n");
152
	}
153
290
}
154
155
static void
156
print_header(def)
157
	definition *def;
158
{
159
870
	print_generic_header(def->def_name,
160
620
	    def->def_kind != DEF_TYPEDEF ||
161
40
	    !isvectordef(def->def.ty.old_type, def->def.ty.rel));
162
163
	/* Now add Inline support */
164
165
290
	if (doinline == 0)
166
		return;
167
290
}
168
169
static void
170
print_prog_header(plist)
171
	proc_list *plist;
172
{
173
	print_generic_header(plist->args.argname, 1);
174
}
175
176
static void
177
print_trailer()
178
{
179
580
	fprintf(fout, "\treturn (TRUE);\n");
180
290
	fprintf(fout, "}\n");
181
290
}
182
183
static void
184
print_ifopen(indent, name)
185
	int     indent;
186
	char   *name;
187
{
188
2384
	tabify(fout, indent);
189
1192
	fprintf(fout, "if (!xdr_%s(xdrs", name);
190
1192
}
191
192
static void
193
print_ifarg(arg)
194
	char   *arg;
195
{
196
2560
	fprintf(fout, ", %s", arg);
197
1280
}
198
199
static void
200
print_ifsizeof(prefix, type)
201
	char   *prefix;
202
	char   *type;
203
{
204
152
	if (streq(type, "bool")) {
205
		fprintf(fout, ", sizeof(bool_t), (xdrproc_t)xdr_bool");
206
	} else {
207
76
		fprintf(fout, ", sizeof(");
208
76
		if (undefined(type) && prefix) {
209
6
			fprintf(fout, "%s ", prefix);
210
6
		}
211
76
		fprintf(fout, "%s), (xdrproc_t)xdr_%s", type, type);
212
	}
213
76
}
214
215
static void
216
print_ifclose(indent)
217
	int     indent;
218
{
219
2384
	fprintf(fout, "))\n");
220
1192
	tabify(fout, indent);
221
1192
	fprintf(fout, "\treturn (FALSE);\n");
222
1192
}
223
224
static void
225
print_ifstat(indent, prefix, type, rel, amax, objname, name)
226
	int     indent;
227
	char   *prefix;
228
	char   *type;
229
	relation rel;
230
	char   *amax;
231
	char   *objname;
232
	char   *name;
233
{
234
	char   *alt = NULL;
235
236

3498
	switch (rel) {
237
	case REL_POINTER:
238
14
		print_ifopen(indent, "pointer");
239
14
		print_ifarg("(char **)");
240
14
		fprintf(fout, "%s", objname);
241
14
		print_ifsizeof(prefix, type);
242
14
		break;
243
	case REL_VECTOR:
244
70
		if (streq(type, "string")) {
245
			alt = "string";
246
		} else
247
70
			if (streq(type, "opaque")) {
248
				alt = "opaque";
249
22
			}
250
70
		if (alt) {
251
22
			print_ifopen(indent, alt);
252
22
			print_ifarg(objname);
253
22
			print_ifarg(amax);
254
22
		} else {
255
48
			print_ifopen(indent, "vector");
256
48
			print_ifarg("(char *)");
257
48
			fprintf(fout, "%s,\n", objname);
258
48
			tabify(fout, indent);
259
48
			fprintf(fout, "    %s", amax);
260
		}
261
70
		if (!alt) {
262
48
			print_ifsizeof(prefix, type);
263
48
		}
264
		break;
265
	case REL_ARRAY:
266
94
		if (streq(type, "string")) {
267
			alt = "string";
268
66
		} else
269
28
			if (streq(type, "opaque")) {
270
				alt = "bytes";
271
14
			}
272
94
		if (streq(type, "string")) {
273
66
			print_ifopen(indent, alt);
274
66
			print_ifarg(objname);
275
66
			print_ifarg(amax);
276
66
		} else {
277
28
			if (alt) {
278
14
				print_ifopen(indent, alt);
279
14
			} else {
280
14
				print_ifopen(indent, "array");
281
			}
282
28
			print_ifarg("(char **)");
283
28
			if (*objname == '&') {
284
20
				fprintf(fout, "%s.%s_val,\n\t    (u_int *)%s.%s_len",
285
				    objname, name, objname, name);
286
20
			} else {
287
8
				fprintf(fout, "&%s->%s_val,\n\t    (u_int *)&%s->%s_len",
288
				    objname, name, objname, name);
289
			}
290
28
			fprintf(fout, ",\n\t    %s", amax);
291
		}
292
94
		if (!alt) {
293
14
			print_ifsizeof(prefix, type);
294
14
		}
295
		break;
296
	case REL_ALIAS:
297
988
		print_ifopen(indent, type);
298
988
		print_ifarg(objname);
299
988
		break;
300
	}
301
1166
	print_ifclose(indent);
302
1166
}
303
304
/* ARGSUSED */
305
static void
306
emit_enum(def)
307
	definition *def;
308
{
309
52
	fprintf(fout, "\n");
310
311
26
	print_ifopen(1, "enum");
312
26
	print_ifarg("(enum_t *)objp");
313
26
	print_ifclose(1);
314
26
}
315
316
static void
317
emit_program(def)
318
	definition *def;
319
{
320
	decl_list *dl;
321
	version_list *vlist;
322
	proc_list *plist;
323
324
180
	for (vlist = def->def.pr.versions; vlist != NULL; vlist = vlist->next)
325
540
		for (plist = vlist->procs; plist != NULL; plist = plist->next) {
326

228
			if (!newstyle || plist->arg_num < 2)
327
				continue;	/* old style, or single
328
						 * argument */
329
			print_prog_header(plist);
330
			for (dl = plist->args.decls; dl != NULL;
331
			    dl = dl->next)
332
				print_stat(1, &dl->decl);
333
			print_trailer();
334
		}
335
32
}
336
337
static void
338
emit_union(def)
339
	definition *def;
340
{
341
	declaration *dflt;
342
	case_list *cl;
343
	declaration *cs;
344
	char   *object;
345
	static const char vecformat[] = "objp->%s_u.%s";
346
	static const char format[] = "&objp->%s_u.%s";
347
348
56
	fprintf(fout, "\n");
349
28
	print_stat(1, &def->def.un.enum_decl);
350
28
	fprintf(fout, "\tswitch (objp->%s) {\n", def->def.un.enum_decl.name);
351
128
	for (cl = def->def.un.cases; cl != NULL; cl = cl->next) {
352
36
		fprintf(fout, "\tcase %s:\n", cl->case_name);
353
36
		if (cl->contflag == 1)	/* a continued case statement */
354
			continue;
355
36
		cs = &cl->case_decl;
356
36
		if (!streq(cs->type, "void")) {
357
90
			int len = strlen(def->def_name) + strlen(format) +
358
60
			    strlen(cs->name) + 1;
359
360
30
			object = malloc(len);
361
30
			if (object == NULL) {
362
				fprintf(stderr, "Fatal error: no memory\n");
363
				crash();
364
			}
365
30
			if (isvectordef(cs->type, cs->rel)) {
366
2
				snprintf(object, len, vecformat, def->def_name,
367
				    cs->name);
368
2
			} else {
369
28
				snprintf(object, len, format, def->def_name,
370
				    cs->name);
371
			}
372
60
			print_ifstat(2, cs->prefix, cs->type, cs->rel, cs->array_max,
373
30
			    object, cs->name);
374
30
			free(object);
375
30
		}
376
36
		fprintf(fout, "\t\tbreak;\n");
377
36
	}
378
28
	dflt = def->def.un.default_decl;
379
28
	fprintf(fout, "\tdefault:\n");
380
28
	if (dflt != NULL) {
381
20
		if (!streq(dflt->type, "void")) {
382
			int len = strlen(def->def_name) + strlen(format) +
383
			    strlen(dflt->name) + 1;
384
385
			object = malloc(len);
386
			if (object == NULL) {
387
				fprintf(stderr, "Fatal error: no memory\n");
388
				crash();
389
			}
390
			if (isvectordef(dflt->type, dflt->rel)) {
391
				snprintf(object, len, vecformat, def->def_name,
392
				    dflt->name);
393
			} else {
394
				snprintf(object, len, format, def->def_name,
395
				    dflt->name);
396
			}
397
398
			print_ifstat(2, dflt->prefix, dflt->type, dflt->rel,
399
			    dflt->array_max, object, dflt->name);
400
			free(object);
401
		}
402
20
		fprintf(fout, "\t\tbreak;\n");
403
20
	} else {
404
8
		fprintf(fout, "\t\treturn (FALSE);\n");
405
	}
406
407
28
	fprintf(fout, "\t}\n");
408
28
}
409
410
static void
411
emit_struct(def)
412
	definition *def;
413
{
414
	decl_list *dl;
415
	int     i, j, size, flag;
416
	decl_list *cur, *psav;
417
	bas_type *ptr;
418
	char   *sizestr, *plus;
419
392
	char    ptemp[256];
420
	int     can_inline;
421
422
196
	if (doinline == 0) {
423
		for (dl = def->def.st.decls; dl != NULL; dl = dl->next)
424
			print_stat(1, &dl->decl);
425
		return;
426
	}
427
1392
	for (dl = def->def.st.decls; dl != NULL; dl = dl->next)
428

628
		if (dl->decl.rel == REL_VECTOR &&
429
24
		    strcmp(dl->decl.type, "opaque") != 0) {
430
6
			fprintf(fout, "\tint i;\n");
431
6
			break;
432
		}
433
196
	fprintf(fout, "\n");
434
435
	size = 0;
436
	can_inline = 0;
437
1564
	for (dl = def->def.st.decls; dl != NULL; dl = dl->next)
438

604
		if (dl->decl.prefix == NULL &&
439
572
		    (ptr = find_type(dl->decl.type)) != NULL &&
440
246
		    (dl->decl.rel == REL_ALIAS || dl->decl.rel == REL_VECTOR)) {
441
240
			if (dl->decl.rel == REL_ALIAS)
442
234
				size += ptr->length;
443
			else {
444
				can_inline = 1;
445
6
				break;	/* can be inlined */
446
			}
447
234
		} else {
448
358
			if (size >= doinline) {
449
				can_inline = 1;
450
6
				break;	/* can be inlined */
451
			}
452
			size = 0;
453
		}
454
196
	if (size > doinline)
455
12
		can_inline = 1;
456
457
196
	if (can_inline == 0) {	/* can not inline, drop back to old mode */
458
176
		fprintf(fout, "\n");
459
1336
		for (dl = def->def.st.decls; dl != NULL; dl = dl->next)
460
492
			print_stat(1, &dl->decl);
461
176
		return;
462
	}
463
464
	/* May cause lint to complain. but  ... */
465
20
	fprintf(fout, "\tint32_t *buf;\n");
466
467
	flag = PUT;
468
120
	for (j = 0; j < 2; j++) {
469
40
		if (flag == PUT)
470
20
			fprintf(fout, "\n\tif (xdrs->x_op == XDR_ENCODE) {\n");
471
		else
472
20
			fprintf(fout, "\t\treturn (TRUE);\n\t} else if (xdrs->x_op == XDR_DECODE) {\n");
473
474
		i = 0;
475
		size = 0;
476
		sizestr = NULL;
477
848
		for (dl = def->def.st.decls; dl != NULL; dl = dl->next) {	/* xxx */
478
479
			/* now walk down the list and check for basic types */
480

416
			if (dl->decl.prefix == NULL &&
481
384
			    (ptr = find_type(dl->decl.type)) != NULL &&
482
352
			    (dl->decl.rel == REL_ALIAS || dl->decl.rel == REL_VECTOR)) {
483
320
				if (i == 0)
484
48
					cur = dl;
485
320
				i++;
486
487
320
				if (dl->decl.rel == REL_ALIAS)
488
288
					size += ptr->length;
489
				else {
490
					/* this is required to handle arrays */
491
492
32
					if (sizestr == NULL)
493
12
						plus = "";
494
					else
495
						plus = "+";
496
497
32
					if (ptr->length != 1)
498
						snprintf(ptemp, sizeof ptemp,
499
						    "%s%s* %d", plus,
500
						    dl->decl.array_max,
501
						    ptr->length);
502
					else
503
32
						snprintf(ptemp, sizeof ptemp,
504
						    "%s%s", plus,
505
						    dl->decl.array_max);
506
507
					/* now concatenate to sizestr !!!! */
508
32
					if (sizestr == NULL) {
509
12
						sizestr = strdup(ptemp);
510
12
						if (sizestr == NULL) {
511
							fprintf(stderr,
512
							    "Fatal error: no memory\n");
513
							crash();
514
						}
515
					} else {
516
						size_t len;
517
518
40
						len = strlen(sizestr) +
519
40
						    strlen(ptemp) + 1;
520
20
						sizestr = realloc(sizestr, len);
521
20
						if (sizestr == NULL) {
522
							fprintf(stderr,
523
							    "Fatal error: no memory\n");
524
							crash();
525
						}
526
						/* build up length of array */
527
20
						strlcat(sizestr, ptemp, len);
528
					}
529
				}
530
531
			} else {
532
64
				if (i > 0) {
533

32
					if (sizestr == NULL && size < doinline) {
534
						/* don't expand into inline
535
						 * code if size < doinline */
536
						while (cur != dl) {
537
							print_stat(2, &cur->decl);
538
							cur = cur->next;
539
						}
540
					} else {
541
						/* were already looking at a
542
						 * xdr_inlineable structure */
543
20
						if (sizestr == NULL)
544
12
							fprintf(fout,
545
							    "\t\tbuf = (int32_t *)XDR_INLINE(xdrs,\n\t\t    %d * BYTES_PER_XDR_UNIT);", size);
546
8
						else if (size == 0)
547
							fprintf(fout,
548
							    "\t\tbuf = (int32_t *)XDR_INLINE(xdrs,\n\t\t    %s * BYTES_PER_XDR_UNIT);",
549
								    sizestr);
550
						else
551
8
							fprintf(fout,
552
							    "\t\tbuf = (int32_t *)XDR_INLINE(xdrs,\n\t\t    (%d + %s) * BYTES_PER_XDR_UNIT);", size, sizestr);
553
554
20
						fprintf(fout,
555
						    "\n\t\tif (buf == NULL) {\n");
556
557
						psav = cur;
558
384
						while (cur != dl) {
559
172
							print_stat(3, &cur->decl);
560
172
							cur = cur->next;
561
						}
562
563
20
						fprintf(fout, "\t\t} else {\n");
564
565
						cur = psav;
566
384
						while (cur != dl) {
567
172
							emit_inline(&cur->decl, flag);
568
172
							cur = cur->next;
569
						}
570
20
						fprintf(fout, "\t\t}\n");
571
					}
572
				}
573
				size = 0;
574
				i = 0;
575
				sizestr = NULL;
576
64
				print_stat(2, &dl->decl);
577
			}
578
		}
579
40
		if (i > 0) {
580

52
			if (sizestr == NULL && size < doinline) {
581
				/* don't expand into inline code if size <
582
				 * doinline */
583
24
				while (cur != dl) {
584
8
					print_stat(2, &cur->decl);
585
8
					cur = cur->next;
586
				}
587
			} else {
588
				/* were already looking at a xdr_inlineable
589
				 * structure */
590
20
				if (sizestr == NULL)
591
16
					fprintf(fout, "\t\tbuf = (int32_t *)XDR_INLINE(xdrs,\n\t\t    %d * BYTES_PER_XDR_UNIT);",
592
					    size);
593
				else
594
4
					if (size == 0)
595
						fprintf(fout,
596
						    "\t\tbuf = (int32_t *)XDR_INLINE(xdrs,\n\t\t    %s * BYTES_PER_XDR_UNIT);",
597
						    sizestr);
598
					else
599
4
						fprintf(fout,
600
						    "\t\tbuf = (int32_t *)XDR_INLINE(xdrs,\n\t\t    (%d + %s) * BYTES_PER_XDR_UNIT);",
601
						    size, sizestr);
602
603
20
				fprintf(fout, "\n\t\tif (buf == NULL) {\n");
604
605
				psav = cur;
606
320
				while (cur != NULL) {
607
140
					print_stat(3, &cur->decl);
608
140
					cur = cur->next;
609
				}
610
20
				fprintf(fout, "\t\t} else {\n");
611
612
				cur = psav;
613
320
				while (cur != dl) {
614
140
					emit_inline(&cur->decl, flag);
615
140
					cur = cur->next;
616
				}
617
618
20
				fprintf(fout, "\t\t}\n");
619
620
			}
621
		}
622
		flag = GET;
623
	}
624
20
	fprintf(fout, "\t\treturn (TRUE);\n\t}\n\n");
625
626
	/* now take care of XDR_FREE case */
627
628
424
	for (dl = def->def.st.decls; dl != NULL; dl = dl->next)
629
192
		print_stat(1, &dl->decl);
630
216
}
631
632
static void
633
emit_typedef(def)
634
	definition *def;
635
{
636
80
	char   *prefix = def->def.ty.old_prefix;
637
40
	char   *type = def->def.ty.old_type;
638
40
	char   *amax = def->def.ty.array_max;
639
40
	relation rel = def->def.ty.rel;
640
641
40
	fprintf(fout, "\n");
642
40
	print_ifstat(1, prefix, type, rel, amax, "objp", def->def_name);
643
40
}
644
645
static void
646
print_stat(indent, dec)
647
	declaration *dec;
648
	int     indent;
649
{
650
2192
	char   *prefix = dec->prefix;
651
1096
	char   *type = dec->type;
652
1096
	char   *amax = dec->array_max;
653
1096
	relation rel = dec->rel;
654
1096
	char    name[256];
655
656
1096
	if (isvectordef(type, rel)) {
657
70
		snprintf(name, sizeof name, "objp->%s", dec->name);
658
70
	} else {
659
1026
		snprintf(name, sizeof name, "&objp->%s", dec->name);
660
	}
661
1096
	print_ifstat(indent, prefix, type, rel, amax, name, dec->name);
662
1096
}
663
664
char   *upcase(char *);
665
666
void
667
emit_inline(decl, flag)
668
	declaration *decl;
669
	int     flag;
670
{
671
	/*check whether an array or not */
672
673
936
	switch (decl->rel) {
674
	case REL_ALIAS:
675
280
		fprintf(fout, "\t");
676
280
		emit_single_in_line(decl, flag, REL_ALIAS);
677
280
		break;
678
	case REL_VECTOR:
679
32
		fprintf(fout, "\t\t\t{\n\t\t\t\t%s *genp;\n\n", decl->type);
680
64
		fprintf(fout, "\t\t\t\tfor (i = 0, genp = objp->%s;\n\t\t\t\t    i < %s; i++) {\n\t\t\t",
681
32
		    decl->name, decl->array_max);
682
32
		emit_single_in_line(decl, flag, REL_VECTOR);
683
32
		fprintf(fout, "\t\t\t\t}\n\t\t\t}\n");
684
32
		break;
685
	default:
686
		break;
687
688
	}
689
312
}
690
691
void
692
emit_single_in_line(decl, flag, rel)
693
	declaration *decl;
694
	int     flag;
695
	relation rel;
696
{
697
	char   *upp_case;
698
	int     freed = 0;
699
700
624
	if (flag == PUT)
701
156
		fprintf(fout, "\t\tIXDR_PUT_");
702
	else
703
156
		if (rel == REL_ALIAS)
704
140
			fprintf(fout, "\t\tobjp->%s = IXDR_GET_", decl->name);
705
		else
706
16
			fprintf(fout, "\t\t*genp++ = IXDR_GET_");
707
708
312
	upp_case = upcase(decl->type);
709
710
	/* hack  - XX */
711
312
	if (strcmp(upp_case, "INT") == 0) {
712
88
		free(upp_case);
713
		freed = 1;
714
		upp_case = "LONG";
715
88
	}
716
312
	if (strcmp(upp_case, "U_INT") == 0) {
717
216
		free(upp_case);
718
		freed = 1;
719
		upp_case = "U_LONG";
720
216
	}
721
312
	if (flag == PUT)
722
156
		if (rel == REL_ALIAS)
723
140
			fprintf(fout, "%s(buf, objp->%s);\n", upp_case, decl->name);
724
		else
725
16
			fprintf(fout, "%s(buf, *genp++);\n", upp_case);
726
727
	else
728
156
		fprintf(fout, "%s(buf);\n", upp_case);
729
312
	if (!freed)
730
8
		free(upp_case);
731
312
}
732
733
char *
734
upcase(str)
735
	char   *str;
736
{
737
	char   *ptr, *hptr;
738
739
624
	ptr = malloc(strlen(str)+1);
740
312
	if (ptr == (char *) NULL) {
741
		fprintf(stderr, "malloc failed\n");
742
		exit(1);
743
	}
744
745
	hptr = ptr;
746
3376
	while (*str != '\0')
747
1376
		*ptr++ = toupper((unsigned char)*str++);
748
749
312
	*ptr = '\0';
750
312
	return (hptr);
751
}