This is stack.c in view mode; [Download] [Up]
#include "polylistP.h"
static int BlockSize, array_size;
static Poly *mystack, *stackptr;
static int count = 0, debug = 0;
int
initstack()
{
array_size = 1;
BlockSize = 1024;
count = 0;
if ((mystack = OOGLNewN (Poly, BlockSize )) == (Poly *) NULL) return(0);
stackptr = mystack;
return(1);
}
int
push(pp)
Poly *pp;
{
register int i;
if (stackptr >= &mystack[BlockSize*array_size]) {
if (debug)
fprintf(stderr,"allocating again: size is now %d\n",array_size*BlockSize);
array_size = array_size*2;
if ((mystack = OOGLRenewN(Poly,mystack, array_size*BlockSize)) == (Poly *) NULL) return (0);
stackptr = &mystack[count];
}
*stackptr = *pp;
if ((stackptr->v = OOGLNewN(Vertex *, pp->n_vertices)) == (Vertex **) NULL)
return(0);
for (i=0; i<pp->n_vertices; ++i) stackptr->v[i] = pp->v[i];
stackptr++;
count++;
return(1);
}
int
getsize()
{
return(count);
}
Poly *
getstack()
{
return(mystack);
}
These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.