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,80 @@
1
+ zstr(3)
2
+ =======
3
+
4
+ NAME
5
+ ----
6
+ zstr - sending and receiving strings
7
+
8
+ SYNOPSIS
9
+ --------
10
+ ----
11
+ // Receive a string off a socket, caller must free it
12
+ CZMQ_EXPORT char *
13
+ zstr_recv (void *socket);
14
+
15
+ // Receive a string off a socket if socket had input waiting
16
+ CZMQ_EXPORT char *
17
+ zstr_recv_nowait (void *socket);
18
+
19
+ // Send a formatted string to a socket
20
+ CZMQ_EXPORT int
21
+ zstr_send (void *socket, const char *format, ...);
22
+
23
+ // Send a formatted string to a socket, with MORE flag
24
+ CZMQ_EXPORT int
25
+ zstr_sendm (void *socket, const char *format, ...);
26
+
27
+ // Self test of this class
28
+ CZMQ_EXPORT int
29
+ zstr_test (bool verbose);
30
+ ----
31
+
32
+ DESCRIPTION
33
+ -----------
34
+
35
+ The zstr class provides utility functions for sending and receiving C
36
+ strings across 0MQ sockets. It sends strings without a terminating null,
37
+ and appends a null byte on received strings. This class is for simple
38
+ message sending.
39
+
40
+
41
+ EXAMPLE
42
+ -------
43
+ .From zstr_test method
44
+ ----
45
+ zctx_t *ctx = zctx_new ();
46
+ assert (ctx);
47
+
48
+ void *output = zsocket_new (ctx, ZMQ_PAIR);
49
+ assert (output);
50
+ zsocket_bind (output, "inproc://zstr.test");
51
+ void *input = zsocket_new (ctx, ZMQ_PAIR);
52
+ assert (input);
53
+ zsocket_connect (input, "inproc://zstr.test");
54
+
55
+ // Send ten strings, five strings with MORE flag and then END
56
+ int string_nbr;
57
+ for (string_nbr = 0; string_nbr < 10; string_nbr++)
58
+ zstr_send (output, "this is string %d", string_nbr);
59
+ for (string_nbr = 0; string_nbr < 5; string_nbr++)
60
+ zstr_sendm (output, "this is string %d", string_nbr);
61
+ zstr_send (output, "END");
62
+
63
+ // Read and count until we receive END
64
+ string_nbr = 0;
65
+ for (string_nbr = 0;; string_nbr++) {
66
+ char *string = zstr_recv (input);
67
+ if (streq (string, "END")) {
68
+ free (string);
69
+ break;
70
+ }
71
+ free (string);
72
+ }
73
+ assert (string_nbr == 15);
74
+
75
+ zctx_destroy (&ctx);
76
+ ----
77
+
78
+ SEE ALSO
79
+ --------
80
+ linkczmq:czmq[7]
@@ -0,0 +1,44 @@
1
+ zsys(3)
2
+ =======
3
+
4
+ NAME
5
+ ----
6
+ zsys - system wrapper
7
+
8
+ SYNOPSIS
9
+ --------
10
+ ----
11
+ // Callback for interrupt signal handler
12
+ typedef void (zsys_handler_fn) (int signal_value);
13
+
14
+ // Set interrupt handler (NULL means external handler)
15
+ CZMQ_EXPORT void
16
+ zsys_handler_set (zsys_handler_fn *handler_fn);
17
+
18
+ // Reset interrupt handler, call this at exit if needed
19
+ CZMQ_EXPORT void
20
+ zsys_handler_reset (void);
21
+
22
+ // Self test of this class
23
+ CZMQ_EXPORT int
24
+ zsys_test (bool verbose);
25
+ ----
26
+
27
+ DESCRIPTION
28
+ -----------
29
+
30
+ The zsys class provides a portable wrapper for miscellaneous functions
31
+ that we want to wrap but which don't fit into any of the existing
32
+ classes. Eventually all non-portable functionality might be moved here
33
+ but for now it covers only file systems.
34
+
35
+
36
+ EXAMPLE
37
+ -------
38
+ .From zsys_test method
39
+ ----
40
+ ----
41
+
42
+ SEE ALSO
43
+ --------
44
+ linkczmq:czmq[7]
@@ -0,0 +1,126 @@
1
+ zthread(3)
2
+ ==========
3
+
4
+ NAME
5
+ ----
6
+ zthread - working with system threads
7
+
8
+ SYNOPSIS
9
+ --------
10
+ ----
11
+ // Detached threads follow POSIX pthreads API
12
+ typedef void *(zthread_detached_fn) (void *args);
13
+
14
+ // Attached threads get context and pipe from parent
15
+ typedef void (zthread_attached_fn) (void *args, zctx_t *ctx, void *pipe);
16
+
17
+ // Create a detached thread. A detached thread operates autonomously
18
+ // and is used to simulate a separate process. It gets no ctx, and no
19
+ // pipe.
20
+ CZMQ_EXPORT int
21
+ zthread_new (zthread_detached_fn *thread_fn, void *args);
22
+
23
+ // Create an attached thread. An attached thread gets a ctx and a PAIR
24
+ // pipe back to its parent. It must monitor its pipe, and exit if the
25
+ // pipe becomes unreadable. Do not destroy the ctx, the thread does this
26
+ // automatically when it ends.
27
+ CZMQ_EXPORT void *
28
+ zthread_fork (zctx_t *ctx, zthread_attached_fn *thread_fn, void *args);
29
+
30
+ // Self test of this class
31
+ CZMQ_EXPORT int
32
+ zthread_test (bool verbose);
33
+ ----
34
+
35
+ DESCRIPTION
36
+ -----------
37
+
38
+ The zthread class wraps OS thread creation. It creates detached threads
39
+ that look like normal OS threads, or attached threads that share the
40
+ caller's 0MQ context, and get an inproc pipe to talk back to the parent
41
+ thread. Detached threads create their own 0MQ contexts as needed.
42
+
43
+ We have several use cases for multiple threads. One is to simulate many
44
+ processes, so we can test 0MQ designs and flows more easily. Another is
45
+ to create APIs that can send and receive 0MQ messages in the background.
46
+
47
+ zthread solves these two use cases separately, using the zthread_new
48
+ and zthead_fork methods respectively. These methods wrap the native
49
+ system calls needed to start threads, so your code can remain fully
50
+ portable.
51
+
52
+ Detached threads follow the POSIX pthreads API; they accept a void *
53
+ argument and return a void * result (always NULL in our case).
54
+
55
+ Attached thread receive a void * argument, a zctx_t context, and a pipe
56
+ socket. The pipe socket is a PAIR socket that is connected back to the
57
+ caller. When you call zthread_fork, it returns you a PAIR socket that
58
+ is the other end of this pipe. Thus attached threads can talk back to
59
+ their parent threads over the pipe. We use this very heavily when making
60
+ so-called "asynchronous" APIs, which you can see in the Guide examples
61
+ like 'clone'.
62
+
63
+ To recap some rules about threading: do not share sockets between
64
+ threads or your code will crash. You can migrate a socket from one
65
+ thread to a child thread, if you stop using it in the parent thread
66
+ immediately after creating the child thread. If you want to connect
67
+ sockets over inproc:// they must share the same 0MQ context, i.e. be
68
+ attached threads. You should always use zthread_fork to create an
69
+ attached thread; it is not sufficient to pass a zctx_t structure to
70
+ a detached thread (this will crash).
71
+
72
+ If you want to communicate over ipc:// or tcp:// you may be sharing
73
+ the same context, or use separate contexts. Thus, every detached thread
74
+ usually starts by creating its own zctx_t instance.
75
+
76
+ EXAMPLE
77
+ -------
78
+ .From zthread_test method
79
+ ----
80
+ static void *
81
+ s_test_detached (void *args)
82
+ {
83
+ // Create a socket to check it'll be automatically deleted
84
+ zctx_t *ctx = zctx_new ();
85
+ assert (ctx);
86
+
87
+ void *push = zsocket_new (ctx, ZMQ_PUSH);
88
+ assert (push);
89
+ zctx_destroy (&ctx);
90
+ return NULL;
91
+ }
92
+
93
+ static void
94
+ s_test_attached (void *args, zctx_t *ctx, void *pipe)
95
+ {
96
+ // Create a socket to check it'll be automatically deleted
97
+ zsocket_new (ctx, ZMQ_PUSH);
98
+ // Wait for our parent to ping us, and pong back
99
+ free (zstr_recv (pipe));
100
+ zstr_send (pipe, "pong");
101
+ }
102
+
103
+ zctx_t *ctx = zctx_new ();
104
+ assert (ctx);
105
+ int rc = 0;
106
+
107
+ // Create a detached thread, let it run
108
+ rc = zthread_new (s_test_detached, NULL);
109
+ assert (rc == 0);
110
+ zclock_sleep (100);
111
+
112
+ // Create an attached thread, check it's safely alive
113
+ void *pipe = zthread_fork (ctx, s_test_attached, NULL);
114
+ assert (pipe);
115
+ zstr_send (pipe, "ping");
116
+ char *pong = zstr_recv (pipe);
117
+ assert (streq (pong, "pong"));
118
+ free (pong);
119
+
120
+ // Everything should be cleanly closed now
121
+ zctx_destroy (&ctx);
122
+ ----
123
+
124
+ SEE ALSO
125
+ --------
126
+ linkczmq:czmq[7]
@@ -0,0 +1,236 @@
1
+ ztree(3)
2
+ ========
3
+
4
+ NAME
5
+ ----
6
+ ztree - generic type-free red-black tree container
7
+
8
+ SYNOPSIS
9
+ --------
10
+ ----
11
+ // Callback function for ztee_walk method
12
+ typedef int (ztree_walk_fn) (const char *key, void *value, void *argument);
13
+
14
+ // Callback function for ztree_freefn method
15
+ typedef void (ztree_free_fn) (void *data);
16
+
17
+ // Comparison function for ztree ordering
18
+ // returns -1 for key1 < key2, 0 if key1 == key 2, 1 for key1 > key2
19
+ // if key's are strings okay to use strcmp as function
20
+ typedef int (ztree_compare_fn) (const char *key1, const char *key2);
21
+
22
+ // Create a new tree container
23
+ CZMQ_EXPORT ztree_t *
24
+ ztree_new (ztree_compare_fn *compare_func);
25
+
26
+ // Destroy a tree container
27
+ CZMQ_EXPORT void
28
+ ztree_destroy (ztree_t **self_p);
29
+
30
+ // Insert node into tree with specified key and value
31
+ // If key is already present returns -1 and leaves existing node unchanged
32
+ // Returns 0 on success.
33
+ CZMQ_EXPORT int
34
+ ztree_insert (ztree_t *self, const char *key, void *value);
35
+
36
+ // Update node in tree with specified key and value.
37
+ // If key is already present, destroys old value and inserts new one.
38
+ // Use free_fn method to ensure deallocator is properly called on value.
39
+ CZMQ_EXPORT void
40
+ ztree_update (ztree_t *self, const char *key, void *value);
41
+
42
+ // Remove a node specified by key from the tree. If there was no such
43
+ // node, this function does nothing.
44
+ CZMQ_EXPORT void
45
+ ztree_delete (ztree_t *self, const char *key);
46
+
47
+ // Return the value at the specified key, or null
48
+ CZMQ_EXPORT void *
49
+ ztree_lookup (ztree_t *self, const char *key);
50
+
51
+ // Set a free function for the specified tree node. When the value is
52
+ // destroyed, the free function, if any, is called on that node.
53
+ // Use this when tree values are dynamically allocated, to ensure that
54
+ // you don't have memory leaks. You can pass 'free' or NULL as a free_fn.
55
+ // Returns the item, or NULL if there is no such item.
56
+ CZMQ_EXPORT void *
57
+ ztree_freefn (ztree_t *self, const char *key, ztree_free_fn *free_fn);
58
+
59
+ // Return the number of keys/values in the tree
60
+ CZMQ_EXPORT size_t
61
+ ztree_size (ztree_t *self);
62
+
63
+ // Return keys for nodes in tree
64
+ CZMQ_EXPORT zlist_t *
65
+ ztree_keys (ztree_t *self);
66
+
67
+ // Copy the entire tree, return the copy
68
+ CZMQ_EXPORT ztree_t *
69
+ ztree_dup (ztree_t *self);
70
+
71
+ // Walk the tree depth-first, left-to-right order.
72
+ // Stops if callback function returns non-zero and returns
73
+ // final return code from callback function (zero = success).
74
+ CZMQ_EXPORT int
75
+ ztree_walk (ztree_t *self, ztree_walk_fn *callback, void *argument);
76
+
77
+ // Save tree to a text file in name=value format. Values must be
78
+ // printable strings; keys may not contain '=' character. Returns 0 if OK,
79
+ // else -1 if a file error occurred.
80
+ CZMQ_EXPORT int
81
+ ztree_save (ztree_t *self, const char *filename);
82
+
83
+ // Load tree from a text file in name=value format; tree must
84
+ // already exist. Tree values must printable strings; keys may not contain
85
+ // '=' character. Returns 0 if OK, else -1 if a file was not readable.
86
+ CZMQ_EXPORT int
87
+ ztree_load (ztree_t *self, const char *filename);
88
+
89
+ // Set tree for automatic value destruction
90
+ CZMQ_EXPORT void
91
+ ztree_autofree (ztree_t *self);
92
+
93
+ // Self test of this class
94
+ CZMQ_EXPORT void
95
+ ztree_test (int verbose);
96
+ ----
97
+
98
+ DESCRIPTION
99
+ -----------
100
+
101
+ Red black tree container
102
+
103
+
104
+ EXAMPLE
105
+ -------
106
+ .From ztree_test method
107
+ ----
108
+ ztree_t *tree = ztree_new (strcmp);
109
+ assert (tree);
110
+ assert (ztree_size (tree) == 0);
111
+
112
+ assert (ztree_lookup (tree, "NOTHING") == NULL);
113
+
114
+ // Insert some nodes
115
+ int rc;
116
+ rc = ztree_insert (tree, "DEADBEEF", "dead beef");
117
+ assert (rc == 0);
118
+ rc = ztree_insert (tree, "ABADCAFE", "a bad cafe");
119
+ assert (rc == 0);
120
+ rc = ztree_insert (tree, "C0DEDBAD", "coded bad");
121
+ assert (rc == 0);
122
+ rc = ztree_insert (tree, "DEADF00D", "dead food");
123
+ assert (rc == 0);
124
+ assert (ztree_size (tree) == 4);
125
+
126
+ // Look for existing nodes
127
+ char *value;
128
+ value = (char *) ztree_lookup (tree, "DEADBEEF");
129
+ assert (streq (value, "dead beef"));
130
+ value = (char *) ztree_lookup (tree, "ABADCAFE");
131
+ assert (streq (value, "a bad cafe"));
132
+ value = (char *) ztree_lookup (tree, "C0DEDBAD");
133
+ assert (streq (value, "coded bad"));
134
+ value = (char *) ztree_lookup (tree, "DEADF00D");
135
+ assert (streq (value, "dead food"));
136
+
137
+ // Look for non-existent nodes
138
+ value = (char *) ztree_lookup (tree, "foo");
139
+ assert (value == NULL);
140
+
141
+ // Try to insert duplicate nodes
142
+ rc = ztree_insert (tree, "DEADBEEF", "foo");
143
+ assert (rc == -1);
144
+ value = (char *) ztree_lookup (tree, "DEADBEEF");
145
+ assert (streq (value, "dead beef"));
146
+
147
+ // Test keys method
148
+ zlist_t *keys = ztree_keys (tree);
149
+ assert (zlist_size (keys) == 4);
150
+
151
+ // Test that keys are in order
152
+ void *key, *pred;
153
+ pred = zlist_first (keys);
154
+ assert(pred);
155
+ while ((key = zlist_next (keys))) {
156
+ assert(strcmp(key, pred) > 0);
157
+ pred = key;
158
+ }
159
+ zlist_destroy (&keys);
160
+
161
+ // Test dup method
162
+ ztree_t *copy = ztree_dup (tree);
163
+ assert (ztree_size (copy) == ztree_size (tree));
164
+ value = (char *) ztree_lookup (copy, "DEADF00D");
165
+ assert (value);
166
+ assert (streq (value, "dead food"));
167
+ ztree_destroy (&copy);
168
+
169
+ // Test walk
170
+ assert (0 == ztree_walk(tree, test_walk, tree));
171
+ assert (-1 == ztree_walk(tree, test_walk_error, tree));
172
+
173
+ // Test save and load
174
+ ztree_save (tree, ".cache");
175
+ copy = ztree_new (strcasecmp);
176
+ ztree_load (copy, ".cache");
177
+ assert (ztree_size (copy) == ztree_size (tree));
178
+ value = (char *) ztree_lookup (copy, "DEADBEEF");
179
+ assert (value);
180
+ assert (streq (value, "dead beef"));
181
+ ztree_destroy (&copy);
182
+ #if (defined (WIN32))
183
+ DeleteFile (".cache");
184
+ #else
185
+ unlink (".cache");
186
+ #endif
187
+
188
+ // Delete some nodes
189
+ assert (ztree_size (tree) == 4);
190
+ ztree_delete (tree, "DEADF00D");
191
+ value = (char *) ztree_lookup (tree, "DEADF00D");
192
+ assert (value == NULL);
193
+ assert (ztree_size (tree) == 3);
194
+
195
+ ztree_delete (tree, "C0DEDBAD");
196
+ value = (char *) ztree_lookup (tree, "C0DEDBAD");
197
+ assert (value == NULL);
198
+ assert (ztree_size (tree) == 2);
199
+
200
+ // Check that the queue is robust against random usage
201
+ struct {
202
+ char name [100];
203
+ bool exists;
204
+ } testset [200];
205
+ memset (testset, 0, sizeof (testset));
206
+ int testmax = 200, testnbr, iteration;
207
+
208
+ srandom ((unsigned) time (NULL));
209
+ for (iteration = 0; iteration < 25000; iteration++) {
210
+ testnbr = randof (testmax);
211
+ if (testset [testnbr].exists) {
212
+ value = (char *) ztree_lookup (tree, testset [testnbr].name);
213
+ assert (value);
214
+ ztree_delete (tree, testset [testnbr].name);
215
+ testset [testnbr].exists = false;
216
+ }
217
+ else {
218
+ sprintf (testset [testnbr].name, "%x-%x", rand (), rand ());
219
+ if (ztree_insert (tree, testset [testnbr].name, "") == 0)
220
+ testset [testnbr].exists = true;
221
+ }
222
+ }
223
+
224
+ // Test 10K lookups
225
+ for (iteration = 0; iteration < 10000; iteration++)
226
+ value = (char *) ztree_lookup (tree, "DEADBEEFABADCAFE");
227
+
228
+ // Destructor should be safe to call twice
229
+ ztree_destroy (&tree);
230
+ ztree_destroy (&tree);
231
+ assert (tree == NULL);
232
+ ----
233
+
234
+ SEE ALSO
235
+ --------
236
+ linkczmq:czmq[7]