confarray.c

来自「Minix比较全的源码」· C语言 代码 · 共 73 行

C
73
字号
/*  (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>#ifndef EM_WSIZE#define EM_WSIZE _EM_WSIZE#define EM_PSIZE _EM_PSIZE#endif#if EM_WSIZE==EM_PSIZEtypedef unsigned pcnt;#elsetypedef unsigned long pcnt;#endifstruct descr {	char *addr;	int low;	unsigned int highminlow;	unsigned int size;};static struct descr *descrs[10];static struct descr **ppdescr = descrs;pcntnew_stackptr(pdscr, a)	struct descr *pdscr;{	register struct descr *pdescr = pdscr;	pcnt size = (((pdescr->highminlow + 1) * pdescr->size +				(EM_WSIZE - 1)) & ~(EM_WSIZE - 1));	if (ppdescr >= &descrs[10]) {		/* to many nested traps + handlers ! */		TRP(M2_TOOMANY);	}	*ppdescr++ = pdescr;	if ((char *) &a - (char *) &pdscr > 0) {		/* stack grows downwards */		return - size;	}	return size;}copy_array(pp, a)	char *pp;{	register char *p = pp;	register char *q;	register pcnt sz;	char dummy;	ppdescr--;	sz = ((*ppdescr)->highminlow + 1) * (*ppdescr)->size;		if ((char *) &a - (char *) &pp > 0) {		(*ppdescr)->addr = q = (char *) &a;	}	else	(*ppdescr)->addr = q = (char *) &a - 			((sz + (EM_WSIZE - 1)) & ~ (EM_WSIZE - 1));	while (sz--) *q++ = *p++;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?