277 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			277 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
| /*
 | |
|  * mdef.h
 | |
|  * Facility: m4 macro processor
 | |
|  * by: oz
 | |
|  */
 | |
| 
 | |
| 
 | |
| #define unix	1	/* (kjb) */
 | |
| 
 | |
| #ifndef unix
 | |
| #define unix 0
 | |
| #endif 
 | |
| 
 | |
| #ifndef vms
 | |
| #define vms 0
 | |
| #endif
 | |
| 
 | |
| #if vms
 | |
| 
 | |
| #include stdio
 | |
| #include ctype
 | |
| #include signal
 | |
| 
 | |
| #else 
 | |
| 
 | |
| #include <sys/types.h>
 | |
| #include <ctype.h>
 | |
| #include <signal.h>
 | |
| #include <string.h>
 | |
| #include <stdlib.h>
 | |
| #include <unistd.h>
 | |
| #include <stdio.h>
 | |
| 
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  *
 | |
|  * m4 constants..
 | |
|  *
 | |
|  */
 | |
|  
 | |
| #define MACRTYPE        1
 | |
| #define DEFITYPE        2
 | |
| #define EXPRTYPE        3
 | |
| #define SUBSTYPE        4
 | |
| #define IFELTYPE        5
 | |
| #define LENGTYPE        6
 | |
| #define CHNQTYPE        7
 | |
| #define SYSCTYPE        8
 | |
| #define UNDFTYPE        9
 | |
| #define INCLTYPE        10
 | |
| #define SINCTYPE        11
 | |
| #define PASTTYPE        12
 | |
| #define SPASTYPE        13
 | |
| #define INCRTYPE        14
 | |
| #define IFDFTYPE        15
 | |
| #define PUSDTYPE        16
 | |
| #define POPDTYPE        17
 | |
| #define SHIFTYPE        18
 | |
| #define DECRTYPE        19
 | |
| #define DIVRTYPE        20
 | |
| #define UNDVTYPE        21
 | |
| #define DIVNTYPE        22
 | |
| #define MKTMTYPE        23
 | |
| #define ERRPTYPE        24
 | |
| #define M4WRTYPE        25
 | |
| #define TRNLTYPE        26
 | |
| #define DNLNTYPE        27
 | |
| #define DUMPTYPE        28
 | |
| #define CHNCTYPE        29
 | |
| #define INDXTYPE        30
 | |
| #define SYSVTYPE        31
 | |
| #define EXITTYPE        32
 | |
| #define DEFNTYPE        33
 | |
|  
 | |
| #define STATIC          128
 | |
| 
 | |
| /*
 | |
|  * m4 special characters
 | |
|  */
 | |
|  
 | |
| #define ARGFLAG         '$'
 | |
| #define LPAREN          '('
 | |
| #define RPAREN          ')'
 | |
| #define LQUOTE          '`'
 | |
| #define RQUOTE          '\''
 | |
| #define COMMA           ','
 | |
| #define SCOMMT          '#'
 | |
| #define ECOMMT          '\n'
 | |
| 
 | |
| /*
 | |
|  * definitions of diversion files. If the name of
 | |
|  * the file is changed, adjust UNIQUE to point to the
 | |
|  * wildcard (*) character in the filename.
 | |
|  */
 | |
| 
 | |
| #if unix
 | |
| #define DIVNAM  "/tmp/m4*XXXXXX"        /* unix diversion files    */
 | |
| #define UNIQUE          7               /* unique char location    */
 | |
| #else
 | |
| #if vms
 | |
| #define DIVNAM  "sys$login:m4*XXXXXX"   /* vms diversion files     */
 | |
| #define UNIQUE          12              /* unique char location    */
 | |
| #else
 | |
| #define DIVNAM	"\M4*XXXXXX"		/* msdos diversion files   */
 | |
| #define	UNIQUE	    3			/* unique char location    */
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * other important constants
 | |
|  */
 | |
| 
 | |
| #define EOS             (char) 0
 | |
| #define MAXINP          10              /* maximum include files   */
 | |
