libzmq 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (300) hide show
  1. data/LICENSE +703 -0
  2. data/README.md +31 -0
  3. data/lib/libzmq.rb +17 -0
  4. data/lib/libzmq/ffi-rzmq.rb +3 -0
  5. data/libzmq/Makefile +5 -0
  6. data/libzmq/extconf.rb +24 -0
  7. data/libzmq/zeromq-2.1.7/AUTHORS +92 -0
  8. data/libzmq/zeromq-2.1.7/COPYING +674 -0
  9. data/libzmq/zeromq-2.1.7/COPYING.LESSER +206 -0
  10. data/libzmq/zeromq-2.1.7/ChangeLog +15620 -0
  11. data/libzmq/zeromq-2.1.7/INSTALL +237 -0
  12. data/libzmq/zeromq-2.1.7/MAINTAINERS +56 -0
  13. data/libzmq/zeromq-2.1.7/Makefile.am +42 -0
  14. data/libzmq/zeromq-2.1.7/Makefile.in +779 -0
  15. data/libzmq/zeromq-2.1.7/NEWS +275 -0
  16. data/libzmq/zeromq-2.1.7/README +39 -0
  17. data/libzmq/zeromq-2.1.7/acinclude.m4 +582 -0
  18. data/libzmq/zeromq-2.1.7/aclocal.m4 +1206 -0
  19. data/libzmq/zeromq-2.1.7/autogen.sh +45 -0
  20. data/libzmq/zeromq-2.1.7/builds/msvc/Makefile.am +8 -0
  21. data/libzmq/zeromq-2.1.7/builds/msvc/Makefile.in +390 -0
  22. data/libzmq/zeromq-2.1.7/builds/msvc/c_local_lat/c_local_lat.vcproj +176 -0
  23. data/libzmq/zeromq-2.1.7/builds/msvc/c_local_thr/c_local_thr.vcproj +176 -0
  24. data/libzmq/zeromq-2.1.7/builds/msvc/c_remote_lat/c_remote_lat.vcproj +176 -0
  25. data/libzmq/zeromq-2.1.7/builds/msvc/c_remote_thr/c_remote_thr.vcproj +176 -0
  26. data/libzmq/zeromq-2.1.7/builds/msvc/libzmq/libzmq.vcproj +783 -0
  27. data/libzmq/zeromq-2.1.7/builds/msvc/msvc.sln +89 -0
  28. data/libzmq/zeromq-2.1.7/builds/msvc/platform.hpp +32 -0
  29. data/libzmq/zeromq-2.1.7/builds/redhat/zeromq.spec.in +139 -0
  30. data/libzmq/zeromq-2.1.7/config/compile +143 -0
  31. data/libzmq/zeromq-2.1.7/config/config.guess +1502 -0
  32. data/libzmq/zeromq-2.1.7/config/config.sub +1714 -0
  33. data/libzmq/zeromq-2.1.7/config/depcomp +630 -0
  34. data/libzmq/zeromq-2.1.7/config/install-sh +520 -0
  35. data/libzmq/zeromq-2.1.7/config/libtool.m4 +7377 -0
  36. data/libzmq/zeromq-2.1.7/config/ltmain.sh +8413 -0
  37. data/libzmq/zeromq-2.1.7/config/ltoptions.m4 +368 -0
  38. data/libzmq/zeromq-2.1.7/config/ltsugar.m4 +123 -0
  39. data/libzmq/zeromq-2.1.7/config/ltversion.m4 +23 -0
  40. data/libzmq/zeromq-2.1.7/config/lt~obsolete.m4 +92 -0
  41. data/libzmq/zeromq-2.1.7/config/missing +376 -0
  42. data/libzmq/zeromq-2.1.7/configure +21645 -0
  43. data/libzmq/zeromq-2.1.7/configure.in +380 -0
  44. data/libzmq/zeromq-2.1.7/doc/Makefile.am +46 -0
  45. data/libzmq/zeromq-2.1.7/doc/Makefile.in +546 -0
  46. data/libzmq/zeromq-2.1.7/doc/asciidoc.conf +56 -0
  47. data/libzmq/zeromq-2.1.7/doc/zmq.7 +242 -0
  48. data/libzmq/zeromq-2.1.7/doc/zmq.html +846 -0
  49. data/libzmq/zeromq-2.1.7/doc/zmq.txt +218 -0
  50. data/libzmq/zeromq-2.1.7/doc/zmq_bind.3 +166 -0
  51. data/libzmq/zeromq-2.1.7/doc/zmq_bind.html +746 -0
  52. data/libzmq/zeromq-2.1.7/doc/zmq_bind.txt +91 -0
  53. data/libzmq/zeromq-2.1.7/doc/zmq_close.3 +81 -0
  54. data/libzmq/zeromq-2.1.7/doc/zmq_close.html +645 -0
  55. data/libzmq/zeromq-2.1.7/doc/zmq_close.txt +52 -0
  56. data/libzmq/zeromq-2.1.7/doc/zmq_connect.3 +161 -0
  57. data/libzmq/zeromq-2.1.7/doc/zmq_connect.html +732 -0
  58. data/libzmq/zeromq-2.1.7/doc/zmq_connect.txt +89 -0
  59. data/libzmq/zeromq-2.1.7/doc/zmq_cpp.7 +410 -0
  60. data/libzmq/zeromq-2.1.7/doc/zmq_cpp.html +765 -0
  61. data/libzmq/zeromq-2.1.7/doc/zmq_cpp.txt +212 -0
  62. data/libzmq/zeromq-2.1.7/doc/zmq_device.3 +140 -0
  63. data/libzmq/zeromq-2.1.7/doc/zmq_device.html +736 -0
  64. data/libzmq/zeromq-2.1.7/doc/zmq_device.txt +138 -0
  65. data/libzmq/zeromq-2.1.7/doc/zmq_epgm.7 +209 -0
  66. data/libzmq/zeromq-2.1.7/doc/zmq_epgm.html +749 -0
  67. data/libzmq/zeromq-2.1.7/doc/zmq_epgm.txt +162 -0
  68. data/libzmq/zeromq-2.1.7/doc/zmq_errno.3 +78 -0
  69. data/libzmq/zeromq-2.1.7/doc/zmq_errno.html +634 -0
  70. data/libzmq/zeromq-2.1.7/doc/zmq_errno.txt +50 -0
  71. data/libzmq/zeromq-2.1.7/doc/zmq_getsockopt.3 +944 -0
  72. data/libzmq/zeromq-2.1.7/doc/zmq_getsockopt.html +1713 -0
  73. data/libzmq/zeromq-2.1.7/doc/zmq_getsockopt.txt +407 -0
  74. data/libzmq/zeromq-2.1.7/doc/zmq_init.3 +71 -0
  75. data/libzmq/zeromq-2.1.7/doc/zmq_init.html +635 -0
  76. data/libzmq/zeromq-2.1.7/doc/zmq_init.txt +51 -0
  77. data/libzmq/zeromq-2.1.7/doc/zmq_inproc.7 +115 -0
  78. data/libzmq/zeromq-2.1.7/doc/zmq_inproc.html +669 -0
  79. data/libzmq/zeromq-2.1.7/doc/zmq_inproc.txt +89 -0
  80. data/libzmq/zeromq-2.1.7/doc/zmq_ipc.7 +109 -0
  81. data/libzmq/zeromq-2.1.7/doc/zmq_ipc.html +662 -0
  82. data/libzmq/zeromq-2.1.7/doc/zmq_ipc.txt +80 -0
  83. data/libzmq/zeromq-2.1.7/doc/zmq_msg_close.3 +81 -0
  84. data/libzmq/zeromq-2.1.7/doc/zmq_msg_close.html +647 -0
  85. data/libzmq/zeromq-2.1.7/doc/zmq_msg_close.txt +55 -0
  86. data/libzmq/zeromq-2.1.7/doc/zmq_msg_copy.3 +95 -0
  87. data/libzmq/zeromq-2.1.7/doc/zmq_msg_copy.html +656 -0
  88. data/libzmq/zeromq-2.1.7/doc/zmq_msg_copy.txt +57 -0
  89. data/libzmq/zeromq-2.1.7/doc/zmq_msg_data.3 +76 -0
  90. data/libzmq/zeromq-2.1.7/doc/zmq_msg_data.html +633 -0
  91. data/libzmq/zeromq-2.1.7/doc/zmq_msg_data.txt +48 -0
  92. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init.3 +110 -0
  93. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init.html +656 -0
  94. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init.txt +65 -0
  95. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_data.3 +138 -0
  96. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_data.html +678 -0
  97. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_data.txt +83 -0
  98. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_size.3 +97 -0
  99. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_size.html +656 -0
  100. data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_size.txt +58 -0
  101. data/libzmq/zeromq-2.1.7/doc/zmq_msg_move.3 +79 -0
  102. data/libzmq/zeromq-2.1.7/doc/zmq_msg_move.html +645 -0
  103. data/libzmq/zeromq-2.1.7/doc/zmq_msg_move.txt +52 -0
  104. data/libzmq/zeromq-2.1.7/doc/zmq_msg_size.3 +76 -0
  105. data/libzmq/zeromq-2.1.7/doc/zmq_msg_size.html +633 -0
  106. data/libzmq/zeromq-2.1.7/doc/zmq_msg_size.txt +48 -0
  107. data/libzmq/zeromq-2.1.7/doc/zmq_pgm.7 +209 -0
  108. data/libzmq/zeromq-2.1.7/doc/zmq_pgm.html +749 -0
  109. data/libzmq/zeromq-2.1.7/doc/zmq_pgm.txt +162 -0
  110. data/libzmq/zeromq-2.1.7/doc/zmq_poll.3 +204 -0
  111. data/libzmq/zeromq-2.1.7/doc/zmq_poll.html +755 -0
  112. data/libzmq/zeromq-2.1.7/doc/zmq_poll.txt +132 -0
  113. data/libzmq/zeromq-2.1.7/doc/zmq_recv.3 +172 -0
  114. data/libzmq/zeromq-2.1.7/doc/zmq_recv.html +746 -0
  115. data/libzmq/zeromq-2.1.7/doc/zmq_recv.txt +121 -0
  116. data/libzmq/zeromq-2.1.7/doc/zmq_send.3 +185 -0
  117. data/libzmq/zeromq-2.1.7/doc/zmq_send.html +755 -0
  118. data/libzmq/zeromq-2.1.7/doc/zmq_send.txt +120 -0
  119. data/libzmq/zeromq-2.1.7/doc/zmq_setsockopt.3 +878 -0
  120. data/libzmq/zeromq-2.1.7/doc/zmq_setsockopt.html +1603 -0
  121. data/libzmq/zeromq-2.1.7/doc/zmq_setsockopt.txt +382 -0
  122. data/libzmq/zeromq-2.1.7/doc/zmq_socket.3 +779 -0
  123. data/libzmq/zeromq-2.1.7/doc/zmq_socket.html +1424 -0
  124. data/libzmq/zeromq-2.1.7/doc/zmq_socket.txt +342 -0
  125. data/libzmq/zeromq-2.1.7/doc/zmq_strerror.3 +78 -0
  126. data/libzmq/zeromq-2.1.7/doc/zmq_strerror.html +634 -0
  127. data/libzmq/zeromq-2.1.7/doc/zmq_strerror.txt +55 -0
  128. data/libzmq/zeromq-2.1.7/doc/zmq_tcp.7 +244 -0
  129. data/libzmq/zeromq-2.1.7/doc/zmq_tcp.html +755 -0
  130. data/libzmq/zeromq-2.1.7/doc/zmq_tcp.txt +162 -0
  131. data/libzmq/zeromq-2.1.7/doc/zmq_term.3 +135 -0
  132. data/libzmq/zeromq-2.1.7/doc/zmq_term.html +672 -0
  133. data/libzmq/zeromq-2.1.7/doc/zmq_term.txt +65 -0
  134. data/libzmq/zeromq-2.1.7/doc/zmq_version.3 +78 -0
  135. data/libzmq/zeromq-2.1.7/doc/zmq_version.html +632 -0
  136. data/libzmq/zeromq-2.1.7/doc/zmq_version.txt +53 -0
  137. data/libzmq/zeromq-2.1.7/foreign/openpgm/Makefile.am +8 -0
  138. data/libzmq/zeromq-2.1.7/foreign/openpgm/Makefile.in +588 -0
  139. data/libzmq/zeromq-2.1.7/foreign/openpgm/libpgm-5.1.115~dfsg.tar.gz +0 -0
  140. data/libzmq/zeromq-2.1.7/foreign/xmlParser/xmlParser.cpp +2923 -0
  141. data/libzmq/zeromq-2.1.7/foreign/xmlParser/xmlParser.hpp +762 -0
  142. data/libzmq/zeromq-2.1.7/include/zmq.h +269 -0
  143. data/libzmq/zeromq-2.1.7/include/zmq.hpp +301 -0
  144. data/libzmq/zeromq-2.1.7/include/zmq_utils.h +64 -0
  145. data/libzmq/zeromq-2.1.7/perf/Makefile.am +21 -0
  146. data/libzmq/zeromq-2.1.7/perf/Makefile.in +566 -0
  147. data/libzmq/zeromq-2.1.7/perf/inproc_lat.cpp +232 -0
  148. data/libzmq/zeromq-2.1.7/perf/inproc_thr.cpp +246 -0
  149. data/libzmq/zeromq-2.1.7/perf/local_lat.cpp +108 -0
  150. data/libzmq/zeromq-2.1.7/perf/local_thr.cpp +138 -0
  151. data/libzmq/zeromq-2.1.7/perf/remote_lat.cpp +121 -0
  152. data/libzmq/zeromq-2.1.7/perf/remote_thr.cpp +104 -0
  153. data/libzmq/zeromq-2.1.7/src/Makefile.am +155 -0
  154. data/libzmq/zeromq-2.1.7/src/Makefile.in +1320 -0
  155. data/libzmq/zeromq-2.1.7/src/array.hpp +147 -0
  156. data/libzmq/zeromq-2.1.7/src/atomic_counter.hpp +164 -0
  157. data/libzmq/zeromq-2.1.7/src/atomic_ptr.hpp +159 -0
  158. data/libzmq/zeromq-2.1.7/src/blob.hpp +34 -0
  159. data/libzmq/zeromq-2.1.7/src/clock.cpp +118 -0
  160. data/libzmq/zeromq-2.1.7/src/clock.hpp +60 -0
  161. data/libzmq/zeromq-2.1.7/src/command.cpp +39 -0
  162. data/libzmq/zeromq-2.1.7/src/command.hpp +147 -0
  163. data/libzmq/zeromq-2.1.7/src/config.hpp +88 -0
  164. data/libzmq/zeromq-2.1.7/src/connect_session.cpp +119 -0
  165. data/libzmq/zeromq-2.1.7/src/connect_session.hpp +65 -0
  166. data/libzmq/zeromq-2.1.7/src/ctx.cpp +322 -0
  167. data/libzmq/zeromq-2.1.7/src/ctx.hpp +159 -0
  168. data/libzmq/zeromq-2.1.7/src/decoder.cpp +129 -0
  169. data/libzmq/zeromq-2.1.7/src/decoder.hpp +207 -0
  170. data/libzmq/zeromq-2.1.7/src/device.cpp +120 -0
  171. data/libzmq/zeromq-2.1.7/src/device.hpp +32 -0
  172. data/libzmq/zeromq-2.1.7/src/devpoll.cpp +190 -0
  173. data/libzmq/zeromq-2.1.7/src/devpoll.hpp +100 -0
  174. data/libzmq/zeromq-2.1.7/src/dist.cpp +200 -0
  175. data/libzmq/zeromq-2.1.7/src/dist.hpp +90 -0
  176. data/libzmq/zeromq-2.1.7/src/encoder.cpp +90 -0
  177. data/libzmq/zeromq-2.1.7/src/encoder.hpp +184 -0
  178. data/libzmq/zeromq-2.1.7/src/epoll.cpp +177 -0
  179. data/libzmq/zeromq-2.1.7/src/epoll.hpp +96 -0
  180. data/libzmq/zeromq-2.1.7/src/err.cpp +238 -0
  181. data/libzmq/zeromq-2.1.7/src/err.hpp +145 -0
  182. data/libzmq/zeromq-2.1.7/src/fd.hpp +45 -0
  183. data/libzmq/zeromq-2.1.7/src/fq.cpp +164 -0
  184. data/libzmq/zeromq-2.1.7/src/fq.hpp +80 -0
  185. data/libzmq/zeromq-2.1.7/src/i_engine.hpp +53 -0
  186. data/libzmq/zeromq-2.1.7/src/i_inout.hpp +50 -0
  187. data/libzmq/zeromq-2.1.7/src/i_poll_events.hpp +46 -0
  188. data/libzmq/zeromq-2.1.7/src/io_object.cpp +107 -0
  189. data/libzmq/zeromq-2.1.7/src/io_object.hpp +78 -0
  190. data/libzmq/zeromq-2.1.7/src/io_thread.cpp +109 -0
  191. data/libzmq/zeromq-2.1.7/src/io_thread.hpp +88 -0
  192. data/libzmq/zeromq-2.1.7/src/ip.cpp +339 -0
  193. data/libzmq/zeromq-2.1.7/src/ip.hpp +68 -0
  194. data/libzmq/zeromq-2.1.7/src/kqueue.cpp +194 -0
  195. data/libzmq/zeromq-2.1.7/src/kqueue.hpp +103 -0
  196. data/libzmq/zeromq-2.1.7/src/lb.cpp +174 -0
  197. data/libzmq/zeromq-2.1.7/src/lb.hpp +79 -0
  198. data/libzmq/zeromq-2.1.7/src/libzmq.pc.in +10 -0
  199. data/libzmq/zeromq-2.1.7/src/likely.hpp +33 -0
  200. data/libzmq/zeromq-2.1.7/src/mailbox.cpp +382 -0
  201. data/libzmq/zeromq-2.1.7/src/mailbox.hpp +62 -0
  202. data/libzmq/zeromq-2.1.7/src/msg_content.hpp +52 -0
  203. data/libzmq/zeromq-2.1.7/src/mutex.hpp +121 -0
  204. data/libzmq/zeromq-2.1.7/src/named_session.cpp +85 -0
  205. data/libzmq/zeromq-2.1.7/src/named_session.hpp +57 -0
  206. data/libzmq/zeromq-2.1.7/src/object.cpp +467 -0
  207. data/libzmq/zeromq-2.1.7/src/object.hpp +127 -0
  208. data/libzmq/zeromq-2.1.7/src/options.cpp +336 -0
  209. data/libzmq/zeromq-2.1.7/src/options.hpp +87 -0
  210. data/libzmq/zeromq-2.1.7/src/own.cpp +214 -0
  211. data/libzmq/zeromq-2.1.7/src/own.hpp +140 -0
  212. data/libzmq/zeromq-2.1.7/src/pair.cpp +180 -0
  213. data/libzmq/zeromq-2.1.7/src/pair.hpp +76 -0
  214. data/libzmq/zeromq-2.1.7/src/pgm_receiver.cpp +259 -0
  215. data/libzmq/zeromq-2.1.7/src/pgm_receiver.hpp +129 -0
  216. data/libzmq/zeromq-2.1.7/src/pgm_sender.cpp +215 -0
  217. data/libzmq/zeromq-2.1.7/src/pgm_sender.hpp +105 -0
  218. data/libzmq/zeromq-2.1.7/src/pgm_socket.cpp +705 -0
  219. data/libzmq/zeromq-2.1.7/src/pgm_socket.hpp +118 -0
  220. data/libzmq/zeromq-2.1.7/src/pipe.cpp +409 -0
  221. data/libzmq/zeromq-2.1.7/src/pipe.hpp +214 -0
  222. data/libzmq/zeromq-2.1.7/src/platform.hpp.in +228 -0
  223. data/libzmq/zeromq-2.1.7/src/poll.cpp +180 -0
  224. data/libzmq/zeromq-2.1.7/src/poll.hpp +104 -0
  225. data/libzmq/zeromq-2.1.7/src/poller.hpp +73 -0
  226. data/libzmq/zeromq-2.1.7/src/poller_base.cpp +99 -0
  227. data/libzmq/zeromq-2.1.7/src/poller_base.hpp +84 -0
  228. data/libzmq/zeromq-2.1.7/src/pub.cpp +31 -0
  229. data/libzmq/zeromq-2.1.7/src/pub.hpp +44 -0
  230. data/libzmq/zeromq-2.1.7/src/pull.cpp +61 -0
  231. data/libzmq/zeromq-2.1.7/src/pull.hpp +60 -0
  232. data/libzmq/zeromq-2.1.7/src/push.cpp +62 -0
  233. data/libzmq/zeromq-2.1.7/src/push.hpp +59 -0
  234. data/libzmq/zeromq-2.1.7/src/reaper.cpp +121 -0
  235. data/libzmq/zeromq-2.1.7/src/reaper.hpp +77 -0
  236. data/libzmq/zeromq-2.1.7/src/rep.cpp +131 -0
  237. data/libzmq/zeromq-2.1.7/src/rep.hpp +59 -0
  238. data/libzmq/zeromq-2.1.7/src/req.cpp +121 -0
  239. data/libzmq/zeromq-2.1.7/src/req.hpp +58 -0
  240. data/libzmq/zeromq-2.1.7/src/select.cpp +211 -0
  241. data/libzmq/zeromq-2.1.7/src/select.hpp +116 -0
  242. data/libzmq/zeromq-2.1.7/src/semaphore.hpp +189 -0
  243. data/libzmq/zeromq-2.1.7/src/session.cpp +347 -0
  244. data/libzmq/zeromq-2.1.7/src/session.hpp +150 -0
  245. data/libzmq/zeromq-2.1.7/src/socket_base.cpp +811 -0
  246. data/libzmq/zeromq-2.1.7/src/socket_base.hpp +207 -0
  247. data/libzmq/zeromq-2.1.7/src/stdint.hpp +63 -0
  248. data/libzmq/zeromq-2.1.7/src/sub.cpp +75 -0
  249. data/libzmq/zeromq-2.1.7/src/sub.hpp +50 -0
  250. data/libzmq/zeromq-2.1.7/src/swap.cpp +325 -0
  251. data/libzmq/zeromq-2.1.7/src/swap.hpp +123 -0
  252. data/libzmq/zeromq-2.1.7/src/tcp_connecter.cpp +310 -0
  253. data/libzmq/zeromq-2.1.7/src/tcp_connecter.hpp +81 -0
  254. data/libzmq/zeromq-2.1.7/src/tcp_listener.cpp +371 -0
  255. data/libzmq/zeromq-2.1.7/src/tcp_listener.hpp +73 -0
  256. data/libzmq/zeromq-2.1.7/src/tcp_socket.cpp +228 -0
  257. data/libzmq/zeromq-2.1.7/src/tcp_socket.hpp +72 -0
  258. data/libzmq/zeromq-2.1.7/src/thread.cpp +97 -0
  259. data/libzmq/zeromq-2.1.7/src/thread.hpp +78 -0
  260. data/libzmq/zeromq-2.1.7/src/transient_session.cpp +41 -0
  261. data/libzmq/zeromq-2.1.7/src/transient_session.hpp +52 -0
  262. data/libzmq/zeromq-2.1.7/src/trie.cpp +181 -0
  263. data/libzmq/zeromq-2.1.7/src/trie.hpp +59 -0
  264. data/libzmq/zeromq-2.1.7/src/uuid.cpp +233 -0
  265. data/libzmq/zeromq-2.1.7/src/uuid.hpp +111 -0
  266. data/libzmq/zeromq-2.1.7/src/windows.hpp +79 -0
  267. data/libzmq/zeromq-2.1.7/src/wire.hpp +99 -0
  268. data/libzmq/zeromq-2.1.7/src/xpub.cpp +76 -0
  269. data/libzmq/zeromq-2.1.7/src/xpub.hpp +61 -0
  270. data/libzmq/zeromq-2.1.7/src/xrep.cpp +337 -0
  271. data/libzmq/zeromq-2.1.7/src/xrep.hpp +116 -0
  272. data/libzmq/zeromq-2.1.7/src/xreq.cpp +74 -0
  273. data/libzmq/zeromq-2.1.7/src/xreq.hpp +65 -0
  274. data/libzmq/zeromq-2.1.7/src/xsub.cpp +172 -0
  275. data/libzmq/zeromq-2.1.7/src/xsub.hpp +80 -0
  276. data/libzmq/zeromq-2.1.7/src/ypipe.hpp +209 -0
  277. data/libzmq/zeromq-2.1.7/src/yqueue.hpp +198 -0
  278. data/libzmq/zeromq-2.1.7/src/zmq.cpp +798 -0
  279. data/libzmq/zeromq-2.1.7/src/zmq_connecter.cpp +166 -0
  280. data/libzmq/zeromq-2.1.7/src/zmq_connecter.hpp +92 -0
  281. data/libzmq/zeromq-2.1.7/src/zmq_engine.cpp +220 -0
  282. data/libzmq/zeromq-2.1.7/src/zmq_engine.hpp +87 -0
  283. data/libzmq/zeromq-2.1.7/src/zmq_init.cpp +216 -0
  284. data/libzmq/zeromq-2.1.7/src/zmq_init.hpp +93 -0
  285. data/libzmq/zeromq-2.1.7/src/zmq_listener.cpp +78 -0
  286. data/libzmq/zeromq-2.1.7/src/zmq_listener.hpp +67 -0
  287. data/libzmq/zeromq-2.1.7/tests/Makefile.am +30 -0
  288. data/libzmq/zeromq-2.1.7/tests/Makefile.in +713 -0
  289. data/libzmq/zeromq-2.1.7/tests/test_hwm.cpp +68 -0
  290. data/libzmq/zeromq-2.1.7/tests/test_pair_inproc.cpp +31 -0
  291. data/libzmq/zeromq-2.1.7/tests/test_pair_ipc.cpp +31 -0
  292. data/libzmq/zeromq-2.1.7/tests/test_pair_tcp.cpp +31 -0
  293. data/libzmq/zeromq-2.1.7/tests/test_reqrep_inproc.cpp +31 -0
  294. data/libzmq/zeromq-2.1.7/tests/test_reqrep_ipc.cpp +31 -0
  295. data/libzmq/zeromq-2.1.7/tests/test_reqrep_tcp.cpp +31 -0
  296. data/libzmq/zeromq-2.1.7/tests/test_shutdown_stress.cpp +87 -0
  297. data/libzmq/zeromq-2.1.7/tests/testutil.hpp +130 -0
  298. data/libzmq/zeromq-2.1.7/version.sh +21 -0
  299. data/libzmq/zeromq-2.1.7/zeromq.spec +139 -0
  300. metadata +348 -0
