mdef.h revision 1.12 1 /* $NetBSD: mdef.h,v 1.12 2003/08/07 11:14:33 agc Exp $ */
2 /* $OpenBSD: mdef.h,v 1.21 2001/09/27 11:40:33 espie Exp $ */
3
4 /*
5 * Copyright (c) 1989, 1993
6 * The Regents of the University of California. All rights reserved.
7 *
8 * This code is derived from software contributed to Berkeley by
9 * Ozan Yigit at York University.
10 *
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
13 * are met:
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions and the following disclaimer.
16 * 2. Redistributions in binary form must reproduce the above copyright
17 * notice, this list of conditions and the following disclaimer in the
18 * documentation and/or other materials provided with the distribution.
19 * 3. Neither the name of the University nor the names of its contributors
20 * may be used to endorse or promote products derived from this software
21 * without specific prior written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 * SUCH DAMAGE.
34 *
35 * @(#)mdef.h 8.1 (Berkeley) 6/6/93
36 */
37
38 #define MACRTYPE 1
39 #define DEFITYPE 2
40 #define EXPRTYPE 3
41 #define SUBSTYPE 4
42 #define IFELTYPE 5
43 #define LENGTYPE 6
44 #define CHNQTYPE 7
45 #define SYSCTYPE 8
46 #define UNDFTYPE 9
47 #define INCLTYPE 10
48 #define SINCTYPE 11
49 #define PASTTYPE 12
50 #define SPASTYPE 13
51 #define INCRTYPE 14
52 #define IFDFTYPE 15
53 #define PUSDTYPE 16
54 #define POPDTYPE 17
55 #define SHIFTYPE 18
56 #define DECRTYPE 19
57 #define DIVRTYPE 20
58 #define UNDVTYPE 21
59 #define DIVNTYPE 22
60 #define MKTMTYPE 23
61 #define ERRPTYPE 24
62 #define M4WRTYPE 25
63 #define TRNLTYPE 26
64 #define DNLNTYPE 27
65 #define DUMPTYPE 28
66 #define CHNCTYPE 29
67 #define INDXTYPE 30
68 #define SYSVTYPE 31
69 #define EXITTYPE 32
70 #define DEFNTYPE 33
71 #define SELFTYPE 34
72 #define INDIRTYPE 35
73 #define BUILTINTYPE 36
74 #define PATSTYPE 37
75 #define FILENAMETYPE 38
76 #define LINETYPE 39
77 #define REGEXPTYPE 40
78 #define ESYSCMDTYPE 41
79 #define TRACEONTYPE 42
80 #define TRACEOFFTYPE 43
81
82
83 #define TYPEMASK 63 /* Keep bits really corresponding to a type. */
84 #define RECDEF 256 /* Pure recursive def, don't expand it */
85 #define NOARGS 512 /* builtin needs no args */
86 #define NEEDARGS 1024 /* mark builtin that need args with this */
87
88 /*
89 * m4 special characters
90 */
91
92 #define ARGFLAG '$'
93 #define LPAREN '('
94 #define RPAREN ')'
95 #define LQUOTE '`'
96 #define RQUOTE '\''
97 #define COMMA ','
98 #define SCOMMT '#'
99 #define ECOMMT '\n'
100
101 #ifdef msdos
102 #define system(str) (-1)
103 #endif
104
105 /*
106 * other important constants
107 */
108
109 #define EOS '\0'
110 #define MAXINP 10 /* maximum include files */
111 #define MAXOUT 10 /* maximum # of diversions */
112 #define BUFSIZE 4096 /* starting size of pushback buffer */
113 #define INITSTACKMAX 4096 /* starting size of call stack */
114 #define STRSPMAX 4096 /* starting size of string space */
115 #define MAXTOK 512 /* maximum chars in a tokn */
116 #define HASHSIZE 199 /* maximum size of hashtab */
117 #define MAXCCHARS 5 /* max size of comment/quote delim */
118
119 #define ALL 1
120 #define TOP 0
121
122 #define TRUE 1
123 #define FALSE 0
124 #define cycle for(;;)
125
126 /*
127 * m4 data structures
128 */
129
130 typedef struct ndblock *ndptr;
131
132 struct ndblock { /* hastable structure */
133 char *name; /* entry name.. */
134 char *defn; /* definition.. */
135 unsigned int type; /* type of the entry.. */
136 unsigned int hv; /* hash function value.. */
137 ndptr nxtptr; /* link to next entry.. */
138 };
139
140 #define nil ((ndptr) 0)
141
142 struct keyblk {
143 const char *knam; /* keyword name */
144 int ktyp; /* keyword type */
145 };
146
147 typedef union { /* stack structure */
148 int sfra; /* frame entry */
149 char *sstr; /* string entry */
150 } stae;
151
152 struct input_file {
153 FILE *file;
154 char *name;
155 unsigned long lineno;
156 int c;
157 };
158
159 #define CURRENT_NAME (infile[ilevel].name)
160 #define CURRENT_LINE (infile[ilevel].lineno)
161 /*
162 * macros for readibility and/or speed
163 *
164 * gpbc() - get a possibly pushed-back character
165 * pushf() - push a call frame entry onto stack
166 * pushs() - push a string pointer onto stack
167 */
168 #define gpbc() (bp > bufbase) ? *--bp : obtain_char(infile+ilevel)
169 #define pushf(x) \
170 do { \
171 if (++sp == STACKMAX) \
172 enlarge_stack();\
173 mstack[sp].sfra = (x); \
174 sstack[sp] = 0; \
175 } while (0)
176
177 #define pushs(x) \
178 do { \
179 if (++sp == STACKMAX) \
180 enlarge_stack();\
181 mstack[sp].sstr = (x); \
182 sstack[sp] = 1; \
183 } while (0)
184
185 #define pushs1(x) \
186 do { \
187 if (++sp == STACKMAX) \
188 enlarge_stack();\
189 mstack[sp].sstr = (x); \
190 sstack[sp] = 0; \
191 } while (0)
192
193 /*
194 * . .
195 * | . | <-- sp | . |
196 * +-------+ +-----+
197 * | arg 3 ----------------------->| str |
198 * +-------+ | . |
199 * | arg 2 ---PREVEP-----+ .
200 * +-------+ |
201 * . | | |
202 * +-------+ | +-----+
203 * | plev | PARLEV +-------->| str |
204 * +-------+ | . |
205 * | type | CALTYP .
206 * +-------+
207 * | prcf ---PREVFP--+
208 * +-------+ |
209 * | . | PREVSP |
210 * . |
211 * +-------+ |
212 * | <----------+
213 * +-------+
214 *
215 */
216 #define PARLEV (mstack[fp].sfra)
217 #define CALTYP (mstack[fp-1].sfra)
218 #define PREVEP (mstack[fp+3].sstr)
219 #define PREVSP (fp-3)
220 #define PREVFP (mstack[fp-2].sfra)
221