home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Club Amiga de Montreal - CAM
/
CAM_CD_1.iso
/
files
/
342a.lha
/
make
/
macro.c
< prev
next >
Wrap
C/C++ Source or Header
|
1990-02-10
|
3KB
|
147 lines
/*
* Macro control for make
*/
#include "h.h"
#undef strcmp /*OIS*0.80*/
struct macro *macrohead;
struct macro *
getmp(name)
register char *name;
{
register struct macro *rp;
for (rp = macrohead; rp; rp = rp->m_next)
if (strcmp(name, rp->m_name) == 0)
return rp;
return (struct macro *) 0;
}
char *
getmacro(name)
char *name;
{
struct macro *mp;
if (mp = getmp(name))
return mp->m_val;
else
return "";
}
struct macro *
setmacro(name, val)
char *name;
char *val;
{
register struct macro *rp;
register char *cp;
/* Replace macro definition if it exists */
for (rp = macrohead; rp; rp = rp->m_next)
if (strcmp(name, rp->m_name) == 0) {
free(rp->m_val); /* Free space from old */
break;
}
if (!rp) { /* If not defined, allocate space for new */
if ((rp = (struct macro *) malloc(sizeof(struct macro)))
== (struct macro *) 0)
fatal("No memory for macro");
rp->m_next = macrohead;
macrohead = rp;
rp->m_flag = FALSE;
if ((cp = malloc((unsigned) strlen(name) + 1)) == (char *) 0)
fatal("No memory for macro");
strcpy(cp, name);
rp->m_name = cp;
}
if ((cp = malloc((unsigned) strlen(val) + 1)) == (char *) 0)
fatal("No memory for macro");
strcpy(cp, val); /* Copy in new value */
rp->m_val = cp;
return rp;
}
/*
* Do the dirty work for expand
*/
void
doexp(to, from, len, buf)
char **to;
char *from;
int *len;
char *buf;
{
register char *rp;
register char *p;
register char *q;
register struct macro *mp;
rp = from;
p = *to;
while (*rp) {
if (*rp != '$') {
*p++ = *rp++;
(*len)--;
} else {
q = buf;
if (*++rp == '{')
while (*++rp && *rp != '}')
*q++ = *rp;
else if (*rp == '(')
while (*++rp && *rp != ')')
*q++ = *rp;
else if (!*rp) {
*p++ = '$';
break;
} else
*q++ = *rp;
*q = '\0';
if (*rp)
rp++;
if (!(mp = getmp(buf)))
mp = setmacro(buf, "");
if (mp->m_flag)
fatal("Infinitely recursive macro %s", mp->m_name);
mp->m_flag = TRUE;
*to = p;
doexp(to, mp->m_val, len, buf);
p = *to;
mp->m_flag = FALSE;
}
if (*len <= 0)
error("Expanded line too long"); /*OIS*0.80*/
}
*p = '\0';
*to = p;
}
/*
* Expand any macros in str.
*/
void
expand(str)
char *str;
{
static char a[LZ];
static char b[LZ];
char *p = str;
int len = LZ - 1;
strcpy(a, str);
doexp(&p, a, &len, b);
}