rbczmq 1.6.2 → 1.6.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (398) hide show
  1. data/.gitignore +4 -3
  2. data/.gitmodules +6 -0
  3. data/.travis.yml +5 -1
  4. data/CHANGELOG.rdoc +15 -0
  5. data/Gemfile.lock +2 -2
  6. data/README.rdoc +5 -2
  7. data/Rakefile +8 -3
  8. data/ext/czmq/.gitignore +52 -0
  9. data/ext/czmq/.travis.yml +18 -0
  10. data/ext/czmq/AUTHORS +9 -0
  11. data/ext/czmq/COPYING +674 -0
  12. data/ext/czmq/COPYING.LESSER +178 -0
  13. data/ext/czmq/ChangeLog +0 -0
  14. data/ext/czmq/Makefile.am +22 -0
  15. data/ext/czmq/NEWS +263 -0
  16. data/ext/czmq/README +0 -0
  17. data/ext/czmq/README.md +1122 -0
  18. data/ext/czmq/README.txt +327 -0
  19. data/ext/czmq/autogen.sh +46 -0
  20. data/ext/czmq/builds/android/Android.mk +35 -0
  21. data/ext/czmq/builds/android/Application.mk +1 -0
  22. data/ext/czmq/builds/android/build.sh +59 -0
  23. data/ext/czmq/builds/android/clean.sh +26 -0
  24. data/ext/czmq/builds/mingw32/Makefile.mingw32 +38 -0
  25. data/ext/czmq/builds/mingw32/platform.h +0 -0
  26. data/ext/czmq/builds/msvc/.gitignore +18 -0
  27. data/ext/czmq/builds/msvc/README.txt +17 -0
  28. data/ext/czmq/builds/msvc/czmq.sln +69 -0
  29. data/ext/czmq/builds/msvc/czmq.vcproj +2246 -0
  30. data/ext/czmq/builds/msvc/czmq.vcxproj +329 -0
  31. data/ext/czmq/builds/msvc/czmq.vcxproj.filters +117 -0
  32. data/ext/czmq/builds/msvc/czmq11.sln +36 -0
  33. data/ext/czmq/builds/msvc/czmq_selftest.vcproj +840 -0
  34. data/ext/czmq/builds/msvc/czmq_selftest.vcxproj +189 -0
  35. data/ext/czmq/builds/msvc/czmq_selftest.vcxproj.filters +14 -0
  36. data/ext/czmq/c +520 -0
  37. data/ext/czmq/configure.ac +229 -0
  38. data/ext/czmq/doc/Makefile.am +49 -0
  39. data/ext/czmq/doc/asciidoc.conf +57 -0
  40. data/ext/czmq/doc/czmq.txt +334 -0
  41. data/ext/czmq/doc/mkman +100 -0
  42. data/ext/czmq/doc/mksite +65 -0
  43. data/ext/czmq/doc/wdput +43 -0
  44. data/ext/czmq/doc/xml2wd.pl +242 -0
  45. data/ext/czmq/doc/zbeacon.txt +173 -0
  46. data/ext/czmq/doc/zclock.txt +51 -0
  47. data/ext/czmq/doc/zconfig.txt +92 -0
  48. data/ext/czmq/doc/zctx.txt +111 -0
  49. data/ext/czmq/doc/zfile.txt +77 -0
  50. data/ext/czmq/doc/zframe.txt +222 -0
  51. data/ext/czmq/doc/zhash.txt +225 -0
  52. data/ext/czmq/doc/zlist.txt +176 -0
  53. data/ext/czmq/doc/zloop.txt +106 -0
  54. data/ext/czmq/doc/zmsg.txt +315 -0
  55. data/ext/czmq/doc/zmutex.txt +54 -0
  56. data/ext/czmq/doc/zsocket.txt +110 -0
  57. data/ext/czmq/doc/zsockopt.txt +528 -0
  58. data/ext/czmq/doc/zstr.txt +80 -0
  59. data/ext/czmq/doc/zsys.txt +44 -0
  60. data/ext/czmq/doc/zthread.txt +126 -0
  61. data/ext/czmq/doc/ztree.txt +236 -0
  62. data/ext/czmq/images/README_1.png +0 -0
  63. data/ext/czmq/images/README_2.png +0 -0
  64. data/ext/czmq/include/czmq.h +64 -0
  65. data/ext/czmq/include/czmq_prelude.h +504 -0
  66. data/ext/czmq/include/zbeacon.h +91 -0
  67. data/ext/czmq/include/zclock.h +56 -0
  68. data/ext/czmq/include/zconfig.h +117 -0
  69. data/ext/czmq/include/zctx.h +96 -0
  70. data/ext/czmq/include/zfile.h +82 -0
  71. data/ext/czmq/include/zframe.h +145 -0
  72. data/ext/czmq/include/zhash.h +127 -0
  73. data/ext/czmq/include/zlist.h +113 -0
  74. data/ext/czmq/include/zloop.h +98 -0
  75. data/ext/czmq/include/zmsg.h +165 -0
  76. data/ext/czmq/include/zmutex.h +62 -0
  77. data/ext/czmq/include/zsocket.h +104 -0
  78. data/ext/czmq/include/zsockopt.h +249 -0
  79. data/ext/czmq/include/zstr.h +69 -0
  80. data/ext/czmq/include/zsys.h +66 -0
  81. data/ext/czmq/include/zthread.h +62 -0
  82. data/ext/czmq/include/ztree.h +133 -0
  83. data/ext/czmq/mkdoc +14 -0
  84. data/ext/czmq/model/generate +2 -0
  85. data/ext/czmq/model/sockopts.xml +101 -0
  86. data/ext/czmq/notes.txt +21 -0
  87. data/ext/czmq/scripts/sockopts.gsl +325 -0
  88. data/ext/czmq/src/Makefile.am +61 -0
  89. data/ext/czmq/src/czmq_selftest.c +60 -0
  90. data/ext/czmq/src/libczmq.pc.in +11 -0
  91. data/ext/czmq/src/selftest +7 -0
  92. data/ext/czmq/src/selftest.cfg +5 -0
  93. data/ext/czmq/src/valgrind.supp +14 -0
  94. data/ext/czmq/src/vg +2 -0
  95. data/ext/czmq/src/zbeacon.c +787 -0
  96. data/ext/czmq/src/zclock.c +143 -0
  97. data/ext/czmq/src/zconfig.c +691 -0
  98. data/ext/czmq/src/zctx.c +287 -0
  99. data/ext/czmq/src/zfile.c +237 -0
  100. data/ext/czmq/src/zframe.c +551 -0
  101. data/ext/czmq/src/zhash.c +664 -0
  102. data/ext/czmq/src/zlist.c +459 -0
  103. data/ext/czmq/src/zloop.c +496 -0
  104. data/ext/czmq/src/zmsg.c +854 -0
  105. data/ext/czmq/src/zmutex.c +134 -0
  106. data/ext/czmq/src/zsocket.c +313 -0
  107. data/ext/czmq/src/zsockopt.c +1756 -0
  108. data/ext/czmq/src/zstr.c +297 -0
  109. data/ext/czmq/src/zsys.c +136 -0
  110. data/ext/czmq/src/zthread.c +269 -0
  111. data/ext/czmq/src/ztree.c +888 -0
  112. data/ext/czmq/version.sh +21 -0
  113. data/ext/rbczmq/extconf.rb +1 -18
  114. data/ext/rbczmq/poller.c +4 -1
  115. data/ext/rbczmq/socket.c +28 -5
  116. data/ext/rbczmq/socket.h +1 -0
  117. data/ext/zeromq/AUTHORS +110 -0
  118. data/ext/zeromq/CMakeLists.txt +392 -0
  119. data/ext/zeromq/COPYING +674 -0
  120. data/ext/zeromq/COPYING.LESSER +179 -0
  121. data/ext/zeromq/INSTALL +246 -0
  122. data/ext/zeromq/MAINTAINERS +56 -0
  123. data/ext/zeromq/Makefile.am +40 -0
  124. data/ext/zeromq/NEWS +333 -0
  125. data/ext/zeromq/README +39 -0
  126. data/ext/zeromq/acinclude.m4 +930 -0
  127. data/ext/zeromq/autogen.sh +45 -0
  128. data/ext/zeromq/branding.bmp +0 -0
  129. data/ext/zeromq/builds/msvc/Makefile.am +33 -0
  130. data/ext/zeromq/builds/msvc/c_local_lat/c_local_lat.vcproj +176 -0
  131. data/ext/zeromq/builds/msvc/c_local_lat/c_local_lat.vcxproj +87 -0
  132. data/ext/zeromq/builds/msvc/c_local_thr/c_local_thr.vcproj +176 -0
  133. data/ext/zeromq/builds/msvc/c_local_thr/c_local_thr.vcxproj +87 -0
  134. data/ext/zeromq/builds/msvc/c_remote_lat/c_remote_lat.vcproj +176 -0
  135. data/ext/zeromq/builds/msvc/c_remote_lat/c_remote_lat.vcxproj +87 -0
  136. data/ext/zeromq/builds/msvc/c_remote_thr/c_remote_thr.vcproj +176 -0
  137. data/ext/zeromq/builds/msvc/c_remote_thr/c_remote_thr.vcxproj +87 -0
  138. data/ext/zeromq/builds/msvc/errno.cpp +32 -0
  139. data/ext/zeromq/builds/msvc/errno.hpp +56 -0
  140. data/ext/zeromq/builds/msvc/inproc_lat/inproc_lat.vcproj +174 -0
  141. data/ext/zeromq/builds/msvc/inproc_lat/inproc_lat.vcxproj +86 -0
  142. data/ext/zeromq/builds/msvc/inproc_thr/inproc_thr.vcproj +174 -0
  143. data/ext/zeromq/builds/msvc/inproc_thr/inproc_thr.vcxproj +86 -0
  144. data/ext/zeromq/builds/msvc/libzmq/libzmq.vcproj +804 -0
  145. data/ext/zeromq/builds/msvc/libzmq/libzmq.vcxproj +252 -0
  146. data/ext/zeromq/builds/msvc/libzmq/libzmq.vcxproj.filters +431 -0
  147. data/ext/zeromq/builds/msvc/msvc.sln +89 -0
  148. data/ext/zeromq/builds/msvc/msvc10.sln +116 -0
  149. data/ext/zeromq/builds/msvc/platform.hpp +32 -0
  150. data/ext/zeromq/builds/msvc/properties/Common.props +21 -0
  151. data/ext/zeromq/builds/msvc/properties/Debug.props +19 -0
  152. data/ext/zeromq/builds/msvc/properties/Dynamic.props +20 -0
  153. data/ext/zeromq/builds/msvc/properties/Executable.props +19 -0
  154. data/ext/zeromq/builds/msvc/properties/Precompiled.props +14 -0
  155. data/ext/zeromq/builds/msvc/properties/Release.props +22 -0
  156. data/ext/zeromq/builds/msvc/properties/Win32.props +12 -0
  157. data/ext/zeromq/builds/msvc/properties/Win32_Release.props +17 -0
  158. data/ext/zeromq/builds/msvc/properties/WithOpenPGM.props +12 -0
  159. data/ext/zeromq/builds/msvc/properties/ZeroMQ.props +23 -0
  160. data/ext/zeromq/builds/msvc/properties/x64.props +12 -0
  161. data/ext/zeromq/builds/redhat/zeromq.spec.in +160 -0
  162. data/ext/zeromq/builds/valgrind/valgrind.supp +14 -0
  163. data/ext/zeromq/builds/valgrind/vg +1 -0
  164. data/ext/zeromq/cmake/Modules/TestZMQVersion.cmake +35 -0
  165. data/ext/zeromq/cmake/Modules/zmq_version.cpp +31 -0
  166. data/ext/zeromq/cmake/NSIS.template32.in +952 -0
  167. data/ext/zeromq/cmake/NSIS.template64.in +960 -0
  168. data/ext/zeromq/configure.in +428 -0
  169. data/ext/zeromq/doc/Makefile.am +51 -0
  170. data/ext/zeromq/doc/asciidoc.conf +56 -0
  171. data/ext/zeromq/doc/zmq.txt +233 -0
  172. data/ext/zeromq/doc/zmq_bind.txt +102 -0
  173. data/ext/zeromq/doc/zmq_close.txt +52 -0
  174. data/ext/zeromq/doc/zmq_connect.txt +98 -0
  175. data/ext/zeromq/doc/zmq_ctx_destroy.txt +66 -0
  176. data/ext/zeromq/doc/zmq_ctx_get.txt +67 -0
  177. data/ext/zeromq/doc/zmq_ctx_new.txt +49 -0
  178. data/ext/zeromq/doc/zmq_ctx_set.txt +75 -0
  179. data/ext/zeromq/doc/zmq_disconnect.txt +67 -0
  180. data/ext/zeromq/doc/zmq_epgm.txt +162 -0
  181. data/ext/zeromq/doc/zmq_errno.txt +50 -0
  182. data/ext/zeromq/doc/zmq_getsockopt.txt +516 -0
  183. data/ext/zeromq/doc/zmq_init.txt +52 -0
  184. data/ext/zeromq/doc/zmq_inproc.txt +85 -0
  185. data/ext/zeromq/doc/zmq_ipc.txt +85 -0
  186. data/ext/zeromq/doc/zmq_msg_close.txt +55 -0
  187. data/ext/zeromq/doc/zmq_msg_copy.txt +57 -0
  188. data/ext/zeromq/doc/zmq_msg_data.txt +48 -0
  189. data/ext/zeromq/doc/zmq_msg_get.txt +72 -0
  190. data/ext/zeromq/doc/zmq_msg_init.txt +65 -0
  191. data/ext/zeromq/doc/zmq_msg_init_data.txt +85 -0
  192. data/ext/zeromq/doc/zmq_msg_init_size.txt +58 -0
  193. data/ext/zeromq/doc/zmq_msg_more.txt +63 -0
  194. data/ext/zeromq/doc/zmq_msg_move.txt +52 -0
  195. data/ext/zeromq/doc/zmq_msg_recv.txt +125 -0
  196. data/ext/zeromq/doc/zmq_msg_send.txt +122 -0
  197. data/ext/zeromq/doc/zmq_msg_set.txt +45 -0
  198. data/ext/zeromq/doc/zmq_msg_size.txt +48 -0
  199. data/ext/zeromq/doc/zmq_pgm.txt +162 -0
  200. data/ext/zeromq/doc/zmq_poll.txt +132 -0
  201. data/ext/zeromq/doc/zmq_proxy.txt +97 -0
  202. data/ext/zeromq/doc/zmq_recv.txt +93 -0
  203. data/ext/zeromq/doc/zmq_recvmsg.txt +123 -0
  204. data/ext/zeromq/doc/zmq_send.txt +100 -0
  205. data/ext/zeromq/doc/zmq_sendmsg.txt +119 -0
  206. data/ext/zeromq/doc/zmq_setsockopt.txt +523 -0
  207. data/ext/zeromq/doc/zmq_socket.txt +369 -0
  208. data/ext/zeromq/doc/zmq_socket_monitor.txt +288 -0
  209. data/ext/zeromq/doc/zmq_strerror.txt +55 -0
  210. data/ext/zeromq/doc/zmq_tcp.txt +101 -0
  211. data/ext/zeromq/doc/zmq_term.txt +66 -0
  212. data/ext/zeromq/doc/zmq_unbind.txt +65 -0
  213. data/ext/zeromq/doc/zmq_version.txt +53 -0
  214. data/ext/zeromq/foreign/openpgm/Makefile.am +8 -0
  215. data/ext/zeromq/foreign/openpgm/libpgm-5.1.118~dfsg.tar.gz +0 -0
  216. data/ext/zeromq/include/zmq.h +402 -0
  217. data/ext/zeromq/include/zmq_utils.h +64 -0
  218. data/ext/zeromq/installer.ico +0 -0
  219. data/ext/zeromq/perf/Makefile.am +22 -0
  220. data/ext/zeromq/perf/inproc_lat.cpp +233 -0
  221. data/ext/zeromq/perf/inproc_thr.cpp +241 -0
  222. data/ext/zeromq/perf/local_lat.cpp +109 -0
  223. data/ext/zeromq/perf/local_thr.cpp +133 -0
  224. data/ext/zeromq/perf/remote_lat.cpp +122 -0
  225. data/ext/zeromq/perf/remote_thr.cpp +105 -0
  226. data/ext/zeromq/src/Makefile.am +171 -0
  227. data/ext/zeromq/src/address.cpp +78 -0
  228. data/ext/zeromq/src/address.hpp +52 -0
  229. data/ext/zeromq/src/array.hpp +155 -0
  230. data/ext/zeromq/src/atomic_counter.hpp +197 -0
  231. data/ext/zeromq/src/atomic_ptr.hpp +196 -0
  232. data/ext/zeromq/src/blob.hpp +129 -0
  233. data/ext/zeromq/src/clock.cpp +147 -0
  234. data/ext/zeromq/src/clock.hpp +60 -0
  235. data/ext/zeromq/src/command.hpp +154 -0
  236. data/ext/zeromq/src/config.hpp +89 -0
  237. data/ext/zeromq/src/ctx.cpp +352 -0
  238. data/ext/zeromq/src/ctx.hpp +173 -0
  239. data/ext/zeromq/src/dealer.cpp +133 -0
  240. data/ext/zeromq/src/dealer.hpp +92 -0
  241. data/ext/zeromq/src/decoder.cpp +166 -0
  242. data/ext/zeromq/src/decoder.hpp +248 -0
  243. data/ext/zeromq/src/devpoll.cpp +190 -0
  244. data/ext/zeromq/src/devpoll.hpp +105 -0
  245. data/ext/zeromq/src/dist.cpp +194 -0
  246. data/ext/zeromq/src/dist.hpp +105 -0
  247. data/ext/zeromq/src/encoder.cpp +102 -0
  248. data/ext/zeromq/src/encoder.hpp +200 -0
  249. data/ext/zeromq/src/epoll.cpp +178 -0
  250. data/ext/zeromq/src/epoll.hpp +101 -0
  251. data/ext/zeromq/src/err.cpp +291 -0
  252. data/ext/zeromq/src/err.hpp +155 -0
  253. data/ext/zeromq/src/fd.hpp +45 -0
  254. data/ext/zeromq/src/fq.cpp +141 -0
  255. data/ext/zeromq/src/fq.hpp +74 -0
  256. data/ext/zeromq/src/i_decoder.hpp +49 -0
  257. data/ext/zeromq/src/i_encoder.hpp +55 -0
  258. data/ext/zeromq/src/i_engine.hpp +55 -0
  259. data/ext/zeromq/src/i_msg_sink.hpp +43 -0
  260. data/ext/zeromq/src/i_msg_source.hpp +44 -0
  261. data/ext/zeromq/src/i_poll_events.hpp +47 -0
  262. data/ext/zeromq/src/io_object.cpp +108 -0
  263. data/ext/zeromq/src/io_object.hpp +81 -0
  264. data/ext/zeromq/src/io_thread.cpp +104 -0
  265. data/ext/zeromq/src/io_thread.hpp +91 -0
  266. data/ext/zeromq/src/ip.cpp +109 -0
  267. data/ext/zeromq/src/ip.hpp +41 -0
  268. data/ext/zeromq/src/ipc_address.cpp +84 -0
  269. data/ext/zeromq/src/ipc_address.hpp +67 -0
  270. data/ext/zeromq/src/ipc_connecter.cpp +265 -0
  271. data/ext/zeromq/src/ipc_connecter.hpp +128 -0
  272. data/ext/zeromq/src/ipc_listener.cpp +206 -0
  273. data/ext/zeromq/src/ipc_listener.hpp +99 -0
  274. data/ext/zeromq/src/kqueue.cpp +201 -0
  275. data/ext/zeromq/src/kqueue.hpp +107 -0
  276. data/ext/zeromq/src/lb.cpp +148 -0
  277. data/ext/zeromq/src/lb.hpp +73 -0
  278. data/ext/zeromq/src/libzmq.pc.in +10 -0
  279. data/ext/zeromq/src/likely.hpp +33 -0
  280. data/ext/zeromq/src/mailbox.cpp +87 -0
  281. data/ext/zeromq/src/mailbox.hpp +75 -0
  282. data/ext/zeromq/src/msg.cpp +299 -0
  283. data/ext/zeromq/src/msg.hpp +148 -0
  284. data/ext/zeromq/src/mtrie.cpp +428 -0
  285. data/ext/zeromq/src/mtrie.hpp +93 -0
  286. data/ext/zeromq/src/mutex.hpp +118 -0
  287. data/ext/zeromq/src/object.cpp +393 -0
  288. data/ext/zeromq/src/object.hpp +134 -0
  289. data/ext/zeromq/src/options.cpp +562 -0
  290. data/ext/zeromq/src/options.hpp +135 -0
  291. data/ext/zeromq/src/own.cpp +206 -0
  292. data/ext/zeromq/src/own.hpp +145 -0
  293. data/ext/zeromq/src/pair.cpp +136 -0
  294. data/ext/zeromq/src/pair.hpp +79 -0
  295. data/ext/zeromq/src/pgm_receiver.cpp +283 -0
  296. data/ext/zeromq/src/pgm_receiver.hpp +141 -0
  297. data/ext/zeromq/src/pgm_sender.cpp +218 -0
  298. data/ext/zeromq/src/pgm_sender.hpp +113 -0
  299. data/ext/zeromq/src/pgm_socket.cpp +706 -0
  300. data/ext/zeromq/src/pgm_socket.hpp +124 -0
  301. data/ext/zeromq/src/pipe.cpp +447 -0
  302. data/ext/zeromq/src/pipe.hpp +207 -0
  303. data/ext/zeromq/src/poll.cpp +176 -0
  304. data/ext/zeromq/src/poll.hpp +105 -0
  305. data/ext/zeromq/src/poller.hpp +82 -0
  306. data/ext/zeromq/src/poller_base.cpp +99 -0
  307. data/ext/zeromq/src/poller_base.hpp +86 -0
  308. data/ext/zeromq/src/precompiled.cpp +21 -0
  309. data/ext/zeromq/src/precompiled.hpp +47 -0
  310. data/ext/zeromq/src/proxy.cpp +150 -0
  311. data/ext/zeromq/src/proxy.hpp +32 -0
  312. data/ext/zeromq/src/pub.cpp +57 -0
  313. data/ext/zeromq/src/pub.hpp +69 -0
  314. data/ext/zeromq/src/pull.cpp +79 -0
  315. data/ext/zeromq/src/pull.hpp +81 -0
  316. data/ext/zeromq/src/push.cpp +76 -0
  317. data/ext/zeromq/src/push.hpp +80 -0
  318. data/ext/zeromq/src/random.cpp +52 -0
  319. data/ext/zeromq/src/random.hpp +37 -0
  320. data/ext/zeromq/src/reaper.cpp +117 -0
  321. data/ext/zeromq/src/reaper.hpp +80 -0
  322. data/ext/zeromq/src/rep.cpp +137 -0
  323. data/ext/zeromq/src/rep.hpp +80 -0
  324. data/ext/zeromq/src/req.cpp +185 -0
  325. data/ext/zeromq/src/req.hpp +91 -0
  326. data/ext/zeromq/src/router.cpp +364 -0
  327. data/ext/zeromq/src/router.hpp +138 -0
  328. data/ext/zeromq/src/select.cpp +216 -0
  329. data/ext/zeromq/src/select.hpp +126 -0
  330. data/ext/zeromq/src/session_base.cpp +503 -0
  331. data/ext/zeromq/src/session_base.hpp +156 -0
  332. data/ext/zeromq/src/signaler.cpp +406 -0
  333. data/ext/zeromq/src/signaler.hpp +63 -0
  334. data/ext/zeromq/src/socket_base.cpp +1236 -0
  335. data/ext/zeromq/src/socket_base.hpp +255 -0
  336. data/ext/zeromq/src/stdint.hpp +63 -0
  337. data/ext/zeromq/src/stream_engine.cpp +594 -0
  338. data/ext/zeromq/src/stream_engine.hpp +149 -0
  339. data/ext/zeromq/src/sub.cpp +93 -0
  340. data/ext/zeromq/src/sub.hpp +71 -0
  341. data/ext/zeromq/src/tcp.cpp +131 -0
  342. data/ext/zeromq/src/tcp.hpp +38 -0
  343. data/ext/zeromq/src/tcp_address.cpp +613 -0
  344. data/ext/zeromq/src/tcp_address.hpp +100 -0
  345. data/ext/zeromq/src/tcp_connecter.cpp +319 -0
  346. data/ext/zeromq/src/tcp_connecter.hpp +123 -0
  347. data/ext/zeromq/src/tcp_listener.cpp +293 -0
  348. data/ext/zeromq/src/tcp_listener.hpp +91 -0
  349. data/ext/zeromq/src/thread.cpp +107 -0
  350. data/ext/zeromq/src/thread.hpp +79 -0
  351. data/ext/zeromq/src/trie.cpp +337 -0
  352. data/ext/zeromq/src/trie.hpp +79 -0
  353. data/ext/zeromq/src/v1_decoder.cpp +162 -0
  354. data/ext/zeromq/src/v1_decoder.hpp +68 -0
  355. data/ext/zeromq/src/v1_encoder.cpp +103 -0
  356. data/ext/zeromq/src/v1_encoder.hpp +60 -0
  357. data/ext/zeromq/src/v1_protocol.hpp +43 -0
  358. data/ext/zeromq/src/version.rc.in +93 -0
  359. data/ext/zeromq/src/windows.hpp +181 -0
  360. data/ext/zeromq/src/wire.hpp +99 -0
  361. data/ext/zeromq/src/xpub.cpp +200 -0
  362. data/ext/zeromq/src/xpub.hpp +110 -0
  363. data/ext/zeromq/src/xsub.cpp +242 -0
  364. data/ext/zeromq/src/xsub.hpp +108 -0
  365. data/ext/zeromq/src/ypipe.hpp +210 -0
  366. data/ext/zeromq/src/yqueue.hpp +199 -0
  367. data/ext/zeromq/src/zmq.cpp +1058 -0
  368. data/ext/zeromq/src/zmq_utils.cpp +61 -0
  369. data/ext/zeromq/tests/Makefile.am +55 -0
  370. data/ext/zeromq/tests/test_connect_delay.cpp +260 -0
  371. data/ext/zeromq/tests/test_connect_resolve.cpp +54 -0
  372. data/ext/zeromq/tests/test_disconnect_inproc.cpp +120 -0
  373. data/ext/zeromq/tests/test_hwm.cpp +83 -0
  374. data/ext/zeromq/tests/test_invalid_rep.cpp +92 -0
  375. data/ext/zeromq/tests/test_last_endpoint.cpp +60 -0
  376. data/ext/zeromq/tests/test_monitor.cpp +289 -0
  377. data/ext/zeromq/tests/test_msg_flags.cpp +78 -0
  378. data/ext/zeromq/tests/test_pair_inproc.cpp +53 -0
  379. data/ext/zeromq/tests/test_pair_ipc.cpp +53 -0
  380. data/ext/zeromq/tests/test_pair_tcp.cpp +54 -0
  381. data/ext/zeromq/tests/test_reqrep_device.cpp +143 -0
  382. data/ext/zeromq/tests/test_reqrep_inproc.cpp +53 -0
  383. data/ext/zeromq/tests/test_reqrep_ipc.cpp +53 -0
  384. data/ext/zeromq/tests/test_reqrep_tcp.cpp +54 -0
  385. data/ext/zeromq/tests/test_router_mandatory.cpp +62 -0
  386. data/ext/zeromq/tests/test_shutdown_stress.cpp +93 -0
  387. data/ext/zeromq/tests/test_sub_forward.cpp +99 -0
  388. data/ext/zeromq/tests/test_term_endpoint.cpp +118 -0
  389. data/ext/zeromq/tests/test_timeo.cpp +119 -0
  390. data/ext/zeromq/tests/testutil.hpp +77 -0
  391. data/ext/zeromq/version.sh +21 -0
  392. data/lib/zmq/version.rb +1 -1
  393. data/rbczmq.gemspec +16 -3
  394. data/test/test_socket.rb +13 -1
  395. metadata +398 -9
  396. checksums.yaml +0 -15
  397. data/ext/czmq-1.4.1.tar.gz +0 -0
  398. data/ext/zeromq-3.2.3.tar.gz +0 -0
