~zulcss/samba/server-dailies-3.4

« back to all changes in this revision

Viewing changes to lib/tevent/tevent_util.h

  • Committer: Chuck Short
  • Date: 2010-09-28 20:38:39 UTC
  • Revision ID: zulcss@ubuntu.com-20100928203839-pgjulytsi9ue63x1
Initial version

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
   Unix SMB/CIFS implementation.
 
3
 
 
4
   Copyright (C) Andrew Tridgell 1998-2005
 
5
   Copyright (C) Jelmer Vernooij 2005
 
6
 
 
7
   This program is free software; you can redistribute it and/or modify
 
8
   it under the terms of the GNU General Public License as published by
 
9
   the Free Software Foundation; either version 3 of the License, or
 
10
   (at your option) any later version.
 
11
 
 
12
   This program is distributed in the hope that it will be useful,
 
13
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
15
   GNU General Public License for more details.
 
16
 
 
17
   You should have received a copy of the GNU General Public License
 
18
   along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
19
*/
 
20
 
 
21
/* To use these macros you must have a structure containing a next and
 
22
   prev pointer */
 
23
 
 
24
#ifndef _DLINKLIST_H
 
25
#define _DLINKLIST_H
 
26
 
 
27
 
 
28
/* hook into the front of the list */
 
29
#define DLIST_ADD(list, p) \
 
30
do { \
 
31
        if (!(list)) { \
 
32
                (list) = (p); \
 
33
                (p)->next = (p)->prev = NULL; \
 
34
        } else { \
 
35
                (list)->prev = (p); \
 
36
                (p)->next = (list); \
 
37
                (p)->prev = NULL; \
 
38
                (list) = (p); \
 
39
        }\
 
40
} while (0)
 
41
 
 
42
/* remove an element from a list - element doesn't have to be in list. */
 
43
#define DLIST_REMOVE(list, p) \
 
44
do { \
 
45
        if ((p) == (list)) { \
 
46
                (list) = (p)->next; \
 
47
                if (list) (list)->prev = NULL; \
 
48
        } else { \
 
49
                if ((p)->prev) (p)->prev->next = (p)->next; \
 
50
                if ((p)->next) (p)->next->prev = (p)->prev; \
 
51
        } \
 
52
        if ((p) != (list)) (p)->next = (p)->prev = NULL; \
 
53
} while (0)
 
54
 
 
55
/* promote an element to the top of the list */
 
56
#define DLIST_PROMOTE(list, p) \
 
57
do { \
 
58
          DLIST_REMOVE(list, p); \
 
59
          DLIST_ADD(list, p); \
 
60
} while (0)
 
61
 
 
62
/* hook into the end of the list - needs a tmp pointer */
 
63
#define DLIST_ADD_END(list, p, type) \
 
64
do { \
 
65
                if (!(list)) { \
 
66
                        (list) = (p); \
 
67
                        (p)->next = (p)->prev = NULL; \
 
68
                } else { \
 
69
                        type tmp; \
 
70
                        for (tmp = (list); tmp->next; tmp = tmp->next) ; \
 
71
                        tmp->next = (p); \
 
72
                        (p)->next = NULL; \
 
73
                        (p)->prev = tmp; \
 
74
                } \
 
75
} while (0)
 
76
 
 
77
/* insert 'p' after the given element 'el' in a list. If el is NULL then
 
78
   this is the same as a DLIST_ADD() */
 
79
#define DLIST_ADD_AFTER(list, p, el) \
 
80
do { \
 
81
        if (!(list) || !(el)) { \
 
82
                DLIST_ADD(list, p); \
 
83
        } else { \
 
84
                p->prev = el; \
 
85
                p->next = el->next; \
 
86
                el->next = p; \
 
87
                if (p->next) p->next->prev = p; \
 
88
        }\
 
89
} while (0)
 
90
 
 
91
/* demote an element to the end of the list, needs a tmp pointer */
 
92
#define DLIST_DEMOTE(list, p, tmp) \
 
93
do { \
 
94
                DLIST_REMOVE(list, p); \
 
95
                DLIST_ADD_END(list, p, tmp); \
 
96
} while (0)
 
97
 
 
98
/* concatenate two lists - putting all elements of the 2nd list at the
 
99
   end of the first list */
 
100
#define DLIST_CONCATENATE(list1, list2, type) \
 
101
do { \
 
102
                if (!(list1)) { \
 
103
                        (list1) = (list2); \
 
104
                } else { \
 
105
                        type tmp; \
 
106
                        for (tmp = (list1); tmp->next; tmp = tmp->next) ; \
 
107
                        tmp->next = (list2); \
 
108
                        if (list2) { \
 
109
                                (list2)->prev = tmp;    \
 
110
                        } \
 
111
                } \
 
112
} while (0)
 
113
 
 
114
#endif /* _DLINKLIST_H */
 
115
 
 
116
const char **ev_str_list_add(const char **list, const char *s);
 
117
int ev_set_blocking(int fd, bool set);
 
118
size_t ev_str_list_length(const char **list);
 
119
 
 
120
/* Defined here so we can build against older talloc versions that don't
 
121
 * have this define yet. */
 
122
#ifndef TALLOC_FREE
 
123
#define TALLOC_FREE(ctx) do { talloc_free(ctx); ctx=NULL; } while(0)
 
124
#endif