* Copyright (c) 1983 Eric P. Allman
* Copyright (c) 1988 Regents of the University of California.
* Redistribution and use in source and binary forms are permitted
* provided that the above copyright notice and this paragraph are
* duplicated in all such forms and that any documentation,
* advertising materials, and other materials related to such
* distribution and use acknowledge that the software was developed
* by the University of California, Berkeley. The name of the
* University may not be used to endorse or promote products derived
* from this software without specific prior written permission.
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
static char sccsid
[] = "@(#)macro.c 5.6 (Berkeley) 1/1/89";
** 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.
expand(s
, buf
, buflim
, e
)
bool skipping
; /* set if conditionally skipping output */
bool recurse
= FALSE
; /* set if recursion required */
for (xp
= xbuf
; *s
!= '\0'; s
++)
** 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 '\001': /* macro interpolation */
q
= macvalue(c
& 0177, e
);
** Interpolate q or output one character
if (skipping
|| xp
>= &xbuf
[sizeof xbuf
])
/* copy to end of q or max space remaining in buf */
while ((c
= *q
++) != '\0' && xp
< &xbuf
[sizeof xbuf
- 1])
if (iscntrl(c
) && !isspace(c
))
/* recurse as appropriate */
expand(xbuf
, buf
, buflim
, e
);
** 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
];