Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
cosmetics
[simgrid.git] / include / xbt / heap.h
1 /* Authors: Arnaud Legrand                                                  */
2
3 /* This program is free software; you can redistribute it and/or modify it
4    under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #ifndef _XBT_HEAP_H
7 #define _XBT_HEAP_H
8
9 typedef struct xbt_heap *xbt_heap_t;
10
11 /* The following two definitions concern the type of the keys used for
12    the heaps. That should be handled via configure (FIXME). */
13 typedef long double xbt_heap_float_t;
14 #define XBT_HEAP_FLOAT_T "%Lg"  /* for printing purposes */
15
16
17 /* pointer to a function freeing something (should be common to all .h : FIXME) */
18 typedef void (void_f_pvoid_t) (void *);
19
20 xbt_heap_t xbt_heap_new(int num, void_f_pvoid_t free_func);
21 void xbt_heap_free(xbt_heap_t H);
22
23 void xbt_heap_push(xbt_heap_t H, void *content, xbt_heap_float_t key);
24 void *xbt_heap_pop(xbt_heap_t H);
25
26 xbt_heap_float_t xbt_heap_maxkey(xbt_heap_t H);
27 void *xbt_heap_maxcontent(xbt_heap_t H);
28
29 #endif                          /* _XBT_HEAP_H */