| #define MAXOUT          10              /* maximum # of diversions */
 | |
| #define MAXSTR          512             /* maximum size of string  */
 | |
| #define BUFSIZE         4096            /* size of pushback buffer */
 | |
| #define STACKMAX        1024            /* size of call stack      */
 | |
| #define STRSPMAX        4096            /* size of string space    */
 | |
| #define MAXTOK          MAXSTR          /* maximum chars in a tokn */
 | |
| #define HASHSIZE        199             /* maximum size of hashtab */
 | |
|  
 | |
| #define ALL             1
 | |
| #define TOP             0
 | |
|  
 | |
| #define TRUE            1
 | |
| #define FALSE           0
 | |
| #define cycle           for(;;)
 | |
| 
 | |
| #ifdef VOID
 | |
| #define void            int             /* define if void is void. */
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * m4 data structures
 | |
|  */
 | |
|  
 | |
| typedef struct ndblock *ndptr;
 | |
|  
 | |
| struct ndblock {                /* hastable structure         */
 | |
|         char    *name;          /* entry name..               */
 | |
|         char    *defn;          /* definition..               */
 | |
|         int     type;           /* type of the entry..        */
 | |
|         ndptr   nxtptr;         /* link to next entry..       */
 | |
| };
 | |
|  
 | |
| #define nil     ((ndptr) 0)
 | |
|  
 | |
| struct keyblk {
 | |
|         char    *knam;          /* keyword name */
 | |
|         int     ktyp;           /* keyword type */
 | |
| };
 | |
| 
 | |
| typedef union {			/* stack structure */
 | |
| 	int	sfra;		/* frame entry  */
 | |
| 	char 	*sstr;		/* string entry */
 | |
| } stae;
 | |
| 
 | |
| /*
 | |
|  * macros for readibility and/or speed
 | |
|  *
 | |
|  *      gpbc()  - get a possibly pushed-back character
 | |
|  *      min()   - select the minimum of two elements
 | |
|  *      pushf() - push a call frame entry onto stack
 | |
|  *      pushs() - push a string pointer onto stack
 | |
|  */
 | |
| #define gpbc() 	 (bp > buf) ? *--bp : getc(infile[ilevel])
 | |
| #define min(x,y) ((x > y) ? y : x)
 | |
| #define pushf(x) if (sp < STACKMAX) mstack[++sp].sfra = (x)
 | |
| #define pushs(x) if (sp < STACKMAX) mstack[++sp].sstr = (x)
 | |
| 
 | |
| /*
 | |
|  *	    .				   .
 | |
|  *	|   .	|  <-- sp		|  .  |
 | |
|  *	+-------+			+-----+
 | |
|  *	| arg 3 ----------------------->| str |
 | |
|  *	+-------+			|  .  |
 | |
|  *	| arg 2 ---PREVEP-----+ 	   .
 | |
|  *	+-------+	      |
 | |
|  *	    .		      |		|     |
 | |
|  *	+-------+	      | 	+-----+
 | |
|  *	| plev	|  PARLEV     +-------->| str |
 | |
|  *	+-------+			|  .  |
 | |
|  *	| type	|  CALTYP		   .
 | |
|  *	+-------+
 | |
|  *	| prcf	---PREVFP--+
 | |
|  *	+-------+  	   |
 | |
|  *	|   .	|  PREVSP  |
 | |
|  *	    .	   	   |
 | |
|  *	+-------+	   |
 | |
|  *	|	<----------+
 | |
|  *	+-------+
 | |
|  *
 | |
|  */
 | |
| #define PARLEV  (mstack[fp].sfra)
 | |
| #define CALTYP  (mstack[fp-1].sfra)
 | |
| #define PREVEP	(mstack[fp+3].sstr)
 | |
| #define PREVSP	(fp-3)
 | |
| #define PREVFP	(mstack[fp-2].sfra)
 | |
| 
 | |
| /* function prototypes */
 | |
| 
 | |
| /* eval.c */
 | |
| 
 | |
| _PROTOTYPE(void eval, (char *argv [], int argc, int td ));
 | |
| 
 | |
