V10/cmd/sno/sno4.c

Compare this file to the similar file:
Show the results in this format:

/*	@(#)sno4.c	1.1	*/
#include "sno.h"
/*
 * sno4
 */


struct node *
and (ptr)
	struct node *ptr;
{
	register struct node *a, *p;

	p = ptr;
	a = p->p1;
	if (p->typ == 0) {
		switch (a->typ) {
		case0:
		case 0:
			a->typ = 1;
		case 1:
			goto l1;
		case 3:
			fflush (stdout);
			return (syspit());
		case 5:
			a = a->p2->p1;
			goto l1;
		case 6:
			return (binstr (nfree()));
		}
		writes ("attempt to take an illegal value");
		goto case0;
	l1:
		a = copy (a->p2);
	}
	return (a);
}

struct node *
eval (e, t)
	struct node *e;
{
	struct node *list, *a2, *a3, *a4, *a3base;
	register struct node *a1, *stack, *op;

	if (rfail == 1)
		return (0);
	stack = 0;
	list = e;
	goto l1;
advanc:
	list = list->p1;
l1:
	switch (list->typ) {
		default:
		case 0:
		if (t == 1) {
			a1 = and (stack);
			goto e1;
		}
		if (stack->typ == 1)
			writes ("attempt to store in a value");
		a1 = stack->p1;
	e1:
		stack = pop (stack);
		if (stack)
			writes ("phase error");
		return (a1);
	case 12:
		a1 = and (stack);
		stack->p1 = look (a1);
		delete (a1);
		stack->typ = 0;
		goto advanc;
	case 13:
		if (stack->typ)
			writes ("illegal function");
		a1 = stack->p1;
		if (a1->typ!=5)
			writes ("illegal function");
		a1 = a1->p2;
		op = a1->p1;
		a3base = a3 = salloc();
		a3->p2 = op->p2;
		op->p2 = 0;
		a1 = a1->p2;
		a2 = list->p2;
	f1:
		if (a1!=0 && a2!=0)
			goto f2;
		if (a1!=a2)
			writes ("parameters do not match");
		op = op->p1;
		goto f3;
	f2:
		a3->p1 = a4 = salloc();
		a3 = a4;
		a3->p2 = and (a1);
		assign (a1->p1, eval (a2->p2, 1));/* recursive */
		a1 = a1->p2;
		a2 = a2->p1;
		goto f1;
	f3:
		op = execute (op); /* recursive */
		if (op)
			goto f3;
		a1 = stack->p1->p2;
		op = a1->p1;
		a3 = a3base;
		stack->p1 = op->p2;
		stack->typ = 1;
		op->p2 = a3->p2;
	f4:
		a4 = a3->p1;
		sfree (a3);
		a3 = a4;
		a1 = a1->p2;
		if (a1 == 0)
			goto advanc;
		assign (a1->p1, a3->p2);
		goto f4;
	case 11:
	case 10:
	case 9:
	case 8:
	case 7:
		a1 = and (stack);
		stack = pop (stack);
		a2 = and (stack);
		a3 = doop (list->typ, a2, a1);
		delete (a1);
		delete (a2);
		stack->p1 = a3;
		stack->typ = 1;
		goto advanc;
	case 15:
		a1 = copy (list->p2);
		a2 = (struct node *) 1;
		goto l3;
	case 14:
		a1 = list->p2;
		a2 = 0;
	l3:
		stack = push (stack);
		stack->p1 = a1;
		stack->typ = (int) a2;
		goto advanc;
	}
}

struct node *
doop (op, arg1, arg2)
	struct node *arg1, *arg2;
{
	register struct node *a1, *a2;

	a1 = arg1;
	a2 = arg2;
	switch (op) {

	case 11:
		return (div (a1, a2));
	case 10:
		return (mult (a1, a2));
	case 8:
		return (add (a1, a2));
	case 9:
		return (sub (a1, a2));
	case 7:
		return (cat (a1, a2));
	}
	return (0);
}

struct node *
execute (e)
	struct node *e;
{
	register struct node *r, *b, *c;
	struct node *m, *ca, *d, *a;

	r = e->p2;
	lc = e->ch;
	switch (e->typ) {
	case 0: /*  r g */
		a = r->p1;
		delete (eval (r->p2, 1));
		goto xsuc;
	case 1: /*  r m g */
		m = r->p1;
		a = m->p1;
		b = eval (r->p2, 1);
		c = search (m, b);
		delete (b);
		if (c == 0)
			goto xfail;
		sfree (c);
		goto xsuc;
	case 2: /*  r a g */
		ca = r->p1;
		a = ca->p1;
		b = eval (r->p2, 0);
		assign (b, eval (ca->p2, 1));
		goto xsuc;
	case 3: /*  r m a g */
		m = r->p1;
		ca = m->p1;
		a = ca->p1;
		b = eval (r->p2, 0);
		d = search (m, b->p2);
		if (d == 0)
			goto xfail;
		c = eval (ca->p2, 1);
		if (d->p1 == 0) {
			sfree (d);
			assign (b, cat (c, b->p2));
			delete (c);
			goto xsuc;
		}
		if (d->p2 == b->p2->p2) {
			assign (b, c);
			sfree (d);
			goto xsuc;
		}
		(r=salloc())->p1 = d->p2->p1;
		r->p2 = b->p2->p2;
		assign (b, cat (c, r));
		sfree (d);
		sfree (r);
		delete (c);
		goto xsuc;
	}
xsuc:
	if (rfail)
		goto xfail;
	b = a->p1;
	goto xboth;
xfail:
	rfail = 0;
	b = a->p2;
xboth:
	if (b == 0) {
		return (e->p1);
	}
	b = eval (b, 0);
	if (b == lookret)
		return (0);
	if (b == lookfret) {
		rfail = 1;
		return (0);
	}
	if (b->typ!=2)
		writes ("attempt to transfer to non-label");
	return (b->p2);
}

assign (adr, val)
	struct node *adr, *val;
{
	register struct node *a, *addr, *value;

	addr = adr;
	value = val;
	if (rfail == 1) {
		delete (value);
		return;
	}
	switch (addr->typ) {
	default:
		writes ("attempt to make an illegal assignment");
	case 0:
		addr->typ = 1;
	case 1:
		delete (addr->p2);
		addr->p2 = value;
		return;
	case 4:
		sysput (value);
		return;
	case 5:
		a = addr->p2->p1;
		delete (a->p2);
		a->p2 = value;
		return;
	}
}