@@ -0,0 +1,297 @@
1
+ /* =========================================================================
2
+ zstr - sending and receiving strings
3
+
4
+ -------------------------------------------------------------------------
5
+ Copyright (c) 1991-2013 iMatix Corporation <www.imatix.com>
6
+ Copyright other contributors as noted in the AUTHORS file.
7
+
8
+ This file is part of CZMQ, the high-level C binding for 0MQ:
9
+ http://czmq.zeromq.org.
10
+
11
+ This is free software; you can redistribute it and/or modify it under
12
+ the terms of the GNU Lesser General Public License as published by the
13
+ Free Software Foundation; either version 3 of the License, or (at your
14
+ option) any later version.
15
+
16
+ This software is distributed in the hope that it will be useful, but
17
+ WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABIL-
18
+ ITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
19
+ Public License for more details.
20
+
21
+ You should have received a copy of the GNU Lesser General Public License
22
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
23
+ =========================================================================
24
+ */
25
+
26
+ /*
27
+ @header
28
+ The zstr class provides utility functions for sending and receiving C
29
+ strings across 0MQ sockets. It sends strings without a terminating null,
30
+ and appends a null byte on received strings. This class is for simple
31
+ message sending.
32
+ @discuss
33
+ @end
34
+ */
35
+
36
+ #include "../include/czmq.h"
37
+
38
+ static int
39
+ s_send_string (void *zocket, bool more, char *string)
40
+ {
41
+ assert (zocket);
42
+
43
+ int len = strlen (string);
44
+ zmq_msg_t message;
45
+ zmq_msg_init_size (&message, len);
46
+ memcpy (zmq_msg_data (&message), string, len);
47
+ int rc = zmq_sendmsg (zocket, &message, more? ZMQ_SNDMORE: 0);
48
+
49
+ return rc == -1? -1: 0;
50
+ }
51
+
52
+
53
+ // --------------------------------------------------------------------------
54
+ // Receive C string from socket. Caller must free returned string. Returns
55
+ // NULL if the context is being terminated or the process was interrupted.
56
+
57
+ char *
58
+ zstr_recv (void *zocket)
59
+ {
60
+ assert (zocket);
61
+ zmq_msg_t message;
62
+ zmq_msg_init (&message);
63
+ if (zmq_recvmsg (zocket, &message, 0) < 0)
64
+ return NULL;
65
+
66
+ size_t size = zmq_msg_size (&message);
67
+ char *string = (char *) malloc (size + 1);
68
+ memcpy (string, zmq_msg_data (&message), size);
69
+ zmq_msg_close (&message);
70
+ string [size] = 0;
71
+ return string;
72
+ }
73
+
74
+
75
+ // --------------------------------------------------------------------------
76
+ // Receive C string from socket, if socket had input ready. Caller must
77
+ // free returned string. Returns NULL if there was no input waiting, or if
78
+ // the context was terminated. Use zctx_interrupted to exit any loop that
79
+ // relies on this method.
80
+
81
+ char *
82
+ zstr_recv_nowait (void *zocket)
83
+ {
84
+ assert (zocket);
85
+ zmq_msg_t message;
86
+ zmq_msg_init (&message);
87
+ if (zmq_recvmsg (zocket, &message, ZMQ_DONTWAIT) < 0)
88
+ return NULL;
89
+
90
+ size_t size = zmq_msg_size (&message);
91
+ char *string = (char *) malloc (size + 1);
92
+ memcpy (string, zmq_msg_data (&message), size);
93
+ zmq_msg_close (&message);
94
+ string [size] = 0;
95
+ return string;
96
+ }
97
+
98
+
99
+ // --------------------------------------------------------------------------
100
+ // Send C string to socket. Returns 0 if successful, -1 if there was an
101
+ // error.
102
+
103
+ int
104
+ zstr_send (void *zocket, const char *format, ...)
105
+ {
106
+ assert (zocket);
107
+ assert (format);
108
+ // Format string into buffer
109
+ int size = 255 + 1;
110
+ char stackbuffer[255+1];
111
+ char *string = stackbuffer;
112
+ va_list argptr;
113
+ va_start (argptr, format);
114
+ int required = vsnprintf (string, size, format, argptr);
115
+ va_end (argptr);
116
+ #ifdef _MSC_VER
117
+ if (required < 0 || required >= size) {
118
+ va_start (argptr, format);
119
+ required = _vscprintf (format, argptr);
120
+ va_end (argptr);
121
+ }
122
+ #endif
123
+ if (required >= size) {
124
+ size = required + 1;
125
+ string = (char *) malloc (size);
126
+ if (!string)
127
+ return -1;
128
+ va_start (argptr, format);
129
+ vsnprintf (string, size, format, argptr);
130
+ va_end (argptr);
131
+ }
132
+
133
+ int rc = s_send_string (zocket, false, string);
134
+ if (string!=stackbuffer)
135
+ free (string);
136
+ return rc;
137
+ }
138
+
139
+ // Deprecated, does exactly the same
140
+ int
141
+ zstr_sendf (void *zocket, const char *format, ...)
142
+ {
143
+ assert (zocket);
144
+ assert (format);
145
+ // Format string into buffer
146
+ int size = 255 + 1;
147
+ char stackbuffer[255+1];
148
+ char *string = stackbuffer;
149
+ va_list argptr;
150
+ va_start (argptr, format);
151
+ int required = vsnprintf (string, size, format, argptr);
152
+ va_end (argptr);
153
+ #ifdef _MSC_VER
154
+ if (required < 0 || required >= size) {
155
+ va_start (argptr, format);
156
+ required = _vscprintf (format, argptr);
157
+ va_end (argptr);
158
+ }
159
+ #endif
160
+ if (required >= size) {
161
+ size = required + 1;
162
+ string = (char *) malloc (size);
163
+ if (!string)
164
+ return -1;
165
+ va_start (argptr, format);
166
+ vsnprintf (string, size, format, argptr);
167
+ va_end (argptr);
168
+ }
169
+
170
+ int rc = s_send_string (zocket, false, string);
171
+ if (string!=stackbuffer)
172
+ free (string);
173
+ return rc;
174
+ }
175
+
176
+
177
+ // --------------------------------------------------------------------------
178
+ // Send a string to a socket in 0MQ string format, with MORE flag
179
+
180
+ int
181
+ zstr_sendm (void *zocket, const char *format, ...)
182
+ {
183
+ assert (zocket);
184
+ assert (format);
185
+ // Format string into buffer
186
+ int size = 255 + 1;
187
+ char stackbuffer[255+1];
188
+ char *string = stackbuffer;
189
+ va_list argptr;
190
+ va_start (argptr, format);
191
+ int required = vsnprintf (string, size, format, argptr);
192
+ va_end (argptr);
193
+ #ifdef _MSC_VER
194
+ if (required < 0 || required >= size) {
195
+ va_start (argptr, format);
196
+ required = _vscprintf (format, argptr);
197
+ va_end (argptr);
198
+ }
199
+ #endif
200
+ if (required >= size) {
201
+ size = required + 1;
202
+ string = (char *) malloc (size);
203
+ if (!string)
204
+ return -1;
205
+ va_start (argptr, format);
206
+ vsnprintf (string, size, format, argptr);
207
+ va_end (argptr);
208
+ }
209
+
210
+ int rc = s_send_string (zocket, true, string);
211
+ if (string!=stackbuffer)
212
+ free (string);
213
+ return rc;
214
+ }
215
+
216
+ // Deprecated, does exactly the same
217
+ int
218
+ zstr_sendfm (void *zocket, const char *format, ...)
219
+ {
220
+ assert (zocket);
221
+ assert (format);
222
+ // Format string into buffer
223
+ int size = 255 + 1;
224
+ char stackbuffer[255+1];
225
+ char *string = stackbuffer;
226
+ va_list argptr;
227
+ va_start (argptr, format);
228
+ int required = vsnprintf (string, size, format, argptr);
229
+ va_end (argptr);
230
+ #ifdef _MSC_VER
231
+ if (required < 0 || required >= size) {
232
+ va_start (argptr, format);
233
+ required = _vscprintf (format, argptr);
234
+ va_end (argptr);
235
+ }
236
+ #endif
237
+ if (required >= size) {
238
+ size = required + 1;
239
+ string = (char *) malloc (size);
240
+ if (!string)
241
+ return -1;
242
+ va_start (argptr, format);
243
+ vsnprintf (string, size, format, argptr);
244
+ va_end (argptr);
245
+ }
246
+
247
+ int rc = s_send_string (zocket, true, string);
248
+ if (string!=stackbuffer)
249
+ free (string);
250
+ return rc;
251
+ }
252
+
253
+ // --------------------------------------------------------------------------
254
+ // Selftest
255
+
256
+ int
257
+ zstr_test (bool verbose)
258
+ {
259
+ printf (" * zstr: ");
260
+
261
+ // @selftest
262
+ zctx_t *ctx = zctx_new ();
263
+ assert (ctx);
264
+
265
+ void *output = zsocket_new (ctx, ZMQ_PAIR);
266
+ assert (output);
267
+ zsocket_bind (output, "inproc://zstr.test");
268
+ void *input = zsocket_new (ctx, ZMQ_PAIR);
269
+ assert (input);
270
+ zsocket_connect (input, "inproc://zstr.test");
271
+
272
+ // Send ten strings, five strings with MORE flag and then END
273
+ int string_nbr;
274
+ for (string_nbr = 0; string_nbr < 10; string_nbr++)
275
+ zstr_send (output, "this is string %d", string_nbr);
276
+ for (string_nbr = 0; string_nbr < 5; string_nbr++)
277
+ zstr_sendm (output, "this is string %d", string_nbr);
278
+ zstr_send (output, "END");
279
+
280
+ // Read and count until we receive END
281
+ string_nbr = 0;
282
+ for (string_nbr = 0;; string_nbr++) {
283
+ char *string = zstr_recv (input);
284
+ if (streq (string, "END")) {
285
+ free (string);
286
+ break;
287
+ }
288
+ free (string);
289
+ }
290
+ assert (string_nbr == 15);
291
+
292
+ zctx_destroy (&ctx);
293
+ // @end
294
+
295
+ printf ("OK\n");
296
+ return 0;
297
+ }
@@ -0,0 +1,136 @@
1
+ /* =========================================================================
2
+ zsys - system wrapper
3
+
4
+ -------------------------------------------------------------------------
5
+ Copyright (c) 1991-2013 iMatix Corporation <www.imatix.com>
6
+ Copyright other contributors as noted in the AUTHORS file.
7
+
8
+ This file is part of CZMQ, the high-level C binding for 0MQ:
9
+ http://czmq.zeromq.org.
10
+
11
+ This is free software; you can redistribute it and/or modify it under
12
+ the terms of the GNU Lesser General Public License as published by the
13
+ Free Software Foundation; either version 3 of the License, or (at your
14
+ option) any later version.
15
+
16
+ This software is distributed in the hope that it will be useful, but
17
+ WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABIL-
18
+ ITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
19
+ Public License for more details.
20
+
21
+ You should have received a copy of the GNU Lesser General Public License
22
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
23
+ =========================================================================
24
+ */
25
+
26
+ /*
27
+ @header
28
+ The zsys class provides a portable wrapper for miscellaneous functions
29
+ that we want to wrap but which don't fit into any of the existing
30
+ classes. Eventually all non-portable functionality might be moved here
31
+ but for now it covers only file systems.
32
+ @discuss
33
+ @end
34
+ */
35
+
36
+ #include "../include/czmq.h"
37
+
38
+ #if defined (__UNIX__)
39
+ static bool s_first_time = true;
40
+ static struct sigaction sigint_default;
41
+ static struct sigaction sigterm_default;
42
+ #endif
43
+
44
+ // --------------------------------------------------------------------------
45
+ // Set interrupt handler (NULL means external handler)
46
+ // Idempotent; safe to call multiple times
47
+
48
+ void
49
+ zsys_handler_set (zsys_handler_fn *handler_fn)
50
+ {
51
+ #if defined (__UNIX__)
52
+ // Install signal handler for SIGINT and SIGTERM if not NULL
53
+ // and if this is the first time we've been called
54
+ if (s_first_time) {
55
+ s_first_time = false;
56
+ if (handler_fn) {
57
+ struct sigaction action;
58
+ action.sa_handler = handler_fn;
59
+ action.sa_flags = 0;
60
+ sigemptyset (&action.sa_mask);
61
+ sigaction (SIGINT, &action, &sigint_default);
62
+ sigaction (SIGTERM, &action, &sigterm_default);
63
+ }
64
+ else {
65
+ // Save default handlers if not already done
66
+ sigaction (SIGINT, NULL, &sigint_default);
67
+ sigaction (SIGTERM, NULL, &sigterm_default);
68
+ }
69
+ }
70
+ #endif
71
+ }
72
+
73
+
74
+ // --------------------------------------------------------------------------
75
+ // Reset interrupt handler, call this at exit if needed
76
+ // Idempotent; safe to call multiple times
77
+
78
+ void
79
+ zsys_handler_reset (void)
80
+ {
81
+ #if defined (__UNIX__)
82
+ // Restore default handlers if not already done
83
+ if (sigint_default.sa_handler) {
84
+ sigaction (SIGINT, &sigint_default, NULL);
85
+ sigaction (SIGTERM, &sigterm_default, NULL);
86
+ sigint_default.sa_handler = NULL;
87
+ sigterm_default.sa_handler = NULL;
88
+ s_first_time = true;
89
+ }
90
+ #endif
91
+ }
92
+
93
+
94
+ // --------------------------------------------------------------------------
95
+ // Set network interface name to use for broadcasts
96
+ // Use this to force the interface for beacons
97
+ // This is experimental; may be merged into zbeacon class.
98
+
99
+ // NOT thread safe, not a good design; this is to test the feasibility
100
+ // of forcing a network interface name instead of writing code to find it.
101
+ static char *s_interface = NULL;
102
+
103
+ void
104
+ zsys_set_interface (char *interface)
105
+ {
106
+ free (s_interface);
107
+ s_interface = strdup (interface);
108
+ }
109
+
110
+
111
+ // Return network interface name to use for broadcasts.
112
+ // Returns "" if no interface was set.
113
+ // This is experimental; may be merged into zbeacon class.
114
+
115
+ char *
116
+ zsys_interface (void)
117
+ {
118
+ return (s_interface? s_interface: "");
119
+ }
120
+
121
+
122
+ // --------------------------------------------------------------------------
123
+ // Selftest
124
+
125
+ int
126
+ zsys_test (bool verbose)
127
+ {
128
+ printf (" * zsys: ");
129
+ zsys_handler_reset ();
130
+ zsys_handler_set (NULL);
131
+ zsys_handler_set (NULL);
132
+ zsys_handler_reset ();
133
+ zsys_handler_reset ();
134
+ printf ("OK\n");
135
+ return 0;
136
+ }
@@ -0,0 +1,269 @@
1
+ /* =========================================================================
2
+ zthread - working with system threads
3
+
4
+ -------------------------------------------------------------------------
5
+ Copyright (c) 1991-2013 iMatix Corporation <www.imatix.com>
6
+ Copyright other contributors as noted in the AUTHORS file.
7
+
8
+ This file is part of CZMQ, the high-level C binding for 0MQ:
9
+ http://czmq.zeromq.org.
10
+
11
+ This is free software; you can redistribute it and/or modify it under
12
+ the terms of the GNU Lesser General Public License as published by the
13
+ Free Software Foundation; either version 3 of the License, or (at your
14
+ option) any later version.
15
+
16
+ This software is distributed in the hope that it will be useful, but
17
+ WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABIL-
18
+ ITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
19
+ Public License for more details.
20
+
21
+ You should have received a copy of the GNU Lesser General Public License
22
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
23
+ =========================================================================
24
+ */
25
+
26
+ /*
27
+ @header
28
+ The zthread class wraps OS thread creation. It creates detached threads
29
+ that look like normal OS threads, or attached threads that share the
30
+ caller's 0MQ context, and get an inproc pipe to talk back to the parent
31
+ thread. Detached threads create their own 0MQ contexts as needed.
32
+ @discuss
33
+ We have several use cases for multiple threads. One is to simulate many
34
+ processes, so we can test 0MQ designs and flows more easily. Another is
35
+ to create APIs that can send and receive 0MQ messages in the background.
36
+
37
+ zthread solves these two use cases separately, using the zthread_new
38
+ and zthead_fork methods respectively. These methods wrap the native
39
+ system calls needed to start threads, so your code can remain fully
40
+ portable.
41
+
42
+ Detached threads follow the POSIX pthreads API; they accept a void *
43
+ argument and return a void * result (always NULL in our case).
44
+
45
+ Attached thread receive a void * argument, a zctx_t context, and a pipe
46
+ socket. The pipe socket is a PAIR socket that is connected back to the
47
+ caller. When you call zthread_fork, it returns you a PAIR socket that
48
+ is the other end of this pipe. Thus attached threads can talk back to
49
+ their parent threads over the pipe. We use this very heavily when making
50
+ so-called "asynchronous" APIs, which you can see in the Guide examples
51
+ like 'clone'.
52
+
53
+ To recap some rules about threading: do not share sockets between
54
+ threads or your code will crash. You can migrate a socket from one
55
+ thread to a child thread, if you stop using it in the parent thread
56
+ immediately after creating the child thread. If you want to connect
57
+ sockets over inproc:// they must share the same 0MQ context, i.e. be
58
+ attached threads. You should always use zthread_fork to create an
59
+ attached thread; it is not sufficient to pass a zctx_t structure to
60
+ a detached thread (this will crash).
61
+
62
+ If you want to communicate over ipc:// or tcp:// you may be sharing
63
+ the same context, or use separate contexts. Thus, every detached thread
64
+ usually starts by creating its own zctx_t instance.
65
+ @end
66
+ */
67
+
68
+ #include "../include/czmq.h"
69
+
70
+ // --------------------------------------------------------------------------
71
+ // Thread creation code, wrapping POSIX and Win32 thread APIs
72
+
73
+ typedef struct {
74
+ // Two thread handlers, one will be set, one NULL
75
+ zthread_attached_fn *attached;
76
+ zthread_detached_fn *detached;
77
+ void *args; // Application arguments
78
+ zctx_t *ctx; // Context object if any
79
+ void *pipe; // Pipe, if any, back to parent
80
+ #if defined (__WINDOWS__)
81
+ HANDLE handle; // Win32 thread handle
82
+ #endif
83
+ } shim_t;
84
+
85
+ #if defined (__UNIX__)
86
+ // Thread shim for UNIX calls the real thread and cleans up afterwards.
87
+ void *
88
+ s_thread_shim (void *args)
89
+ {
90
+ assert (args);
91
+ shim_t *shim = (shim_t *) args;
92
+ if (shim->attached)
93
+ shim->attached (shim->args, shim->ctx, shim->pipe);
94
+ else
95
+ shim->detached (shim->args);
96
+
97
+ zctx_destroy (&shim->ctx);
98
+ free (shim);
99
+ return NULL;
100
+ }
101
+
102
+ #elif defined (__WINDOWS__)
103
+ // Thread shim for Windows that wraps a POSIX-style thread handler
104
+ // and does the _endthreadex for us automatically.
105
+ unsigned __stdcall
106
+ s_thread_shim (void *args)
107
+ {
108
+ assert (args);
109
+ shim_t *shim = (shim_t *) args;
110
+ if (shim->attached)
111
+ shim->attached (shim->args, shim->ctx, shim->pipe);
112
+ else
113
+ shim->detached (shim->args);
114
+
115
+ zctx_destroy (&shim->ctx); // Close any dangling sockets
116
+ free (shim);
117
+ _endthreadex (0); // Terminates thread
118
+ return 0;
119
+ }
120
+ #endif
121
+
122
+ static void
123
+ s_thread_start (shim_t *shim)
124
+ {
125
+ #if defined (__UNIX__)
126
+ pthread_t thread;
127
+ pthread_create (&thread, NULL, s_thread_shim, shim);
128
+ pthread_detach (thread);
129
+
130
+ #elif defined (__WINDOWS__)
131
+ shim->handle = (HANDLE)_beginthreadex(
132
+ NULL, // Handle is private to this process
133
+ 0, // Use a default stack size for new thread
134
+ &s_thread_shim, // Start real thread function via this shim
135
+ shim, // Which gets the current object as argument
136
+ CREATE_SUSPENDED, // Set thread priority before starting it
137
+ NULL); // We don't use the thread ID
138
+
139
+ assert (shim->handle);
140
+ // Set child thread priority to same as current
141
+ int priority = GetThreadPriority (GetCurrentThread ());
142
+ SetThreadPriority (shim->handle, priority);
143
+ // Start thread
144
+ ResumeThread (shim->handle);
145
+ // Release resources
146
+ CloseHandle (shim->handle);
147
+ shim->handle = 0;
148
+ #endif
149
+ }
150
+
151
+
152
+ // --------------------------------------------------------------------------
153
+ // Create a detached thread. A detached thread operates autonomously
154
+ // and is used to simulate a separate process. It gets no ctx, and no
155
+ // pipe. Returns 0 on success, -1 if insufficient memory.
156
+
157
+ int
158
+ zthread_new (zthread_detached_fn *thread_fn, void *args)
159
+ {
160
+ // Prepare argument shim for child thread
161
+ shim_t *shim = (shim_t *) zmalloc (sizeof (shim_t));
162
+ if (shim) {
163
+ shim->detached = thread_fn;
164
+ shim->args = args;
165
+ s_thread_start (shim);
166
+ return 0;
167
+ }
168
+ return -1;
169
+ }
170
+
171
+
172
+ // --------------------------------------------------------------------------
173
+ // Create an attached thread. An attached thread gets a ctx and a PAIR
174
+ // pipe back to its parent. It must monitor its pipe, and exit if the
175
+ // pipe becomes unreadable. Returns pipe, or NULL if there was an error.
176
+
177
+ void *
178
+ zthread_fork (zctx_t *ctx, zthread_attached_fn *thread_fn, void *args)
179
+ {
180
+ shim_t *shim = NULL;
181
+ // Create our end of the pipe
182
+ void *pipe = zsocket_new (ctx, ZMQ_PAIR);
183
+ if (pipe)
184
+ zsocket_bind (pipe, "inproc://zctx-pipe-%p", pipe);
185
+ else
186
+ return NULL;
187
+
188
+ // Prepare argument shim for child thread
189
+ shim = (shim_t *) zmalloc (sizeof (shim_t));
190
+ if (shim) {
191
+ shim->attached = thread_fn;
192
+ shim->args = args;
193
+ shim->ctx = zctx_shadow (ctx);
194
+ if (!shim->ctx)
195
+ return NULL;
196
+ }
197
+ else
198
+ return NULL;
199
+
200
+ // Connect child pipe to our pipe
201
+ shim->pipe = zsocket_new (shim->ctx, ZMQ_PAIR);
202
+ if (!shim->pipe)
203
+ return NULL;
204
+ zsocket_connect (shim->pipe, "inproc://zctx-pipe-%p", pipe);
205
+
206
+ s_thread_start (shim);
207
+ return pipe;
208
+ }
209
+
210
+
211
+ // --------------------------------------------------------------------------
212
+ // Selftest
213
+
214
+ // @selftest
215
+ static void *
216
+ s_test_detached (void *args)
217
+ {
218
+ // Create a socket to check it'll be automatically deleted
219
+ zctx_t *ctx = zctx_new ();
220
+ assert (ctx);
221
+
222
+ void *push = zsocket_new (ctx, ZMQ_PUSH);
223
+ assert (push);
224
+ zctx_destroy (&ctx);
225
+ return NULL;
226
+ }
227
+
228
+ static void
229
+ s_test_attached (void *args, zctx_t *ctx, void *pipe)
230
+ {
231
+ // Create a socket to check it'll be automatically deleted
232
+ zsocket_new (ctx, ZMQ_PUSH);
233
+ // Wait for our parent to ping us, and pong back
234
+ free (zstr_recv (pipe));
235
+ zstr_send (pipe, "pong");
236
+ }
237
+
238
+ // @end
239
+
240
+ int
241
+ zthread_test (bool verbose)
242
+ {
243
+ printf (" * zthread: ");
244
+
245
+ // @selftest
246
+ zctx_t *ctx = zctx_new ();
247
+ assert (ctx);
248
+ int rc = 0;
249
+
250
+ // Create a detached thread, let it run
251
+ rc = zthread_new (s_test_detached, NULL);
252
+ assert (rc == 0);
253
+ zclock_sleep (100);
254
+
255
+ // Create an attached thread, check it's safely alive
256
+ void *pipe = zthread_fork (ctx, s_test_attached, NULL);
257
+ assert (pipe);
258
+ zstr_send (pipe, "ping");
259
+ char *pong = zstr_recv (pipe);
260
+ assert (streq (pong, "pong"));
261
+ free (pong);
262
+
263
+ // Everything should be cleanly closed now
264
+ zctx_destroy (&ctx);
265
+ // @end
266
+
267
+ printf ("OK\n");
268
+ return 0;
269
+ }