5  * A priority queue implementation, primarily for keeping track of
 
   6  * commits in the 'date-order' so that we process them from new to old
 
   7  * as they are discovered, but can be used to hold any pointer to
 
   8  * struct.  The caller is responsible for supplying a function to
 
   9  * compare two "things".
 
  11  * Alternatively, this data structure can also be used as a LIFO stack
 
  12  * by specifying NULL as the comparison function.
 
  16  * Compare two "things", one and two; the third parameter is cb_data
 
  17  * in the prio_queue structure.  The result is returned as a sign of
 
  18  * the return value, being the same as the sign of the result of
 
  19  * subtracting "two" from "one" (i.e. negative if "one" sorts earlier
 
  22 typedef int (*prio_queue_compare_fn)(const void *one, const void *two, void *cb_data);
 
  25         prio_queue_compare_fn compare;
 
  32  * Add the "thing" to the queue.
 
  34 extern void prio_queue_put(struct prio_queue *, void *thing);
 
  37  * Extract the "thing" that compares the smallest out of the queue,
 
  38  * or NULL.  If compare function is NULL, the queue acts as a LIFO
 
  41 extern void *prio_queue_get(struct prio_queue *);
 
  43 extern void clear_prio_queue(struct prio_queue *);
 
  45 /* Reverse the LIFO elements */
 
  46 extern void prio_queue_reverse(struct prio_queue *);
 
  48 #endif /* PRIO_QUEUE_H */