diff options
Diffstat (limited to 'usr.bin/rpcgen/rpc_util.h')
-rw-r--r-- | usr.bin/rpcgen/rpc_util.h | 134 |
1 files changed, 115 insertions, 19 deletions
diff --git a/usr.bin/rpcgen/rpc_util.h b/usr.bin/rpcgen/rpc_util.h index dcca92f..259860f 100644 --- a/usr.bin/rpcgen/rpc_util.h +++ b/usr.bin/rpcgen/rpc_util.h @@ -25,34 +25,87 @@ * Sun Microsystems, Inc. * 2550 Garcia Avenue * Mountain View, California 94043 - * - * from: @(#)rpc_util.h 1.6 87/06/24 (C) 1987 SMI - * from: @(#)rpc_util.h 2.1 88/08/01 4.0 RPCSRC - * $Id: rpc_util.h,v 1.1 1993/09/13 23:20:21 jtc Exp $ */ +#pragma ident "@(#)rpc_util.h 1.16 94/05/15 SMI" + +/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */ +/* All Rights Reserved */ + +/* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T */ +/* The copyright notice above does not evidence any */ +/* actual or intended publication of such source code. */ + + +/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++ +* PROPRIETARY NOTICE (Combined) +* +* This source code is unpublished proprietary information +* constituting, or derived under license from AT&T's UNIX(r) System V. +* In addition, portions of such source code were derived from Berkeley +* 4.3 BSD under license from the Regents of the University of +* California. +* +* +* +* Copyright Notice +* +* Notice of copyright on this source code product does not indicate +* publication. +* +* (c) 1986,1987,1988.1989 Sun Microsystems, Inc +* (c) 1983,1984,1985,1986,1987,1988,1989 AT&T. +* All rights reserved. +*/ + +/* @(#)rpc_util.h 1.5 90/08/29 (C) 1987 SMI */ /* * rpc_util.h, Useful definitions for the RPC protocol compiler - * Copyright (C) 1987, Sun Microsystems, Inc. */ -extern char *malloc(); +#include <sys/types.h> +#include <stdlib.h> -#define alloc(size) malloc((unsigned)(size)) -#define ALLOC(object) (object *) malloc(sizeof(object)) +#define alloc(size) malloc((unsigned)(size)) +#define ALLOC(object) (object *) malloc(sizeof(object)) -#define s_print (void) sprintf -#define f_print (void) fprintf +#define s_print (void) sprintf +#define f_print (void) fprintf struct list { - char *val; + definition *val; struct list *next; }; typedef struct list list; +struct xdrfunc { + char *name; + int pointerp; + struct xdrfunc *next; +}; +typedef struct xdrfunc xdrfunc; + +struct commandline { + int cflag; /* xdr C routines */ + int hflag; /* header file */ + int lflag; /* client side stubs */ + int mflag; /* server side stubs */ + int nflag; /* netid flag */ + int sflag; /* server stubs for the given transport */ + int tflag; /* dispatch Table file */ + int Ssflag; /* produce server sample code */ + int Scflag; /* produce client sample code */ + int makefileflag; /* Generate a template Makefile */ + char *infile; /* input module name */ + char *outfile; /* output module name */ +}; + +#define PUT 1 +#define GET 2 + /* * Global variables */ -#define MAXLINESIZE 1024 +#define MAXLINESIZE 1024 extern char curline[MAXLINESIZE]; extern char *where; extern int linenum; @@ -63,21 +116,53 @@ extern FILE *fin; extern list *defined; + +extern bas_type *typ_list_h; +extern bas_type *typ_list_t; +extern xdrfunc *xdrfunc_head, *xdrfunc_tail; + +/* + * All the option flags + */ +extern int inetdflag; +extern int pmflag; +extern int tblflag; +extern int logflag; +extern int newstyle; +extern int Cflag; /* ANSI-C/C++ flag */ +extern int CCflag; /* C++ flag */ +extern int tirpcflag; /* flag for generating tirpc code */ +extern int inline; /* if this is 0, then do not generate inline code */ +extern int mtflag; + +/* + * Other flags related with inetd jumpstart. + */ +extern int indefinitewait; +extern int exitnow; +extern int timerflag; + +extern int nonfatalerrors; + +extern pid_t childpid; + /* * rpc_util routines */ void storeval(); -#define STOREVAL(list,item) \ - storeval(list,(char *)item) +#define STOREVAL(list,item) \ + storeval(list,item) -char *findval(); +definition *findval(); -#define FINDVAL(list,item,finder) \ - findval(list, (char *) item, finder) +#define FINDVAL(list,item,finder) \ + findval(list, item, finder) char *fixtype(); char *stringfix(); +char *locase(); +void pvname_svc(); void pvname(); void ptype(); int isvectordef(); @@ -88,7 +173,7 @@ void expected2(); void expected3(); void tabify(); void record_open(); - +bas_type *find_type(); /* * rpc_cout routines */ @@ -99,6 +184,8 @@ void emit(); * rpc_hout routines */ void print_datadef(); +void print_funcdef(); +void print_xdr_func_def(); /* * rpc_svcout routines @@ -106,8 +193,17 @@ void print_datadef(); void write_most(); void write_register(); void write_rest(); - +void write_programs(); +void write_svc_aux(); +void write_inetd_register(); +void write_netid_register(); +void write_nettype_register(); /* * rpc_clntout routines */ void write_stubs(); + +/* + * rpc_tblout routines + */ +void write_tables(); |