aboutsummaryrefslogtreecommitdiff
path: root/desiredata
diff options
context:
space:
mode:
Diffstat (limited to 'desiredata')
-rw-r--r--desiredata/extra/expr~/vexp.c1927
1 files changed, 480 insertions, 1447 deletions
diff --git a/desiredata/extra/expr~/vexp.c b/desiredata/extra/expr~/vexp.c
index 7d4d7b52..d13682a0 100644
--- a/desiredata/extra/expr~/vexp.c
+++ b/desiredata/extra/expr~/vexp.c
@@ -21,7 +21,6 @@
* Based on Max/ISPW by Miller Puckette.
*
* Authors: Maurizio De Cecco, Francois Dechelle, Enzo Maggi, Norbert Schnell.
- *
*/
/* "expr" was written by Shahrokh Yadegari c. 1989. -msp */
@@ -33,11 +32,9 @@
* new short hand forms for fexpr~
* now $y or $y1 = $y1[-1] and $y2 = $y2[-1]
* --sdy
- *
* July 2002
* fixed bugs introduced in last changes in store and ET_EQ
* --sdy
- *
*/
/*
@@ -78,622 +75,299 @@
char *atoif(char *s, long int *value, long int *type);
-static struct ex_ex *ex_lex(struct expr *expr, long int *n);
-struct ex_ex *ex_match(struct ex_ex *eptr, long int op);
-struct ex_ex *ex_parse(struct expr *expr, struct ex_ex *iptr,
- struct ex_ex *optr, long int *argc);
-struct ex_ex *ex_eval(struct expr *expr, struct ex_ex *eptr,
- struct ex_ex *optr, int i);
+typedef struct ex_ex ex_ex;
+
+static ex_ex *ex_lex(struct expr *expr, long int *n);
+ex_ex *ex_match(ex_ex *eptr, long int op);
+ex_ex *ex_parse(struct expr *expr, ex_ex *iptr, ex_ex *optr, long int *argc);
+ex_ex *ex_eval(struct expr *expr, ex_ex *eptr, ex_ex *optr, int i);
int expr_donew(struct expr *exprr, int ac, t_atom *av);
-struct ex_ex *eval_func(struct expr *expr,struct ex_ex *eptr,
- struct ex_ex *optr, int i);
-struct ex_ex *eval_tab(struct expr *expr, struct ex_ex *eptr,
- struct ex_ex *optr, int i);
-struct ex_ex *eval_var(struct expr *expr, struct ex_ex *eptr,
- struct ex_ex *optr, int i);
-struct ex_ex *eval_store(struct expr *expr, struct ex_ex *eptr,
- struct ex_ex *optr, int i);
-struct ex_ex *eval_sigidx(struct expr *expr, struct ex_ex *eptr,
- struct ex_ex *optr, int i);
-static int cal_sigidx(struct ex_ex *optr, /* The output value */
- int i, float rem_i, /* integer and fractinal part of index */
- int idx, /* index of current fexpr~ processing */
- int vsize, /* vector size */
- float *curvec, float *prevec); /* current and previous table */
+ex_ex *eval_func(struct expr *expr,ex_ex *eptr, ex_ex *optr, int i);
+ex_ex *eval_tab(struct expr *expr, ex_ex *eptr, ex_ex *optr, int i);
+ex_ex *eval_var(struct expr *expr, ex_ex *eptr, ex_ex *optr, int i);
+ex_ex *eval_store(struct expr *expr, ex_ex *eptr, ex_ex *optr, int i);
+ex_ex *eval_sigidx(struct expr *expr, ex_ex *eptr, ex_ex *optr, int i);
+static int cal_sigidx(ex_ex *optr, /* The output value */
+ int i, float rem_i, /* integer and fractinal part of index */
+ int idx, /* index of current fexpr~ processing */
+ int vsize, /* vector size */
+ float *curvec, float *prevec); /* current and previous table */
t_ex_func *find_func(char *s);
void ex_dzdetect(struct expr *expr);
#define MAX_ARGS 10
extern t_ex_func ex_funcs[];
-struct ex_ex nullex;
+ex_ex nullex;
void set_tokens (char *s);
-int getoken (struct expr *expr, struct ex_ex *eptr);
-void ex_print (struct ex_ex *eptr);
-#ifdef MSP
-void atom_string(t_atom *a, char *buf, unsigned int bufsize);
-
-void atom_string(t_atom *a, char *buf, unsigned int bufsize)
-{
- char tbuf[30];
- switch(a->a_type)
- {
- case A_SEMI: strcpy(buf, ";"); break;
- case A_COMMA: strcpy(buf, ","); break;
-#ifdef PD
- case A_POINTER:
- strcpy(buf, "(pointer)");
- break;
-#endif
- case A_FLOAT:
- sprintf(tbuf, "%g", a->a_w.w_float);
- if (strlen(tbuf) < bufsize-1) strcpy(buf, tbuf);
- else if (a->a_w.w_float < 0) strcpy(buf, "-");
- else strcat(buf, "+");
- break;
- case A_LONG:
- sprintf(tbuf, "%d", a->a_w.w_long);
- if (strlen(tbuf) < bufsize-1) strcpy(buf, tbuf);
- else if (a->a_w.w_float < 0) strcpy(buf, "-");
- else strcat(buf, "+");
- break;
- case A_SYMBOL:
- {
- char *sp;
- unsigned int len;
- int quote;
- for (sp = a->a_w.w_symbol->s_name, len = 0, quote = 0; *sp; sp++, len++)
- if (*sp == ';' || *sp == ',' || *sp == '\\' ||
- (*sp == '$' && sp == a->a_w.w_symbol->s_name && sp[1] >= '0'
- && sp[1] <= '9'))
- quote = 1;
- if (quote)
- {
- char *bp = buf, *ep = buf + (bufsize-2);
- sp = a->a_w.w_symbol->s_name;
- while (bp < ep && *sp)
- {
- if (*sp == ';' || *sp == ',' || *sp == '\\' ||
- (*sp == '$' && bp == buf && sp[1] >= '0' && sp[1] <= '9'))
- *bp++ = '\\';
- *bp++ = *sp++;
- }
- if (*sp) *bp++ = '*';
- *bp = 0;
- /* post("quote %s -> %s", a->a_w.w_symbol->s_name, buf); */
- }
- else
- {
- if (len < bufsize-1) strcpy(buf, a->a_w.w_symbol->s_name);
- else
- {
- strncpy(buf, a->a_w.w_symbol->s_name, bufsize - 2);
- strcpy(buf + (bufsize - 2), "*");
- }
- }
- }
- break;
-#ifdef PD
- case A_DOLLAR:
- sprintf(buf, "$%d", a->a_w.w_index);
- break;
- case A_DOLLSYM:
- sprintf(buf, "$%s", a->a_w.w_symbol->s_name);
- break;
-#else /* MAX */
- case A_DOLLAR:
- sprintf(buf, "$%s", a->a_w.w_symbol->s_name);
- break;
-#endif
- default:
- post("atom_string bug");
- }
-}
-#endif /* MSP */
-/*
- * expr_donew -- create a new "expr" object.
- * returns 1 on failure, 0 on success.
- */
-int
-expr_donew(struct expr *expr, int ac, t_atom *av)
-{
- struct ex_ex *list;
- struct ex_ex *ret;
- long max_node = 0; /* maximum number of nodes needed */
+int getoken (struct expr *expr, ex_ex *eptr);
+void ex_print (ex_ex *eptr);
+
+/* create a new "expr" object. returns 1 on failure, 0 on success. */
+int expr_donew(struct expr *expr, int ac, t_atom *av) {
+ ex_ex *list;
+ ex_ex *ret;
+ long max_node = 0; /* maximum number of nodes needed */
char *exp_string;
int exp_strlen;
t_binbuf *b;
int i;
-
memset(expr->exp_var, 0, MAX_VARS * sizeof (*expr->exp_var));
-#ifdef PD
b = binbuf_new();
binbuf_add(b, ac, av);
binbuf_gettext(b, &exp_string, &exp_strlen);
-
-#else /* MSP */
- {
- char *buf = getbytes(0), *newbuf;
- int length = 0;
- char string[250];
- t_atom *ap;
- int indx;
-
- for (ap = av, indx = 0; indx < ac; indx++, ap = ++av) {
- int newlength;
- if ((ap->a_type == A_SEMI || ap->a_type == A_COMMA) &&
- length && buf[length-1] == ' ') length--;
- atom_string(ap, string, 250);
- newlength = length + strlen(string) + 1;
- if (!(newbuf = t_resizebytes(buf, length, newlength))) break;
- buf = newbuf;
- strcpy(buf + length, string);
- length = newlength;
- if (ap->a_type == A_SEMI) buf[length-1] = '\n';
- else buf[length-1] = ' ';
- }
-
- if (length && buf[length-1] == ' ') {
- if (newbuf = t_resizebytes(buf, length, length-1))
- {
- buf = newbuf;
- length--;
- }
- }
- exp_string = buf;
- exp_strlen = length;
- }
-#endif
exp_string = (char *)t_resizebytes(exp_string, exp_strlen,exp_strlen+1);
exp_string[exp_strlen] = 0;
expr->exp_string = exp_string;
expr->exp_str = exp_string;
expr->exp_nexpr = 0;
- ret = (struct ex_ex *) 0;
- /*
- * if ret == 0 it means that we have no expression
- * so we let the pass go through to build a single null stack
- */
+ ret = (ex_ex *) 0;
+ /* if ret == 0 it means that we have no expression so we let the pass go through to build a single null stack */
while (*expr->exp_str || !ret) {
list = ex_lex(expr, &max_node);
- if (!list) { /* syntax error */
- goto error;
- }
- expr->exp_stack[expr->exp_nexpr] =
- (struct ex_ex *)fts_malloc(max_node * sizeof (struct ex_ex));
+ if (!list) goto error;
+ expr->exp_stack[expr->exp_nexpr] = (ex_ex *)fts_malloc(max_node * sizeof(ex_ex));
expr->exp_nexpr++;
- ret = ex_match(list, (long)0);
- if (!ret) /* syntax error */
- goto error;
- ret = ex_parse(expr,
- list, expr->exp_stack[expr->exp_nexpr - 1], (long *)0);
- if (!ret)
- goto error;
+ ret = ex_match(list,0L);
+ if (!ret) goto error;
+ ret = ex_parse(expr, list, expr->exp_stack[expr->exp_nexpr-1], (long *)0);
+ if (!ret) goto error;
}
*ret = nullex;
t_freebytes(exp_string, exp_strlen+1);
- return (0);
-error:
- for (i = 0; i < expr->exp_nexpr; i++) {
- fts_free(expr->exp_stack[i]);
- expr->exp_stack[i] = 0;
- }
+ return 0;
+error: for (i = 0; i < expr->exp_nexpr; i++) {fts_free(expr->exp_stack[i]); expr->exp_stack[i] = 0;}
expr->exp_nexpr = 0;
- if (list)
- fts_free(list);
+ if (list) fts_free(list);
t_freebytes(exp_string, exp_strlen+1);
- return (1);
+ return 1;
}
-/*
- * ex_lex -- This routine is a bit more than a lexical parser since it will
- * also do some syntax checking. It reads the string s and will
- * return a linked list of struct ex_ex.
- * It will also put the number of the nodes in *n.
- */
-struct ex_ex *
-ex_lex(struct expr *expr, long int *n)
-{
- struct ex_ex *list_arr;
- struct ex_ex *exptr;
+/* This routine is a bit more than a lexical parser since it will also do some syntax checking.
+ It reads the string s and will return a linked list of ex_ex. It will also put the number of the nodes in *n. */
+ex_ex *ex_lex(struct expr *expr, long int *n) {
+ ex_ex *list_arr;
+ ex_ex *exptr;
long non = 0; /* number of nodes */
long maxnode = 0;
-
- list_arr = (struct ex_ex *)fts_malloc(sizeof (struct ex_ex) * MINODES);
- if (! list_arr) {
- post("ex_lex: no mem\n");
- return ((struct ex_ex *)0);
- }
+ list_arr = (ex_ex *)fts_malloc(sizeof (ex_ex) * MINODES);
+ if (!list_arr) {post("ex_lex: no mem\n"); return 0;}
exptr = list_arr;
maxnode = MINODES;
-
- while (8)
- {
+ for (;;) {
if (non >= maxnode) {
maxnode += MINODES;
-
- list_arr = fts_realloc((void *)list_arr,
- sizeof (struct ex_ex) * maxnode);
- if (!list_arr) {
- post("ex_lex: no mem\n");
- return ((struct ex_ex *)0);
- }
+ list_arr = fts_realloc((void *)list_arr, sizeof (ex_ex) * maxnode);
+ if (!list_arr) {post("ex_lex: no mem\n"); return 0;}
exptr = &(list_arr)[non];
}
-
- if (getoken(expr, exptr)) {
- fts_free(list_arr);
- return ((struct ex_ex *)0);
- }
+ if (getoken(expr, exptr)) {fts_free(list_arr); return 0;}
non++;
-
- if (!exptr->ex_type)
- break;
-
+ if (!exptr->ex_type) break;
exptr++;
}
*n = non;
-
return list_arr;
}
-/*
- * ex_match -- this routine walks through the eptr and matches the
- * perentheses and brackets, it also converts the function
- * names to a pointer to the describing structure of the
- * specified function
- */
-/* operator to match */
-struct ex_ex *
-ex_match(struct ex_ex *eptr, long int op)
-{
+/* this routine walks through the eptr and matches the parentheses and brackets, it also converts the function
+ * names to a pointer to the describing structure of the specified function operator to match */
+ex_ex *ex_match(ex_ex *eptr, long int op) {
int firstone = 1;
- struct ex_ex *ret;
+ ex_ex *ret;
t_ex_func *fun;
-
- for (; 8; eptr++, firstone = 0) {
+ for (; ; eptr++, firstone = 0) {
switch (eptr->ex_type) {
case 0:
- if (!op)
- return (eptr);
- post("expr syntax error: an open %s not matched\n",
- op == OP_RP ? "parenthesis" : "bracket");
- return (exNULL);
- case ET_INT:
- case ET_FLT:
- case ET_II:
- case ET_FI:
- case ET_SI:
- case ET_VI:
- case ET_SYM:
- case ET_VSYM:
- continue;
- case ET_YO:
- if (eptr[1].ex_type != ET_OP || eptr[1].ex_op != OP_LB)
- eptr->ex_type = ET_YOM1;
- continue;
- case ET_XI:
- if (eptr[1].ex_type != ET_OP || eptr[1].ex_op != OP_LB)
- eptr->ex_type = ET_XI0;
- continue;
- case ET_TBL:
- case ET_FUNC:
- case ET_LP:
- /* CHANGE
- case ET_RP:
- */
- case ET_LB:
- /* CHANGE
- case ET_RB:
- */
+ if (!op) return eptr;
+ post("expr syntax error: an open %s not matched\n", op == OP_RP ? "parenthesis" : "bracket");
+ return 0;
+ case ET_INT: case ET_FLT: case ET_II: case ET_FI: case ET_SI: case ET_VI: case ET_SYM: case ET_VSYM: continue;
+ case ET_YO: if (eptr[1].ex_type != ET_OP || eptr[1].ex_op != OP_LB) eptr->ex_type = ET_YOM1; continue;
+ case ET_XI: if (eptr[1].ex_type != ET_OP || eptr[1].ex_op != OP_LB) eptr->ex_type = ET_XI0; continue;
+ case ET_TBL: case ET_FUNC: case ET_LP: case ET_LB:
post("ex_match: unexpected type, %ld\n", eptr->ex_type);
- return (exNULL);
- case ET_OP:
- if (op == eptr->ex_op)
- return (eptr);
- /*
- * if we are looking for a right peranthesis
- * or a right bracket and find the other kind,
- * it has to be a syntax error
- */
+ return 0;
+ case ET_OP: if (op == eptr->ex_op) return eptr;
+ /* if we are looking for a right peranthesis or a right bracket and find the other kind, it has to be a syntax error */
if ((eptr->ex_op == OP_RP && op == OP_RB) ||
(eptr->ex_op == OP_RB && op == OP_RP)) {
post("expr syntax error: prenthesis or brackets not matched\n");
- return (exNULL);
+ return 0;
}
- /*
- * Up to now we have marked the unary minuses as
- * subrtacts. Any minus that is the first one in
- * chain or is preceeded by anything except ')' and
- * ']' is a unary minus.
- */
+ /* Up to now we have marked the unary minuses as subrtacts. Any minus that is the first one in
+ * chain or is preceeded by anything except ')' and ']' is a unary minus. */
if (eptr->ex_op == OP_SUB) {
ret = eptr - 1;
- if (firstone || (ret->ex_type == ET_OP &&
- ret->ex_op != OP_RB && ret->ex_op != OP_RP))
+ if (firstone || (ret->ex_type == ET_OP && ret->ex_op != OP_RB && ret->ex_op != OP_RP))
eptr->ex_op = OP_UMINUS;
} else if (eptr->ex_op == OP_LP) {
- ret = ex_match(eptr + 1, OP_RP);
- if (!ret)
- return (ret);
- eptr->ex_type = ET_LP;
- eptr->ex_ptr = (char *) ret;
- eptr = ret;
+ ret = ex_match(eptr + 1, OP_RP); if (!ret) return ret;
+ eptr->ex_type = ET_LP; eptr->ex_ptr = (char *) ret; eptr = ret;
} else if (eptr->ex_op == OP_LB) {
- ret = ex_match(eptr + 1, OP_RB);
- if (!ret)
- return (ret);
- eptr->ex_type = ET_LB;
- eptr->ex_ptr = (char *) ret;
- eptr = ret;
+ ret = ex_match(eptr + 1, OP_RB); if (!ret) return ret;
+ eptr->ex_type = ET_LB; eptr->ex_ptr = (char *) ret; eptr = ret;
}
continue;
case ET_STR:
if (eptr[1].ex_op == OP_LB) {
- char *tmp;
-
+ char *tmp = eptr->ex_ptr;
eptr->ex_type = ET_TBL;
- tmp = eptr->ex_ptr;
if (ex_getsym(tmp, (t_symbol **)&(eptr->ex_ptr))) {
post("expr: syntax error: problms with ex_getsym\n");
- return (exNULL);
+ return 0;
}
fts_free((void *)tmp);
} else if (eptr[1].ex_op == OP_LP) {
fun = find_func(eptr->ex_ptr);
- if (!fun) {
- post(
- "expr: error: function %s not found\n",
- eptr->ex_ptr);
- return (exNULL);
- }
+ if (!fun) {post("expr: error: function %s not found\n", eptr->ex_ptr); return 0;}
eptr->ex_type = ET_FUNC;
eptr->ex_ptr = (char *) fun;
} else {
char *tmp;
-
- if (eptr[1].ex_type && eptr[1].ex_type!=ET_OP){
+ if (eptr[1].ex_type && eptr[1].ex_type!=ET_OP) {
post("expr: syntax error: bad string '%s'\n", eptr->ex_ptr);
- return (exNULL);
+ return 0;
}
/* it is a variable */
eptr->ex_type = ET_VAR;
tmp = eptr->ex_ptr;
- if (ex_getsym(tmp,
- (t_symbol **)&(eptr->ex_ptr))) {
- post("expr: variable '%s' not found",tmp);
- return (exNULL);
- }
+ if (ex_getsym(tmp, (t_symbol **)&(eptr->ex_ptr))) {post("expr: variable '%s' not found",tmp); return 0;}
}
continue;
default:
post("ex_match: bad type\n");
- return (exNULL);
+ return 0;
}
}
/* NOTREACHED */
}
-/*
- * ex_parse -- This function if called when we have already done some
- * parsing on the expression, and we have already matched
- * our brackets and parenthesis. The main job of this
- * function is to convert the infix expression to the
- * prefix form.
- * First we find the operator with the lowest precedence and
- * put it on the stack ('optr', it is really just an array), then
- * we call ourself (ex_parse()), on its arguments (unary operators
- * only have one operator.)
- * When "argc" is set it means that we are parsing the arguments
- * of a function and we will increment *argc anytime we find
- * a a segment that can qualify as an argument (counting commas).
- *
- * returns 0 on syntax error
- */
+/* This function if called when we have already done some parsing on the expression, and we have already matched
+ * our brackets and parenthesis. The main job of this function is to convert the infix expression to the prefix form.
+ * First we find the operator with the lowest precedence and put it on the stack ('optr', it is really just an array), then
+ * we call ourself (ex_parse()), on its arguments (unary operators only have one operator.)
+ * When "argc" is set it means that we are parsing the arguments of a function and we will increment *argc anytime we find
+ * a segment that can qualify as an argument (counting commas). returns 0 on syntax error. */
/* number of argument separated by comma */
-struct ex_ex *
-ex_parse(struct expr *x, struct ex_ex *iptr, struct ex_ex *optr, long int *argc)
-{
- struct ex_ex *eptr;
- struct ex_ex *lowpre = 0; /* pointer to the lowest precedence */
- struct ex_ex savex;
+ex_ex *ex_parse(struct expr *x, ex_ex *iptr, ex_ex *optr, long int *argc) {
+ ex_ex *eptr;
+ ex_ex *lowpre = 0; /* pointer to the lowest precedence */
+ ex_ex savex;
long pre = HI_PRE;
long count;
-
- if (!iptr) {
- post("ex_parse: input is null, iptr = 0x%lx\n", iptr);
- return (exNULL);
- }
- if (!iptr->ex_type)
- return (exNULL);
-
- /*
- * the following loop finds the lowest precedence operator in the
- * the input token list, comma is explicitly checked here since
- * that is a special operator and is only legal in functions
- */
+ if (!iptr) {post("ex_parse: input is null, iptr = 0x%lx\n", (long)iptr); return 0;}
+ if (!iptr->ex_type) return 0;
+ /* the following loop finds the lowest precedence operator in the the input token list, comma is explicitly
+ checked here since that is a special operator and is only legal in functions */
for (eptr = iptr, count = 0; eptr->ex_type; eptr++, count++)
switch (eptr->ex_type) {
- case ET_SYM:
- case ET_VSYM:
- if (!argc) {
- post("expr: syntax error: symbols allowed for functions only\n");
- ex_print(eptr);
- return (exNULL);
- }
- case ET_INT:
- case ET_FLT:
- case ET_II:
- case ET_FI:
- case ET_XI0:
- case ET_YOM1:
- case ET_VI:
- case ET_VAR:
- if (!count && !eptr[1].ex_type) {
- *optr++ = *eptr;
- return (optr);
- }
+ case ET_SYM: case ET_VSYM:
+ if (!argc) {post("expr: syntax error: symbols allowed for functions only\n"); ex_print(eptr); return 0;}
+ case ET_INT: case ET_FLT: case ET_II: case ET_FI: case ET_XI0: case ET_YOM1: case ET_VI: case ET_VAR:
+ if (!count && !eptr[1].ex_type) {*optr++ = *eptr; return optr;}
break;
- case ET_XI:
- case ET_YO:
- case ET_SI:
- case ET_TBL:
- if (eptr[1].ex_type != ET_LB) {
- post("expr: syntax error: brackets missing\n");
- ex_print(eptr);
- return (exNULL);
- }
+ case ET_XI: case ET_YO: case ET_SI: case ET_TBL:
+ if (eptr[1].ex_type != ET_LB) {post("expr: syntax error: brackets missing\n"); ex_print(eptr); return 0;}
/* if this table is the only token, parse the table */
- if (!count &&
- !((struct ex_ex *) eptr[1].ex_ptr)[1].ex_type) {
- savex = *((struct ex_ex *) eptr[1].ex_ptr);
- *((struct ex_ex *) eptr[1].ex_ptr) = nullex;
+ if (!count && !((ex_ex *) eptr[1].ex_ptr)[1].ex_type) {
+ savex = *((ex_ex *) eptr[1].ex_ptr);
+ *((ex_ex *) eptr[1].ex_ptr) = nullex;
*optr++ = *eptr;
lowpre = ex_parse(x, &eptr[2], optr, (long *)0);
- *((struct ex_ex *) eptr[1].ex_ptr) = savex;
+ *((ex_ex *) eptr[1].ex_ptr) = savex;
return(lowpre);
}
- eptr = (struct ex_ex *) eptr[1].ex_ptr;
+ eptr = (ex_ex *) eptr[1].ex_ptr;
break;
case ET_OP:
if (eptr->ex_op == OP_COMMA) {
if (!argc || !count || !eptr[1].ex_type) {
post("expr: syntax error: illegal comma\n");
ex_print(eptr[1].ex_type ? eptr : iptr);
- return (exNULL);
+ return 0;
}
}
- if (!eptr[1].ex_type) {
- post("expr: syntax error: missing operand\n");
- ex_print(iptr);
- return (exNULL);
- }
- if ((eptr->ex_op & PRE_MASK) <= pre) {
- pre = eptr->ex_op & PRE_MASK;
- lowpre = eptr;
- }
+ if (!eptr[1].ex_type) {post("expr: syntax error: missing operand\n"); ex_print(iptr); return 0;}
+ if ((eptr->ex_op & PRE_MASK) <= pre) {pre = eptr->ex_op & PRE_MASK; lowpre = eptr;}
break;
case ET_FUNC:
- if (eptr[1].ex_type != ET_LP) {
- post("expr: ex_parse: no parenthesis\n");
- return (exNULL);
- }
+ if (eptr[1].ex_type != ET_LP) {post("expr: ex_parse: no parenthesis\n"); return 0;}
/* if this function is the only token, parse it */
if (!count &&
- !((struct ex_ex *) eptr[1].ex_ptr)[1].ex_type) {
- long ac;
-
- if (eptr[1].ex_ptr == (char *) &eptr[2]) {
- post("expr: syntax error: missing argument\n");
- ex_print(eptr);
- return (exNULL);
- }
- ac = 0;
- savex = *((struct ex_ex *) eptr[1].ex_ptr);
- *((struct ex_ex *) eptr[1].ex_ptr) = nullex;
+ !((ex_ex *) eptr[1].ex_ptr)[1].ex_type) {
+ long ac=0;
+ if (eptr[1].ex_ptr==(char *)&eptr[2]) {post("expr: syntax error: missing argument\n");ex_print(eptr);return 0;}
+ savex = *((ex_ex *) eptr[1].ex_ptr);
+ *((ex_ex *) eptr[1].ex_ptr) = nullex;
*optr++ = *eptr;
lowpre = ex_parse(x, &eptr[2], optr, &ac);
- if (!lowpre)
- return (exNULL);
+ if (!lowpre) return 0;
ac++;
- if (ac !=
- ((t_ex_func *)eptr->ex_ptr)->f_argc){
+ if (ac != ((t_ex_func *)eptr->ex_ptr)->f_argc) {
post("expr: syntax error: function '%s' needs %ld arguments\n",
((t_ex_func *)eptr->ex_ptr)->f_name,
((t_ex_func *)eptr->ex_ptr)->f_argc);
- return (exNULL);
+ return 0;
}
- *((struct ex_ex *) eptr[1].ex_ptr) = savex;
- return (lowpre);
+ *((ex_ex *) eptr[1].ex_ptr) = savex;
+ return lowpre;
}
- eptr = (struct ex_ex *) eptr[1].ex_ptr;
+ eptr = (ex_ex *) eptr[1].ex_ptr;
break;
- case ET_LP:
- case ET_LB:
- if (!count &&
- !((struct ex_ex *) eptr->ex_ptr)[1].ex_type) {
+ case ET_LP: case ET_LB:
+ if (!count && !((ex_ex *) eptr->ex_ptr)[1].ex_type) {
if (eptr->ex_ptr == (char *)(&eptr[1])) {
- post("expr: syntax error: empty '%s'\n",
- eptr->ex_type==ET_LP?"()":"[]");
+ post("expr: syntax error: empty '%s'\n", eptr->ex_type==ET_LP?"()":"[]");
ex_print(eptr);
- return (exNULL);
+ return 0;
}
- savex = *((struct ex_ex *) eptr->ex_ptr);
- *((struct ex_ex *) eptr->ex_ptr) = nullex;
+ savex = *((ex_ex *) eptr->ex_ptr);
+ *((ex_ex *) eptr->ex_ptr) = nullex;
lowpre = ex_parse(x, &eptr[1], optr, (long *)0);
- *((struct ex_ex *) eptr->ex_ptr) = savex;
- return (lowpre);
+ *((ex_ex *) eptr->ex_ptr) = savex;
+ return lowpre;
}
- eptr = (struct ex_ex *)eptr->ex_ptr;
+ eptr = (ex_ex *)eptr->ex_ptr;
break;
case ET_STR:
default:
ex_print(eptr);
post("expr: ex_parse: type = 0x%lx\n", eptr->ex_type);
- return (exNULL);
+ return 0;
}
-
- if (pre == HI_PRE) {
- post("expr: syntax error: missing operation\n");
- ex_print(iptr);
- return (exNULL);
- }
- if (count < 2) {
- post("expr: syntax error: mission operand\n");
- ex_print(iptr);
- return (exNULL);
- }
+ if (pre == HI_PRE) {post("expr: syntax error: missing operation\n"); ex_print(iptr); return 0;}
+ if (count < 2) {post("expr: syntax error: mission operand\n"); ex_print(iptr); return 0;}
if (count == 2) {
- if (lowpre != iptr) {
- post("expr: ex_parse: unary operator should be first\n");
- return (exNULL);
- }
- if (!unary_op(lowpre->ex_op)) {
- post("expr: syntax error: not a uniary operator\n");
- ex_print(iptr);
- return (exNULL);
- }
+ if (lowpre != iptr) {post("expr: ex_parse: unary operator should be first\n"); return 0;}
+ if (!unary_op(lowpre->ex_op)) {post("expr: syntax error: not a uniary operator\n"); ex_print(iptr); return 0;}
*optr++ = *lowpre;
eptr = ex_parse(x, &lowpre[1], optr, argc);
- return (eptr);
- }
- if (lowpre == iptr) {
- post("expr: syntax error: mission operand\n");
- ex_print(iptr);
- return (exNULL);
+ return eptr;
}
+ if (lowpre == iptr) {post("expr: syntax error: mission operand\n"); ex_print(iptr); return 0;}
savex = *lowpre;
*lowpre = nullex;
- if (savex.ex_op != OP_COMMA)
- *optr++ = savex;
- else
- (*argc)++;
+ if (savex.ex_op != OP_COMMA) *optr++ = savex; else (*argc)++;
eptr = ex_parse(x, iptr, optr, argc);
- if (eptr) {
- eptr = ex_parse(x, &lowpre[1], eptr, argc);
- *lowpre = savex;
- }
- return (eptr);
+ if (eptr) {eptr = ex_parse(x, &lowpre[1], eptr, argc); *lowpre = savex;}
+ return eptr;
}
-/*
- * this is the devide zero check for a a non devide operator
- */
-#define DZC(ARG1,OPR,ARG2) (ARG1 OPR ARG2)
+/* this is the divide zero check for a a non divide operator */
+#define DZC(ARG1,OPR,ARG2) (ARG1 OPR ARG2)
#define EVAL(OPR); \
eptr = ex_eval(expr, ex_eval(expr, eptr, &left, idx), &right, idx); \
switch (left.ex_type) { \
-case ET_INT: \
- switch(right.ex_type) { \
+case ET_INT: switch(right.ex_type) { \
case ET_INT: \
if (optr->ex_type == ET_VEC) { \
op = optr->ex_vec; \
scalar = (float)DZC(left.ex_int, OPR, right.ex_int); \
- for (j = 0; j < expr->exp_vsize; j++) \
- *op++ = scalar; \
+ for (j=0; j<expr->exp_vsize; j++) *op++ = scalar; \
} else { \
optr->ex_type = ET_INT; \
optr->ex_int = DZC(left.ex_int, OPR, right.ex_int); \
@@ -703,38 +377,26 @@ case ET_INT: \
if (optr->ex_type == ET_VEC) { \
op = optr->ex_vec; \
scalar = DZC(((float)left.ex_int), OPR, right.ex_flt);\
- for (j = 0; j < expr->exp_vsize; j++) \
- *op++ = scalar; \
+ for (j=0; j<expr->exp_vsize; j++) *op++ = scalar; \
} else { \
optr->ex_type = ET_FLT; \
- optr->ex_flt = DZC(((float)left.ex_int), OPR, \
- right.ex_flt); \
+ optr->ex_flt = DZC(((float)left.ex_int), OPR, right.ex_flt); \
} \
break; \
- case ET_VEC: \
- case ET_VI: \
+ case ET_VEC: case ET_VI: \
if (optr->ex_type != ET_VEC) { \
- if (optr->ex_type == ET_VI) { \
- post("expr~: Int. error %d", __LINE__); \
- abort(); \
- } \
+ if (optr->ex_type == ET_VI) {post("expr~: Int. error %d", __LINE__); abort();} \
optr->ex_type = ET_VEC; \
- optr->ex_vec = (t_float *) \
- fts_malloc(sizeof (t_float)*expr->exp_vsize); \
+ optr->ex_vec = (t_float *)fts_malloc(sizeof (t_float)*expr->exp_vsize); \
} \
scalar = left.ex_int; \
rp = right.ex_vec; \
op = optr->ex_vec; \
- for (i = 0; i < expr->exp_vsize; i++) { \
- *op++ = DZC (scalar, OPR, *rp); \
- rp++; \
- } \
+ for (i=0; i<expr->exp_vsize; i++) {*op++ = DZC (scalar, OPR, *rp); rp++;} \
break; \
case ET_SYM: \
default: \
- post_error((fts_object_t *) expr, \
- "expr: ex_eval(%d): bad right type %ld\n", \
- __LINE__, right.ex_type); \
+ post_error((fts_object_t *) expr, "expr: ex_eval(%d): bad right type %ld\n", __LINE__, right.ex_type); \
nullret = 1; \
} \
break; \
@@ -744,8 +406,7 @@ case ET_FLT: \
if (optr->ex_type == ET_VEC) { \
op = optr->ex_vec; \
scalar = DZC((float) left.ex_flt, OPR, right.ex_int); \
- for (j = 0; j < expr->exp_vsize; j++) \
- *op++ = scalar; \
+ for (j=0; j<expr->exp_vsize; j++) *op++ = scalar; \
} else { \
optr->ex_type = ET_FLT; \
optr->ex_flt = DZC(left.ex_flt, OPR, right.ex_int); \
@@ -755,285 +416,191 @@ case ET_FLT: \
if (optr->ex_type == ET_VEC) { \
op = optr->ex_vec; \
scalar = DZC(left.ex_flt, OPR, right.ex_flt); \
- for (j = 0; j < expr->exp_vsize; j++) \
- *op++ = scalar; \
+ for (j=0; j<expr->exp_vsize; j++) *op++ = scalar; \
} else { \
optr->ex_type = ET_FLT; \
optr->ex_flt= DZC(left.ex_flt, OPR, right.ex_flt); \
} \
break; \
- case ET_VEC: \
- case ET_VI: \
+ case ET_VEC: case ET_VI: \
if (optr->ex_type != ET_VEC) { \
- if (optr->ex_type == ET_VI) { \
- post("expr~: Int. error %d", __LINE__); \
- abort(); \
- } \
+ if (optr->ex_type == ET_VI) {post("expr~: Int. error %d", __LINE__); abort();} \
optr->ex_type = ET_VEC; \
- optr->ex_vec = (t_float *) \
- fts_malloc(sizeof (t_float)*expr->exp_vsize); \
+ optr->ex_vec = (t_float *)fts_malloc(sizeof (t_float)*expr->exp_vsize); \
} \
scalar = left.ex_flt; \
rp = right.ex_vec; \
op = optr->ex_vec; \
- for (i = 0; i < expr->exp_vsize; i++) { \
- *op++ = DZC(scalar, OPR, *rp); \
- rp++; \
- } \
+ for (i=0; i<expr->exp_vsize; i++) {*op++ = DZC(scalar, OPR, *rp); rp++;} \
break; \
case ET_SYM: \
default: \
- post_error((fts_object_t *) expr, \
- "expr: ex_eval(%d): bad right type %ld\n", \
- __LINE__, right.ex_type); \
+ post_error((fts_object_t *) expr, "expr: ex_eval(%d): bad right type %ld\n", __LINE__, right.ex_type); \
nullret = 1; \
} \
break; \
-case ET_VEC: \
-case ET_VI: \
+case ET_VEC: case ET_VI: \
if (optr->ex_type != ET_VEC) { \
- if (optr->ex_type == ET_VI) { \
- post("expr~: Int. error %d", __LINE__); \
- abort(); \
- } \
+ if (optr->ex_type == ET_VI) {post("expr~: Int. error %d", __LINE__); abort();} \
optr->ex_type = ET_VEC; \
- optr->ex_vec = (t_float *) \
- fts_malloc(sizeof (t_float)*expr->exp_vsize); \
+ optr->ex_vec = (t_float *)fts_malloc(sizeof (t_float)*expr->exp_vsize); \
} \
op = optr->ex_vec; \
lp = left.ex_vec; \
switch(right.ex_type) { \
case ET_INT: \
scalar = right.ex_int; \
- for (i = 0; i < expr->exp_vsize; i++) { \
- *op++ = DZC(*lp, OPR, scalar); \
- lp++; \
- } \
+ for (i=0; i<expr->exp_vsize; i++) {*op++ = DZC(*lp, OPR, scalar); lp++;} \
break; \
case ET_FLT: \
scalar = right.ex_flt; \
- for (i = 0; i < expr->exp_vsize; i++) { \
- *op++ = DZC(*lp, OPR, scalar); \
- lp++; \
- } \
+ for (i=0; i<expr->exp_vsize; i++) {*op++ = DZC(*lp, OPR, scalar); lp++;} \
break; \
- case ET_VEC: \
- case ET_VI: \
+ case ET_VEC: case ET_VI: \
rp = right.ex_vec; \
for (i = 0; i < expr->exp_vsize; i++) { \
- /* \
- * on a RISC processor one could copy \
- * 8 times in each round to get a considerable \
- * improvement \
- */ \
+ /* on a RISC processor one could copy 8 times in each round to get a considerable improvement */ \
*op++ = DZC(*lp, OPR, *rp); \
rp++; lp++; \
} \
break; \
case ET_SYM: \
default: \
- post_error((fts_object_t *) expr, \
- "expr: ex_eval(%d): bad right type %ld\n", \
- __LINE__, right.ex_type); \
+ post_error((fts_object_t *) expr, "expr: ex_eval(%d): bad right type %ld\n", __LINE__, right.ex_type); \
nullret = 1; \
} \
break; \
case ET_SYM: \
default: \
- post_error((fts_object_t *) expr, \
- "expr: ex_eval(%d): bad left type %ld\n", \
- __LINE__, left.ex_type); \
+ post_error((fts_object_t *) expr, "expr: ex_eval(%d): bad left type %ld\n", __LINE__, left.ex_type); \
} \
break;
-/*
- * evaluate a unary operator, TYPE is applied to float operands
- */
+/* evaluate a unary operator, TYPE is applied to float operands */
#define EVAL_UNARY(OPR, TYPE) \
eptr = ex_eval(expr, eptr, &left, idx); \
switch(left.ex_type) { \
case ET_INT: \
- if (optr->ex_type == ET_VEC) { \
- ex_mkvector(optr->ex_vec,(float)(OPR left.ex_int),\
- expr->exp_vsize);\
- break; \
- } \
+ if (optr->ex_type == ET_VEC) {ex_mkvector(optr->ex_vec,(float)(OPR left.ex_int), expr->exp_vsize); break;} \
optr->ex_type = ET_INT; \
optr->ex_int = OPR left.ex_int; \
break; \
case ET_FLT: \
- if (optr->ex_type == ET_VEC) { \
- ex_mkvector(optr->ex_vec, OPR (TYPE left.ex_flt),\
- expr->exp_vsize);\
- break; \
- } \
+ if (optr->ex_type == ET_VEC) {ex_mkvector(optr->ex_vec, OPR (TYPE left.ex_flt), expr->exp_vsize); break;} \
optr->ex_type = ET_FLT; \
optr->ex_flt = OPR (TYPE left.ex_flt); \
break; \
- case ET_VI: \
- case ET_VEC: \
+ case ET_VI: case ET_VEC: \
j = expr->exp_vsize; \
if (optr->ex_type != ET_VEC) { \
optr->ex_type = ET_VEC; \
- optr->ex_vec = (t_float *) \
- fts_malloc(sizeof (t_float)*expr->exp_vsize); \
+ optr->ex_vec = (t_float *) fts_malloc(sizeof (t_float)*expr->exp_vsize); \
} \
op = optr->ex_vec; \
lp = left.ex_vec; \
j = expr->exp_vsize; \
- for (i = 0; i < j; i++) \
- *op++ = OPR (TYPE *lp++); \
+ for (i=0; i<j; i++) *op++ = OPR (TYPE *lp++); \
break; \
default: \
- post_error((fts_object_t *) expr, \
- "expr: ex_eval(%d): bad left type %ld\n", \
- __LINE__, left.ex_type); \
+ post_error((fts_object_t *) expr, "expr: ex_eval(%d): bad left type %ld\n", __LINE__, left.ex_type); \
nullret++; \
- } \
+ } \
break;
-void
-ex_mkvector(t_float *fp, t_float x, int size)
-{
- while (size--)
- *fp++ = x;
-}
+void ex_mkvector(t_float *fp, t_float x, int size) {while (size--) *fp++ = x;}
-/*
- * ex_dzdetect -- divide by zero detected
- */
-void
-ex_dzdetect(struct expr *expr)
-{
+/* divide by zero detected */
+void ex_dzdetect(struct expr *expr) {
char *etype;
-
if (!expr->exp_error & EE_DZ) {
- if (IS_EXPR(expr))
- etype = "expr";
- else if (IS_EXPR_TILDE(expr))
- etype = "expr~";
- else if (IS_FEXPR_TILDE(expr))
- etype = "fexpr~";
- else {
- post ("expr -- ex_dzdetect internal error");
- etype = "";
- }
+ if (IS_EXPR(expr)) etype = "expr";
+ else if (IS_EXPR_TILDE(expr)) etype = "expr~";
+ else if (IS_FEXPR_TILDE(expr)) etype = "fexpr~";
+ else {post ("expr -- ex_dzdetect internal error"); etype = "";}
post ("%s divide by zero detected", etype);
expr->exp_error |= EE_DZ;
}
}
-
-
-/*
- * ex_eval -- evaluate the array of prefix expression
- * ex_eval returns the pointer to the first unevaluated node
- * in the array. This is a recursive routine.
- */
+/* evaluate the array of prefix expression ex_eval returns the pointer to the first unevaluated node in the array.
+ This is a recursive routine. */
/* SDY
all the returns in this function need to be changed so that the code
ends up at the end to check for newly allocated right and left vectors which
-need to be freed
-
-look into the variable nullret
-*/
-struct ex_ex *
-ex_eval(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
+need to be freed. look into the variable nullret */
/* the expr object data pointer */
/* the operation stack */
/* the result pointer */
-/* the sample numnber processed for fexpr~ */
-{
+/* the sample number processed for fexpr~ */
+ex_ex * ex_eval(struct expr *expr, ex_ex *eptr, ex_ex *optr, int idx) {
int i, j;
t_float *lp, *rp, *op; /* left, right, and out pointer to vectors */
t_float scalar;
int nullret = 0; /* did we have an error */
- struct ex_ex left, right; /* left and right operands */
-
+ ex_ex left, right; /* left and right operands */
left.ex_type = 0;
left.ex_int = 0;
right.ex_type = 0;
right.ex_int = 0;
-
- if (!eptr)
- return (exNULL);
+ if (!eptr) return 0;
switch (eptr->ex_type) {
case ET_INT:
- if (optr->ex_type == ET_VEC)
- ex_mkvector(optr->ex_vec, (float) eptr->ex_int,
- expr->exp_vsize);
- else
- *optr = *eptr;
- return (++eptr);
-
+ if (optr->ex_type == ET_VEC) ex_mkvector(optr->ex_vec, (float) eptr->ex_int, expr->exp_vsize);
+ else *optr = *eptr;
+ return ++eptr;
case ET_FLT:
-
- if (optr->ex_type == ET_VEC)
- ex_mkvector(optr->ex_vec, eptr->ex_flt, expr->exp_vsize);
- else
- *optr = *eptr;
- return (++eptr);
-
+ if (optr->ex_type == ET_VEC) ex_mkvector(optr->ex_vec, eptr->ex_flt, expr->exp_vsize);
+ else *optr = *eptr;
+ return ++eptr;
case ET_SYM:
if (optr->ex_type == ET_VEC) {
- post_error((fts_object_t *) expr,
- "expr: ex_eval: cannot turn string to vector\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: ex_eval: cannot turn string to vector\n");
+ return 0;
}
*optr = *eptr;
- return (++eptr);
+ return ++eptr;
case ET_II:
if (eptr->ex_int == -1) {
- post_error((fts_object_t *) expr,
- "expr: ex_eval: inlet number not set\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: ex_eval: inlet number not set\n");
+ return 0;
}
if (optr->ex_type == ET_VEC) {
- ex_mkvector(optr->ex_vec,
- (t_float)expr->exp_var[eptr->ex_int].ex_int,
- expr->exp_vsize);
+ ex_mkvector(optr->ex_vec, (t_float)expr->exp_var[eptr->ex_int].ex_int, expr->exp_vsize);
} else {
optr->ex_type = ET_INT;
optr->ex_int = expr->exp_var[eptr->ex_int].ex_int;
}
- return (++eptr);
+ return ++eptr;
case ET_FI:
if (eptr->ex_int == -1) {
- post_error((fts_object_t *) expr,
- "expr: ex_eval: inlet number not set\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: ex_eval: inlet number not set\n");
+ return 0;
}
if (optr->ex_type == ET_VEC) {
- ex_mkvector(optr->ex_vec,
- expr->exp_var[eptr->ex_int].ex_flt, expr->exp_vsize);
+ ex_mkvector(optr->ex_vec, expr->exp_var[eptr->ex_int].ex_flt, expr->exp_vsize);
} else {
optr->ex_type = ET_FLT;
optr->ex_flt = expr->exp_var[eptr->ex_int].ex_flt;
}
- return (++eptr);
+ return ++eptr;
case ET_VSYM:
if (optr->ex_type == ET_VEC) {
- post_error((fts_object_t *) expr,
- "expr: IntErr. vsym in for vec out\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: IntErr. vsym in for vec out\n");
+ return 0;
}
if (eptr->ex_int == -1) {
- post_error((fts_object_t *) expr,
- "expr: ex_eval: inlet number not set\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: ex_eval: inlet number not set\n");
+ return 0;
}
optr->ex_type = ET_SYM;
optr->ex_ptr = expr->exp_var[eptr->ex_int].ex_ptr;
- return(++eptr);
-
+ return ++eptr;
case ET_VI:
- if (optr->ex_type != ET_VEC)
- *optr = expr->exp_var[eptr->ex_int];
+ if (optr->ex_type != ET_VEC) *optr = expr->exp_var[eptr->ex_int];
else if (optr->ex_vec != expr->exp_var[eptr->ex_int].ex_vec)
- memcpy(optr->ex_vec, expr->exp_var[eptr->ex_int].ex_vec,
- expr->exp_vsize * sizeof (t_float));
- return(++eptr);
+ memcpy(optr->ex_vec, expr->exp_var[eptr->ex_int].ex_vec, expr->exp_vsize * sizeof(t_float));
+ return ++eptr;
case ET_VEC:
if (optr->ex_type != ET_VEC) {
optr->ex_type = ET_VEC;
@@ -1041,23 +608,18 @@ ex_eval(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
eptr->ex_type = ET_INT;
eptr->ex_int = 0;
} else if (optr->ex_vec != eptr->ex_vec) {
- memcpy(optr->ex_vec, eptr->ex_vec,
- expr->exp_vsize * sizeof (t_float));
-/* do we need to free here? or can we free higher up */
-/* SDY the next lines do not make sense */
-post("calling fts_free\n");
-abort();
+ memcpy(optr->ex_vec, eptr->ex_vec, expr->exp_vsize * sizeof (t_float));
+ /* do we need to free here? or can we free higher up */
+ /* SDY the next lines do not make sense */
+ post("calling fts_free\n");
+ abort();
fts_free(optr->ex_vec);
optr->ex_type = ET_INT;
eptr->ex_int = 0;
- } else { /* this should not happen */
- post("expr int. error, optr->ex_vec = %d",optr->ex_vec);
- abort();
- }
- return(++eptr);
+ } else {post("expr int. error, optr->ex_vec = %ld",(long)optr->ex_vec); abort();}
+ return ++eptr;
case ET_XI0:
/* short hand for $x?[0] */
-
/* SDY delete the following check */
if (!IS_FEXPR_TILDE(expr) || optr->ex_type==ET_VEC) {
post("%d:exp->exp_flags = %d", __LINE__,expr->exp_flags);
@@ -1065,305 +627,149 @@ abort();
}
optr->ex_type = ET_FLT;
optr->ex_flt = expr->exp_var[eptr->ex_int].ex_vec[idx];
- return(++eptr);
+ return ++eptr;
case ET_YOM1:
- /*
- * short hand for $y?[-1]
- * if we are calculating the first sample of the vector
- * we need to look at the previous results buffer
- */
+ /* short hand for $y?[-1].
+ if we are calculating the first sample of the vector we need to look at the previous results buffer */
optr->ex_type = ET_FLT;
- if (idx == 0)
- optr->ex_flt =
- expr->exp_p_res[eptr->ex_int][expr->exp_vsize - 1];
- else
- optr->ex_flt=expr->exp_tmpres[eptr->ex_int][idx-1];
+ if (idx==0) optr->ex_flt = expr->exp_p_res[ eptr->ex_int][expr->exp_vsize-1];
+ else optr->ex_flt = expr->exp_tmpres[eptr->ex_int][idx-1];
return(++eptr);
-
- case ET_YO:
- case ET_XI:
+ case ET_YO: case ET_XI:
/* SDY delete the following */
if (!IS_FEXPR_TILDE(expr) || optr->ex_type==ET_VEC) {
post("%d:expr->exp_flags = %d", __LINE__,expr->exp_flags);
abort();
}
- return (eval_sigidx(expr, eptr, optr, idx));
-
+ return eval_sigidx(expr, eptr, optr, idx);
case ET_TBL:
- case ET_SI:
- return (eval_tab(expr, eptr, optr, idx));
- case ET_FUNC:
- return (eval_func(expr, eptr, optr, idx));
- case ET_VAR:
- return (eval_var(expr, eptr, optr, idx));
- case ET_OP:
- break;
- case ET_STR:
- case ET_LP:
- case ET_LB:
+ case ET_SI: return eval_tab( expr, eptr, optr, idx);
+ case ET_FUNC:return eval_func(expr, eptr, optr, idx);
+ case ET_VAR: return eval_var( expr, eptr, optr, idx);
+ case ET_OP: break;
+ case ET_STR: case ET_LP: case ET_LB:
default:
- post_error((fts_object_t *) expr,
- "expr: ex_eval: unexpected type %d\n", eptr->ex_type);
- return (exNULL);
- }
- if (!eptr[1].ex_type) {
- post_error((fts_object_t *) expr,
- "expr: ex_eval: not enough nodes 1\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: ex_eval: unexpected type %ld\n", eptr->ex_type);
+ return 0;
}
+ if (!eptr[1].ex_type) {post_error((fts_object_t *) expr, "expr: ex_eval: not enough nodes 1\n"); return 0;}
if (!unary_op(eptr->ex_op) && !eptr[2].ex_type) {
- post_error((fts_object_t *) expr,
- "expr: ex_eval: not enough nodes 2\n");
- return (exNULL);
+ post_error((fts_object_t *) expr, "expr: ex_eval: not enough nodes 2\n");
+ return 0;
}
-
switch((eptr++)->ex_op) {
- case OP_STORE:
- return (eval_store(expr, eptr, optr, idx));
- case OP_NOT:
- EVAL_UNARY(!, +);
- case OP_NEG:
- EVAL_UNARY(~, (long));
- case OP_UMINUS:
- EVAL_UNARY(-, +);
- case OP_MUL:
- EVAL(*);
- case OP_ADD:
- EVAL(+);
- case OP_SUB:
- EVAL(-);
- case OP_LT:
- EVAL(<);
- case OP_LE:
- EVAL(<=);
- case OP_GT:
- EVAL(>);
- case OP_GE:
- EVAL(>=);
- case OP_EQ:
- EVAL(==);
- case OP_NE:
- EVAL(!=);
-/*
- * following operators convert their argument to integer
- */
+ case OP_STORE: return (eval_store(expr, eptr, optr, idx));
+ case OP_NOT: EVAL_UNARY(!, +);
+ case OP_NEG: EVAL_UNARY(~, (long));
+ case OP_UMINUS:EVAL_UNARY(-, +);
+ case OP_MUL: EVAL(*);
+ case OP_ADD: EVAL(+);
+ case OP_SUB: EVAL(-);
+ case OP_LT: EVAL(<);
+ case OP_LE: EVAL(<=);
+ case OP_GT: EVAL(>);
+ case OP_GE: EVAL(>=);
+ case OP_EQ: EVAL(==);
+ case OP_NE: EVAL(!=);
+/* following operators convert their argument to integer */
#undef DZC
#define DZC(ARG1,OPR,ARG2) (((int)ARG1) OPR ((int)ARG2))
- case OP_SL:
- EVAL(<<);
- case OP_SR:
- EVAL(>>);
- case OP_AND:
- EVAL(&);
- case OP_XOR:
- EVAL(^);
- case OP_OR:
- EVAL(|);
- case OP_LAND:
- EVAL(&&);
- case OP_LOR:
- EVAL(||);
-/*
- * for modulo we need to convert to integer and check for divide by zero
- */
+ case OP_SL: EVAL(<<);
+ case OP_SR: EVAL(>>);
+ case OP_AND: EVAL(&);
+ case OP_XOR: EVAL(^);
+ case OP_OR: EVAL(|);
+ case OP_LAND: EVAL(&&);
+ case OP_LOR: EVAL(||);
+/* for modulo we need to convert to integer and check for divide by zero */
#undef DZC
-#define DZC(ARG1,OPR,ARG2) (((ARG2)?(((int)ARG1) OPR ((int)ARG2)) \
- : (ex_dzdetect(expr),0)))
- case OP_MOD:
- EVAL(%);
-/*
- * define the divide by zero check for divide
- */
+#define DZC(ARG1,OPR,ARG2) (((ARG2)?(((int)ARG1) OPR ((int)ARG2)) : (ex_dzdetect(expr),0)))
+ case OP_MOD: EVAL(%);
+/* define the divide by zero check for divide */
#undef DZC
#define DZC(ARG1,OPR,ARG2) (((ARG2)?(ARG1 OPR ARG2):(ex_dzdetect(expr),0)))
- case OP_DIV:
- EVAL(/);
- case OP_LP:
- case OP_RP:
- case OP_LB:
- case OP_RB:
- case OP_COMMA:
- case OP_SEMI:
- default:
- post_error((fts_object_t *) expr, "expr: ex_print: bad op 0x%x\n", eptr->ex_op);
- return (exNULL);
+ case OP_DIV: EVAL(/);
+ case OP_LP: case OP_RP: case OP_LB: case OP_RB: case OP_COMMA: case OP_SEMI:
+ default: post_error((fts_object_t *) expr, "expr: ex_print: bad op 0x%lx\n", eptr->ex_op); return 0;
}
-
-
- /*
- * the left and right nodes could have been transformed to vectors
- * down the chain
- */
- if (left.ex_type == ET_VEC)
- fts_free(left.ex_vec);
- if (right.ex_type == ET_VEC)
- fts_free(right.ex_vec);
- if (nullret)
- return (exNULL);
- else
- return (eptr);
+ /* the left and right nodes could have been transformed to vectors down the chain */
+ if (left.ex_type == ET_VEC) fts_free(left.ex_vec);
+ if (right.ex_type == ET_VEC) fts_free(right.ex_vec);
+ if (nullret) return 0; else return eptr;
}
-/*
- * eval_func -- evaluate a function, call ex_eval() on all the arguments
- * so that all of them are terminal nodes. The call the
- * appropriate function
- */
-struct ex_ex *
-eval_func(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
-/* the expr object data pointer */
-/* the operation stack */
-/* the result pointer */
-{
+/* evaluate a function: call ex_eval() on all the arguments so that all of them are terminal nodes. Then call the appropriate function */
+ex_ex *eval_func(struct expr *expr, ex_ex *eptr, ex_ex *optr, int idx) {
int i;
- struct ex_ex args[MAX_ARGS];
- t_ex_func *f;
-
- f = (t_ex_func *)(eptr++)->ex_ptr;
- if (!f || !f->f_name) {
- return (exNULL);
- }
- if (f->f_argc > MAX_ARGS) {
- post_error((fts_object_t *) expr, "expr: eval_func: asking too many arguments\n");
- return (exNULL);
- }
-
+ ex_ex args[MAX_ARGS];
+ t_ex_func *f = (t_ex_func *)(eptr++)->ex_ptr;
+ if (!f || !f->f_name) return 0;
+ if (f->f_argc > MAX_ARGS) {post_error((fts_object_t *) expr, "expr: eval_func: asking too many arguments\n"); return 0;}
for (i = 0; i < f->f_argc; i++) {
args[i].ex_type = 0;
args[i].ex_int = 0;
eptr = ex_eval(expr, eptr, &args[i], idx);
}
(*f->f_func)(expr, f->f_argc, args, optr);
- for (i = 0; i < f->f_argc; i++) {
- if (args[i].ex_type == ET_VEC)
- fts_free(args[i].ex_vec);
- }
- return (eptr);
+ for (i = 0; i < f->f_argc; i++) if (args[i].ex_type == ET_VEC) fts_free(args[i].ex_vec);
+ return eptr;
}
-
-/*
- * eval_store -- evaluate the '=' operator,
- * make sure the first operator is a legal left operator
- * and call ex_eval on the right operator
- */
-struct ex_ex *
-eval_store(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
+/* evaluate the '=' operator, make sure the first operator is a legal left operator and call ex_eval on the right operator */
/* the expr object data pointer */
/* the operation stack */
/* the result pointer */
-{
- struct ex_ex arg;
+ex_ex *eval_store(struct expr *expr, ex_ex *eptr, ex_ex *optr, int idx) {
+ ex_ex arg;
int isvalue;
char *tbl = (char *) 0;
char *var = (char *) 0;
int badleft = 0;
-
-post("store called\n");
-ex_print(eptr);
-eptr = ex_eval(expr, ++eptr, optr, idx);
-return (eptr);
-
-#ifdef notdef /* SDY */
- arg.ex_type = ET_INT;
- arg.ex_int = 0;
- if (eptr->ex_type == ET_VAR) {
- var = (char *) eptr->ex_ptr;
-
- eptr = ex_eval(expr, ++eptr, &arg, idx);
- (void)max_ex_var_store(expr, (t_symbol *)var, &arg, optr);
- if (arg.ex_type == ET_VEC)
- fts_free(arg.ex_vec);
- }
-
-
- if (eptr->ex_type == ET_SI) {
- eptr++;
- if (eptr->ex_type =
- }
-
- /* the left operator should either be a value or a array member */
- switch (eptr->ex_type) {
- case ET_SI:
- if ((eptr + 1)->ex_type == OP_LB) {
- }
- if (!expr->exp_var[eptr->ex_int].ex_ptr) {
- if (!(expr->exp_error & EE_NOTABLE)) {
- post("expr: syntax error: no string for inlet %d", eptr->ex_int + 1);
- post("expr: No more table errors will be reported");
- post("expr: till the next reset");
- expr->exp_error |= EE_NOTABLE;
- }
- badleft++;
- } else
- tbl = (char *) expr->exp_var[eptr->ex_int].ex_ptr;
- break;
- case ET_TBL:
- }
-#endif /* SDY */
+ post("store called\n");
+ ex_print(eptr);
+ eptr = ex_eval(expr, ++eptr, optr, idx);
+ return eptr;
}
-/*
- * eval_tab -- evaluate a table operation
- */
-struct ex_ex *
-eval_tab(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
-/* the expr object data pointer */
-/* the operation stack */
-/* the result pointer */
-{
- struct ex_ex arg;
+/* evaluate a table operation */
+ex_ex *eval_tab(struct expr *expr, ex_ex *eptr, ex_ex *optr, int idx) {
+ ex_ex arg;
char *tbl = (char *) 0;
int notable = 0;
-
if (eptr->ex_type == ET_SI) {
if (!expr->exp_var[eptr->ex_int].ex_ptr) {
/* SDY post_error() does not work in MAX/MSP yet
- post_error((fts_object_t *) expr,
- "expr: syntax error: no string for inlet %d\n", eptr->ex_int + 1);
+ post_error((fts_object_t *) expr, "expr: syntax error: no string for inlet %d\n", eptr->ex_int + 1);
*/
if (!(expr->exp_error & EE_NOTABLE)) {
- post("expr: syntax error: no string for inlet %d", eptr->ex_int + 1);
+ post("expr: syntax error: no string for inlet %ld", eptr->ex_int+1);
post("expr: No more table errors will be reported");
post("expr: till the next reset");
expr->exp_error |= EE_NOTABLE;
}
notable++;
- } else
- tbl = (char *) expr->exp_var[eptr->ex_int].ex_ptr;
- } else if (eptr->ex_type == ET_TBL)
+ } else tbl = (char *) expr->exp_var[eptr->ex_int].ex_ptr;
+ } else if (eptr->ex_type == ET_TBL) {
tbl = (char *) eptr->ex_ptr;
- else {
+ } else {
post_error((fts_object_t *) expr, "expr: eval_tbl: bad type %ld\n", eptr->ex_type);
notable++;
-
}
arg.ex_type = 0;
arg.ex_int = 0;
eptr = ex_eval(expr, ++eptr, &arg, idx);
-
optr->ex_type = ET_INT;
optr->ex_int = 0;
- if (!notable)
- (void)max_ex_tab(expr, (t_symbol *)tbl, &arg, optr);
- if (arg.ex_type == ET_VEC)
- fts_free(arg.ex_vec);
- return (eptr);
+ if (!notable) max_ex_tab(expr, (t_symbol *)tbl, &arg, optr);
+ if (arg.ex_type == ET_VEC) fts_free(arg.ex_vec);
+ return eptr;
}
-/*
- * eval_var -- evaluate a variable
- */
-struct ex_ex *
-eval_var(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
-/* the expr object data pointer */
-/* the operation stack */
-/* the result pointer */
-{
- struct ex_ex arg;
+/* evaluate a variable */
+ex_ex *eval_var(struct expr *expr, ex_ex *eptr, ex_ex *optr, int idx) {
+ ex_ex arg;
char *var = (char *) 0;
int novar = 0;
-
if (eptr->ex_type == ET_SI) {
if (!expr->exp_var[eptr->ex_int].ex_ptr) {
/* SDY post_error() does not work in MAX/MSP yet
@@ -1371,70 +777,49 @@ post_error((fts_object_t *) expr,
"expr: syntax error: no string for inlet %d\n", eptr->ex_int + 1);
*/
if (!(expr->exp_error & EE_NOVAR)) {
- post("expr: syntax error: no string for inlet %d", eptr->ex_int + 1);
+ post("expr: syntax error: no string for inlet %ld", eptr->ex_int+1);
post("expr: No more table errors will be reported");
post("expr: till the next reset");
expr->exp_error |= EE_NOVAR;
}
novar++;
- } else
- var = (char *) expr->exp_var[eptr->ex_int].ex_ptr;
+ } else var = (char *) expr->exp_var[eptr->ex_int].ex_ptr;
} else if (eptr->ex_type == ET_VAR)
var = (char *) eptr->ex_ptr;
- else {
- post_error((fts_object_t *) expr, "expr: eval_tbl: bad type %ld\n", eptr->ex_type);
- novar++;
-
- }
-
+ else {post_error((fts_object_t *) expr, "expr: eval_tbl: bad type %ld\n", eptr->ex_type); novar++;}
optr->ex_type = ET_INT;
optr->ex_int = 0;
- if (!novar)
- (void)max_ex_var(expr, (t_symbol *)var, optr);
- return (++eptr);
+ if (!novar) max_ex_var(expr, (t_symbol *)var, optr);
+ return ++eptr;
}
-/*
- * eval_sigidx -- evaluate the value of an indexed signal for fexpr~
- */
-struct ex_ex *
-eval_sigidx(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
-/* the expr object data pointer */
-/* the operation stack */
-/* the result pointer */
-/* the index */
-{
- struct ex_ex arg;
- struct ex_ex *reteptr;
+/* evaluate the value of an indexed signal for fexpr~ */
+ex_ex * eval_sigidx(struct expr *expr, ex_ex *eptr, ex_ex *optr, int idx) {
+ ex_ex arg;
+ ex_ex *reteptr;
int i = 0, j = 0;
- float fi = 0, /* index in float */
- rem_i = 0; /* remains of the float */
+ float fi = 0; /* index in float */
+ float rem_i = 0; /* remains of the float */
char *tbl;
-
arg.ex_type = 0;
arg.ex_int = 0;
reteptr = ex_eval(expr, eptr + 1, &arg, idx);
if (arg.ex_type == ET_FLT) {
- fi = arg.ex_flt; /* float index */
- i = (int) arg.ex_flt; /* integer index */
- rem_i = arg.ex_flt - i; /* remains of integer */
+ fi = arg.ex_flt; /* float index */
+ i = (int)arg.ex_flt; /* integer index */
+ rem_i = arg.ex_flt - i; /* remains of integer */
} else if (arg.ex_type == ET_INT) {
- fi = arg.ex_int; /* float index */
+ fi = arg.ex_int; /* float index */
i = arg.ex_int;
rem_i = 0;
- } else {
- post("eval_sigidx: bad res type (%d)", arg.ex_type);
- }
+ } else post("eval_sigidx: bad res type (%ld)", arg.ex_type);
optr->ex_type = ET_FLT;
- /*
- * indexing an input vector
- */
+ /* indexing an input vector */
if (eptr->ex_type == ET_XI) {
if (fi > 0) {
if (!(expr->exp_error & EE_BI_INPUT)) {
expr->exp_error |= EE_BI_INPUT;
- post("expr: input vector index > 0, (vector x%d[%f])",
- eptr->ex_int + 1, i + rem_i);
+ post("expr: input vector index > 0, (vector x%ld[%f])", eptr->ex_int+1, i+rem_i);
post("fexpr~: index assumed to be = 0");
post("fexpr~: no error report till next reset");
ex_print(eptr);
@@ -1443,22 +828,16 @@ eval_sigidx(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
i = 0;
rem_i = 0;
}
- if (cal_sigidx(optr, i, rem_i, idx, expr->exp_vsize,
- expr->exp_var[eptr->ex_int].ex_vec,
- expr->exp_p_var[eptr->ex_int])) {
+ if (cal_sigidx(optr, i, rem_i, idx, expr->exp_vsize, expr->exp_var[eptr->ex_int].ex_vec, expr->exp_p_var[eptr->ex_int])) {
if (!(expr->exp_error & EE_BI_INPUT)) {
expr->exp_error |= EE_BI_INPUT;
- post("expr: input vector index < -VectorSize, (vector x%d[%f])", eptr->ex_int + 1, fi);
+ post("expr: input vector index < -VectorSize, (vector x%ld[%f])", eptr->ex_int+1, fi);
ex_print(eptr);
- post("fexpr~: index assumed to be = -%d",
- expr->exp_vsize);
+ post("fexpr~: index assumed to be = -%d", expr->exp_vsize);
post("fexpr~: no error report till next reset");
}
}
-
- /*
- * indexing an output vector
- */
+ /* indexing an output vector */
} else if (eptr->ex_type == ET_YO) {
/* for output vectors index of zero is not legal */
if (fi >= 0) {
@@ -1472,266 +851,124 @@ eval_sigidx(struct expr *expr, struct ex_ex *eptr, struct ex_ex *optr, int idx)
i = -1;
}
if (eptr->ex_int >= expr->exp_nexpr) {
- post("fexpr~: $y%d illegal: not that many exprs",
- eptr->ex_int);
+ post("fexpr~: $y%ld illegal: not that many exprs", eptr->ex_int);
optr->ex_flt = 0;
- return (reteptr);
+ return reteptr;
}
- if (cal_sigidx(optr, i, rem_i, idx, expr->exp_vsize,
- expr->exp_tmpres[eptr->ex_int],
- expr->exp_p_res[eptr->ex_int])) {
+ if (cal_sigidx(optr, i, rem_i, idx, expr->exp_vsize, expr->exp_tmpres[eptr->ex_int], expr->exp_p_res[eptr->ex_int])) {
if (!(expr->exp_error & EE_BI_OUTPUT)) {
expr->exp_error |= EE_BI_OUTPUT;
post("fexpr~: bad output index, (%f)", fi);
ex_print(eptr);
- post("fexpr~: index assumed to be = -%d",
- expr->exp_vsize);
+ post("fexpr~: index assumed to be = -%d", expr->exp_vsize);
}
}
} else {
optr->ex_flt = 0;
- post("fexpr~:eval_sigidx: internal error - unknown vector (%d)",
- eptr->ex_type);
+ post("fexpr~:eval_sigidx: internal error - unknown vector (%ld)", eptr->ex_type);
}
- return (reteptr);
+ return reteptr;
}
-/*
- * cal_sigidx -- given two tables (one current one previous) calculate an
- * evaluation of a float index into the vectors by linear
- * interpolation
- * return 0 on success, 1 on failure (index out of bound)
- */
-static int
-cal_sigidx(struct ex_ex *optr, /* The output value */
+/* given two tables (one current one previous) calculate an evaluation of a float index into the vectors by linear interpolation
+ * return 0 on success, 1 on failure (index out of bound) */
+static int cal_sigidx(ex_ex *optr, /* The output value */
int i, float rem_i, /* integer and fractinal part of index */
int idx, /* index of current fexpr~ processing */
int vsize, /* vector size */
float *curvec, float *prevec) /* current and previous table */
{
int n;
-
n = i + idx;
if (n > 0) {
/* from the curvec */
- if (rem_i)
- optr->ex_flt = curvec[n] +
- rem_i * (curvec[n] - curvec[n - 1]);
- else
- optr->ex_flt = curvec[n];
- return (0);
+ if (rem_i) optr->ex_flt = curvec[n] + rem_i*(curvec[n]-curvec[n-1]);
+ else optr->ex_flt = curvec[n];
+ return 0;
}
if (n == 0) {
- /*
- * this is the case that the remaining float
- * is between two tables
- */
- if (rem_i)
- optr->ex_flt = *curvec +
- rem_i * (*curvec - prevec[vsize - 1]);
- else
- optr->ex_flt = *curvec;
- return (0);
+ /* this is the case that the remaining float is between two tables */
+ if (rem_i) optr->ex_flt = *curvec + rem_i*(*curvec-prevec[vsize-1]);
+ else optr->ex_flt = *curvec;
+ return 0;
}
/* find the index in the saved buffer */
n = vsize + n;
if (n > 0) {
- if (rem_i)
- optr->ex_flt = prevec[n] +
- rem_i * (prevec[n] - prevec[n - 1]);
- else
- optr->ex_flt = prevec[n];
- return (0);
+ if (rem_i) optr->ex_flt = prevec[n] + rem_i*(prevec[n]-prevec[n-1]);
+ else optr->ex_flt = prevec[n];
+ return 0;
}
/* out of bound */
optr->ex_flt = *prevec;
- return (1);
+ return 1;
}
-/*
- * getoken -- return 1 on syntax error otherwise 0
- */
-int
-getoken(struct expr *expr, struct ex_ex *eptr)
-{
+/* return 1 on syntax error otherwise 0 */
+int getoken(struct expr *expr, ex_ex *eptr) {
char *p;
long i;
-
-
- if (!expr->exp_str) {
- post("expr: getoken: expression string not set\n");
- return (0);
- }
+ if (!expr->exp_str) {post("expr: getoken: expression string not set\n"); return 0;}
retry:
- if (!*expr->exp_str) {
- eptr->ex_type = 0;
- eptr->ex_int = 0;
- return (0);
- }
- if (*expr->exp_str == ';') {
- expr->exp_str++;
- eptr->ex_type = 0;
- eptr->ex_int = 0;
- return (0);
- }
+ if (!*expr->exp_str) { eptr->ex_type = 0; eptr->ex_int = 0; return 0;}
+ if (*expr->exp_str == ';') {expr->exp_str++; eptr->ex_type = 0; eptr->ex_int = 0; return 0;}
eptr->ex_type = ET_OP;
switch (*expr->exp_str++) {
- case '\\':
- case ' ':
- case '\t':
- goto retry;
- case ';':
- post("expr: syntax error: ';' not implemented\n");
- return (1);
- case ',':
- eptr->ex_op = OP_COMMA;
- break;
- case '(':
- eptr->ex_op = OP_LP;
- break;
- case ')':
- eptr->ex_op = OP_RP;
- break;
- case ']':
- eptr->ex_op = OP_RB;
- break;
- case '~':
- eptr->ex_op = OP_NEG;
- break;
- /* we will take care of unary minus later */
- case '*':
- eptr->ex_op = OP_MUL;
- break;
- case '/':
- eptr->ex_op = OP_DIV;
- break;
- case '%':
- eptr->ex_op = OP_MOD;
- break;
- case '+':
- eptr->ex_op = OP_ADD;
- break;
- case '-':
- eptr->ex_op = OP_SUB;
- break;
- case '^':
- eptr->ex_op = OP_XOR;
- break;
- case '[':
- eptr->ex_op = OP_LB;
- break;
- case '!':
- if (*expr->exp_str == '=') {
- eptr->ex_op = OP_NE;
- expr->exp_str++;
- } else
- eptr->ex_op = OP_NOT;
- break;
- case '<':
- switch (*expr->exp_str) {
- case '<':
- eptr->ex_op = OP_SL;
- expr->exp_str++;
- break;
- case '=':
- eptr->ex_op = OP_LE;
- expr->exp_str++;
- break;
- default:
- eptr->ex_op = OP_LT;
- break;
- }
- break;
- case '>':
- switch (*expr->exp_str) {
- case '>':
- eptr->ex_op = OP_SR;
- expr->exp_str++;
- break;
- case '=':
- eptr->ex_op = OP_GE;
- expr->exp_str++;
- break;
- default:
- eptr->ex_op = OP_GT;
- break;
- }
- break;
- case '=':
- if (*expr->exp_str++ != '=') {
- post("expr: syntax error: =\n");
- return (1);
- }
+ case '\\': case ' ': case '\t': goto retry;
+ case ';': post("expr: syntax error: ';' not implemented\n"); return 1;
+ case ',': eptr->ex_op = OP_COMMA; break;
+ case '(': eptr->ex_op = OP_LP; break;
+ case ')': eptr->ex_op = OP_RP; break;
+ case ']': eptr->ex_op = OP_RB; break;
+ case '~': eptr->ex_op = OP_NEG; break; /* we will take care of unary minus later */
+ case '*': eptr->ex_op = OP_MUL; break;
+ case '/': eptr->ex_op = OP_DIV; break;
+ case '%': eptr->ex_op = OP_MOD; break;
+ case '+': eptr->ex_op = OP_ADD; break;
+ case '-': eptr->ex_op = OP_SUB; break;
+ case '^': eptr->ex_op = OP_XOR; break;
+ case '[': eptr->ex_op = OP_LB; break;
+ case '!': if (*expr->exp_str == '=') {eptr->ex_op = OP_NE; expr->exp_str++;} else eptr->ex_op = OP_NOT; break;
+ case '<': switch (*expr->exp_str) {
+ case '<': eptr->ex_op = OP_SL; expr->exp_str++; break;
+ case '=': eptr->ex_op = OP_LE; expr->exp_str++; break;
+ default: eptr->ex_op = OP_LT; break;
+ } break;
+ case '>': switch (*expr->exp_str) {
+ case '>': eptr->ex_op = OP_SR; expr->exp_str++; break;
+ case '=': eptr->ex_op = OP_GE; expr->exp_str++; break;
+ default: eptr->ex_op = OP_GT; break;
+ } break;
+ case '=': if (*expr->exp_str++ != '=') {post("expr: syntax error: =\n"); return 1;}
eptr->ex_op = OP_EQ;
break;
-/* do not allow the store till the function is fixed
- if (*expr->exp_str != '=')
- eptr->ex_op = OP_STORE;
- else {
- expr->exp_str++;
- eptr->ex_op = OP_EQ;
- }
- break;
-*/
-
- case '&':
- if (*expr->exp_str == '&') {
- expr->exp_str++;
- eptr->ex_op = OP_LAND;
- } else
- eptr->ex_op = OP_AND;
- break;
-
- case '|':
- if ((*expr->exp_str == '|')) {
- expr->exp_str++;
- eptr->ex_op = OP_LOR;
- } else
- eptr->ex_op = OP_OR;
- break;
- case '$':
- switch (*expr->exp_str++) {
- case 'I':
- case 'i':
- eptr->ex_type = ET_II;
- break;
- case 'F':
- case 'f':
- eptr->ex_type = ET_FI;
- break;
- case 'S':
- case 's':
- eptr->ex_type = ET_SI;
- break;
- case 'V':
- case 'v':
- if (IS_EXPR_TILDE(expr)) {
- eptr->ex_type = ET_VI;
- break;
- }
+ case '&': if (*expr->exp_str == '&') {expr->exp_str++; eptr->ex_op = OP_LAND;} else eptr->ex_op = OP_AND; break;
+ case '|': if (*expr->exp_str == '|') {expr->exp_str++; eptr->ex_op = OP_LOR; } else eptr->ex_op = OP_OR; break;
+ case '$': switch (*expr->exp_str++) {
+ case 'I': case 'i': eptr->ex_type = ET_II; break;
+ case 'F': case 'f': eptr->ex_type = ET_FI; break;
+ case 'S': case 's': eptr->ex_type = ET_SI; break;
+ case 'V': case 'v':
+ if (IS_EXPR_TILDE(expr)) {eptr->ex_type = ET_VI; break;}
post("$v? works only for expr~");
post("expr: syntax error: %s\n", &expr->exp_str[-2]);
- return (1);
- case 'X':
- case 'x':
+ return 1;
+ case 'X': case 'x':
if (IS_FEXPR_TILDE(expr)) {
eptr->ex_type = ET_XI;
- if (isdigit(*expr->exp_str))
- break;
+ if (isdigit(*expr->exp_str)) break;
/* for $x[] is a shorhand for $x1[] */
eptr->ex_int = 0;
goto noinletnum;
}
post("$x? works only for fexpr~");
post("expr: syntax error: %s\n", &expr->exp_str[-2]);
- return (1);
- case 'y':
- case 'Y':
+ return 1;
+ case 'y': case 'Y':
if (IS_FEXPR_TILDE(expr)) {
eptr->ex_type = ET_YO;
/*$y takes no number */
- if (isdigit(*expr->exp_str))
- break;
+ if (isdigit(*expr->exp_str)) break;
/* for $y[] is a shorhand for $y1[] */
eptr->ex_int = 0;
goto noinletnum;
@@ -1739,71 +976,51 @@ retry:
post("$y works only for fexpr~");
default:
post("expr: syntax error: %s\n", &expr->exp_str[-2]);
- return (1);
+ return 1;
}
p = atoif(expr->exp_str, &eptr->ex_op, &i);
- if (!p) {
- post("expr: syntax error: %s\n", &expr->exp_str[-2]);
- return (1);
- }
- if (i != ET_INT) {
- post("expr: syntax error: %s\n", expr->exp_str);
- return (1);
- }
- /*
- * make the user inlets one based rather than zero based
- * therefore we decrement the number that user has supplied
- */
+ if (!p) {post("expr: syntax error: %s\n", &expr->exp_str[-2]); return 1;}
+ if (i != ET_INT) {post("expr: syntax error: %s\n", expr->exp_str); return 1;}
+ /* make the user inlets one based rather than zero based
+ * therefore we decrement the number that user has supplied */
if (!eptr->ex_op || (eptr->ex_op)-- > MAX_VARS) {
- post("expr: syntax error: inlet or outlet out of range: %s\n",
- expr->exp_str);
- return (1);
+ post("expr: syntax error: inlet or outlet out of range: %s\n", expr->exp_str);
+ return 1;
}
- /*
- * until we can change the input type of inlets on
- * the fly (at pd_new()
- * time) the first input to expr~ is always a vectore
- * and $f1 or $i1 is
- * illegal for fexr~
- */
- if (eptr->ex_op == 0 &&
- (IS_FEXPR_TILDE(expr) || IS_EXPR_TILDE(expr)) &&
- (eptr->ex_type==ET_II || eptr->ex_type==ET_FI ||
- eptr->ex_type==ET_SI)) {
+ /* until we can change the input type of inlets on the fly (at pd_new() time)
+ * the first input to expr~ is always a vector and $f1 or $i1 is illegal for fexpr~ */
+ if (eptr->ex_op == 0 && (IS_FEXPR_TILDE(expr) || IS_EXPR_TILDE(expr)) &&
+ (eptr->ex_type==ET_II || eptr->ex_type==ET_FI || eptr->ex_type==ET_SI)) {
post("first inlet of expr~/fexpr~ can only be a vector");
- return (1);
+ return 1;
}
/* record the inlet or outlet type and check for consistency */
if (eptr->ex_type == ET_YO ) {
- /* it is an outlet for fexpr~*/
+ /* it is an outlet for fexpr~*/
/* no need to do anything */
- ;
} else if (!expr->exp_var[eptr->ex_op].ex_type)
expr->exp_var[eptr->ex_op].ex_type = eptr->ex_type;
else if (expr->exp_var[eptr->ex_op].ex_type != eptr->ex_type) {
post("expr: syntax error: inlets can only have one type: %s\n", expr->exp_str);
- return (1);
+ return 1;
}
expr->exp_str = p;
noinletnum:
break;
- case '"':
- {
- struct ex_ex ex;
-
+ case '"': {
+ ex_ex ex;
p = expr->exp_str;
if (!*expr->exp_str || *expr->exp_str == '"') {
post("expr: syntax error: empty symbol: %s\n", --expr->exp_str);
- return (1);
+ return 1;
}
- if (getoken(expr, &ex))
- return (1);
+ if (getoken(expr, &ex)) return 1;
switch (ex.ex_type) {
case ET_STR:
if (ex_getsym(ex.ex_ptr, (t_symbol **)&(eptr->ex_ptr))) {
post("expr: syntax error: getoken: problms with ex_getsym\n");
- return (1);
+ return 1;
}
eptr->ex_type = ET_SYM;
break;
@@ -1813,96 +1030,53 @@ noinletnum:
break;
default:
post("expr: syntax error: bad symbol name: %s\n", p);
- return (1);
- }
- if (*expr->exp_str++ != '"') {
- post("expr: syntax error: missing '\"'\n");
- return (1);
+ return 1;
}
+ if (*expr->exp_str++ != '"') {post("expr: syntax error: missing '\"'\n"); return 1;}
break;
}
case '.':
- case '0':
- case '1':
- case '2':
- case '3':
- case '4':
- case '5':
- case '6':
- case '7':
- case '8':
- case '9':
+ case '0': case '1': case '2': case '3': case '4':
+ case '5': case '6': case '7': case '8': case '9':
p = atoif(--expr->exp_str, &eptr->ex_int, &eptr->ex_type);
- if (!p)
- return (1);
+ if (!p) return 1;
expr->exp_str = p;
break;
-
- default:
- /*
- * has to be a string, it should either be a
- * function or a table
- */
+ default: /* has to be a string, it should either be a function or a table */
p = --expr->exp_str;
- for (i = 0; name_ok(*p); i++)
- p++;
- if (!i) {
- post("expr: syntax error: %s\n", expr->exp_str);
- return (1);
- }
+ for (i = 0; name_ok(*p); i++) p++;
+ if (!i) {post("expr: syntax error: %s\n", expr->exp_str); return 1;}
eptr->ex_ptr = (char *)fts_malloc(i + 1);
strncpy(eptr->ex_ptr, expr->exp_str, (int) i);
(eptr->ex_ptr)[i] = 0;
expr->exp_str = p;
- /*
- * we mark this as a string and later we will change this
- * to either a function or a table
- */
+ /* we mark this as a string and later we will change this to either a function or a table */
eptr->ex_type = ET_STR;
break;
}
- return (0);
+ return 0;
}
-/*
- * atoif -- ascii to float or integer (understands hex numbers also)
- */
-char *
-atoif(char *s, long int *value, long int *type)
-{
+/* ascii to float or integer (understands hex numbers also) */
+char *atoif(char *s, long int *value, long int *type) {
char *p;
long int_val = 0;
int flt = 0;
float pos = 0;
float flt_val = 0;
int base = 10;
-
p = s;
- if (*p == '0' && (p[1] == 'x' || p[1] == 'X')) {
- base = 16;
- p += 2;
- }
- while (8) {
+ if (*p == '0' && (p[1] == 'x' || p[1] == 'X')) {base = 16; p += 2;}
+ for (;;) {
switch (*p) {
case '.':
- if (flt || base != 10) {
- post("expr: syntax error: %s\n", s);
- return ((char *) 0);
- }
+ if (flt || base != 10) {post("expr: syntax error: %s\n", s); return 0;}
flt++;
pos = 10;
flt_val = int_val;
break;
- case '0':
- case '1':
- case '2':
- case '3':
- case '4':
- case '5':
- case '6':
- case '7':
- case '8':
- case '9':
+ case '0': case '1': case '2': case '3': case '4':
+ case '5': case '6': case '7': case '8': case '9':
if (flt) {
flt_val += (*p - '0') / pos;
pos *= 10;
@@ -1911,226 +1085,85 @@ atoif(char *s, long int *value, long int *type)
int_val += (*p - '0');
}
break;
- case 'a':
- case 'b':
- case 'c':
- case 'd':
- case 'e':
- case 'f':
- if (base != 16 || flt) {
- post("expr: syntax error: %s\n", s);
- return ((char *) 0);
- }
+ case 'a': case 'b': case 'c': case 'd': case 'e': case 'f':
+ if (base != 16 || flt) {post("expr: syntax error: %s\n", s); return 0;}
int_val *= base;
int_val += (*p - 'a' + 10);
break;
- case 'A':
- case 'B':
- case 'C':
- case 'D':
- case 'E':
- case 'F':
- if (base != 16 || flt) {
- post("expr: syntax error: %s\n", s);
- return ((char *) 0);
- }
+ case 'A': case 'B': case 'C': case 'D': case 'E': case 'F':
+ if (base != 16 || flt) {post("expr: syntax error: %s\n", s); return 0;}
int_val *= base;
int_val += (*p - 'A' + 10);
break;
default:
- if (flt) {
- *type = ET_FLT;
- *((float *) value) = flt_val;
- } else {
- *type = ET_INT;
- *value = int_val;
- }
- return (p);
+ if (flt) {*type = ET_FLT; *((float *)value) = flt_val;}
+ else {*type = ET_INT; * value = int_val;}
+ return p;
}
p++;
}
}
-/*
- * find_func -- returns a pointer to the found function structure
- * otherwise it returns 0
- */
-t_ex_func *
-find_func(char *s)
-{
+/* returns a pointer to the found function structure otherwise it returns 0 */
+t_ex_func *find_func(char *s) {
t_ex_func *f;
-
- for (f = ex_funcs; f->f_name; f++)
- if (!strcmp(f->f_name, s))
- return (f);
- return ((t_ex_func *) 0);
+ for (f = ex_funcs; f->f_name; f++) if (!strcmp(f->f_name, s)) return f;
+ return 0;
}
-
-/*
- * ex_print -- print an expression array
- */
-
-void
-ex_print(struct ex_ex *eptr)
-{
-
+/* print an expression array */
+void ex_print(ex_ex *eptr) {
while (eptr->ex_type) {
switch (eptr->ex_type) {
- case ET_INT:
- post("%ld ", eptr->ex_int);
- break;
- case ET_FLT:
- post("%f ", eptr->ex_flt);
- break;
- case ET_STR:
- post("%s ", eptr->ex_ptr);
- break;
- case ET_TBL:
- case ET_VAR:
- post("%s ", ex_symname((fts_symbol_t )eptr->ex_ptr));
- break;
- case ET_SYM:
- post("\"%s\" ", ex_symname((fts_symbol_t )eptr->ex_ptr));
- break;
- case ET_VSYM:
- post("\"$s%ld\" ", eptr->ex_int + 1);
- break;
- case ET_FUNC:
- post("%s ",
- ((t_ex_func *)eptr->ex_ptr)->f_name);
- break;
- case ET_LP:
- post("%c", '(');
- break;
- /* CHANGE
- case ET_RP:
- post("%c ", ')');
- break;
- */
- case ET_LB:
- post("%c", '[');
- break;
- /* CHANGE
- case ET_RB:
- post("%c ", ']');
- break;
- */
- case ET_II:
- post("$i%ld ", eptr->ex_int + 1);
- break;
- case ET_FI:
- post("$f%ld ", eptr->ex_int + 1);
- break;
- case ET_SI:
- post("$s%lx ", eptr->ex_ptr);
- break;
- case ET_VI:
- post("$v%lx ", eptr->ex_vec);
- break;
- case ET_VEC:
- post("vec = %ld ", eptr->ex_vec);
- break;
- case ET_YOM1:
- case ET_YO:
- post("$y%d", eptr->ex_int + 1);
- break;
- case ET_XI:
- case ET_XI0:
- post("$x%d", eptr->ex_int + 1);
- break;
- case ET_OP:
- switch (eptr->ex_op) {
- case OP_LP:
- post("%c", '(');
- break;
- case OP_RP:
- post("%c ", ')');
- break;
- case OP_LB:
- post("%c", '[');
- break;
- case OP_RB:
- post("%c ", ']');
- break;
- case OP_NOT:
- post("%c", '!');
- break;
- case OP_NEG:
- post("%c", '~');
- break;
- case OP_UMINUS:
- post("%c", '-');
- break;
- case OP_MUL:
- post("%c", '*');
- break;
- case OP_DIV:
- post("%c", '/');
- break;
- case OP_MOD:
- post("%c", '%');
- break;
- case OP_ADD:
- post("%c", '+');
- break;
- case OP_SUB:
- post("%c", '-');
- break;
- case OP_SL:
- post("%s", "<<");
- break;
- case OP_SR:
- post("%s", ">>");
- break;
- case OP_LT:
- post("%c", '<');
- break;
- case OP_LE:
- post("%s", "<=");
- break;
- case OP_GT:
- post("%c", '>');
- break;
- case OP_GE:
- post("%s", ">=");
- break;
- case OP_EQ:
- post("%s", "==");
- break;
- case OP_STORE:
- post("%s", "=");
- break;
- case OP_NE:
- post("%s", "!=");
- break;
- case OP_AND:
- post("%c", '&');
- break;
- case OP_XOR:
- post("%c", '^');
- break;
- case OP_OR:
- post("%c", '|');
- break;
- case OP_LAND:
- post("%s", "&&");
- break;
- case OP_LOR:
- post("%s", "||");
- break;
- case OP_COMMA:
- post("%c", ',');
- break;
- case OP_SEMI:
- post("%c", ';');
- break;
- default:
- post("expr: ex_print: bad op 0x%lx\n", eptr->ex_op);
+ case ET_INT: post("%ld ", eptr->ex_int); break;
+ case ET_FLT: post("%f ", eptr->ex_flt); break;
+ case ET_STR: post("%s ", eptr->ex_ptr); break;
+ case ET_TBL: case ET_VAR: post("%s ", ex_symname((fts_symbol_t )eptr->ex_ptr)); break;
+ case ET_SYM: post("\"%s\" ", ex_symname((fts_symbol_t )eptr->ex_ptr)); break;
+ case ET_VSYM: post("\"$s%ld\" ", eptr->ex_int+1); break;
+ case ET_FUNC: post("%s ", ((t_ex_func *)eptr->ex_ptr)->f_name); break;
+ case ET_LP: post("%c", '('); break;
+ case ET_LB: post("%c", '['); break;
+ case ET_II: post("$i%ld ", eptr->ex_int + 1); break;
+ case ET_FI: post("$f%ld ", eptr->ex_int + 1); break;
+ case ET_SI: post("$s%lx ", (long)eptr->ex_ptr); break;
+ case ET_VI: post("$v%lx ", (long)eptr->ex_vec); break;
+ case ET_VEC: post("vec = %ld ", (long)eptr->ex_vec); break;
+ case ET_YOM1: case ET_YO: post("$y%ld", eptr->ex_int + 1); break;
+ case ET_XI: case ET_XI0: post("$x%ld", eptr->ex_int + 1); break;
+ case ET_OP: switch (eptr->ex_op) {
+ case OP_LP: post("%c", '('); break;
+ case OP_RP: post("%c ", ')'); break;
+ case OP_LB: post("%c", '['); break;
+ case OP_RB: post("%c ", ']'); break;
+ case OP_NOT:post("%c", '!'); break;
+ case OP_NEG:post("%c", '~'); break;
+ case OP_UMINUS: post("%c", '-'); break;
+ case OP_MUL: post("%c", '*'); break;
+ case OP_DIV: post("%c", '/'); break;
+ case OP_MOD: post("%c", '%'); break;
+ case OP_ADD: post("%c", '+'); break;
+ case OP_SUB: post("%c", '-'); break;
+ case OP_SL: post("%s", "<<"); break;
+ case OP_SR: post("%s", ">>"); break;
+ case OP_LT: post("%c", '<'); break;
+ case OP_LE: post("%s", "<="); break;
+ case OP_GT: post("%c", '>'); break;
+ case OP_GE: post("%s", ">="); break;
+ case OP_EQ: post("%s", "=="); break;
+ case OP_STORE: post("%s", "="); break;
+ case OP_NE: post("%s", "!="); break;
+ case OP_AND: post("%c", '&'); break;
+ case OP_XOR: post("%c", '^'); break;
+ case OP_OR: post("%c", '|'); break;
+ case OP_LAND:post("%s", "&&"); break;
+ case OP_LOR: post("%s", "||"); break;
+ case OP_COMMA:post("%c", ','); break;
+ case OP_SEMI: post("%c", ';'); break;
+ default: post("expr: ex_print: bad op 0x%lx\n", eptr->ex_op);
}
break;
- default:
- post("expr: ex_print: bad type 0x%lx\n", eptr->ex_type);
+ default: post("expr: ex_print: bad type 0x%lx\n", eptr->ex_type);
}
eptr++;
}