@@ -0,0 +1,166 @@
1
+ /*
2
+ Copyright (c) 2007-2011 iMatix Corporation
3
+ Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
4
+
5
+ This file is part of 0MQ.
6
+
7
+ 0MQ is free software; you can redistribute it and/or modify it under
8
+ the terms of the GNU Lesser General Public License as published by
9
+ the Free Software Foundation; either version 3 of the License, or
10
+ (at your option) any later version.
11
+
12
+ 0MQ is distributed in the hope that it will be useful,
13
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
14
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
+ GNU Lesser General Public License for more details.
16
+
17
+ You should have received a copy of the GNU Lesser General Public License
18
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
19
+ */
20
+
21
+ #include <new>
22
+
23
+ #include "platform.hpp"
24
+ #if defined ZMQ_HAVE_WINDOWS
25
+ #include "windows.hpp"
26
+ #else
27
+ #include <sys/types.h>
28
+ #include <unistd.h>
29
+ #endif
30
+
31
+ #include "zmq_connecter.hpp"
32
+ #include "zmq_engine.hpp"
33
+ #include "zmq_init.hpp"
34
+ #include "io_thread.hpp"
35
+ #include "err.hpp"
36
+
37
+ zmq::zmq_connecter_t::zmq_connecter_t (class io_thread_t *io_thread_,
38
+ class session_t *session_, const options_t &options_,
39
+ const char *protocol_, const char *address_, bool wait_) :
40
+ own_t (io_thread_, options_),
41
+ io_object_t (io_thread_),
42
+ handle_valid (false),
43
+ wait (wait_),
44
+ session (session_),
45
+ current_reconnect_ivl(options.reconnect_ivl)
46
+ {
47
+ int rc = tcp_connecter.set_address (protocol_, address_);
48
+ zmq_assert (rc == 0);
49
+ }
50
+
51
+ zmq::zmq_connecter_t::~zmq_connecter_t ()
52
+ {
53
+ if (wait)
54
+ cancel_timer (reconnect_timer_id);
55
+ if (handle_valid)
56
+ rm_fd (handle);
57
+ }
58
+
59
+ void zmq::zmq_connecter_t::process_plug ()
60
+ {
61
+ if (wait)
62
+ add_reconnect_timer();
63
+ else
64
+ start_connecting ();
65
+ }
66
+
67
+ void zmq::zmq_connecter_t::in_event ()
68
+ {
69
+ // We are not polling for incomming data, so we are actually called
70
+ // because of error here. However, we can get error on out event as well
71
+ // on some platforms, so we'll simply handle both events in the same way.
72
+ out_event ();
73
+ }
74
+
75
+ void zmq::zmq_connecter_t::out_event ()
76
+ {
77
+ fd_t fd = tcp_connecter.connect ();
78
+ rm_fd (handle);
79
+ handle_valid = false;
80
+
81
+ // Handle the error condition by attempt to reconnect.
82
+ if (fd == retired_fd) {
83
+ tcp_connecter.close ();
84
+ wait = true;
85
+ add_reconnect_timer();
86
+ return;
87
+ }
88
+
89
+ // Choose I/O thread to run connecter in. Given that we are already
90
+ // running in an I/O thread, there must be at least one available.
91
+ io_thread_t *io_thread = choose_io_thread (options.affinity);
92
+ zmq_assert (io_thread);
93
+
94
+ // Create an init object.
95
+ zmq_init_t *init = new (std::nothrow) zmq_init_t (io_thread, NULL,
96
+ session, fd, options);
97
+ alloc_assert (init);
98
+ launch_sibling (init);
99
+
100
+ // Shut the connecter down.
101
+ terminate ();
102
+ }
103
+
104
+ void zmq::zmq_connecter_t::timer_event (int id_)
105
+ {
106
+ zmq_assert (id_ == reconnect_timer_id);
107
+ wait = false;
108
+ start_connecting ();
109
+ }
110
+
111
+ void zmq::zmq_connecter_t::start_connecting ()
112
+ {
113
+ // Open the connecting socket.
114
+ int rc = tcp_connecter.open ();
115
+
116
+ // Connect may succeed in synchronous manner.
117
+ if (rc == 0) {
118
+ handle = add_fd (tcp_connecter.get_fd ());
119
+ handle_valid = true;
120
+ out_event ();
121
+ return;
122
+ }
123
+
124
+ // Connection establishment may be dealyed. Poll for its completion.
125
+ else if (rc == -1 && errno == EAGAIN) {
126
+ handle = add_fd (tcp_connecter.get_fd ());
127
+ handle_valid = true;
128
+ set_pollout (handle);
129
+ return;
130
+ }
131
+
132
+ // Handle any other error condition by eventual reconnect.
133
+ wait = true;
134
+ add_reconnect_timer();
135
+ }
136
+
137
+ void zmq::zmq_connecter_t::add_reconnect_timer()
138
+ {
139
+ add_timer (get_new_reconnect_ivl(), reconnect_timer_id);
140
+ }
141
+
142
+ int zmq::zmq_connecter_t::get_new_reconnect_ivl ()
143
+ {
144
+ #if defined ZMQ_HAVE_WINDOWS
145
+ int pid = (int) GetCurrentProcessId ();
146
+ #else
147
+ int pid = (int) getpid ();
148
+ #endif
149
+
150
+ // The new interval is the current interval + random value.
151
+ int this_interval = current_reconnect_ivl +
152
+ ((pid * 13) % options.reconnect_ivl);
153
+
154
+ // Only change the current reconnect interval if the maximum reconnect
155
+ // interval was set and if it's larger than the reconnect interval.
156
+ if (options.reconnect_ivl_max > 0 &&
157
+ options.reconnect_ivl_max > options.reconnect_ivl) {
158
+
159
+ // Calculate the next interval
160
+ current_reconnect_ivl = current_reconnect_ivl * 2;
161
+ if(current_reconnect_ivl >= options.reconnect_ivl_max) {
162
+ current_reconnect_ivl = options.reconnect_ivl_max;
163
+ }
164
+ }
165
+ return this_interval;
166
+ }
@@ -0,0 +1,92 @@
1
+ /*
2
+ Copyright (c) 2007-2011 iMatix Corporation
3
+ Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
4
+
5
+ This file is part of 0MQ.
6
+
7
+ 0MQ is free software; you can redistribute it and/or modify it under
8
+ the terms of the GNU Lesser General Public License as published by
9
+ the Free Software Foundation; either version 3 of the License, or
10
+ (at your option) any later version.
11
+
12
+ 0MQ is distributed in the hope that it will be useful,
13
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
14
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
+ GNU Lesser General Public License for more details.
16
+
17
+ You should have received a copy of the GNU Lesser General Public License
18
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
19
+ */
20
+
21
+ #ifndef __ZMQ_ZMQ_CONNECTER_HPP_INCLUDED__
22
+ #define __ZMQ_ZMQ_CONNECTER_HPP_INCLUDED__
23
+
24
+ #include "own.hpp"
25
+ #include "io_object.hpp"
26
+ #include "tcp_connecter.hpp"
27
+ #include "stdint.hpp"
28
+
29
+ namespace zmq
30
+ {
31
+
32
+ class zmq_connecter_t : public own_t, public io_object_t
33
+ {
34
+ public:
35
+
36
+ // If 'wait' is true connecter first waits for a while, then starts
37
+ // connection process.
38
+ zmq_connecter_t (class io_thread_t *io_thread_,
39
+ class session_t *session_, const options_t &options_,
40
+ const char *protocol_, const char *address_, bool delay_);
41
+ ~zmq_connecter_t ();
42
+
43
+ private:
44
+
45
+ // ID of the timer used to delay the reconnection.
46
+ enum {reconnect_timer_id = 1};
47
+
48
+ // Handlers for incoming commands.
49
+ void process_plug ();
50
+
51
+ // Handlers for I/O events.
52
+ void in_event ();
53
+ void out_event ();
54
+ void timer_event (int id_);
55
+
56
+ // Internal function to start the actual connection establishment.
57
+ void start_connecting ();
58
+
59
+ // Internal function to add a reconnect timer
60
+ void add_reconnect_timer();
61
+
62
+ // Internal function to return a reconnect backoff delay.
63
+ // Will modify the current_reconnect_ivl used for next call
64
+ // Returns the currently used interval
65
+ int get_new_reconnect_ivl ();
66
+
67
+ // Actual connecting socket.
68
+ tcp_connecter_t tcp_connecter;
69
+
70
+ // Handle corresponding to the listening socket.
71
+ handle_t handle;
72
+
73
+ // If true file descriptor is registered with the poller and 'handle'
74
+ // contains valid value.
75
+ bool handle_valid;
76
+
77
+ // If true, connecter is waiting a while before trying to connect.
78
+ bool wait;
79
+
80
+ // Reference to the session we belong to.
81
+ class session_t *session;
82
+
83
+ // Current reconnect ivl, updated for backoff strategy
84
+ int current_reconnect_ivl;
85
+
86
+ zmq_connecter_t (const zmq_connecter_t&);
87
+ const zmq_connecter_t &operator = (const zmq_connecter_t&);
88
+ };
89
+
90
+ }
91
+
92
+ #endif
@@ -0,0 +1,220 @@
1
+ /*
2
+ Copyright (c) 2007-2011 iMatix Corporation
3
+ Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file
4
+
5
+ This file is part of 0MQ.
6
+
7
+ 0MQ is free software; you can redistribute it and/or modify it under
8
+ the terms of the GNU Lesser General Public License as published by
9
+ the Free Software Foundation; either version 3 of the License, or
10
+ (at your option) any later version.
11
+
12
+ 0MQ is distributed in the hope that it will be useful,
13
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
14
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
+ GNU Lesser General Public License for more details.
16
+
17
+ You should have received a copy of the GNU Lesser General Public License
18
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
19
+ */
20
+
21
+ #include "platform.hpp"
22
+ #if defined ZMQ_HAVE_WINDOWS
23
+ #include "windows.hpp"
24
+ #endif
25
+
26
+ #include <string.h>
27
+ #include <new>
28
+
29
+ #include "zmq_engine.hpp"
30
+ #include "zmq_connecter.hpp"
31
+ #include "io_thread.hpp"
32
+ #include "i_inout.hpp"
33
+ #include "config.hpp"
34
+ #include "err.hpp"
35
+
36
+ zmq::zmq_engine_t::zmq_engine_t (fd_t fd_, const options_t &options_) :
37
+ inpos (NULL),
38
+ insize (0),
39
+ decoder (in_batch_size),
40
+ outpos (NULL),
41
+ outsize (0),
42
+ encoder (out_batch_size),
43
+ inout (NULL),
44
+ ephemeral_inout (NULL),
45
+ options (options_),
46
+ plugged (false)
47
+ {
48
+ // Initialise the underlying socket.
49
+ int rc = tcp_socket.open (fd_, options.sndbuf, options.rcvbuf);
50
+ zmq_assert (rc == 0);
51
+ }
52
+
53
+ zmq::zmq_engine_t::~zmq_engine_t ()
54
+ {
55
+ zmq_assert (!plugged);
56
+ }
57
+
58
+ void zmq::zmq_engine_t::plug (io_thread_t *io_thread_, i_inout *inout_)
59
+ {
60
+ zmq_assert (!plugged);
61
+ plugged = true;
62
+ ephemeral_inout = NULL;
63
+
64
+ // Connect to session/init object.
65
+ zmq_assert (!inout);
66
+ zmq_assert (inout_);
67
+ encoder.set_inout (inout_);
68
+ decoder.set_inout (inout_);
69
+ inout = inout_;
70
+
71
+ // Connect to I/O threads poller object.
72
+ io_object_t::plug (io_thread_);
73
+ handle = add_fd (tcp_socket.get_fd ());
74
+ set_pollin (handle);
75
+ set_pollout (handle);
76
+
77
+ // Flush all the data that may have been already received downstream.
78
+ in_event ();
79
+ }
80
+
81
+ void zmq::zmq_engine_t::unplug ()
82
+ {
83
+ zmq_assert (plugged);
84
+ plugged = false;
85
+
86
+ // Cancel all fd subscriptions.
87
+ rm_fd (handle);
88
+
89
+ // Disconnect from I/O threads poller object.
90
+ io_object_t::unplug ();
91
+
92
+ // Disconnect from init/session object.
93
+ encoder.set_inout (NULL);
94
+ decoder.set_inout (NULL);
95
+ ephemeral_inout = inout;
96
+ inout = NULL;
97
+ }
98
+
99
+ void zmq::zmq_engine_t::terminate ()
100
+ {
101
+ unplug ();
102
+ delete this;
103
+ }
104
+
105
+ void zmq::zmq_engine_t::in_event ()
106
+ {
107
+ bool disconnection = false;
108
+
109
+ // If there's no data to process in the buffer...
110
+ if (!insize) {
111
+
112
+ // Retrieve the buffer and read as much data as possible.
113
+ decoder.get_buffer (&inpos, &insize);
114
+ insize = tcp_socket.read (inpos, insize);
115
+
116
+ // Check whether the peer has closed the connection.
117
+ if (insize == (size_t) -1) {
118
+ insize = 0;
119
+ disconnection = true;
120
+ }
121
+ }
122
+
123
+ // Push the data to the decoder.
124
+ size_t processed = decoder.process_buffer (inpos, insize);
125
+
126
+ if (unlikely (processed == (size_t) -1)) {
127
+ disconnection = true;
128
+ }
129
+ else {
130
+
131
+ // Stop polling for input if we got stuck.
132
+ if (processed < insize) {
133
+
134
+ // This may happen if queue limits are in effect or when
135
+ // init object reads all required information from the socket
136
+ // and rejects to read more data.
137
+ if (plugged)
138
+ reset_pollin (handle);
139
+ }
140
+
141
+ // Adjust the buffer.
142
+ inpos += processed;
143
+ insize -= processed;
144
+ }
145
+
146
+ // Flush all messages the decoder may have produced.
147
+ // If IO handler has unplugged engine, flush transient IO handler.
148
+ if (unlikely (!plugged)) {
149
+ zmq_assert (ephemeral_inout);
150
+ ephemeral_inout->flush ();
151
+ } else {
152
+ inout->flush ();
153
+ }
154
+
155
+ if (inout && disconnection)
156
+ error ();
157
+ }
158
+
159
+ void zmq::zmq_engine_t::out_event ()
160
+ {
161
+ // If write buffer is empty, try to read new data from the encoder.
162
+ if (!outsize) {
163
+
164
+ outpos = NULL;
165
+ encoder.get_data (&outpos, &outsize);
166
+
167
+ // If IO handler has unplugged engine, flush transient IO handler.
168
+ if (unlikely (!plugged)) {
169
+ zmq_assert (ephemeral_inout);
170
+ ephemeral_inout->flush ();
171
+ return;
172
+ }
173
+
174
+ // If there is no data to send, stop polling for output.
175
+ if (outsize == 0) {
176
+ reset_pollout (handle);
177
+ return;
178
+ }
179
+ }
180
+
181
+ // If there are any data to write in write buffer, write as much as
182
+ // possible to the socket.
183
+ int nbytes = tcp_socket.write (outpos, outsize);
184
+
185
+ // Handle problems with the connection.
186
+ if (nbytes == -1) {
187
+ error ();
188
+ return;
189
+ }
190
+
191
+ outpos += nbytes;
192
+ outsize -= nbytes;
193
+ }
194
+
195
+ void zmq::zmq_engine_t::activate_out ()
196
+ {
197
+ set_pollout (handle);
198
+
199
+ // Speculative write: The assumption is that at the moment new message
200
+ // was sent by the user the socket is probably available for writing.
201
+ // Thus we try to write the data to socket avoiding polling for POLLOUT.
202
+ // Consequently, the latency should be better in request/reply scenarios.
203
+ out_event ();
204
+ }
205
+
206
+ void zmq::zmq_engine_t::activate_in ()
207
+ {
208
+ set_pollin (handle);
209
+
210
+ // Speculative read.
211
+ in_event ();
212
+ }
213
+
214
+ void zmq::zmq_engine_t::error ()
215
+ {
216
+ zmq_assert (inout);
217
+ inout->detach ();
218
+ unplug ();
219
+ delete this;
220
+ }