It was supposed to do tail-recursion in interpret() but it didn't
compile as such. Converting it to loop makes a significant filter
performance improvement for flat filters.
interpret(struct f_inst *what)
{
struct symbol *sym;
- struct f_val v1, v2, res, *vp;
+ struct f_val v1, v2, res = { .type = T_VOID }, *vp;
unsigned u1, u2;
int i;
u32 as;
+ for ( ; what; what = what->next) {
res.type = T_VOID;
- if (!what)
- return res;
-
switch(what->fi_code) {
case FI_COMMA:
TWOARGS;
default:
bug( "Unknown instruction %d (%c)", what->fi_code, what->fi_code & 0xff);
- }
- if (what->next)
- return interpret(what->next);
+ }}
return res;
}