1 1.10 christos /* $NetBSD: rpc_scan.h,v 1.10 2015/05/09 21:44:47 christos Exp $ */ 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.3 pk * program developed by the user or with the express written consent of 9 1.3 pk * Sun Microsystems, Inc. 10 1.3 pk * 11 1.1 glass * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE 12 1.1 glass * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR 13 1.1 glass * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE. 14 1.3 pk * 15 1.1 glass * Sun RPC is provided with no support and without any obligation on the 16 1.1 glass * part of Sun Microsystems, Inc. to assist in its use, correction, 17 1.1 glass * modification or enhancement. 18 1.3 pk * 19 1.1 glass * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE 20 1.1 glass * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC 21 1.1 glass * OR ANY PART THEREOF. 22 1.3 pk * 23 1.1 glass * In no event will Sun Microsystems, Inc. be liable for any lost revenue 24 1.1 glass * or profits or other special, indirect and consequential damages, even if 25 1.1 glass * Sun has been advised of the possibility of such damages. 26 1.3 pk * 27 1.1 glass * Sun Microsystems, Inc. 28 1.1 glass * 2550 Garcia Avenue 29 1.1 glass * Mountain View, California 94043 30 1.1 glass */ 31 1.1 glass 32 1.3 pk /* @(#)rpc_scan.h 1.3 90/08/29 (C) 1987 SMI */ 33 1.5 tv 34 1.7 lukem #if HAVE_NBTOOL_CONFIG_H 35 1.7 lukem #include "nbtool_config.h" 36 1.5 tv #endif 37 1.3 pk 38 1.1 glass /* 39 1.1 glass * rpc_scan.h, Definitions for the RPCL scanner 40 1.1 glass */ 41 1.1 glass 42 1.1 glass /* 43 1.1 glass * kinds of tokens 44 1.1 glass */ 45 1.1 glass enum tok_kind { 46 1.1 glass TOK_IDENT, 47 1.3 pk TOK_CHARCONST, 48 1.1 glass TOK_STRCONST, 49 1.1 glass TOK_LPAREN, 50 1.1 glass TOK_RPAREN, 51 1.1 glass TOK_LBRACE, 52 1.1 glass TOK_RBRACE, 53 1.1 glass TOK_LBRACKET, 54 1.1 glass TOK_RBRACKET, 55 1.1 glass TOK_LANGLE, 56 1.1 glass TOK_RANGLE, 57 1.1 glass TOK_STAR, 58 1.1 glass TOK_COMMA, 59 1.1 glass TOK_EQUAL, 60 1.1 glass TOK_COLON, 61 1.1 glass TOK_SEMICOLON, 62 1.1 glass TOK_CONST, 63 1.1 glass TOK_STRUCT, 64 1.1 glass TOK_UNION, 65 1.1 glass TOK_SWITCH, 66 1.1 glass TOK_CASE, 67 1.1 glass TOK_DEFAULT, 68 1.1 glass TOK_ENUM, 69 1.1 glass TOK_TYPEDEF, 70 1.1 glass TOK_INT, 71 1.1 glass TOK_SHORT, 72 1.1 glass TOK_LONG, 73 1.8 ginsbach TOK_HYPER, 74 1.1 glass TOK_UNSIGNED, 75 1.1 glass TOK_FLOAT, 76 1.1 glass TOK_DOUBLE, 77 1.8 ginsbach TOK_QUAD, 78 1.1 glass TOK_OPAQUE, 79 1.1 glass TOK_CHAR, 80 1.1 glass TOK_STRING, 81 1.1 glass TOK_BOOL, 82 1.1 glass TOK_VOID, 83 1.1 glass TOK_PROGRAM, 84 1.1 glass TOK_VERSION, 85 1.1 glass TOK_EOF 86 1.1 glass }; 87 1.1 glass typedef enum tok_kind tok_kind; 88 1.1 glass 89 1.1 glass /* 90 1.1 glass * a token 91 1.1 glass */ 92 1.1 glass struct token { 93 1.1 glass tok_kind kind; 94 1.9 dholland const char *str; 95 1.1 glass }; 96 1.1 glass typedef struct token token; 97 1.1 glass 98 1.1 glass 99 1.1 glass /* 100 1.1 glass * routine interface 101 1.1 glass */ 102 1.10 christos void scan(tok_kind, token *); 103 1.10 christos void scan2(tok_kind, tok_kind, token *); 104 1.10 christos void scan3(tok_kind, tok_kind, tok_kind, token *); 105 1.10 christos void scan_num(token *); 106 1.10 christos void peek(token *); 107 1.10 christos int peekscan(tok_kind, token *); 108 1.10 christos void get_token(token *); 109