4.3BSD/usr/contrib/apl/src/a3.c

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

static char Sccsid[] = "a3.c @(#)a3.c	1.1	10/1/82 Berkeley ";
#include "apl.h"

ex_miot()
{
	register struct item *p;
	register data *dp;
	register i;

	i = topfix();
	if(i < 0){
		/* must allocate something to ")reset" properly */
		*sp++ = newdat(DA, 1, 0);
		error("miot D");
	}
	p = newdat(DA, 1, i);
	dp = p->datap;
	datum = thread.iorg;
	for(; i; i--) {
		*dp++ = datum;
		datum += one;
	}
	*sp++ = p;
}

ex_mrho()
{
	register struct item *p, *q;
	register data *dp;
	int i;

	p = fetch1();
	q = newdat(DA, 1, p->rank);
	dp = q->datap;
	for(i=0; i<p->rank; i++)
		*dp++ = p->dim[i];
	pop();
	*sp++ = q;
}

ex_drho()
{
	register struct item *p, *q;
	struct item *r;
	int s, i;
	register data *dp;
	char *cp;

	p = fetch2();
	q = sp[-2];
	if(p->type != DA || p->rank > 1 || q->size < 0)
		error("rho C");

	/* Allow null vector to be reshaped if one of the
	 * dimensions is null.
	 */

	if (!q->size){
		dp = p->datap;
		for(i=0; i < p->size; i++)
			if (fix(*dp++) == 0) goto null_ok;
		error("rho C");
	}
null_ok:
	s = 1;
	dp = p->datap;
	for(i=0; i<p->size; i++){
		if (*dp < 0)		/* Negative dimensions illegal */
			error("rho C");
		s *= fix(*dp++);
	}
	r = newdat(q->type, p->size, s);
	dp = p->datap;
	for(i=0; i<p->size; i++)
		r->dim[i] = fix(*dp++);
	cp = (char *)r->datap;
	while(s > 0) {
		i = s;
		if(i > q->size)
			i = q->size;
		cp += copy(q->type, q->datap, cp, i);
		s -= i;
	}
	pop();
	pop();
	*sp++ = r;
}