Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
when using doubles, %lg should be used for scanf and %g for printf (which is
[simgrid.git] / include / xbt / swag.h
1 /*      $Id$     */
2
3 /* Copyright (c) 2004 Arnaud Legrand. All rights reserved.                */
4
5 /* This program is free software; you can redistribute it and/or modify it
6  * under the terms of the license (GNU LGPL) which comes with this package. */
7
8 /* Warning, this module is done to be efficient and performs tons of
9    cast and dirty things. So avoid using it unless you really know
10    what you are doing. */
11
12 #include "xbt/sysdep.h"
13
14 /* This type should be added to a type that is to be used in such a swag */
15 /* Whenever a new object with this struct is created, all fields have
16    to be set to NULL */
17 typedef struct xbt_swag_hookup {
18   void *next;
19   void *prev;
20 } s_xbt_swag_hookup_t, *xbt_swag_hookup_t;
21
22 typedef struct xbt_swag {
23   void *head;
24   void *tail;
25   size_t offset;
26   int count;
27 } s_xbt_swag_t, *xbt_swag_t;
28
29 xbt_swag_t xbt_swag_new(size_t offset);
30 void xbt_swag_free(xbt_swag_t swag);
31 void xbt_swag_init(xbt_swag_t swag, size_t offset);
32 void xbt_swag_insert(void *obj, xbt_swag_t swag);
33 void *xbt_swag_remove(void *obj, xbt_swag_t swag);
34 void *xbt_swag_extract(xbt_swag_t swag);
35 int xbt_swag_size(xbt_swag_t swag);
36 int xbt_swag_belongs(void *obj, xbt_swag_t swag);
37
38 static __inline__ void *xbt_swag_getFirst(xbt_swag_t swag)
39 {
40   return (swag->head);
41 }
42
43 #define xbt_swag_getNext(obj,offset) (((xbt_swag_hookup_t)(((char *) (obj)) + (offset)))->prev)
44 #define xbt_swag_getPrev(obj,offset) (((xbt_swag_hookup_t)(((char *) (obj)) + (offset)))->next)
45
46 #define xbt_swag_offset(var,field) ((char *)&( (var).field ) - (char *)&(var))
47
48 #define xbt_swag_foreach(obj,swag)                            \
49    for((obj)=xbt_swag_getFirst((swag));                       \
50        (obj)!=NULL;                                           \
51        (obj)=xbt_swag_getNext((obj),(swag)->offset))
52
53 #define xbt_swag_foreach_safe(obj,obj_next,swag)                  \
54    for((obj)=xbt_swag_getFirst((swag)),                           \
55        ((obj)?(obj_next=xbt_swag_getNext((obj),(swag)->offset)):  \
56                  (obj_next=NULL));                                \
57        (obj)!=NULL;                                               \
58        (obj)=obj_next,                                            \
59        ((obj)?(obj_next=xbt_swag_getNext((obj),(swag)->offset)):  \
60                  (obj_next=NULL))     )