SCCSID(@
(#)macro.c 3.20 2/3/83);
** EXPAND -- macro expand a string using $x escapes.
** s -- the string to expand.
** buf -- the place to put the expansion.
** buflim -- the buffer limit, i.e., the address
** of the last usable position in buf.
** e -- envelope in which to work.
** The handling of $$ (to get one dollar) is rather bizarre,
** especially if there should be another macro
** expansion in the same string.
expand(s
, buf
, buflim
, e
)
bool skipping
; /* set if conditionally skipping output */
bool gotone
= FALSE
; /* set if any expansion done */
register char *xp
= xbuf
;
** Check for non-ordinary (special?) character.
** 'q' will be the interpolated quantity.
case CONDIF
: /* see if var set */
skipping
= macvalue(c
, e
) == NULL
;
case CONDELSE
: /* change state of skipping */
case CONDFI
: /* stop skipping */
case '$': /* macro interpolation */
q
= macvalue(c
& 0177, e
);
** Interpolate q or output one character
while (xp
< &xbuf
[sizeof xbuf
])
/* recurse as appropriate */
expand(xbuf
, buf
, buflim
, e
);
for (q
= buf
, xp
= xbuf
; xp
!= '\0' && q
< buflim
-1; )
** DEFINE -- define a macro.
** this would be better done using a #define macro.
** e -- the envelope to store the definition in.
** e->e_macro[n] is defined.
** There is one macro for each ASCII character,
** although they are not all used. The currently
** $a date in ARPANET format (preferring the Date: line
** $b the current date (as opposed to the date as found
** the message) in ARPANET format
** $d (current) date in UNIX (ctime) format
** $e the SMTP entry message+
** $g translated from address
** $j official SMTP hostname, used in messages+
** $l UNIX-style from line+
** $n name of sendmail ("MAILER-DAEMON" on local
** $o delimiters ("operators") for address tokens+
** $p my process id in decimal
** $q the string that becomes an address -- this is
** normally used to combine $g & $x.
** $r protocol used to talk to sender
** $t the current time in seconds since 1/1/1970
** $v version number of sendmail
** $w our host name (if it can be determined)
** $x signature (full name) of from person
** $y the tty id of our terminal
** $z home directory of to person
** Macros marked with + must be defined in the
** configuration file and are used internally, but
** There are also some macros that can be used
** arbitrarily to make the configuration file
** cleaner. In general all upper-case letters
printf("define(%c as ", n
);
e
->e_macro
[n
& 0177] = v
;
** MACVALUE -- return uninterpreted value of a macro.
** n -- the name of the macro.
register char *p
= e
->e_macro
[n
];