diff options
author | James Taylor <user234683@users.noreply.github.com> | 2018-09-14 19:32:27 -0700 |
---|---|---|
committer | James Taylor <user234683@users.noreply.github.com> | 2018-09-14 19:32:27 -0700 |
commit | 4212164e91ba2f49583cf44ad623a29b36db8f77 (patch) | |
tree | 47aefe3c0162f03e0c823b43873356f69c1cd636 /python/gevent/libev/libev.pxd | |
parent | 6ca20ff7010f2bafc7fefcb8cad982be27a8aeae (diff) | |
download | yt-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.pxd | 53 |
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*); |