Commit 938f8e32 by Carlos Martín Nieto

pqueue: support not having a comparison function

In this case, we simply behave like a vector.
parent 0bd43371
...@@ -93,7 +93,7 @@ int git_pqueue_insert(git_pqueue *pq, void *item) ...@@ -93,7 +93,7 @@ int git_pqueue_insert(git_pqueue *pq, void *item)
(void)git_pqueue_pop(pq); (void)git_pqueue_pop(pq);
} }
if (!(error = git_vector_insert(pq, item))) if (!(error = git_vector_insert(pq, item)) && pq->_cmp)
pqueue_up(pq, pq->length - 1); pqueue_up(pq, pq->length - 1);
return error; return error;
...@@ -101,9 +101,15 @@ int git_pqueue_insert(git_pqueue *pq, void *item) ...@@ -101,9 +101,15 @@ int git_pqueue_insert(git_pqueue *pq, void *item)
void *git_pqueue_pop(git_pqueue *pq) void *git_pqueue_pop(git_pqueue *pq)
{ {
void *rval = git_pqueue_get(pq, 0); void *rval;
if (git_pqueue_size(pq) > 1) { if (!pq->_cmp) {
rval = git_vector_last(pq);
} else {
rval = git_pqueue_get(pq, 0);
}
if (git_pqueue_size(pq) > 1 && pq->_cmp) {
/* move last item to top of heap, shrink, and push item down */ /* move last item to top of heap, shrink, and push item down */
pq->contents[0] = git_vector_last(pq); pq->contents[0] = git_vector_last(pq);
git_vector_pop(pq); git_vector_pop(pq);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment