noderb 0.0.2
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +19 -0
- data/README.md +25 -0
- data/ext/noderb_extension/extconf.rb +11 -0
- data/ext/noderb_extension/libuv/AUTHORS +11 -0
- data/ext/noderb_extension/libuv/LICENSE +48 -0
- data/ext/noderb_extension/libuv/Makefile +119 -0
- data/ext/noderb_extension/libuv/README +45 -0
- data/ext/noderb_extension/libuv/build/all.gyp +254 -0
- data/ext/noderb_extension/libuv/build/common.gypi +13 -0
- data/ext/noderb_extension/libuv/build/gyp_uv +43 -0
- data/ext/noderb_extension/libuv/config-mingw.mk +67 -0
- data/ext/noderb_extension/libuv/config-unix.mk +121 -0
- data/ext/noderb_extension/libuv/create-msvs-files.bat +14 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ANNOUNCE +482 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/BUGS +141 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/Bmakefile +268 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/CONTRIBUTORS +140 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/COPYING +150 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/COPYING.LIB +504 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ChangeLog +5194 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/FAQ +451 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/GNUmakefile +593 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/MAINTAINERS +4 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/Makefile +516 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/NEWS +1245 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/Nmakefile +24 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/Nmakefile.tests +260 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/PROGRESS +4 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/README +601 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/README.Borland +57 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/README.CV +3036 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/README.NONPORTABLE +783 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/README.Watcom +62 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/README.WinCE +6 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/TODO +7 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/WinCE-PORT +222 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/attr.c +53 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/autostatic.c +69 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/barrier.c +47 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/build/all.gyp +207 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/builddmc.bat +9 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/cancel.c +44 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/cleanup.c +148 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/condvar.c +50 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/config.h +153 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/context.h +74 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/create.c +308 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/dll.c +92 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/errno.c +94 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/exit.c +44 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/fork.c +39 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/global.c +107 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/implement.h +944 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/misc.c +50 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/mutex.c +62 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/need_errno.h +145 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/nonportable.c +47 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/private.c +54 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.c +66 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.dsp +142 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.dsw +29 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.h +1368 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_destroy.c +79 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getdetachstate.c +86 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getinheritsched.c +51 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getschedparam.c +52 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getschedpolicy.c +61 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getscope.c +54 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getstackaddr.c +97 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getstacksize.c +100 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_init.c +117 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setdetachstate.c +91 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setinheritsched.c +57 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setschedparam.c +63 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setschedpolicy.c +55 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setscope.c +62 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setstackaddr.c +97 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setstacksize.c +110 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrier_destroy.c +103 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrier_init.c +69 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrier_wait.c +104 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_destroy.c +83 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_getpshared.c +95 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_init.c +85 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_setpshared.c +119 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cancel.c +189 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_destroy.c +253 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_init.c +167 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_signal.c +231 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_wait.c +567 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_destroy.c +86 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_getpshared.c +97 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_init.c +87 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_setpshared.c +117 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_delay_np.c +172 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_detach.c +136 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_equal.c +76 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_exit.c +106 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getconcurrency.c +45 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getschedparam.c +75 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getspecific.c +87 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getunique_np.c +47 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getw32threadhandle_np.c +65 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_join.c +157 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_key_create.c +108 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_key_delete.c +125 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_kill.c +105 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_consistent.c +187 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_destroy.c +148 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_init.c +130 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_lock.c +269 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_timedlock.c +324 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_trylock.c +154 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_unlock.c +175 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_destroy.c +83 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_getkind_np.c +44 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_getpshared.c +95 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_getrobust.c +113 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_gettype.c +56 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_init.c +86 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_setkind_np.c +44 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_setpshared.c +119 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_setrobust.c +119 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_settype.c +143 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_num_processors_np.c +56 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_once.c +79 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_destroy.c +143 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_init.c +109 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_rdlock.c +102 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_timedrdlock.c +109 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_timedwrlock.c +139 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_tryrdlock.c +102 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_trywrlock.c +122 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_unlock.c +93 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_wrlock.c +133 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_destroy.c +84 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_getpshared.c +97 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_init.c +83 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_setpshared.c +120 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_self.c +141 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setcancelstate.c +125 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setcanceltype.c +126 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setconcurrency.c +53 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setschedparam.c +123 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setspecific.c +167 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_destroy.c +111 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_init.c +123 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_lock.c +80 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_trylock.c +77 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_unlock.c +71 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_testcancel.c +103 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_timechange_handler_np.c +108 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_win32_attach_detach_np.c +258 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_MCS_lock.c +278 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_callUserDestroyRoutines.c +232 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_calloc.c +56 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_cond_check_need_init.c +78 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_getprocessors.c +91 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_is_attr.c +47 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_mutex_check_need_init.c +92 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_new.c +94 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_processInitialize.c +92 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_processTerminate.c +105 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_relmillisecs.c +132 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_reuse.c +151 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_rwlock_cancelwrwait.c +50 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_rwlock_check_need_init.c +77 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_semwait.c +135 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_spinlock_check_need_init.c +78 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_threadDestroy.c +79 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_threadStart.c +357 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_throw.c +189 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_timespec.c +83 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_tkAssocCreate.c +118 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_tkAssocDestroy.c +114 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/rwlock.c +51 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched.c +53 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched.h +183 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched_get_priority_max.c +134 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched_get_priority_min.c +135 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched_getscheduler.c +71 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched_setscheduler.c +83 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sched_yield.c +71 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_close.c +58 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_destroy.c +144 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_getvalue.c +110 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_init.c +169 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_open.c +58 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_post.c +128 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_post_multiple.c +142 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_timedwait.c +238 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_trywait.c +117 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_unlink.c +58 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sem_wait.c +187 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/semaphore.c +69 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/semaphore.h +169 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/signal.c +179 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/spin.c +46 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/sync.c +43 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/tsd.c +44 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/version.rc +388 -0
- data/ext/noderb_extension/libuv/deps/pthread-win32/w32_CancelableWait.c +161 -0
- data/ext/noderb_extension/libuv/doc/desired-api.md +159 -0
- data/ext/noderb_extension/libuv/doc/iocp-links.html +574 -0
- data/ext/noderb_extension/libuv/include/ares.h +582 -0
- data/ext/noderb_extension/libuv/include/ares_version.h +24 -0
- data/ext/noderb_extension/libuv/include/eio.h +376 -0
- data/ext/noderb_extension/libuv/include/ev.h +835 -0
- data/ext/noderb_extension/libuv/include/ngx-queue.h +102 -0
- data/ext/noderb_extension/libuv/include/tree.h +762 -0
- data/ext/noderb_extension/libuv/include/uv-unix.h +138 -0
- data/ext/noderb_extension/libuv/include/uv-win.h +187 -0
- data/ext/noderb_extension/libuv/include/uv.h +635 -0
- data/ext/noderb_extension/libuv/src/ares/AUTHORS +37 -0
- data/ext/noderb_extension/libuv/src/ares/CHANGES +1198 -0
- data/ext/noderb_extension/libuv/src/ares/CMakeLists.txt +22 -0
- data/ext/noderb_extension/libuv/src/ares/NEWS +21 -0
- data/ext/noderb_extension/libuv/src/ares/README +60 -0
- data/ext/noderb_extension/libuv/src/ares/README.cares +13 -0
- data/ext/noderb_extension/libuv/src/ares/README.msvc +118 -0
- data/ext/noderb_extension/libuv/src/ares/README.node +21 -0
- data/ext/noderb_extension/libuv/src/ares/RELEASE-NOTES +25 -0
- data/ext/noderb_extension/libuv/src/ares/TODO +23 -0
- data/ext/noderb_extension/libuv/src/ares/ares__close_sockets.c +66 -0
- data/ext/noderb_extension/libuv/src/ares/ares__get_hostent.c +263 -0
- data/ext/noderb_extension/libuv/src/ares/ares__read_line.c +71 -0
- data/ext/noderb_extension/libuv/src/ares/ares__timeval.c +111 -0
- data/ext/noderb_extension/libuv/src/ares/ares_cancel.c +63 -0
- data/ext/noderb_extension/libuv/src/ares/ares_data.c +190 -0
- data/ext/noderb_extension/libuv/src/ares/ares_data.h +65 -0
- data/ext/noderb_extension/libuv/src/ares/ares_destroy.c +105 -0
- data/ext/noderb_extension/libuv/src/ares/ares_dns.h +90 -0
- data/ext/noderb_extension/libuv/src/ares/ares_expand_name.c +193 -0
- data/ext/noderb_extension/libuv/src/ares/ares_expand_string.c +75 -0
- data/ext/noderb_extension/libuv/src/ares/ares_fds.c +62 -0
- data/ext/noderb_extension/libuv/src/ares/ares_free_hostent.c +39 -0
- data/ext/noderb_extension/libuv/src/ares/ares_free_string.c +25 -0
- data/ext/noderb_extension/libuv/src/ares/ares_gethostbyaddr.c +292 -0
- data/ext/noderb_extension/libuv/src/ares/ares_gethostbyname.c +515 -0
- data/ext/noderb_extension/libuv/src/ares/ares_getnameinfo.c +426 -0
- data/ext/noderb_extension/libuv/src/ares/ares_getopt.c +122 -0
- data/ext/noderb_extension/libuv/src/ares/ares_getopt.h +53 -0
- data/ext/noderb_extension/libuv/src/ares/ares_getsock.c +72 -0
- data/ext/noderb_extension/libuv/src/ares/ares_init.c +1665 -0
- data/ext/noderb_extension/libuv/src/ares/ares_ipv6.h +78 -0
- data/ext/noderb_extension/libuv/src/ares/ares_library_init.c +132 -0
- data/ext/noderb_extension/libuv/src/ares/ares_library_init.h +39 -0
- data/ext/noderb_extension/libuv/src/ares/ares_llist.c +86 -0
- data/ext/noderb_extension/libuv/src/ares/ares_llist.h +42 -0
- data/ext/noderb_extension/libuv/src/ares/ares_mkquery.c +195 -0
- data/ext/noderb_extension/libuv/src/ares/ares_nowarn.c +59 -0
- data/ext/noderb_extension/libuv/src/ares/ares_nowarn.h +24 -0
- data/ext/noderb_extension/libuv/src/ares/ares_options.c +253 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_a_reply.c +260 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_aaaa_reply.c +256 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_mx_reply.c +170 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_ns_reply.c +182 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_ptr_reply.c +208 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_srv_reply.c +179 -0
- data/ext/noderb_extension/libuv/src/ares/ares_parse_txt_reply.c +201 -0
- data/ext/noderb_extension/libuv/src/ares/ares_private.h +351 -0
- data/ext/noderb_extension/libuv/src/ares/ares_process.c +1296 -0
- data/ext/noderb_extension/libuv/src/ares/ares_query.c +183 -0
- data/ext/noderb_extension/libuv/src/ares/ares_rules.h +144 -0
- data/ext/noderb_extension/libuv/src/ares/ares_search.c +322 -0
- data/ext/noderb_extension/libuv/src/ares/ares_send.c +134 -0
- data/ext/noderb_extension/libuv/src/ares/ares_setup.h +191 -0
- data/ext/noderb_extension/libuv/src/ares/ares_strcasecmp.c +66 -0
- data/ext/noderb_extension/libuv/src/ares/ares_strcasecmp.h +30 -0
- data/ext/noderb_extension/libuv/src/ares/ares_strdup.c +42 -0
- data/ext/noderb_extension/libuv/src/ares/ares_strdup.h +26 -0
- data/ext/noderb_extension/libuv/src/ares/ares_strerror.c +56 -0
- data/ext/noderb_extension/libuv/src/ares/ares_timeout.c +80 -0
- data/ext/noderb_extension/libuv/src/ares/ares_version.c +11 -0
- data/ext/noderb_extension/libuv/src/ares/ares_writev.c +79 -0
- data/ext/noderb_extension/libuv/src/ares/ares_writev.h +36 -0
- data/ext/noderb_extension/libuv/src/ares/bitncmp.c +59 -0
- data/ext/noderb_extension/libuv/src/ares/bitncmp.h +26 -0
- data/ext/noderb_extension/libuv/src/ares/config_cygwin/ares_config.h +510 -0
- data/ext/noderb_extension/libuv/src/ares/config_darwin/ares_config.h +510 -0
- data/ext/noderb_extension/libuv/src/ares/config_freebsd/ares_config.h +510 -0
- data/ext/noderb_extension/libuv/src/ares/config_linux/ares_config.h +510 -0
- data/ext/noderb_extension/libuv/src/ares/config_openbsd/ares_config.h +510 -0
- data/ext/noderb_extension/libuv/src/ares/config_sunos/ares_config.h +510 -0
- data/ext/noderb_extension/libuv/src/ares/config_win32/ares_config.h +369 -0
- data/ext/noderb_extension/libuv/src/ares/get_ver.awk +35 -0
- data/ext/noderb_extension/libuv/src/ares/inet_net_pton.c +450 -0
- data/ext/noderb_extension/libuv/src/ares/inet_net_pton.h +31 -0
- data/ext/noderb_extension/libuv/src/ares/inet_ntop.c +232 -0
- data/ext/noderb_extension/libuv/src/ares/inet_ntop.h +27 -0
- data/ext/noderb_extension/libuv/src/ares/nameser.h +193 -0
- data/ext/noderb_extension/libuv/src/ares/setup_once.h +488 -0
- data/ext/noderb_extension/libuv/src/ares/windows_port.c +22 -0
- data/ext/noderb_extension/libuv/src/eio/Changes +63 -0
- data/ext/noderb_extension/libuv/src/eio/LICENSE +36 -0
- data/ext/noderb_extension/libuv/src/eio/Makefile.am +15 -0
- data/ext/noderb_extension/libuv/src/eio/aclocal.m4 +8957 -0
- data/ext/noderb_extension/libuv/src/eio/autogen.sh +3 -0
- data/ext/noderb_extension/libuv/src/eio/config.h.in +86 -0
- data/ext/noderb_extension/libuv/src/eio/config_cygwin.h +77 -0
- data/ext/noderb_extension/libuv/src/eio/config_darwin.h +137 -0
- data/ext/noderb_extension/libuv/src/eio/config_freebsd.h +78 -0
- data/ext/noderb_extension/libuv/src/eio/config_linux.h +101 -0
- data/ext/noderb_extension/libuv/src/eio/config_sunos.h +81 -0
- data/ext/noderb_extension/libuv/src/eio/configure.ac +22 -0
- data/ext/noderb_extension/libuv/src/eio/demo.c +194 -0
- data/ext/noderb_extension/libuv/src/eio/ecb.h +370 -0
- data/ext/noderb_extension/libuv/src/eio/eio.3 +3428 -0
- data/ext/noderb_extension/libuv/src/eio/eio.c +2562 -0
- data/ext/noderb_extension/libuv/src/eio/eio.pod +969 -0
- data/ext/noderb_extension/libuv/src/eio/libeio.m4 +195 -0
- data/ext/noderb_extension/libuv/src/eio/xthread.h +164 -0
- data/ext/noderb_extension/libuv/src/ev/Changes +388 -0
- data/ext/noderb_extension/libuv/src/ev/LICENSE +36 -0
- data/ext/noderb_extension/libuv/src/ev/Makefile.am +18 -0
- data/ext/noderb_extension/libuv/src/ev/Makefile.in +771 -0
- data/ext/noderb_extension/libuv/src/ev/README +58 -0
- data/ext/noderb_extension/libuv/src/ev/aclocal.m4 +8957 -0
- data/ext/noderb_extension/libuv/src/ev/autogen.sh +6 -0
- data/ext/noderb_extension/libuv/src/ev/config.guess +1526 -0
- data/ext/noderb_extension/libuv/src/ev/config.h.in +125 -0
- data/ext/noderb_extension/libuv/src/ev/config.sub +1658 -0
- data/ext/noderb_extension/libuv/src/ev/config_cygwin.h +123 -0
- data/ext/noderb_extension/libuv/src/ev/config_darwin.h +122 -0
- data/ext/noderb_extension/libuv/src/ev/config_freebsd.h +120 -0
- data/ext/noderb_extension/libuv/src/ev/config_linux.h +130 -0
- data/ext/noderb_extension/libuv/src/ev/config_sunos.h +122 -0
- data/ext/noderb_extension/libuv/src/ev/configure +13037 -0
- data/ext/noderb_extension/libuv/src/ev/configure.ac +18 -0
- data/ext/noderb_extension/libuv/src/ev/depcomp +630 -0
- data/ext/noderb_extension/libuv/src/ev/ev++.h +816 -0
- data/ext/noderb_extension/libuv/src/ev/ev.3 +5311 -0
- data/ext/noderb_extension/libuv/src/ev/ev.c +3913 -0
- data/ext/noderb_extension/libuv/src/ev/ev.pod +5243 -0
- data/ext/noderb_extension/libuv/src/ev/ev_epoll.c +266 -0
- data/ext/noderb_extension/libuv/src/ev/ev_kqueue.c +198 -0
- data/ext/noderb_extension/libuv/src/ev/ev_poll.c +148 -0
- data/ext/noderb_extension/libuv/src/ev/ev_port.c +179 -0
- data/ext/noderb_extension/libuv/src/ev/ev_select.c +310 -0
- data/ext/noderb_extension/libuv/src/ev/ev_vars.h +203 -0
- data/ext/noderb_extension/libuv/src/ev/ev_win32.c +153 -0
- data/ext/noderb_extension/libuv/src/ev/ev_wrap.h +196 -0
- data/ext/noderb_extension/libuv/src/ev/event.c +402 -0
- data/ext/noderb_extension/libuv/src/ev/event.h +170 -0
- data/ext/noderb_extension/libuv/src/ev/install-sh +294 -0
- data/ext/noderb_extension/libuv/src/ev/libev.m4 +39 -0
- data/ext/noderb_extension/libuv/src/ev/ltmain.sh +8413 -0
- data/ext/noderb_extension/libuv/src/ev/missing +336 -0
- data/ext/noderb_extension/libuv/src/ev/mkinstalldirs +111 -0
- data/ext/noderb_extension/libuv/src/uv-common.c +172 -0
- data/ext/noderb_extension/libuv/src/uv-common.h +53 -0
- data/ext/noderb_extension/libuv/src/uv-cygwin.c +52 -0
- data/ext/noderb_extension/libuv/src/uv-darwin.c +64 -0
- data/ext/noderb_extension/libuv/src/uv-eio.c +113 -0
- data/ext/noderb_extension/libuv/src/uv-eio.h +13 -0
- data/ext/noderb_extension/libuv/src/uv-freebsd.c +65 -0
- data/ext/noderb_extension/libuv/src/uv-linux.c +51 -0
- data/ext/noderb_extension/libuv/src/uv-sunos.c +60 -0
- data/ext/noderb_extension/libuv/src/uv-unix.c +2408 -0
- data/ext/noderb_extension/libuv/src/win/async.c +129 -0
- data/ext/noderb_extension/libuv/src/win/cares.c +304 -0
- data/ext/noderb_extension/libuv/src/win/core.c +155 -0
- data/ext/noderb_extension/libuv/src/win/error.c +140 -0
- data/ext/noderb_extension/libuv/src/win/getaddrinfo.c +341 -0
- data/ext/noderb_extension/libuv/src/win/handle.c +176 -0
- data/ext/noderb_extension/libuv/src/win/internal.h +237 -0
- data/ext/noderb_extension/libuv/src/win/loop-watcher.c +128 -0
- data/ext/noderb_extension/libuv/src/win/pipe.c +828 -0
- data/ext/noderb_extension/libuv/src/win/process.c +936 -0
- data/ext/noderb_extension/libuv/src/win/req.c +141 -0
- data/ext/noderb_extension/libuv/src/win/stdio.c +75 -0
- data/ext/noderb_extension/libuv/src/win/stream.c +149 -0
- data/ext/noderb_extension/libuv/src/win/tcp.c +895 -0
- data/ext/noderb_extension/libuv/src/win/timer.c +269 -0
- data/ext/noderb_extension/libuv/src/win/util.c +82 -0
- data/ext/noderb_extension/libuv/test/benchmark-ares.c +117 -0
- data/ext/noderb_extension/libuv/test/benchmark-getaddrinfo.c +90 -0
- data/ext/noderb_extension/libuv/test/benchmark-list.h +77 -0
- data/ext/noderb_extension/libuv/test/benchmark-ping-pongs.c +210 -0
- data/ext/noderb_extension/libuv/test/benchmark-pound.c +237 -0
- data/ext/noderb_extension/libuv/test/benchmark-pump.c +459 -0
- data/ext/noderb_extension/libuv/test/benchmark-sizes.c +39 -0
- data/ext/noderb_extension/libuv/test/benchmark-spawn.c +154 -0
- data/ext/noderb_extension/libuv/test/dns-server.c +323 -0
- data/ext/noderb_extension/libuv/test/echo-server.c +299 -0
- data/ext/noderb_extension/libuv/test/run-benchmarks.c +64 -0
- data/ext/noderb_extension/libuv/test/run-tests.c +82 -0
- data/ext/noderb_extension/libuv/test/runner-unix.c +335 -0
- data/ext/noderb_extension/libuv/test/runner-unix.h +36 -0
- data/ext/noderb_extension/libuv/test/runner-win.c +343 -0
- data/ext/noderb_extension/libuv/test/runner-win.h +42 -0
- data/ext/noderb_extension/libuv/test/runner.c +311 -0
- data/ext/noderb_extension/libuv/test/runner.h +155 -0
- data/ext/noderb_extension/libuv/test/task.h +111 -0
- data/ext/noderb_extension/libuv/test/test-async.c +218 -0
- data/ext/noderb_extension/libuv/test/test-callback-stack.c +205 -0
- data/ext/noderb_extension/libuv/test/test-connection-fail.c +149 -0
- data/ext/noderb_extension/libuv/test/test-delayed-accept.c +198 -0
- data/ext/noderb_extension/libuv/test/test-fail-always.c +29 -0
- data/ext/noderb_extension/libuv/test/test-get-currentexe.c +53 -0
- data/ext/noderb_extension/libuv/test/test-getaddrinfo.c +110 -0
- data/ext/noderb_extension/libuv/test/test-gethostbyname.c +192 -0
- data/ext/noderb_extension/libuv/test/test-getsockname.c +196 -0
- data/ext/noderb_extension/libuv/test/test-hrtime.c +51 -0
- data/ext/noderb_extension/libuv/test/test-idle.c +83 -0
- data/ext/noderb_extension/libuv/test/test-list.h +165 -0
- data/ext/noderb_extension/libuv/test/test-loop-handles.c +361 -0
- data/ext/noderb_extension/libuv/test/test-pass-always.c +28 -0
- data/ext/noderb_extension/libuv/test/test-ping-pong.c +256 -0
- data/ext/noderb_extension/libuv/test/test-pipe-bind-error.c +148 -0
- data/ext/noderb_extension/libuv/test/test-ref.c +91 -0
- data/ext/noderb_extension/libuv/test/test-shutdown-eof.c +183 -0
- data/ext/noderb_extension/libuv/test/test-spawn.c +345 -0
- data/ext/noderb_extension/libuv/test/test-tcp-bind-error.c +204 -0
- data/ext/noderb_extension/libuv/test/test-tcp-bind6-error.c +164 -0
- data/ext/noderb_extension/libuv/test/test-tcp-writealot.c +198 -0
- data/ext/noderb_extension/libuv/test/test-timer-again.c +141 -0
- data/ext/noderb_extension/libuv/test/test-timer.c +134 -0
- data/ext/noderb_extension/noderb.c +340 -0
- data/ext/noderb_extension/noderb.h +2 -0
- data/lib/noderb/connection.rb +21 -0
- data/lib/noderb/process.rb +17 -0
- data/lib/noderb.rb +25 -0
- metadata +470 -0
@@ -0,0 +1,125 @@
|
|
1
|
+
/*
|
2
|
+
* pthread_key_delete.c
|
3
|
+
*
|
4
|
+
* Description:
|
5
|
+
* POSIX thread functions which implement thread-specific data (TSD).
|
6
|
+
*
|
7
|
+
* --------------------------------------------------------------------------
|
8
|
+
*
|
9
|
+
* Pthreads-win32 - POSIX Threads Library for Win32
|
10
|
+
* Copyright(C) 1998 John E. Bossom
|
11
|
+
* Copyright(C) 1999,2005 Pthreads-win32 contributors
|
12
|
+
*
|
13
|
+
* Contact Email: rpj@callisto.canberra.edu.au
|
14
|
+
*
|
15
|
+
* The current list of contributors is contained
|
16
|
+
* in the file CONTRIBUTORS included with the source
|
17
|
+
* code distribution. The list can also be seen at the
|
18
|
+
* following World Wide Web location:
|
19
|
+
* http://sources.redhat.com/pthreads-win32/contributors.html
|
20
|
+
*
|
21
|
+
* This library is free software; you can redistribute it and/or
|
22
|
+
* modify it under the terms of the GNU Lesser General Public
|
23
|
+
* License as published by the Free Software Foundation; either
|
24
|
+
* version 2 of the License, or (at your option) any later version.
|
25
|
+
*
|
26
|
+
* This library is distributed in the hope that it will be useful,
|
27
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
28
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
29
|
+
* Lesser General Public License for more details.
|
30
|
+
*
|
31
|
+
* You should have received a copy of the GNU Lesser General Public
|
32
|
+
* License along with this library in the file COPYING.LIB;
|
33
|
+
* if not, write to the Free Software Foundation, Inc.,
|
34
|
+
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
35
|
+
*/
|
36
|
+
|
37
|
+
#include "pthread.h"
|
38
|
+
#include "implement.h"
|
39
|
+
|
40
|
+
|
41
|
+
int
|
42
|
+
pthread_key_delete (pthread_key_t key)
|
43
|
+
/*
|
44
|
+
* ------------------------------------------------------
|
45
|
+
* DOCPUBLIC
|
46
|
+
* This function deletes a thread-specific data key. This
|
47
|
+
* does not change the value of the thread specific data key
|
48
|
+
* for any thread and does not run the key's destructor
|
49
|
+
* in any thread so it should be used with caution.
|
50
|
+
*
|
51
|
+
* PARAMETERS
|
52
|
+
* key
|
53
|
+
* pointer to an instance of pthread_key_t
|
54
|
+
*
|
55
|
+
*
|
56
|
+
* DESCRIPTION
|
57
|
+
* This function deletes a thread-specific data key. This
|
58
|
+
* does not change the value of the thread specific data key
|
59
|
+
* for any thread and does not run the key's destructor
|
60
|
+
* in any thread so it should be used with caution.
|
61
|
+
*
|
62
|
+
* RESULTS
|
63
|
+
* 0 successfully deleted the key,
|
64
|
+
* EINVAL key is invalid,
|
65
|
+
*
|
66
|
+
* ------------------------------------------------------
|
67
|
+
*/
|
68
|
+
{
|
69
|
+
ptw32_mcs_local_node_t keyLock;
|
70
|
+
int result = 0;
|
71
|
+
|
72
|
+
if (key != NULL)
|
73
|
+
{
|
74
|
+
if (key->threads != NULL && key->destructor != NULL)
|
75
|
+
{
|
76
|
+
ThreadKeyAssoc *assoc;
|
77
|
+
ptw32_mcs_lock_acquire (&(key->keyLock), &keyLock);
|
78
|
+
/*
|
79
|
+
* Run through all Thread<-->Key associations
|
80
|
+
* for this key.
|
81
|
+
*
|
82
|
+
* While we hold at least one of the locks guarding
|
83
|
+
* the assoc, we know that the assoc pointed to by
|
84
|
+
* key->threads is valid.
|
85
|
+
*/
|
86
|
+
while ((assoc = (ThreadKeyAssoc *) key->threads) != NULL)
|
87
|
+
{
|
88
|
+
ptw32_mcs_local_node_t threadLock;
|
89
|
+
ptw32_thread_t * thread = assoc->thread;
|
90
|
+
|
91
|
+
if (assoc == NULL)
|
92
|
+
{
|
93
|
+
/* Finished */
|
94
|
+
break;
|
95
|
+
}
|
96
|
+
|
97
|
+
ptw32_mcs_lock_acquire (&(thread->threadLock), &threadLock);
|
98
|
+
/*
|
99
|
+
* Since we are starting at the head of the key's threads
|
100
|
+
* chain, this will also point key->threads at the next assoc.
|
101
|
+
* While we hold key->keyLock, no other thread can insert
|
102
|
+
* a new assoc via pthread_setspecific.
|
103
|
+
*/
|
104
|
+
ptw32_tkAssocDestroy (assoc);
|
105
|
+
ptw32_mcs_lock_release (&threadLock);
|
106
|
+
ptw32_mcs_lock_release (&keyLock);
|
107
|
+
}
|
108
|
+
}
|
109
|
+
|
110
|
+
TlsFree (key->key);
|
111
|
+
if (key->destructor != NULL)
|
112
|
+
{
|
113
|
+
/* A thread could be holding the keyLock */
|
114
|
+
ptw32_mcs_lock_acquire (&(key->keyLock), &keyLock);
|
115
|
+
ptw32_mcs_lock_release (&keyLock);
|
116
|
+
}
|
117
|
+
|
118
|
+
#if defined( _DEBUG )
|
119
|
+
memset ((char *) key, 0, sizeof (*key));
|
120
|
+
#endif
|
121
|
+
free (key);
|
122
|
+
}
|
123
|
+
|
124
|
+
return (result);
|
125
|
+
}
|
@@ -0,0 +1,105 @@
|
|
1
|
+
/*
|
2
|
+
* pthread_kill.c
|
3
|
+
*
|
4
|
+
* Description:
|
5
|
+
* This translation unit implements the pthread_kill routine.
|
6
|
+
*
|
7
|
+
* --------------------------------------------------------------------------
|
8
|
+
*
|
9
|
+
* Pthreads-win32 - POSIX Threads Library for Win32
|
10
|
+
* Copyright(C) 1998 John E. Bossom
|
11
|
+
* Copyright(C) 1999,2005 Pthreads-win32 contributors
|
12
|
+
*
|
13
|
+
* Contact Email: rpj@callisto.canberra.edu.au
|
14
|
+
*
|
15
|
+
* The current list of contributors is contained
|
16
|
+
* in the file CONTRIBUTORS included with the source
|
17
|
+
* code distribution. The list can also be seen at the
|
18
|
+
* following World Wide Web location:
|
19
|
+
* http://sources.redhat.com/pthreads-win32/contributors.html
|
20
|
+
*
|
21
|
+
* This library is free software; you can redistribute it and/or
|
22
|
+
* modify it under the terms of the GNU Lesser General Public
|
23
|
+
* License as published by the Free Software Foundation; either
|
24
|
+
* version 2 of the License, or (at your option) any later version.
|
25
|
+
*
|
26
|
+
* This library is distributed in the hope that it will be useful,
|
27
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
28
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
29
|
+
* Lesser General Public License for more details.
|
30
|
+
*
|
31
|
+
* You should have received a copy of the GNU Lesser General Public
|
32
|
+
* License along with this library in the file COPYING.LIB;
|
33
|
+
* if not, write to the Free Software Foundation, Inc.,
|
34
|
+
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
35
|
+
*/
|
36
|
+
|
37
|
+
#include "pthread.h"
|
38
|
+
#include "implement.h"
|
39
|
+
|
40
|
+
/*
|
41
|
+
* Not needed yet, but defining it should indicate clashes with build target
|
42
|
+
* environment that should be fixed.
|
43
|
+
*/
|
44
|
+
#if !defined(WINCE)
|
45
|
+
# include <signal.h>
|
46
|
+
#endif
|
47
|
+
|
48
|
+
int
|
49
|
+
pthread_kill (pthread_t thread, int sig)
|
50
|
+
/*
|
51
|
+
* ------------------------------------------------------
|
52
|
+
* DOCPUBLIC
|
53
|
+
* This function requests that a signal be delivered to the
|
54
|
+
* specified thread. If sig is zero, error checking is
|
55
|
+
* performed but no signal is actually sent such that this
|
56
|
+
* function can be used to check for a valid thread ID.
|
57
|
+
*
|
58
|
+
* PARAMETERS
|
59
|
+
* thread reference to an instances of pthread_t
|
60
|
+
* sig signal. Currently only a value of 0 is supported.
|
61
|
+
*
|
62
|
+
*
|
63
|
+
* DESCRIPTION
|
64
|
+
* This function requests that a signal be delivered to the
|
65
|
+
* specified thread. If sig is zero, error checking is
|
66
|
+
* performed but no signal is actually sent such that this
|
67
|
+
* function can be used to check for a valid thread ID.
|
68
|
+
*
|
69
|
+
* RESULTS
|
70
|
+
* ESRCH the thread is not a valid thread ID,
|
71
|
+
* EINVAL the value of the signal is invalid
|
72
|
+
* or unsupported.
|
73
|
+
* 0 the signal was successfully sent.
|
74
|
+
*
|
75
|
+
* ------------------------------------------------------
|
76
|
+
*/
|
77
|
+
{
|
78
|
+
int result = 0;
|
79
|
+
ptw32_thread_t * tp;
|
80
|
+
ptw32_mcs_local_node_t node;
|
81
|
+
|
82
|
+
ptw32_mcs_lock_acquire(&ptw32_thread_reuse_lock, &node);
|
83
|
+
|
84
|
+
tp = (ptw32_thread_t *) thread.p;
|
85
|
+
|
86
|
+
if (NULL == tp
|
87
|
+
|| thread.x != tp->ptHandle.x
|
88
|
+
|| NULL == tp->threadH)
|
89
|
+
{
|
90
|
+
result = ESRCH;
|
91
|
+
}
|
92
|
+
|
93
|
+
ptw32_mcs_lock_release(&node);
|
94
|
+
|
95
|
+
if (0 == result && 0 != sig)
|
96
|
+
{
|
97
|
+
/*
|
98
|
+
* Currently does not support any signals.
|
99
|
+
*/
|
100
|
+
result = EINVAL;
|
101
|
+
}
|
102
|
+
|
103
|
+
return result;
|
104
|
+
|
105
|
+
} /* pthread_kill */
|
@@ -0,0 +1,187 @@
|
|
1
|
+
/*
|
2
|
+
* pthread_mutex_consistent.c
|
3
|
+
*
|
4
|
+
* Description:
|
5
|
+
* This translation unit implements mutual exclusion (mutex) primitives.
|
6
|
+
*
|
7
|
+
* --------------------------------------------------------------------------
|
8
|
+
*
|
9
|
+
* Pthreads-win32 - POSIX Threads Library for Win32
|
10
|
+
* Copyright(C) 1998 John E. Bossom
|
11
|
+
* Copyright(C) 1999,2005 Pthreads-win32 contributors
|
12
|
+
*
|
13
|
+
* Contact Email: rpj@callisto.canberra.edu.au
|
14
|
+
*
|
15
|
+
* The current list of contributors is contained
|
16
|
+
* in the file CONTRIBUTORS included with the source
|
17
|
+
* code distribution. The list can also be seen at the
|
18
|
+
* following World Wide Web location:
|
19
|
+
* http://sources.redhat.com/pthreads-win32/contributors.html
|
20
|
+
*
|
21
|
+
* This library is free software; you can redistribute it and/or
|
22
|
+
* modify it under the terms of the GNU Lesser General Public
|
23
|
+
* License as published by the Free Software Foundation; either
|
24
|
+
* version 2 of the License, or (at your option) any later version.
|
25
|
+
*
|
26
|
+
* This library is distributed in the hope that it will be useful,
|
27
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
28
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
29
|
+
* Lesser General Public License for more details.
|
30
|
+
*
|
31
|
+
* You should have received a copy of the GNU Lesser General Public
|
32
|
+
* License along with this library in the file COPYING.LIB;
|
33
|
+
* if not, write to the Free Software Foundation, Inc.,
|
34
|
+
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
35
|
+
*/
|
36
|
+
|
37
|
+
/*
|
38
|
+
* From the Sun Multi-threaded Programming Guide
|
39
|
+
*
|
40
|
+
* robustness defines the behavior when the owner of the mutex terminates without unlocking the
|
41
|
+
* mutex, usually because its process terminated abnormally. The value of robustness that is
|
42
|
+
* defined in pthread.h is PTHREAD_MUTEX_ROBUST or PTHREAD_MUTEX_STALLED. The
|
43
|
+
* default value is PTHREAD_MUTEX_STALLED .
|
44
|
+
* ■ PTHREAD_MUTEX_STALLED
|
45
|
+
* When the owner of the mutex terminates without unlocking the mutex, all subsequent calls
|
46
|
+
* to pthread_mutex_lock() are blocked from progress in an unspecified manner.
|
47
|
+
* ■ PTHREAD_MUTEX_ROBUST
|
48
|
+
* When the owner of the mutex terminates without unlocking the mutex, the mutex is
|
49
|
+
* unlocked. The next owner of this mutex acquires the mutex with an error return of
|
50
|
+
* EOWNERDEAD.
|
51
|
+
* Note – Your application must always check the return code from pthread_mutex_lock() for
|
52
|
+
* a mutex initialized with the PTHREAD_MUTEX_ROBUST attribute.
|
53
|
+
* ■ The new owner of this mutex should make the state protected by the mutex consistent.
|
54
|
+
* This state might have been left inconsistent when the previous owner terminated.
|
55
|
+
* ■ If the new owner is able to make the state consistent, call
|
56
|
+
* pthread_mutex_consistent() for the mutex before unlocking the mutex. This
|
57
|
+
* marks the mutex as consistent and subsequent calls to pthread_mutex_lock() and
|
58
|
+
* pthread_mutex_unlock() will behave in the normal manner.
|
59
|
+
* ■ If the new owner is not able to make the state consistent, do not call
|
60
|
+
* pthread_mutex_consistent() for the mutex, but unlock the mutex.
|
61
|
+
* All waiters are woken up and all subsequent calls to pthread_mutex_lock() fail to
|
62
|
+
* acquire the mutex. The return code is ENOTRECOVERABLE. The mutex can be made
|
63
|
+
* consistent by calling pthread_mutex_destroy() to uninitialize the mutex, and calling
|
64
|
+
* pthread_mutex_int() to reinitialize the mutex.However, the state that was protected
|
65
|
+
* by the mutex remains inconsistent and some form of application recovery is required.
|
66
|
+
* ■ If the thread that acquires the lock with EOWNERDEAD terminates without unlocking the
|
67
|
+
* mutex, the next owner acquires the lock with an EOWNERDEAD return code.
|
68
|
+
*/
|
69
|
+
#if !defined(_UWIN)
|
70
|
+
/*# include <process.h> */
|
71
|
+
#endif
|
72
|
+
#include "pthread.h"
|
73
|
+
#include "implement.h"
|
74
|
+
|
75
|
+
int
|
76
|
+
ptw32_robust_mutex_inherit(pthread_mutex_t * mutex)
|
77
|
+
{
|
78
|
+
int result;
|
79
|
+
pthread_mutex_t mx = *mutex;
|
80
|
+
ptw32_robust_node_t* robust = mx->robustNode;
|
81
|
+
|
82
|
+
switch ((LONG)PTW32_INTERLOCKED_COMPARE_EXCHANGE_LONG(
|
83
|
+
(PTW32_INTERLOCKED_LONGPTR)&robust->stateInconsistent,
|
84
|
+
(PTW32_INTERLOCKED_LONG)PTW32_ROBUST_INCONSISTENT,
|
85
|
+
(PTW32_INTERLOCKED_LONG)-1 /* The terminating thread sets this */))
|
86
|
+
{
|
87
|
+
case -1L:
|
88
|
+
result = EOWNERDEAD;
|
89
|
+
break;
|
90
|
+
case (LONG)PTW32_ROBUST_NOTRECOVERABLE:
|
91
|
+
result = ENOTRECOVERABLE;
|
92
|
+
break;
|
93
|
+
default:
|
94
|
+
result = 0;
|
95
|
+
break;
|
96
|
+
}
|
97
|
+
|
98
|
+
return result;
|
99
|
+
}
|
100
|
+
|
101
|
+
/*
|
102
|
+
* The next two internal support functions depend on only being
|
103
|
+
* called by the thread that owns the robust mutex. This enables
|
104
|
+
* us to avoid additional locks.
|
105
|
+
* Any mutex currently in the thread's robust mutex list is held
|
106
|
+
* by the thread, again eliminating the need for locks.
|
107
|
+
* The forward/backward links allow the thread to unlock mutexes
|
108
|
+
* in any order, not necessarily the reverse locking order.
|
109
|
+
* This is all possible because it is an error if a thread that
|
110
|
+
* does not own the [robust] mutex attempts to unlock it.
|
111
|
+
*/
|
112
|
+
|
113
|
+
void
|
114
|
+
ptw32_robust_mutex_add(pthread_mutex_t* mutex, pthread_t self)
|
115
|
+
{
|
116
|
+
ptw32_robust_node_t** list;
|
117
|
+
pthread_mutex_t mx = *mutex;
|
118
|
+
ptw32_thread_t* tp = (ptw32_thread_t*)self.p;
|
119
|
+
ptw32_robust_node_t* robust = mx->robustNode;
|
120
|
+
|
121
|
+
list = &tp->robustMxList;
|
122
|
+
mx->ownerThread = self;
|
123
|
+
if (NULL == *list)
|
124
|
+
{
|
125
|
+
robust->prev = NULL;
|
126
|
+
robust->next = NULL;
|
127
|
+
*list = robust;
|
128
|
+
}
|
129
|
+
else
|
130
|
+
{
|
131
|
+
robust->prev = NULL;
|
132
|
+
robust->next = *list;
|
133
|
+
(*list)->prev = robust;
|
134
|
+
*list = robust;
|
135
|
+
}
|
136
|
+
}
|
137
|
+
|
138
|
+
void
|
139
|
+
ptw32_robust_mutex_remove(pthread_mutex_t* mutex, ptw32_thread_t* otp)
|
140
|
+
{
|
141
|
+
ptw32_robust_node_t** list;
|
142
|
+
pthread_mutex_t mx = *mutex;
|
143
|
+
ptw32_robust_node_t* robust = mx->robustNode;
|
144
|
+
|
145
|
+
list = &(((ptw32_thread_t*)mx->ownerThread.p)->robustMxList);
|
146
|
+
mx->ownerThread.p = otp;
|
147
|
+
if (robust->next != NULL)
|
148
|
+
{
|
149
|
+
robust->next->prev = robust->prev;
|
150
|
+
}
|
151
|
+
if (robust->prev != NULL)
|
152
|
+
{
|
153
|
+
robust->prev->next = robust->next;
|
154
|
+
}
|
155
|
+
if (*list == robust)
|
156
|
+
{
|
157
|
+
*list = robust->next;
|
158
|
+
}
|
159
|
+
}
|
160
|
+
|
161
|
+
|
162
|
+
int
|
163
|
+
pthread_mutex_consistent (pthread_mutex_t* mutex)
|
164
|
+
{
|
165
|
+
pthread_mutex_t mx = *mutex;
|
166
|
+
int result = 0;
|
167
|
+
|
168
|
+
/*
|
169
|
+
* Let the system deal with invalid pointers.
|
170
|
+
*/
|
171
|
+
if (mx == NULL)
|
172
|
+
{
|
173
|
+
return EINVAL;
|
174
|
+
}
|
175
|
+
|
176
|
+
if (mx->kind >= 0
|
177
|
+
|| (PTW32_INTERLOCKED_LONG)PTW32_ROBUST_INCONSISTENT != PTW32_INTERLOCKED_COMPARE_EXCHANGE_LONG(
|
178
|
+
(PTW32_INTERLOCKED_LONGPTR)&mx->robustNode->stateInconsistent,
|
179
|
+
(PTW32_INTERLOCKED_LONG)PTW32_ROBUST_CONSISTENT,
|
180
|
+
(PTW32_INTERLOCKED_LONG)PTW32_ROBUST_INCONSISTENT))
|
181
|
+
{
|
182
|
+
result = EINVAL;
|
183
|
+
}
|
184
|
+
|
185
|
+
return (result);
|
186
|
+
}
|
187
|
+
|
@@ -0,0 +1,148 @@
|
|
1
|
+
/*
|
2
|
+
* pthread_mutex_destroy.c
|
3
|
+
*
|
4
|
+
* Description:
|
5
|
+
* This translation unit implements mutual exclusion (mutex) primitives.
|
6
|
+
*
|
7
|
+
* --------------------------------------------------------------------------
|
8
|
+
*
|
9
|
+
* Pthreads-win32 - POSIX Threads Library for Win32
|
10
|
+
* Copyright(C) 1998 John E. Bossom
|
11
|
+
* Copyright(C) 1999,2005 Pthreads-win32 contributors
|
12
|
+
*
|
13
|
+
* Contact Email: rpj@callisto.canberra.edu.au
|
14
|
+
*
|
15
|
+
* The current list of contributors is contained
|
16
|
+
* in the file CONTRIBUTORS included with the source
|
17
|
+
* code distribution. The list can also be seen at the
|
18
|
+
* following World Wide Web location:
|
19
|
+
* http://sources.redhat.com/pthreads-win32/contributors.html
|
20
|
+
*
|
21
|
+
* This library is free software; you can redistribute it and/or
|
22
|
+
* modify it under the terms of the GNU Lesser General Public
|
23
|
+
* License as published by the Free Software Foundation; either
|
24
|
+
* version 2 of the License, or (at your option) any later version.
|
25
|
+
*
|
26
|
+
* This library is distributed in the hope that it will be useful,
|
27
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
28
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
29
|
+
* Lesser General Public License for more details.
|
30
|
+
*
|
31
|
+
* You should have received a copy of the GNU Lesser General Public
|
32
|
+
* License along with this library in the file COPYING.LIB;
|
33
|
+
* if not, write to the Free Software Foundation, Inc.,
|
34
|
+
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
35
|
+
*/
|
36
|
+
|
37
|
+
#include "pthread.h"
|
38
|
+
#include "implement.h"
|
39
|
+
|
40
|
+
|
41
|
+
int
|
42
|
+
pthread_mutex_destroy (pthread_mutex_t * mutex)
|
43
|
+
{
|
44
|
+
int result = 0;
|
45
|
+
pthread_mutex_t mx;
|
46
|
+
|
47
|
+
/*
|
48
|
+
* Let the system deal with invalid pointers.
|
49
|
+
*/
|
50
|
+
|
51
|
+
/*
|
52
|
+
* Check to see if we have something to delete.
|
53
|
+
*/
|
54
|
+
if (*mutex < PTHREAD_ERRORCHECK_MUTEX_INITIALIZER)
|
55
|
+
{
|
56
|
+
mx = *mutex;
|
57
|
+
|
58
|
+
result = pthread_mutex_trylock (&mx);
|
59
|
+
|
60
|
+
/*
|
61
|
+
* If trylock succeeded and the mutex is not recursively locked it
|
62
|
+
* can be destroyed.
|
63
|
+
*/
|
64
|
+
if (0 == result || ENOTRECOVERABLE == result)
|
65
|
+
{
|
66
|
+
if (mx->kind != PTHREAD_MUTEX_RECURSIVE || 1 == mx->recursive_count)
|
67
|
+
{
|
68
|
+
/*
|
69
|
+
* FIXME!!!
|
70
|
+
* The mutex isn't held by another thread but we could still
|
71
|
+
* be too late invalidating the mutex below since another thread
|
72
|
+
* may already have entered mutex_lock and the check for a valid
|
73
|
+
* *mutex != NULL.
|
74
|
+
*/
|
75
|
+
*mutex = NULL;
|
76
|
+
|
77
|
+
result = (0 == result)?pthread_mutex_unlock(&mx):0;
|
78
|
+
|
79
|
+
if (0 == result)
|
80
|
+
{
|
81
|
+
if (mx->robustNode != NULL)
|
82
|
+
{
|
83
|
+
free(mx->robustNode);
|
84
|
+
}
|
85
|
+
if (!CloseHandle (mx->event))
|
86
|
+
{
|
87
|
+
*mutex = mx;
|
88
|
+
result = EINVAL;
|
89
|
+
}
|
90
|
+
else
|
91
|
+
{
|
92
|
+
free (mx);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
else
|
96
|
+
{
|
97
|
+
/*
|
98
|
+
* Restore the mutex before we return the error.
|
99
|
+
*/
|
100
|
+
*mutex = mx;
|
101
|
+
}
|
102
|
+
}
|
103
|
+
else /* mx->recursive_count > 1 */
|
104
|
+
{
|
105
|
+
/*
|
106
|
+
* The mutex must be recursive and already locked by us (this thread).
|
107
|
+
*/
|
108
|
+
mx->recursive_count--; /* Undo effect of pthread_mutex_trylock() above */
|
109
|
+
result = EBUSY;
|
110
|
+
}
|
111
|
+
}
|
112
|
+
}
|
113
|
+
else
|
114
|
+
{
|
115
|
+
ptw32_mcs_local_node_t node;
|
116
|
+
|
117
|
+
/*
|
118
|
+
* See notes in ptw32_mutex_check_need_init() above also.
|
119
|
+
*/
|
120
|
+
|
121
|
+
ptw32_mcs_lock_acquire(&ptw32_mutex_test_init_lock, &node);
|
122
|
+
|
123
|
+
/*
|
124
|
+
* Check again.
|
125
|
+
*/
|
126
|
+
if (*mutex >= PTHREAD_ERRORCHECK_MUTEX_INITIALIZER)
|
127
|
+
{
|
128
|
+
/*
|
129
|
+
* This is all we need to do to destroy a statically
|
130
|
+
* initialised mutex that has not yet been used (initialised).
|
131
|
+
* If we get to here, another thread
|
132
|
+
* waiting to initialise this mutex will get an EINVAL.
|
133
|
+
*/
|
134
|
+
*mutex = NULL;
|
135
|
+
}
|
136
|
+
else
|
137
|
+
{
|
138
|
+
/*
|
139
|
+
* The mutex has been initialised while we were waiting
|
140
|
+
* so assume it's in use.
|
141
|
+
*/
|
142
|
+
result = EBUSY;
|
143
|
+
}
|
144
|
+
ptw32_mcs_lock_release(&node);
|
145
|
+
}
|
146
|
+
|
147
|
+
return (result);
|
148
|
+
}
|
@@ -0,0 +1,130 @@
|
|
1
|
+
/*
|
2
|
+
* pthread_mutex_init.c
|
3
|
+
*
|
4
|
+
* Description:
|
5
|
+
* This translation unit implements mutual exclusion (mutex) primitives.
|
6
|
+
*
|
7
|
+
* --------------------------------------------------------------------------
|
8
|
+
*
|
9
|
+
* Pthreads-win32 - POSIX Threads Library for Win32
|
10
|
+
* Copyright(C) 1998 John E. Bossom
|
11
|
+
* Copyright(C) 1999,2005 Pthreads-win32 contributors
|
12
|
+
*
|
13
|
+
* Contact Email: rpj@callisto.canberra.edu.au
|
14
|
+
*
|
15
|
+
* The current list of contributors is contained
|
16
|
+
* in the file CONTRIBUTORS included with the source
|
17
|
+
* code distribution. The list can also be seen at the
|
18
|
+
* following World Wide Web location:
|
19
|
+
* http://sources.redhat.com/pthreads-win32/contributors.html
|
20
|
+
*
|
21
|
+
* This library is free software; you can redistribute it and/or
|
22
|
+
* modify it under the terms of the GNU Lesser General Public
|
23
|
+
* License as published by the Free Software Foundation; either
|
24
|
+
* version 2 of the License, or (at your option) any later version.
|
25
|
+
*
|
26
|
+
* This library is distributed in the hope that it will be useful,
|
27
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
28
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
29
|
+
* Lesser General Public License for more details.
|
30
|
+
*
|
31
|
+
* You should have received a copy of the GNU Lesser General Public
|
32
|
+
* License along with this library in the file COPYING.LIB;
|
33
|
+
* if not, write to the Free Software Foundation, Inc.,
|
34
|
+
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
35
|
+
*/
|
36
|
+
|
37
|
+
#include "pthread.h"
|
38
|
+
#include "implement.h"
|
39
|
+
|
40
|
+
|
41
|
+
int
|
42
|
+
pthread_mutex_init (pthread_mutex_t * mutex, const pthread_mutexattr_t * attr)
|
43
|
+
{
|
44
|
+
int result = 0;
|
45
|
+
pthread_mutex_t mx;
|
46
|
+
|
47
|
+
if (mutex == NULL)
|
48
|
+
{
|
49
|
+
return EINVAL;
|
50
|
+
}
|
51
|
+
|
52
|
+
if (attr != NULL && *attr != NULL)
|
53
|
+
{
|
54
|
+
if ((*attr)->pshared == PTHREAD_PROCESS_SHARED)
|
55
|
+
{
|
56
|
+
/*
|
57
|
+
* Creating mutex that can be shared between
|
58
|
+
* processes.
|
59
|
+
*/
|
60
|
+
#if _POSIX_THREAD_PROCESS_SHARED >= 0
|
61
|
+
|
62
|
+
/*
|
63
|
+
* Not implemented yet.
|
64
|
+
*/
|
65
|
+
|
66
|
+
#error ERROR [__FILE__, line __LINE__]: Process shared mutexes are not supported yet.
|
67
|
+
|
68
|
+
#else
|
69
|
+
|
70
|
+
return ENOSYS;
|
71
|
+
|
72
|
+
#endif /* _POSIX_THREAD_PROCESS_SHARED */
|
73
|
+
}
|
74
|
+
}
|
75
|
+
|
76
|
+
mx = (pthread_mutex_t) calloc (1, sizeof (*mx));
|
77
|
+
|
78
|
+
if (mx == NULL)
|
79
|
+
{
|
80
|
+
result = ENOMEM;
|
81
|
+
}
|
82
|
+
else
|
83
|
+
{
|
84
|
+
mx->lock_idx = 0;
|
85
|
+
mx->recursive_count = 0;
|
86
|
+
mx->robustNode = NULL;
|
87
|
+
if (attr == NULL || *attr == NULL)
|
88
|
+
{
|
89
|
+
mx->kind = PTHREAD_MUTEX_DEFAULT;
|
90
|
+
}
|
91
|
+
else
|
92
|
+
{
|
93
|
+
mx->kind = (*attr)->kind;
|
94
|
+
if ((*attr)->robustness == PTHREAD_MUTEX_ROBUST)
|
95
|
+
{
|
96
|
+
/*
|
97
|
+
* Use the negative range to represent robust types.
|
98
|
+
* Replaces a memory fetch with a register negate and incr
|
99
|
+
* in pthread_mutex_lock etc.
|
100
|
+
*
|
101
|
+
* Map 0,1,..,n to -1,-2,..,(-n)-1
|
102
|
+
*/
|
103
|
+
mx->kind = -mx->kind - 1;
|
104
|
+
|
105
|
+
mx->robustNode = (ptw32_robust_node_t*) malloc(sizeof(ptw32_robust_node_t));
|
106
|
+
mx->robustNode->stateInconsistent = PTW32_ROBUST_CONSISTENT;
|
107
|
+
mx->robustNode->mx = mx;
|
108
|
+
mx->robustNode->next = NULL;
|
109
|
+
mx->robustNode->prev = NULL;
|
110
|
+
}
|
111
|
+
}
|
112
|
+
|
113
|
+
mx->ownerThread.p = NULL;
|
114
|
+
|
115
|
+
mx->event = CreateEvent (NULL, PTW32_FALSE, /* manual reset = No */
|
116
|
+
PTW32_FALSE, /* initial state = not signaled */
|
117
|
+
NULL); /* event name */
|
118
|
+
|
119
|
+
if (0 == mx->event)
|
120
|
+
{
|
121
|
+
result = ENOSPC;
|
122
|
+
free (mx);
|
123
|
+
mx = NULL;
|
124
|
+
}
|
125
|
+
}
|
126
|
+
|
127
|
+
*mutex = mx;
|
128
|
+
|
129
|
+
return (result);
|
130
|
+
}
|