Home | Info | Community | Development | myReactOS | Contact Us
Definition at line 166 of file priorityq-heap.c.
{ long curr; PQhandle free; curr = ++ pq->size; if( (curr*2) > pq->max ) { PQnode *saveNodes= pq->nodes; PQhandleElem *saveHandles= pq->handles; /* If the heap overflows, double its size. */ pq->max <<= 1; pq->nodes = (PQnode *)memRealloc( pq->nodes, (size_t) ((pq->max + 1) * sizeof( pq->nodes[0] ))); if (pq->nodes == NULL) { pq->nodes = saveNodes; /* restore ptr to free upon return */ return LONG_MAX; } pq->handles = (PQhandleElem *)memRealloc( pq->handles, (size_t) ((pq->max + 1) * sizeof( pq->handles[0] ))); if (pq->handles == NULL) { pq->handles = saveHandles; /* restore ptr to free upon return */ return LONG_MAX; } } if( pq->freeList == 0 ) { free = curr; } else { free = pq->freeList; pq->freeList = pq->handles[free].node; } pq->nodes[curr].handle = free; pq->handles[free].node = curr; pq->handles[free].key = keyNew; if( pq->initialized ) { FloatUp( pq, curr ); } assert(free != LONG_MAX); return free; }