| /* expr.c */
 | |
| 
 | |
| _PROTOTYPE(int expr, (char *expbuf ));
 | |
| _PROTOTYPE(int query, (void));
 | |
| _PROTOTYPE(int lor, (void));
 | |
| _PROTOTYPE(int land, (void));
 | |
| _PROTOTYPE(int bor, (void));
 | |
| _PROTOTYPE(int bxor, (void));
 | |
| _PROTOTYPE(int band, (void));
 | |
| _PROTOTYPE(int eql, (void));
 | |
| _PROTOTYPE(int relat, (void));
 | |
| _PROTOTYPE(int shift, (void));
 | |
| _PROTOTYPE(int primary, (void));
 | |
| _PROTOTYPE(int term, (void));
 | |
| _PROTOTYPE(int unary, (void));
 | |
| _PROTOTYPE(int factor, (void));
 | |
| _PROTOTYPE(int constant, (void));
 | |
| _PROTOTYPE(int num, (void));
 | |
| _PROTOTYPE(int geteql, (void));
 | |
| _PROTOTYPE(int getrel, (void));
 | |
| _PROTOTYPE(int skipws, (void));
 | |
| _PROTOTYPE(int experr, (char *msg ));
 | |
| 
 | |
| /* look.c */
 | |
| 
 | |
| _PROTOTYPE(int hash, (char *name ));
 | |
| _PROTOTYPE(ndptr lookup, (char *name ));
 | |
| _PROTOTYPE(ndptr addent, (char *name ));
 | |
| _PROTOTYPE(void remhash, (char *name, int all ));
 | |
| _PROTOTYPE(void freent, (ndptr p ));
 | |
| 
 | |
| /* main.c */
 | |
| 
 | |
| _PROTOTYPE(int main, (int argc, char *argv []));
 | |
| _PROTOTYPE(void macro, (void));
 | |
| _PROTOTYPE(ndptr inspect, (char *tp ));
 | |
| _PROTOTYPE(void initm4, (void));
 | |
| _PROTOTYPE(void initkwds, (void));
 | |
| 
 | |
| /* misc.c */
 | |
| 
 | |
| _PROTOTYPE(int indx, (char *s1, char *s2 ));
 | |
| _PROTOTYPE(void putback, (int c ));
 | |
| _PROTOTYPE(void pbstr, (char *s ));
 | |
| _PROTOTYPE(void pbnum, (int n ));
 | |
| _PROTOTYPE(void chrsave, (int c ));
 | |
| _PROTOTYPE(void getdiv, (int ind ));
 | |
| _PROTOTYPE(void error, (char *s ));
 | |
| _PROTOTYPE(void onintr, (int s ));
 | |
| _PROTOTYPE(void killdiv, (void));
 | |
| _PROTOTYPE(char *strsave, (char *s ));
 | |
| _PROTOTYPE(void usage, (void));
 | |
| 
 | |
| /* serv.c */
 | |
| 
 | |
| _PROTOTYPE(void expand, (char *argv [], int argc ));
 | |
| _PROTOTYPE(void dodefine, (char *name, char *defn ));
 | |
| _PROTOTYPE(void dodefn, (char *name ));
 | |
| _PROTOTYPE(void dopushdef, (char *name, char *defn ));
 | |
| _PROTOTYPE(void dodump, (char *argv [], int argc ));
 | |
| _PROTOTYPE(void doifelse, (char *argv [], int argc ));
 | |
| _PROTOTYPE(int doincl, (char *ifile ));
 | |
| _PROTOTYPE(int dopaste, (char *pfile ));
 | |
| _PROTOTYPE(void dochq, (char *argv [], int argc ));
 | |
| _PROTOTYPE(void dochc, (char *argv [], int argc ));
 | |
| _PROTOTYPE(void dodiv, (int n ));
 | |
| _PROTOTYPE(void doundiv, (char *argv [], int argc ));
 | |
| _PROTOTYPE(void dosub, (char *argv [], int argc ));
 | |
| _PROTOTYPE(void map, (char *dest, char *src, char *from, char *to ));
 | 
