1 | /* |
2 | * Copyright (c) 2000-2007 Niels Provos <provos@citi.umich.edu> |
3 | * Copyright (c) 2007-2012 Niels Provos and Nick Mathewson |
4 | * |
5 | * Redistribution and use in source and binary forms, with or without |
6 | * modification, are permitted provided that the following conditions |
7 | * are met: |
8 | * 1. Redistributions of source code must retain the above copyright |
9 | * notice, this list of conditions and the following disclaimer. |
10 | * 2. Redistributions in binary form must reproduce the above copyright |
11 | * notice, this list of conditions and the following disclaimer in the |
12 | * documentation and/or other materials provided with the distribution. |
13 | * 3. The name of the author may not be used to endorse or promote products |
14 | * derived from this software without specific prior written permission. |
15 | * |
16 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR |
17 | * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES |
18 | * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. |
19 | * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, |
20 | * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT |
21 | * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
22 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
23 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
24 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
25 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
26 | */ |
27 | #ifndef EVENT2_EVENT_COMPAT_H_INCLUDED_ |
28 | #define EVENT2_EVENT_COMPAT_H_INCLUDED_ |
29 | |
30 | /** @file event2/event_compat.h |
31 | |
32 | Potentially non-threadsafe versions of the functions in event.h: provided |
33 | only for backwards compatibility. |
34 | |
35 | In the oldest versions of Libevent, event_base was not a first-class |
36 | structure. Instead, there was a single event base that every function |
37 | manipulated. Later, when separate event bases were added, the old functions |
38 | that didn't take an event_base argument needed to work by manipulating the |
39 | "current" event base. This could lead to thread-safety issues, and obscure, |
40 | hard-to-diagnose bugs. |
41 | |
42 | @deprecated All functions in this file are by definition deprecated. |
43 | */ |
44 | #include <event2/visibility.h> |
45 | |
46 | #ifdef __cplusplus |
47 | extern "C" { |
48 | #endif |
49 | |
50 | #include <event2/event-config.h> |
51 | #ifdef EVENT__HAVE_SYS_TYPES_H |
52 | #include <sys/types.h> |
53 | #endif |
54 | #ifdef EVENT__HAVE_SYS_TIME_H |
55 | #include <sys/time.h> |
56 | #endif |
57 | |
58 | /* For int types. */ |
59 | #include <event2/util.h> |
60 | |
61 | /** |
62 | Initialize the event API. |
63 | |
64 | The event API needs to be initialized with event_init() before it can be |
65 | used. Sets the global current base that gets used for events that have no |
66 | base associated with them. |
67 | |
68 | @deprecated This function is deprecated because it replaces the "current" |
69 | event_base, and is totally unsafe for multithreaded use. The replacement |
70 | is event_base_new(). |
71 | |
72 | @see event_base_set(), event_base_new() |
73 | */ |
74 | EVENT2_EXPORT_SYMBOL |
75 | struct event_base *event_init(void); |
76 | |
77 | /** |
78 | Loop to process events. |
79 | |
80 | Like event_base_dispatch(), but uses the "current" base. |
81 | |
82 | @deprecated This function is deprecated because it is easily confused by |
83 | multiple calls to event_init(), and because it is not safe for |
84 | multithreaded use. The replacement is event_base_dispatch(). |
85 | |
86 | @see event_base_dispatch(), event_init() |
87 | */ |
88 | EVENT2_EXPORT_SYMBOL |
89 | int event_dispatch(void); |
90 | |
91 | /** |
92 | Handle events. |
93 | |
94 | This function behaves like event_base_loop(), but uses the "current" base |
95 | |
96 | @deprecated This function is deprecated because it uses the event base from |
97 | the last call to event_init, and is therefore not safe for multithreaded |
98 | use. The replacement is event_base_loop(). |
99 | |
100 | @see event_base_loop(), event_init() |
101 | */ |
102 | EVENT2_EXPORT_SYMBOL |
103 | int event_loop(int); |
104 | |
105 | |
106 | /** |
107 | Exit the event loop after the specified time. |
108 | |
109 | This function behaves like event_base_loopexit(), except that it uses the |
110 | "current" base. |
111 | |
112 | @deprecated This function is deprecated because it uses the event base from |
113 | the last call to event_init, and is therefore not safe for multithreaded |
114 | use. The replacement is event_base_loopexit(). |
115 | |
116 | @see event_init, event_base_loopexit() |
117 | */ |
118 | EVENT2_EXPORT_SYMBOL |
119 | int event_loopexit(const struct timeval *); |
120 | |
121 | |
122 | /** |
123 | Abort the active event_loop() immediately. |
124 | |
125 | This function behaves like event_base_loopbreakt(), except that it uses the |
126 | "current" base. |
127 | |
128 | @deprecated This function is deprecated because it uses the event base from |
129 | the last call to event_init, and is therefore not safe for multithreaded |
130 | use. The replacement is event_base_loopbreak(). |
131 | |
132 | @see event_base_loopbreak(), event_init() |
133 | */ |
134 | EVENT2_EXPORT_SYMBOL |
135 | int event_loopbreak(void); |
136 | |
137 | /** |
138 | Schedule a one-time event to occur. |
139 | |
140 | @deprecated This function is obsolete, and has been replaced by |
141 | event_base_once(). Its use is deprecated because it relies on the |
142 | "current" base configured by event_init(). |
143 | |
144 | @see event_base_once() |
145 | */ |
146 | EVENT2_EXPORT_SYMBOL |
147 | int event_once(evutil_socket_t , short, |
148 | void (*)(evutil_socket_t, short, void *), void *, const struct timeval *); |
149 | |
150 | |
151 | /** |
152 | Get the kernel event notification mechanism used by Libevent. |
153 | |
154 | @deprecated This function is obsolete, and has been replaced by |
155 | event_base_get_method(). Its use is deprecated because it relies on the |
156 | "current" base configured by event_init(). |
157 | |
158 | @see event_base_get_method() |
159 | */ |
160 | EVENT2_EXPORT_SYMBOL |
161 | const char *event_get_method(void); |
162 | |
163 | |
164 | /** |
165 | Set the number of different event priorities. |
166 | |
167 | @deprecated This function is deprecated because it is easily confused by |
168 | multiple calls to event_init(), and because it is not safe for |
169 | multithreaded use. The replacement is event_base_priority_init(). |
170 | |
171 | @see event_base_priority_init() |
172 | */ |
173 | EVENT2_EXPORT_SYMBOL |
174 | int event_priority_init(int); |
175 | |
176 | /** |
177 | Prepare an event structure to be added. |
178 | |
179 | @deprecated event_set() is not recommended for new code, because it requires |
180 | a subsequent call to event_base_set() to be safe under most circumstances. |
181 | Use event_assign() or event_new() instead. |
182 | */ |
183 | EVENT2_EXPORT_SYMBOL |
184 | void event_set(struct event *, evutil_socket_t, short, void (*)(evutil_socket_t, short, void *), void *); |
185 | |
186 | #define evtimer_set(ev, cb, arg) event_set((ev), -1, 0, (cb), (arg)) |
187 | #define evsignal_set(ev, x, cb, arg) \ |
188 | event_set((ev), (x), EV_SIGNAL|EV_PERSIST, (cb), (arg)) |
189 | |
190 | |
191 | /** |
192 | @name timeout_* macros |
193 | |
194 | @deprecated These macros are deprecated because their naming is inconsistent |
195 | with the rest of Libevent. Use the evtimer_* macros instead. |
196 | @{ |
197 | */ |
198 | #define timeout_add(ev, tv) event_add((ev), (tv)) |
199 | #define timeout_set(ev, cb, arg) event_set((ev), -1, 0, (cb), (arg)) |
200 | #define timeout_del(ev) event_del(ev) |
201 | #define timeout_pending(ev, tv) event_pending((ev), EV_TIMEOUT, (tv)) |
202 | #define timeout_initialized(ev) event_initialized(ev) |
203 | /**@}*/ |
204 | |
205 | /** |
206 | @name signal_* macros |
207 | |
208 | @deprecated These macros are deprecated because their naming is inconsistent |
209 | with the rest of Libevent. Use the evsignal_* macros instead. |
210 | @{ |
211 | */ |
212 | #define signal_add(ev, tv) event_add((ev), (tv)) |
213 | #define signal_set(ev, x, cb, arg) \ |
214 | event_set((ev), (x), EV_SIGNAL|EV_PERSIST, (cb), (arg)) |
215 | #define signal_del(ev) event_del(ev) |
216 | #define signal_pending(ev, tv) event_pending((ev), EV_SIGNAL, (tv)) |
217 | #define signal_initialized(ev) event_initialized(ev) |
218 | /**@}*/ |
219 | |
220 | #ifndef EVENT_FD |
221 | /* These macros are obsolete; use event_get_fd and event_get_signal instead. */ |
222 | #define EVENT_FD(ev) ((int)event_get_fd(ev)) |
223 | #define EVENT_SIGNAL(ev) event_get_signal(ev) |
224 | #endif |
225 | |
226 | #ifdef __cplusplus |
227 | } |
228 | #endif |
229 | |
230 | #endif /* EVENT2_EVENT_COMPAT_H_INCLUDED_ */ |
231 | |