X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/e6692e68ddfe1ef3234cacab53edb44277ae4405..9d0bdd2e04d23fbcc1db6e7e525cf79979c4643b:/include/xbt/heap.h diff --git a/include/xbt/heap.h b/include/xbt/heap.h index 2b44138e67..8ab575331d 100644 --- a/include/xbt/heap.h +++ b/include/xbt/heap.h @@ -1,6 +1,5 @@ -/* $Id$ */ - -/* Copyright (c) 2004 Arnaud Legrand. All rights reserved. */ +/* Copyright (c) 2004-2007, 2009-2011, 2013-2015. The SimGrid Team. + * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -9,20 +8,44 @@ #define _XBT_HEAP_H #include "xbt/misc.h" +#include "xbt/dynar.h" /* void_f_pvoid_t */ -/** \brief Heap data type - \ingroup XBT_heap -*/ -typedef struct xbt_heap *xbt_heap_t; - -xbt_heap_t xbt_heap_new(int num, void_f_pvoid_t free_func); -void xbt_heap_free(xbt_heap_t H); -int xbt_heap_size(xbt_heap_t H); +SG_BEGIN_DECL() -void xbt_heap_push(xbt_heap_t H, void *content, double key); -void *xbt_heap_pop(xbt_heap_t H); - -double xbt_heap_maxkey(xbt_heap_t H); -void *xbt_heap_maxcontent(xbt_heap_t H); +/** @addtogroup XBT_heap + * @brief This section describes the API to generic heap with O(log(n)) access. + * + * @{ + */ +/* @brief heap datatype */ +typedef struct xbt_heap *xbt_heap_t; -#endif /* _XBT_HEAP_H */ +XBT_PUBLIC(xbt_heap_t) xbt_heap_new(int init_size, void_f_pvoid_t const free_func); +XBT_PUBLIC(void) xbt_heap_free(xbt_heap_t H); +XBT_PUBLIC(int) xbt_heap_size(xbt_heap_t H); + +XBT_PUBLIC(void) xbt_heap_push(xbt_heap_t H, void *content, double key); +XBT_PUBLIC(void *) xbt_heap_pop(xbt_heap_t H); +XBT_PUBLIC(void) xbt_heap_rm_elm(xbt_heap_t H, void *content, double key); + +XBT_PUBLIC(double) xbt_heap_maxkey(xbt_heap_t H); +XBT_PUBLIC(void *) xbt_heap_maxcontent(xbt_heap_t H); +XBT_PUBLIC(void) xbt_heap_set_update_callback(xbt_heap_t H, void (*update_callback) (void*, int)); +XBT_PUBLIC(void *) xbt_heap_remove(xbt_heap_t H, int i); +XBT_PUBLIC(void ) xbt_heap_update(xbt_heap_t H, int i, double key); + +/* @} */ +SG_END_DECL() + +#ifdef __cplusplus +namespace simgrid { +namespace xbt { + inline void destroy(xbt_heap_t h) + { + xbt_heap_free(h); + } +} +} +#endif + +#endif /* _XBT_HEAP_H */