X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c5d0a2b0b3b1bba7f39946169f3ab2f63bcdd28a..273f840b0cbfdf3ce198781ad3c7ea195eac7135:/include/xbt/swag.h diff --git a/include/xbt/swag.h b/include/xbt/swag.h index caa54e5afa..82f723fd6a 100644 --- a/include/xbt/swag.h +++ b/include/xbt/swag.h @@ -13,7 +13,9 @@ #define _XBT_SWAG_H #include "xbt/misc.h" -#include "xbt/sysdep.h" /* sizeof */ +#include "xbt/sysdep.h" /* size_t */ + +SG_BEGIN_DECL() /** * @addtogroup XBT_swag @@ -26,7 +28,6 @@ * no call to malloc/free is done. * */ - /** @defgroup XBT_swag_type Swag types @ingroup XBT_swag @@ -38,10 +39,10 @@ those structs directly. Use them as an abstract datatype. */ /* @{ */ -typedef struct xbt_swag_hookup { - void *next; - void *prev; -} s_xbt_swag_hookup_t; + typedef struct xbt_swag_hookup { + void *next; + void *prev; + } s_xbt_swag_hookup_t; /**< This type should be added to a type that is to be used in a swag. * * Whenever a new object with this struct is created, all fields have @@ -68,15 +69,15 @@ typedef struct foo { } \endcode */ -typedef s_xbt_swag_hookup_t *xbt_swag_hookup_t; + typedef s_xbt_swag_hookup_t *xbt_swag_hookup_t; -typedef struct xbt_swag { - void *head; - void *tail; - size_t offset; - int count; -} s_xbt_swag_t, *xbt_swag_t; + typedef struct xbt_swag { + void *head; + void *tail; + size_t offset; + int count; + } s_xbt_swag_t, *xbt_swag_t; /**< A typical swag */ /* @} */ @@ -86,24 +87,29 @@ typedef struct xbt_swag { * @{ */ -xbt_swag_t xbt_swag_new(size_t offset); -void xbt_swag_free(xbt_swag_t swag); -void xbt_swag_init(xbt_swag_t swag, size_t offset); -void xbt_swag_insert(void *obj, xbt_swag_t swag); -void xbt_swag_insert_at_head(void *obj, xbt_swag_t swag); -void xbt_swag_insert_at_tail(void *obj, xbt_swag_t swag); -void *xbt_swag_remove(void *obj, xbt_swag_t swag); -void *xbt_swag_extract(xbt_swag_t swag); -int xbt_swag_size(xbt_swag_t swag); -int xbt_swag_belongs(void *obj, xbt_swag_t swag); +XBT_PUBLIC(xbt_swag_t) xbt_swag_new(size_t offset); +XBT_PUBLIC(void) xbt_swag_free(xbt_swag_t swag); +XBT_INLINE XBT_PUBLIC(void) xbt_swag_init(xbt_swag_t swag, size_t offset); +XBT_PUBLIC(void) xbt_swag_insert(void *obj, xbt_swag_t swag); +XBT_PUBLIC(void) xbt_swag_insert_at_head(void *obj, xbt_swag_t swag); +XBT_PUBLIC(void) xbt_swag_insert_at_tail(void *obj, xbt_swag_t swag); +XBT_PUBLIC(void *) xbt_swag_remove(void *obj, xbt_swag_t swag); +XBT_PUBLIC(void *) xbt_swag_extract(xbt_swag_t swag); +XBT_PUBLIC(int) xbt_swag_size(xbt_swag_t swag); + +#define xbt_swag_getNext(obj,offset) (((xbt_swag_hookup_t)(((char *) (obj)) + (offset)))->prev) +#define xbt_swag_getPrev(obj,offset) (((xbt_swag_hookup_t)(((char *) (obj)) + (offset)))->next) + +static XBT_INLINE int xbt_swag_belongs(void *obj, xbt_swag_t swag) { + return ((xbt_swag_getNext(obj, swag->offset)) || (xbt_swag_getPrev(obj, swag->offset)) + || (swag->head == obj)); +} static XBT_INLINE void *xbt_swag_getFirst(xbt_swag_t swag) { return (swag->head); } -#define xbt_swag_getNext(obj,offset) (((xbt_swag_hookup_t)(((char *) (obj)) + (offset)))->prev) -#define xbt_swag_getPrev(obj,offset) (((xbt_swag_hookup_t)(((char *) (obj)) + (offset)))->next) /** * \brief Offset computation @@ -158,4 +164,5 @@ static XBT_INLINE void *xbt_swag_getFirst(xbt_swag_t swag) (obj_next=NULL)) ) /* @} */ -#endif /* _XBT_SWAG_H */ +SG_END_DECL() +#endif /* _XBT_SWAG_H */