aboutsummaryrefslogtreecommitdiffstats
path: root/python/gevent/libev/libev.pxd
diff options
context:
space:
mode:
authorJames Taylor <user234683@users.noreply.github.com>2018-09-14 19:32:27 -0700
committerJames Taylor <user234683@users.noreply.github.com>2018-09-14 19:32:27 -0700
commit4212164e91ba2f49583cf44ad623a29b36db8f77 (patch)
tree47aefe3c0162f03e0c823b43873356f69c1cd636 /python/gevent/libev/libev.pxd
parent6ca20ff7010f2bafc7fefcb8cad982be27a8aeae (diff)
downloadyt-local-4212164e91ba2f49583cf44ad623a29b36db8f77.tar.lz
yt-local-4212164e91ba2f49583cf44ad623a29b36db8f77.tar.xz
yt-local-4212164e91ba2f49583cf44ad623a29b36db8f77.zip
Windows: Use 32-bit distribution of python
Diffstat (limited to 'python/gevent/libev/libev.pxd')
-rw-r--r--python/gevent/libev/libev.pxd53
1 files changed, 40 insertions, 13 deletions
diff --git a/python/gevent/libev/libev.pxd b/python/gevent/libev/libev.pxd
index d8914b6..e3be525 100644
--- a/python/gevent/libev/libev.pxd
+++ b/python/gevent/libev/libev.pxd
@@ -1,18 +1,22 @@
+# From cython/includes/libc/stdint.pxd
+# Longness only used for type promotion.
+# Actual compile time size used for conversions.
+# We don't have stdint.h on visual studio 9.0 (2008) on windows, sigh,
+# so go with Py_ssize_t
+# ssize_t -> intptr_t
+
cdef extern from "libev_vfd.h":
-#ifdef _WIN32
-#ifdef _WIN64
- ctypedef long long vfd_socket_t
-#else
- ctypedef long vfd_socket_t
-#endif
-#else
- ctypedef int vfd_socket_t
-#endif
- long vfd_get(int)
+# cython doesn't process pre-processor directives, so they
+# don't matter in this file. It just takes the last definition it sees.
+ ctypedef Py_ssize_t intptr_t
+ ctypedef intptr_t vfd_socket_t
+
+ vfd_socket_t vfd_get(int)
int vfd_open(long) except -1
void vfd_free(int)
-cdef extern from "libev.h":
+cdef extern from "libev.h" nogil:
+ int LIBEV_EMBED
int EV_MINPRI
int EV_MAXPRI
@@ -87,6 +91,9 @@ cdef extern from "libev.h":
int sigfd
unsigned int origflags
+ struct ev_watcher:
+ void* data;
+
struct ev_io:
int fd
int events
@@ -125,6 +132,13 @@ cdef extern from "libev.h":
stat prev
double interval
+ union ev_any_watcher:
+ ev_watcher w
+ ev_io io
+ ev_timer timer
+ ev_signal signal
+ ev_idle idle
+
int ev_version_major()
int ev_version_minor()
@@ -132,7 +146,9 @@ cdef extern from "libev.h":
unsigned int ev_recommended_backends()
unsigned int ev_embeddable_backends()
- double ev_time()
+ ctypedef double ev_tstamp
+
+ ev_tstamp ev_time()
void ev_set_syserr_cb(void *)
int ev_priority(void*)
@@ -186,6 +202,8 @@ cdef extern from "libev.h":
ev_loop* ev_default_loop(unsigned int flags)
ev_loop* ev_loop_new(unsigned int flags)
+ void* ev_userdata(ev_loop*)
+ void ev_set_userdata(ev_loop*, void*)
void ev_loop_destroy(ev_loop*)
void ev_loop_fork(ev_loop*)
int ev_is_default_loop(ev_loop*)
@@ -195,7 +213,7 @@ cdef extern from "libev.h":
void ev_verify(ev_loop*)
void ev_run(ev_loop*, int flags) nogil
- double ev_now(ev_loop*)
+ ev_tstamp ev_now(ev_loop*)
void ev_now_update(ev_loop*)
void ev_ref(ev_loop*)
@@ -203,6 +221,15 @@ cdef extern from "libev.h":
void ev_break(ev_loop*, int)
unsigned int ev_pending_count(ev_loop*)
+ # gevent extra functions. These are defined in libev.h.
ev_loop* gevent_ev_default_loop(unsigned int flags)
void gevent_install_sigchld_handler()
void gevent_reset_sigchld_handler()
+
+ # These compensate for lack of access to ev_loop struct definition
+ # when LIBEV_EMBED is false.
+ unsigned int gevent_ev_loop_origflags(ev_loop*);
+ int gevent_ev_loop_sig_pending(ev_loop*);
+ int gevent_ev_loop_backend_fd(ev_loop*);
+ int gevent_ev_loop_activecnt(ev_loop*);
+ int gevent_ev_loop_sigfd(ev_loop*);