ebb 0.2.1 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/README +10 -44
- data/Rakefile +123 -0
- data/ext/ebb.c +794 -0
- data/ext/ebb.h +130 -0
- data/ext/ebb_ffi.c +575 -0
- data/ext/ebb_request_parser.c +5339 -0
- data/ext/ebb_request_parser.h +97 -0
- data/ext/ebb_request_parser.rl +513 -0
- data/{src → ext}/extconf.rb +12 -8
- data/ext/rbtree.c +408 -0
- data/ext/rbtree.h +54 -0
- data/lib/ebb.rb +311 -0
- data/lib/ebb/version.rb +4 -0
- data/libev/ev++.h +803 -0
- data/libev/ev.c +24 -6
- data/libev/ev.h +4 -0
- data/libev/ev_select.c +50 -15
- data/libev/ev_vars.h +3 -0
- data/libev/ev_win32.c +3 -0
- data/libev/ev_wrap.h +2 -0
- data/libev/event.c +403 -0
- data/libev/event.h +152 -0
- metadata +26 -40
- data/benchmark/application.rb +0 -93
- data/benchmark/server_test.rb +0 -193
- data/bin/ebb_rails +0 -4
- data/ruby_lib/ebb.rb +0 -257
- data/ruby_lib/ebb/runner.rb +0 -134
- data/ruby_lib/ebb/runner/rails.rb +0 -31
- data/ruby_lib/rack/adapter/rails.rb +0 -159
- data/src/ebb.c +0 -627
- data/src/ebb.h +0 -102
- data/src/ebb_ruby.c +0 -306
- data/src/parser.c +0 -2860
- data/src/parser.h +0 -53
- data/test/basic_test.rb +0 -46
- data/test/ebb_rails_test.rb +0 -34
- data/test/env_test.rb +0 -110
- data/test/helper.rb +0 -138
data/libev/ev.c
CHANGED
@@ -156,6 +156,7 @@ extern "C" {
|
|
156
156
|
# include <sys/wait.h>
|
157
157
|
# include <unistd.h>
|
158
158
|
#else
|
159
|
+
# include <io.h>
|
159
160
|
# define WIN32_LEAN_AND_MEAN
|
160
161
|
# include <windows.h>
|
161
162
|
# ifndef EV_SELECT_IS_WINSOCKET
|
@@ -166,7 +167,11 @@ extern "C" {
|
|
166
167
|
/* this block tries to deduce configuration from header-defined symbols and defaults */
|
167
168
|
|
168
169
|
#ifndef EV_USE_MONOTONIC
|
169
|
-
#
|
170
|
+
# if defined (_POSIX_MONOTONIC_CLOCK) && _POSIX_MONOTONIC_CLOCK >= 0
|
171
|
+
# define EV_USE_MONOTONIC 1
|
172
|
+
# else
|
173
|
+
# define EV_USE_MONOTONIC 0
|
174
|
+
# endif
|
170
175
|
#endif
|
171
176
|
|
172
177
|
#ifndef EV_USE_REALTIME
|
@@ -174,7 +179,11 @@ extern "C" {
|
|
174
179
|
#endif
|
175
180
|
|
176
181
|
#ifndef EV_USE_NANOSLEEP
|
177
|
-
#
|
182
|
+
# if _POSIX_C_SOURCE >= 199309L
|
183
|
+
# define EV_USE_NANOSLEEP 1
|
184
|
+
# else
|
185
|
+
# define EV_USE_NANOSLEEP 0
|
186
|
+
# endif
|
178
187
|
#endif
|
179
188
|
|
180
189
|
#ifndef EV_USE_SELECT
|
@@ -558,6 +567,9 @@ ev_sleep (ev_tstamp delay)
|
|
558
567
|
tv.tv_sec = (time_t)delay;
|
559
568
|
tv.tv_usec = (long)((delay - (ev_tstamp)(tv.tv_sec)) * 1e6);
|
560
569
|
|
570
|
+
/* here we rely on sys/time.h + sys/types.h + unistd.h providing select */
|
571
|
+
/* somehting nto guaranteed by newer posix versions, but guaranteed */
|
572
|
+
/* by older ones */
|
561
573
|
select (0, 0, 0, 0, &tv);
|
562
574
|
#endif
|
563
575
|
}
|
@@ -701,13 +713,13 @@ fd_reify (EV_P)
|
|
701
713
|
#if EV_SELECT_IS_WINSOCKET
|
702
714
|
if (events)
|
703
715
|
{
|
704
|
-
unsigned long
|
716
|
+
unsigned long arg;
|
705
717
|
#ifdef EV_FD_TO_WIN32_HANDLE
|
706
718
|
anfd->handle = EV_FD_TO_WIN32_HANDLE (fd);
|
707
719
|
#else
|
708
720
|
anfd->handle = _get_osfhandle (fd);
|
709
721
|
#endif
|
710
|
-
assert (("libev only supports socket fds in this configuration", ioctlsocket (anfd->handle, FIONREAD, &
|
722
|
+
assert (("libev only supports socket fds in this configuration", ioctlsocket (anfd->handle, FIONREAD, &arg) == 0));
|
711
723
|
}
|
712
724
|
#endif
|
713
725
|
|
@@ -770,7 +782,7 @@ fd_ebadf (EV_P)
|
|
770
782
|
|
771
783
|
for (fd = 0; fd < anfdmax; ++fd)
|
772
784
|
if (anfds [fd].events)
|
773
|
-
if (!fd_valid (fd)
|
785
|
+
if (!fd_valid (fd) && errno == EBADF)
|
774
786
|
fd_kill (EV_A_ fd);
|
775
787
|
}
|
776
788
|
|
@@ -977,7 +989,7 @@ void inline_speed
|
|
977
989
|
fd_intern (int fd)
|
978
990
|
{
|
979
991
|
#ifdef _WIN32
|
980
|
-
|
992
|
+
unsigned long arg = 1;
|
981
993
|
ioctlsocket (_get_osfhandle (fd), FIONBIO, &arg);
|
982
994
|
#else
|
983
995
|
fcntl (fd, F_SETFD, FD_CLOEXEC);
|
@@ -2563,6 +2575,12 @@ infy_fork (EV_P)
|
|
2563
2575
|
|
2564
2576
|
#endif
|
2565
2577
|
|
2578
|
+
#ifdef _WIN32
|
2579
|
+
# define EV_LSTAT(p,b) _stati64 (p, b)
|
2580
|
+
#else
|
2581
|
+
# define EV_LSTAT(p,b) lstat (p, b)
|
2582
|
+
#endif
|
2583
|
+
|
2566
2584
|
void
|
2567
2585
|
ev_stat_stat (EV_P_ ev_stat *w)
|
2568
2586
|
{
|
data/libev/ev.h
CHANGED
data/libev/ev_select.c
CHANGED
@@ -54,6 +54,8 @@
|
|
54
54
|
#if EV_SELECT_IS_WINSOCKET
|
55
55
|
# undef EV_SELECT_USE_FD_SET
|
56
56
|
# define EV_SELECT_USE_FD_SET 1
|
57
|
+
# undef NFDBITS
|
58
|
+
# define NFDBITS 0
|
57
59
|
#endif
|
58
60
|
|
59
61
|
#if !EV_SELECT_USE_FD_SET
|
@@ -77,15 +79,24 @@ select_modify (EV_P_ int fd, int oev, int nev)
|
|
77
79
|
int handle = fd;
|
78
80
|
#endif
|
79
81
|
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
82
|
+
/* FD_SET is broken on windows (it adds the fd to a set twice or more,
|
83
|
+
* which eventually leads to overflows). Need to call it only on changes.
|
84
|
+
*/
|
85
|
+
#if EV_SELECT_IS_WINSOCKET
|
86
|
+
if ((oev ^ nev) & EV_READ)
|
87
|
+
#endif
|
88
|
+
if (nev & EV_READ)
|
89
|
+
FD_SET (handle, (fd_set *)vec_ri);
|
90
|
+
else
|
91
|
+
FD_CLR (handle, (fd_set *)vec_ri);
|
84
92
|
|
85
|
-
if
|
86
|
-
|
87
|
-
|
88
|
-
|
93
|
+
#if EV_SELECT_IS_WINSOCKET
|
94
|
+
if ((oev ^ nev) & EV_WRITE)
|
95
|
+
#endif
|
96
|
+
if (nev & EV_WRITE)
|
97
|
+
FD_SET (handle, (fd_set *)vec_wi);
|
98
|
+
else
|
99
|
+
FD_CLR (handle, (fd_set *)vec_wi);
|
89
100
|
|
90
101
|
#else
|
91
102
|
|
@@ -100,6 +111,9 @@ select_modify (EV_P_ int fd, int oev, int nev)
|
|
100
111
|
vec_ro = ev_realloc (vec_ro, new_max * NFDBYTES); /* could free/malloc */
|
101
112
|
vec_wi = ev_realloc (vec_wi, new_max * NFDBYTES);
|
102
113
|
vec_wo = ev_realloc (vec_wo, new_max * NFDBYTES); /* could free/malloc */
|
114
|
+
#ifdef _WIN32
|
115
|
+
vec_eo = ev_realloc (vec_eo, new_max * NFDBYTES); /* could free/malloc */
|
116
|
+
#endif
|
103
117
|
|
104
118
|
for (; vec_max < new_max; ++vec_max)
|
105
119
|
((fd_mask *)vec_ri) [vec_max] =
|
@@ -122,19 +136,31 @@ select_poll (EV_P_ ev_tstamp timeout)
|
|
122
136
|
{
|
123
137
|
struct timeval tv;
|
124
138
|
int res;
|
139
|
+
int fd_setsize;
|
140
|
+
|
141
|
+
tv.tv_sec = (long)timeout;
|
142
|
+
tv.tv_usec = (long)((timeout - (ev_tstamp)tv.tv_sec) * 1e6);
|
125
143
|
|
126
144
|
#if EV_SELECT_USE_FD_SET
|
127
|
-
|
128
|
-
memcpy (vec_wo, vec_wi, sizeof (fd_set));
|
145
|
+
fd_setsize = sizeof (fd_set);
|
129
146
|
#else
|
130
|
-
|
131
|
-
memcpy (vec_wo, vec_wi, vec_max * NFDBYTES);
|
147
|
+
fd_setsize = vec_max * NFDBYTES;
|
132
148
|
#endif
|
133
149
|
|
134
|
-
|
135
|
-
|
136
|
-
|
150
|
+
memcpy (vec_ro, vec_ri, fd_setsize);
|
151
|
+
memcpy (vec_wo, vec_wi, fd_setsize);
|
152
|
+
|
153
|
+
#ifdef _WIN32
|
154
|
+
/* pass in the write set as except set.
|
155
|
+
* the idea behind this is to work around a windows bug that causes
|
156
|
+
* errors to be reported as an exception and not by setting
|
157
|
+
* the writable bit. this is so uncontrollably lame.
|
158
|
+
*/
|
159
|
+
memcpy (vec_eo, vec_wi, fd_setsize);
|
160
|
+
res = select (vec_max * NFDBITS, (fd_set *)vec_ro, (fd_set *)vec_wo, (fd_set *)vec_eo, &tv);
|
161
|
+
#else
|
137
162
|
res = select (vec_max * NFDBITS, (fd_set *)vec_ro, (fd_set *)vec_wo, 0, &tv);
|
163
|
+
#endif
|
138
164
|
|
139
165
|
if (expect_false (res < 0))
|
140
166
|
{
|
@@ -192,6 +218,9 @@ select_poll (EV_P_ ev_tstamp timeout)
|
|
192
218
|
|
193
219
|
if (FD_ISSET (handle, (fd_set *)vec_ro)) events |= EV_READ;
|
194
220
|
if (FD_ISSET (handle, (fd_set *)vec_wo)) events |= EV_WRITE;
|
221
|
+
#ifdef _WIN32
|
222
|
+
if (FD_ISSET (handle, (fd_set *)vec_eo)) events |= EV_WRITE;
|
223
|
+
#endif
|
195
224
|
|
196
225
|
if (expect_true (events))
|
197
226
|
fd_event (EV_A_ fd, events);
|
@@ -206,6 +235,9 @@ select_poll (EV_P_ ev_tstamp timeout)
|
|
206
235
|
{
|
207
236
|
fd_mask word_r = ((fd_mask *)vec_ro) [word];
|
208
237
|
fd_mask word_w = ((fd_mask *)vec_wo) [word];
|
238
|
+
#ifdef _WIN32
|
239
|
+
word_w |= ((fd_mask *)vec_eo) [word];
|
240
|
+
#endif
|
209
241
|
|
210
242
|
if (word_r || word_w)
|
211
243
|
for (bit = NFDBITS; bit--; )
|
@@ -238,6 +270,9 @@ select_init (EV_P_ int flags)
|
|
238
270
|
vec_ro = ev_malloc (sizeof (fd_set));
|
239
271
|
vec_wi = ev_malloc (sizeof (fd_set)); FD_ZERO ((fd_set *)vec_wi);
|
240
272
|
vec_wo = ev_malloc (sizeof (fd_set));
|
273
|
+
#ifdef _WIN32
|
274
|
+
vec_eo = ev_malloc (sizeof (fd_set));
|
275
|
+
#endif
|
241
276
|
#else
|
242
277
|
vec_max = 0;
|
243
278
|
vec_ri = 0;
|
data/libev/ev_vars.h
CHANGED
data/libev/ev_win32.c
CHANGED
@@ -39,10 +39,13 @@
|
|
39
39
|
|
40
40
|
#ifdef _WIN32
|
41
41
|
|
42
|
+
/* timeb.h is actually xsi legacy functionality */
|
42
43
|
#include <sys/timeb.h>
|
43
44
|
|
44
45
|
/* note: the comment below could not be substantiated, but what would I care */
|
45
46
|
/* MSDN says this is required to handle SIGFPE */
|
47
|
+
/* my wild guess would be that using something floating-pointy is required */
|
48
|
+
/* for the crt to do something about it */
|
46
49
|
volatile double SIGFPE_REQ = 0.0f;
|
47
50
|
|
48
51
|
/* oh, the humanity! */
|
data/libev/ev_wrap.h
CHANGED
@@ -22,6 +22,7 @@
|
|
22
22
|
#define vec_ro ((loop)->vec_ro)
|
23
23
|
#define vec_wi ((loop)->vec_wi)
|
24
24
|
#define vec_wo ((loop)->vec_wo)
|
25
|
+
#define vec_eo ((loop)->vec_eo)
|
25
26
|
#define vec_max ((loop)->vec_max)
|
26
27
|
#define polls ((loop)->polls)
|
27
28
|
#define pollmax ((loop)->pollmax)
|
@@ -94,6 +95,7 @@
|
|
94
95
|
#undef vec_ro
|
95
96
|
#undef vec_wi
|
96
97
|
#undef vec_wo
|
98
|
+
#undef vec_eo
|
97
99
|
#undef vec_max
|
98
100
|
#undef polls
|
99
101
|
#undef pollmax
|
data/libev/event.c
ADDED
@@ -0,0 +1,403 @@
|
|
1
|
+
/*
|
2
|
+
* libevent compatibility layer
|
3
|
+
*
|
4
|
+
* Copyright (c) 2007,2008 Marc Alexander Lehmann <libev@schmorp.de>
|
5
|
+
* All rights reserved.
|
6
|
+
*
|
7
|
+
* Redistribution and use in source and binary forms, with or without modifica-
|
8
|
+
* tion, are permitted provided that the following conditions are met:
|
9
|
+
*
|
10
|
+
* 1. Redistributions of source code must retain the above copyright notice,
|
11
|
+
* this list of conditions and the following disclaimer.
|
12
|
+
*
|
13
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
14
|
+
* notice, this list of conditions and the following disclaimer in the
|
15
|
+
* documentation and/or other materials provided with the distribution.
|
16
|
+
*
|
17
|
+
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
18
|
+
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MER-
|
19
|
+
* CHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
|
20
|
+
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPE-
|
21
|
+
* CIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
22
|
+
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
23
|
+
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
24
|
+
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTH-
|
25
|
+
* ERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
26
|
+
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
|
+
*
|
28
|
+
* Alternatively, the contents of this file may be used under the terms of
|
29
|
+
* the GNU General Public License ("GPL") version 2 or any later version,
|
30
|
+
* in which case the provisions of the GPL are applicable instead of
|
31
|
+
* the above. If you wish to allow the use of your version of this file
|
32
|
+
* only under the terms of the GPL and not to allow others to use your
|
33
|
+
* version of this file under the BSD license, indicate your decision
|
34
|
+
* by deleting the provisions above and replace them with the notice
|
35
|
+
* and other provisions required by the GPL. If you do not delete the
|
36
|
+
* provisions above, a recipient may use your version of this file under
|
37
|
+
* either the BSD or the GPL.
|
38
|
+
*/
|
39
|
+
|
40
|
+
#include <stddef.h>
|
41
|
+
#include <stdlib.h>
|
42
|
+
#include <assert.h>
|
43
|
+
|
44
|
+
#ifndef WIN32
|
45
|
+
# include <sys/time.h>
|
46
|
+
#endif
|
47
|
+
|
48
|
+
#ifdef EV_EVENT_H
|
49
|
+
# include EV_EVENT_H
|
50
|
+
#else
|
51
|
+
# include "event.h"
|
52
|
+
#endif
|
53
|
+
|
54
|
+
#if EV_MULTIPLICITY
|
55
|
+
# define dLOOPev struct ev_loop *loop = (struct ev_loop *)ev->ev_base
|
56
|
+
# define dLOOPbase struct ev_loop *loop = (struct ev_loop *)base
|
57
|
+
#else
|
58
|
+
# define dLOOPev
|
59
|
+
# define dLOOPbase
|
60
|
+
#endif
|
61
|
+
|
62
|
+
/* never accessed, will always be cast from/to ev_loop */
|
63
|
+
struct event_base
|
64
|
+
{
|
65
|
+
int dummy;
|
66
|
+
};
|
67
|
+
|
68
|
+
static struct event_base *x_cur;
|
69
|
+
|
70
|
+
static void
|
71
|
+
tv_set (struct timeval *tv, ev_tstamp at)
|
72
|
+
{
|
73
|
+
tv->tv_sec = (long)at;
|
74
|
+
tv->tv_usec = (long)((at - (ev_tstamp)tv->tv_sec) * 1e6);
|
75
|
+
}
|
76
|
+
|
77
|
+
static ev_tstamp
|
78
|
+
tv_get (struct timeval *tv)
|
79
|
+
{
|
80
|
+
if (tv)
|
81
|
+
return tv->tv_sec + tv->tv_usec * 1e-6;
|
82
|
+
else
|
83
|
+
return -1.;
|
84
|
+
}
|
85
|
+
|
86
|
+
#define EVENT_VERSION(a,b) # a "." # b
|
87
|
+
|
88
|
+
const char *event_get_version (void)
|
89
|
+
{
|
90
|
+
return EVENT_VERSION (EV_VERSION_MAJOR, EV_VERSION_MINOR);
|
91
|
+
}
|
92
|
+
|
93
|
+
const char *event_get_method (void)
|
94
|
+
{
|
95
|
+
return "libev";
|
96
|
+
}
|
97
|
+
|
98
|
+
void *event_init (void)
|
99
|
+
{
|
100
|
+
#if EV_MULTIPLICITY
|
101
|
+
if (x_cur)
|
102
|
+
x_cur = (struct event_base *)ev_loop_new (EVFLAG_AUTO);
|
103
|
+
else
|
104
|
+
x_cur = (struct event_base *)ev_default_loop (EVFLAG_AUTO);
|
105
|
+
#else
|
106
|
+
assert (("multiple event bases not supported when not compiled with EV_MULTIPLICITY", !x_cur));
|
107
|
+
|
108
|
+
x_cur = (struct event_base *)(long)ev_default_loop (EVFLAG_AUTO);
|
109
|
+
#endif
|
110
|
+
|
111
|
+
return x_cur;
|
112
|
+
}
|
113
|
+
|
114
|
+
void event_base_free (struct event_base *base)
|
115
|
+
{
|
116
|
+
dLOOPbase;
|
117
|
+
|
118
|
+
#if EV_MULTIPLICITY
|
119
|
+
if (ev_default_loop (EVFLAG_AUTO) != loop)
|
120
|
+
ev_loop_destroy (loop);
|
121
|
+
#endif
|
122
|
+
}
|
123
|
+
|
124
|
+
int event_dispatch (void)
|
125
|
+
{
|
126
|
+
return event_base_dispatch (x_cur);
|
127
|
+
}
|
128
|
+
|
129
|
+
#ifdef EV_STANDALONE
|
130
|
+
void event_set_log_callback (event_log_cb cb)
|
131
|
+
{
|
132
|
+
/* nop */
|
133
|
+
}
|
134
|
+
#endif
|
135
|
+
|
136
|
+
int event_loop (int flags)
|
137
|
+
{
|
138
|
+
return event_base_loop (x_cur, flags);
|
139
|
+
}
|
140
|
+
|
141
|
+
int event_loopexit (struct timeval *tv)
|
142
|
+
{
|
143
|
+
return event_base_loopexit (x_cur, tv);
|
144
|
+
}
|
145
|
+
|
146
|
+
static void
|
147
|
+
x_cb (struct event *ev, int revents)
|
148
|
+
{
|
149
|
+
revents &= EV_READ | EV_WRITE | EV_TIMEOUT | EV_SIGNAL;
|
150
|
+
|
151
|
+
ev->ev_res = revents;
|
152
|
+
ev->ev_callback (ev->ev_fd, (short)revents, ev->ev_arg);
|
153
|
+
}
|
154
|
+
|
155
|
+
static void
|
156
|
+
x_cb_sig (EV_P_ struct ev_signal *w, int revents)
|
157
|
+
{
|
158
|
+
struct event *ev = (struct event *)(((char *)w) - offsetof (struct event, iosig.sig));
|
159
|
+
|
160
|
+
if (revents & EV_ERROR)
|
161
|
+
event_del (ev);
|
162
|
+
|
163
|
+
x_cb (ev, revents);
|
164
|
+
}
|
165
|
+
|
166
|
+
static void
|
167
|
+
x_cb_io (EV_P_ struct ev_io *w, int revents)
|
168
|
+
{
|
169
|
+
struct event *ev = (struct event *)(((char *)w) - offsetof (struct event, iosig.io));
|
170
|
+
|
171
|
+
if ((revents & EV_ERROR) || !(ev->ev_events & EV_PERSIST))
|
172
|
+
event_del (ev);
|
173
|
+
|
174
|
+
x_cb (ev, revents);
|
175
|
+
}
|
176
|
+
|
177
|
+
static void
|
178
|
+
x_cb_to (EV_P_ struct ev_timer *w, int revents)
|
179
|
+
{
|
180
|
+
struct event *ev = (struct event *)(((char *)w) - offsetof (struct event, to));
|
181
|
+
|
182
|
+
event_del (ev);
|
183
|
+
|
184
|
+
x_cb (ev, revents);
|
185
|
+
}
|
186
|
+
|
187
|
+
void event_set (struct event *ev, int fd, short events, void (*cb)(int, short, void *), void *arg)
|
188
|
+
{
|
189
|
+
if (events & EV_SIGNAL)
|
190
|
+
ev_init (&ev->iosig.sig, x_cb_sig);
|
191
|
+
else
|
192
|
+
ev_init (&ev->iosig.io, x_cb_io);
|
193
|
+
|
194
|
+
ev_init (&ev->to, x_cb_to);
|
195
|
+
|
196
|
+
ev->ev_base = x_cur; /* not threadsafe, but its like libevent works */
|
197
|
+
ev->ev_fd = fd;
|
198
|
+
ev->ev_events = events;
|
199
|
+
ev->ev_pri = 0;
|
200
|
+
ev->ev_callback = cb;
|
201
|
+
ev->ev_arg = arg;
|
202
|
+
ev->ev_res = 0;
|
203
|
+
ev->ev_flags = EVLIST_INIT;
|
204
|
+
}
|
205
|
+
|
206
|
+
int event_once (int fd, short events, void (*cb)(int, short, void *), void *arg, struct timeval *tv)
|
207
|
+
{
|
208
|
+
return event_base_once (x_cur, fd, events, cb, arg, tv);
|
209
|
+
}
|
210
|
+
|
211
|
+
int event_add (struct event *ev, struct timeval *tv)
|
212
|
+
{
|
213
|
+
dLOOPev;
|
214
|
+
|
215
|
+
if (ev->ev_events & EV_SIGNAL)
|
216
|
+
{
|
217
|
+
if (!ev_is_active (&ev->iosig.sig))
|
218
|
+
{
|
219
|
+
ev_signal_set (&ev->iosig.sig, ev->ev_fd);
|
220
|
+
ev_signal_start (EV_A_ &ev->iosig.sig);
|
221
|
+
|
222
|
+
ev->ev_flags |= EVLIST_SIGNAL;
|
223
|
+
}
|
224
|
+
}
|
225
|
+
else if (ev->ev_events & (EV_READ | EV_WRITE))
|
226
|
+
{
|
227
|
+
if (!ev_is_active (&ev->iosig.io))
|
228
|
+
{
|
229
|
+
ev_io_set (&ev->iosig.io, ev->ev_fd, ev->ev_events & (EV_READ | EV_WRITE));
|
230
|
+
ev_io_start (EV_A_ &ev->iosig.io);
|
231
|
+
|
232
|
+
ev->ev_flags |= EVLIST_INSERTED;
|
233
|
+
}
|
234
|
+
}
|
235
|
+
|
236
|
+
if (tv)
|
237
|
+
{
|
238
|
+
ev->to.repeat = tv_get (tv);
|
239
|
+
ev_timer_again (EV_A_ &ev->to);
|
240
|
+
ev->ev_flags |= EVLIST_TIMEOUT;
|
241
|
+
}
|
242
|
+
else
|
243
|
+
{
|
244
|
+
ev_timer_stop (EV_A_ &ev->to);
|
245
|
+
ev->ev_flags &= ~EVLIST_TIMEOUT;
|
246
|
+
}
|
247
|
+
|
248
|
+
ev->ev_flags |= EVLIST_ACTIVE;
|
249
|
+
|
250
|
+
return 0;
|
251
|
+
}
|
252
|
+
|
253
|
+
int event_del (struct event *ev)
|
254
|
+
{
|
255
|
+
dLOOPev;
|
256
|
+
|
257
|
+
if (ev->ev_events & EV_SIGNAL)
|
258
|
+
ev_signal_stop (EV_A_ &ev->iosig.sig);
|
259
|
+
else if (ev->ev_events & (EV_READ | EV_WRITE))
|
260
|
+
ev_io_stop (EV_A_ &ev->iosig.io);
|
261
|
+
|
262
|
+
if (ev_is_active (&ev->to))
|
263
|
+
ev_timer_stop (EV_A_ &ev->to);
|
264
|
+
|
265
|
+
ev->ev_flags = EVLIST_INIT;
|
266
|
+
|
267
|
+
return 0;
|
268
|
+
}
|
269
|
+
|
270
|
+
void event_active (struct event *ev, int res, short ncalls)
|
271
|
+
{
|
272
|
+
dLOOPev;
|
273
|
+
|
274
|
+
if (res & EV_TIMEOUT)
|
275
|
+
ev_feed_event (EV_A_ &ev->to, res & EV_TIMEOUT);
|
276
|
+
|
277
|
+
if (res & EV_SIGNAL)
|
278
|
+
ev_feed_event (EV_A_ &ev->iosig.sig, res & EV_SIGNAL);
|
279
|
+
|
280
|
+
if (res & (EV_READ | EV_WRITE))
|
281
|
+
ev_feed_event (EV_A_ &ev->iosig.io, res & (EV_READ | EV_WRITE));
|
282
|
+
}
|
283
|
+
|
284
|
+
int event_pending (struct event *ev, short events, struct timeval *tv)
|
285
|
+
{
|
286
|
+
short revents = 0;
|
287
|
+
dLOOPev;
|
288
|
+
|
289
|
+
if (ev->ev_events & EV_SIGNAL)
|
290
|
+
{
|
291
|
+
/* sig */
|
292
|
+
if (ev_is_active (&ev->iosig.sig) || ev_is_pending (&ev->iosig.sig))
|
293
|
+
revents |= EV_SIGNAL;
|
294
|
+
}
|
295
|
+
else if (ev->ev_events & (EV_READ | EV_WRITE))
|
296
|
+
{
|
297
|
+
/* io */
|
298
|
+
if (ev_is_active (&ev->iosig.io) || ev_is_pending (&ev->iosig.io))
|
299
|
+
revents |= ev->ev_events & (EV_READ | EV_WRITE);
|
300
|
+
}
|
301
|
+
|
302
|
+
if (ev->ev_events & EV_TIMEOUT || ev_is_active (&ev->to) || ev_is_pending (&ev->to))
|
303
|
+
{
|
304
|
+
revents |= EV_TIMEOUT;
|
305
|
+
|
306
|
+
if (tv)
|
307
|
+
tv_set (tv, ev_now (EV_A)); /* not sure if this is right :) */
|
308
|
+
}
|
309
|
+
|
310
|
+
return events & revents;
|
311
|
+
}
|
312
|
+
|
313
|
+
int event_priority_init (int npri)
|
314
|
+
{
|
315
|
+
return event_base_priority_init (x_cur, npri);
|
316
|
+
}
|
317
|
+
|
318
|
+
int event_priority_set (struct event *ev, int pri)
|
319
|
+
{
|
320
|
+
ev->ev_pri = pri;
|
321
|
+
|
322
|
+
return 0;
|
323
|
+
}
|
324
|
+
|
325
|
+
int event_base_set (struct event_base *base, struct event *ev)
|
326
|
+
{
|
327
|
+
ev->ev_base = base;
|
328
|
+
|
329
|
+
return 0;
|
330
|
+
}
|
331
|
+
|
332
|
+
int event_base_loop (struct event_base *base, int flags)
|
333
|
+
{
|
334
|
+
dLOOPbase;
|
335
|
+
|
336
|
+
ev_loop (EV_A_ flags);
|
337
|
+
|
338
|
+
return 0;
|
339
|
+
}
|
340
|
+
|
341
|
+
int event_base_dispatch (struct event_base *base)
|
342
|
+
{
|
343
|
+
return event_base_loop (base, 0);
|
344
|
+
}
|
345
|
+
|
346
|
+
static void
|
347
|
+
x_loopexit_cb (int revents, void *base)
|
348
|
+
{
|
349
|
+
dLOOPbase;
|
350
|
+
|
351
|
+
ev_unloop (EV_A_ EVUNLOOP_ONE);
|
352
|
+
}
|
353
|
+
|
354
|
+
int event_base_loopexit (struct event_base *base, struct timeval *tv)
|
355
|
+
{
|
356
|
+
ev_tstamp after = tv_get (tv);
|
357
|
+
dLOOPbase;
|
358
|
+
|
359
|
+
ev_once (EV_A_ -1, 0, after >= 0. ? after : 0., x_loopexit_cb, (void *)base);
|
360
|
+
|
361
|
+
return 0;
|
362
|
+
}
|
363
|
+
|
364
|
+
struct x_once
|
365
|
+
{
|
366
|
+
int fd;
|
367
|
+
void (*cb)(int, short, void *);
|
368
|
+
void *arg;
|
369
|
+
};
|
370
|
+
|
371
|
+
static void
|
372
|
+
x_once_cb (int revents, void *arg)
|
373
|
+
{
|
374
|
+
struct x_once *once = (struct x_once *)arg;
|
375
|
+
|
376
|
+
once->cb (once->fd, (short)revents, once->arg);
|
377
|
+
free (once);
|
378
|
+
}
|
379
|
+
|
380
|
+
int event_base_once (struct event_base *base, int fd, short events, void (*cb)(int, short, void *), void *arg, struct timeval *tv)
|
381
|
+
{
|
382
|
+
struct x_once *once = (struct x_once *)malloc (sizeof (struct x_once));
|
383
|
+
dLOOPbase;
|
384
|
+
|
385
|
+
if (!once)
|
386
|
+
return -1;
|
387
|
+
|
388
|
+
once->fd = fd;
|
389
|
+
once->cb = cb;
|
390
|
+
once->arg = arg;
|
391
|
+
|
392
|
+
ev_once (EV_A_ fd, events & (EV_READ | EV_WRITE), tv_get (tv), x_once_cb, (void *)once);
|
393
|
+
|
394
|
+
return 0;
|
395
|
+
}
|
396
|
+
|
397
|
+
int event_base_priority_init (struct event_base *base, int npri)
|
398
|
+
{
|
399
|
+
/*dLOOPbase;*/
|
400
|
+
|
401
|
+
return 0;
|
402
|
+
}
|
403
|
+
|