ack/lang/m2/libm2/confarray.c

68 lines
1.3 KiB
C
Raw Normal View History

1988-02-19 15:54:01 +00:00
/*
(c) copyright 1988 by the Vrije Universiteit, Amsterdam, The Netherlands.
See the copyright notice in the ACK home directory, in the file "Copyright".
*/
/*
Module: runtime support for conformant arrays
Author: Ceriel J.H. Jacobs
Version: $Header$
*/
#include <m2_traps.h>
#if EM_WSIZE==EM_PSIZE
typedef unsigned pcnt;
#else
typedef unsigned long pcnt;
#endif
1987-06-23 17:12:42 +00:00
struct descr {
char *addr;
int low;
unsigned int highminlow;
unsigned int size;
};
static struct descr *descrs[10];
static struct descr **ppdescr = descrs;
1988-06-13 10:34:14 +00:00
pcnt
new_stackptr(pdscr, a)
struct descr *pdscr;
1987-06-23 17:12:42 +00:00
{
1988-06-13 10:34:14 +00:00
register struct descr *pdescr = pdscr;
pcnt size = (((pdescr->highminlow + 1) * pdescr->size +
1987-06-23 17:12:42 +00:00
(EM_WSIZE - 1)) & ~(EM_WSIZE - 1));
if (ppdescr >= &descrs[10]) {
/* to many nested traps + handlers ! */
TRP(M2_TOOMANY);
1987-06-23 17:12:42 +00:00
}
*ppdescr++ = pdescr;
1988-06-13 10:34:14 +00:00
if ((char *) &a - (char *) &pdscr > 0) {
1987-06-23 17:12:42 +00:00
/* stack grows downwards */
1988-06-13 10:34:14 +00:00
return - size;
1987-06-23 17:12:42 +00:00
}
1988-06-13 10:34:14 +00:00
return size;
1987-06-23 17:12:42 +00:00
}
1988-06-13 10:34:14 +00:00
copy_array(pp, a)
char *pp;
1987-06-23 17:12:42 +00:00
{
1988-06-13 10:34:14 +00:00
register char *p = pp;
register char *q;
register pcnt sz;
1987-06-23 17:12:42 +00:00
char dummy;
ppdescr--;
sz = ((*ppdescr)->highminlow + 1) * (*ppdescr)->size;
1987-06-23 17:12:42 +00:00
1988-06-13 10:34:14 +00:00
if ((char *) &a - (char *) &pp > 0) {
(*ppdescr)->addr = q = (char *) &a;
1987-06-23 17:12:42 +00:00
}
else (*ppdescr)->addr = q = (char *) &a -
((sz + (EM_WSIZE - 1)) & ~ (EM_WSIZE - 1));
1987-06-23 17:12:42 +00:00
while (sz--) *q++ = *p++;
}