xref: /netbsd-src/usr.bin/rpcgen/rpc_util.h (revision 2a399c6883d870daece976daec6ffa7bb7f934ce)
1 /*	$NetBSD: rpc_util.h,v 1.4 1997/10/11 21:01:58 christos Exp $	*/
2 /*
3  * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
4  * unrestricted use provided that this legend is included on all tape
5  * media and as a part of the software program in whole or part.  Users
6  * may copy or modify Sun RPC without charge, but are not authorized
7  * to license or distribute it to anyone else except as part of a product or
8  * program developed by the user or with the express written consent of
9  * Sun Microsystems, Inc.
10  *
11  * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
12  * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
13  * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
14  *
15  * Sun RPC is provided with no support and without any obligation on the
16  * part of Sun Microsystems, Inc. to assist in its use, correction,
17  * modification or enhancement.
18  *
19  * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
20  * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
21  * OR ANY PART THEREOF.
22  *
23  * In no event will Sun Microsystems, Inc. be liable for any lost revenue
24  * or profits or other special, indirect and consequential damages, even if
25  * Sun has been advised of the possibility of such damages.
26  *
27  * Sun Microsystems, Inc.
28  * 2550 Garcia Avenue
29  * Mountain View, California  94043
30  */
31 
32 /*      @(#)rpc_util.h  1.5  90/08/29  (C) 1987 SMI   */
33 
34 /*
35  * rpc_util.h, Useful definitions for the RPC protocol compiler
36  */
37 
38 #define alloc(size)		(void *)malloc((unsigned)(size))
39 #define ALLOC(object)   (object *) malloc(sizeof(object))
40 
41 #define s_print	(void) sprintf
42 #define f_print (void) fprintf
43 
44 struct list {
45 	definition *val;
46 	struct list *next;
47 };
48 typedef struct list list;
49 
50 #define PUT 1
51 #define GET 2
52 
53 /*
54  * Global variables
55  */
56 #define MAXLINESIZE 1024
57 extern char curline[MAXLINESIZE];
58 extern char *where;
59 extern int linenum;
60 
61 extern char *infilename;
62 extern FILE *fout;
63 extern FILE *fin;
64 
65 extern list *defined;
66 
67 
68 extern bas_type *typ_list_h;
69 extern bas_type *typ_list_t;
70 
71 /*
72  * All the option flags
73  */
74 extern int inetdflag;
75 extern int pmflag;
76 extern int tblflag;
77 extern int logflag;
78 extern int newstyle;
79 extern int Cflag;     /* C++ flag */
80 extern int tirpcflag; /* flag for generating tirpc code */
81 extern int doinline; /* if this is 0, then do not generate inline code */
82 extern int callerflag;
83 
84 /*
85  * Other flags related with inetd jumpstart.
86  */
87 extern int indefinitewait;
88 extern int exitnow;
89 extern int timerflag;
90 
91 extern int nonfatalerrors;
92 
93 /*
94  * rpc_util routines
95  */
96 
97 #define STOREVAL(list,item)	\
98 	storeval(list,item)
99 
100 #define FINDVAL(list,item,finder) \
101 	findval(list, item, finder)
102 
103 void reinitialize __P((void));
104 int streq __P((char *, char *));
105 definition *findval __P((list *, char *, int (*)(definition *, char *)));
106 void storeval __P((list **, definition *));
107 char *fixtype __P((char *));
108 char *stringfix __P((char *));
109 void ptype __P((char *, char *, int));
110 int isvectordef __P((char *, relation));
111 char *locase __P((char *));
112 void pvname_svc __P((char *, char *));
113 void pvname __P((char *, char *));
114 void error __P((char *));
115 void crash __P((void));
116 void record_open __P((char *));
117 void expected1 __P((tok_kind));
118 void expected2 __P((tok_kind, tok_kind ));
119 void expected3 __P((tok_kind, tok_kind, tok_kind));
120 void tabify __P((FILE *, int));
121 void record_open __P((char *));
122 char *make_argname __P((char *, char *));
123 void add_type __P((int, char *));
124 bas_type *find_type __P((char *));
125 /*
126  * rpc_cout routines
127  */
128 void emit __P((definition *));
129 void emit_inline __P((declaration *, int));
130 void emit_single_in_line __P((declaration *, int, relation));
131 char *upcase __P((char *));
132 
133 /*
134  * rpc_hout routines
135  */
136 
137 void print_datadef __P((definition *));
138 void print_funcdef __P((definition *));
139 void pxdrfuncdecl __P((char *, int));
140 void pprocdef __P((proc_list *, version_list *, char *, int, int));
141 void pdeclaration __P((char *, declaration *, int, char *));
142 
143 /*
144  * rpc_svcout routines
145  */
146 void write_most __P((char *, int, int));
147 void write_netid_register __P((char *));
148 void write_nettype_register __P((char *));
149 void write_rest __P((void));
150 void write_programs __P((char *));
151 int nullproc __P((proc_list *));
152 void write_svc_aux __P((int));
153 void write_msg_out __P((void));
154 void write_inetd_register __P((char *));
155 
156 /*
157  * rpc_clntout routines
158  */
159 void write_stubs __P((void));
160 void printarglist __P((proc_list *, char *, char *));
161 
162 
163 /*
164  * rpc_tblout routines
165  */
166 void write_tables __P((void));
167 
168 /*
169  * rpc_sample routines
170  */
171 void write_sample_svc __P((definition *));
172 int write_sample_clnt __P((definition *));
173 void add_sample_msg __P((void));
174 void write_sample_clnt_main __P((void));
175