ack/lang/m2/libm2/confarray.c

59 lines
1.1 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
1994-06-24 14:02:31 +00:00
Version: $Id$
1988-02-19 15:54:01 +00:00
*/
#include "libm2.h"
#include <m2_traps.h>
#ifndef EM_WSIZE
#define EM_WSIZE _EM_WSIZE
#define EM_PSIZE _EM_PSIZE
#endif
static struct stack_descr* descrs[10];
static struct stack_descr** ppdescr = descrs;
1987-06-23 17:12:42 +00:00
size_t new_stackptr(struct stack_descr* pdescr, int a)
1987-06-23 17:12:42 +00:00
{
size_t size = (((pdescr->highminlow + 1) * pdescr->size + (EM_WSIZE - 1)) & ~(EM_WSIZE - 1));
1987-06-23 17:12:42 +00:00
if (ppdescr >= &descrs[10])
{
1987-06-23 17:12:42 +00:00
/* to many nested traps + handlers ! */
TRP(M2_TOOMANY);
1987-06-23 17:12:42 +00:00
}
*ppdescr++ = pdescr;
if ((char*)&a - (char*)&pdescr > 0)
{
1987-06-23 17:12:42 +00:00
/* stack grows downwards */
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
}
void copy_array(char* p, int a)
1987-06-23 17:12:42 +00:00
{
char* q;
size_t sz;
1987-06-23 17:12:42 +00:00
char dummy;
ppdescr--;
sz = ((*ppdescr)->highminlow + 1) * (*ppdescr)->size;
if ((char*)&a - (char*)&p > 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++;
1987-06-23 17:12:42 +00:00
}