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 130typedef struct ndblock *ndptr; 131 132struct 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 142struct keyblk { 143 const char *knam; /* keyword name */ 144 int ktyp; /* keyword type */ 145}; 146 147typedef union { /* stack structure */ 148 int sfra; /* frame entry */ 149 char *sstr; /* string entry */ 150} stae; 151 152struct 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