2003-10-06 03:27:59 +08:00
|
|
|
char rcsid_operator[] = "$Id$";
|
|
|
|
|
|
|
|
#include "b.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
int max_arity = -1;
|
|
|
|
|
|
|
|
List operators;
|
|
|
|
List leaves;
|
|
|
|
|
|
|
|
Operator
|
|
|
|
newOperator(name, num, arity) char *name; OperatorNum num; ArityNum arity;
|
|
|
|
{
|
2005-04-22 12:13:13 +08:00
|
|
|
Operator op;
|
2003-10-06 03:27:59 +08:00
|
|
|
|
2005-04-22 12:13:13 +08:00
|
|
|
assert(arity <= MAX_ARITY);
|
|
|
|
op = (Operator) zalloc(sizeof(struct operator));
|
|
|
|
assert(op);
|
|
|
|
op->name = name;
|
|
|
|
op->num = num;
|
|
|
|
op->arity = arity;
|
2003-10-06 03:27:59 +08:00
|
|
|
|
2005-04-22 12:13:13 +08:00
|
|
|
operators = newList(op, operators);
|
2003-10-06 03:27:59 +08:00
|
|
|
|
2005-04-22 12:13:13 +08:00
|
|
|
return op;
|
2003-10-06 03:27:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
dumpOperator_s(op) Operator op;
|
|
|
|
{
|
2005-04-22 12:13:13 +08:00
|
|
|
printf("Op: %s(%d)=%d\n", op->name, op->arity, op->num);
|
2003-10-06 03:27:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
dumpOperator(op, full) Operator op; int full;
|
|
|
|
{
|
2005-04-22 12:13:13 +08:00
|
|
|
dumpOperator_s(op);
|
|
|
|
if (full) {
|
|
|
|
dumpTable(op->table, 0);
|
|
|
|
}
|
2003-10-06 03:27:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
dumpOperator_l(op) Operator op;
|
|
|
|
{
|
2005-04-22 12:13:13 +08:00
|
|
|
dumpOperator(op, 1);
|
2003-10-06 03:27:59 +08:00
|
|
|
}
|
|
|
|
|