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,76 @@
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_PAIR_HPP_INCLUDED__
22
+ #define __ZMQ_PAIR_HPP_INCLUDED__
23
+
24
+ #include "socket_base.hpp"
25
+ #include "pipe.hpp"
26
+
27
+ namespace zmq
28
+ {
29
+
30
+ class pair_t :
31
+ public socket_base_t,
32
+ public i_reader_events,
33
+ public i_writer_events
34
+ {
35
+ public:
36
+
37
+ pair_t (class ctx_t *parent_, uint32_t tid_);
38
+ ~pair_t ();
39
+
40
+ // Overloads of functions from socket_base_t.
41
+ void xattach_pipes (class reader_t *inpipe_, class writer_t *outpipe_,
42
+ const blob_t &peer_identity_);
43
+ int xsend (zmq_msg_t *msg_, int flags_);
44
+ int xrecv (zmq_msg_t *msg_, int flags_);
45
+ bool xhas_in ();
46
+ bool xhas_out ();
47
+
48
+ // i_reader_events interface implementation.
49
+ void activated (class reader_t *pipe_);
50
+ void terminated (class reader_t *pipe_);
51
+ void delimited (class reader_t *pipe_);
52
+
53
+ // i_writer_events interface implementation.
54
+ void activated (class writer_t *pipe_);
55
+ void terminated (class writer_t *pipe_);
56
+
57
+ private:
58
+
59
+ // Hook into termination process.
60
+ void process_term (int linger_);
61
+
62
+ class reader_t *inpipe;
63
+ class writer_t *outpipe;
64
+
65
+ bool inpipe_alive;
66
+ bool outpipe_alive;
67
+
68
+ bool terminating;
69
+
70
+ pair_t (const pair_t&);
71
+ const pair_t &operator = (const pair_t&);
72
+ };
73
+
74
+ }
75
+
76
+ #endif
@@ -0,0 +1,259 @@
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
+
23
+ #if defined ZMQ_HAVE_OPENPGM
24
+
25
+ #include <new>
26
+
27
+ #ifdef ZMQ_HAVE_WINDOWS
28
+ #include "windows.hpp"
29
+ #endif
30
+
31
+ #include "pgm_receiver.hpp"
32
+ #include "err.hpp"
33
+ #include "stdint.hpp"
34
+ #include "wire.hpp"
35
+ #include "i_inout.hpp"
36
+
37
+ zmq::pgm_receiver_t::pgm_receiver_t (class io_thread_t *parent_,
38
+ const options_t &options_) :
39
+ io_object_t (parent_),
40
+ has_rx_timer (false),
41
+ pgm_socket (true, options_),
42
+ options (options_),
43
+ inout (NULL),
44
+ mru_decoder (NULL),
45
+ pending_bytes (0)
46
+ {
47
+ }
48
+
49
+ zmq::pgm_receiver_t::~pgm_receiver_t ()
50
+ {
51
+ // Destructor should not be called before unplug.
52
+ zmq_assert (peers.empty ());
53
+ }
54
+
55
+ int zmq::pgm_receiver_t::init (bool udp_encapsulation_, const char *network_)
56
+ {
57
+ return pgm_socket.init (udp_encapsulation_, network_);
58
+ }
59
+
60
+ void zmq::pgm_receiver_t::plug (io_thread_t *io_thread_, i_inout *inout_)
61
+ {
62
+ // Retrieve PGM fds and start polling.
63
+ int socket_fd;
64
+ int waiting_pipe_fd;
65
+ pgm_socket.get_receiver_fds (&socket_fd, &waiting_pipe_fd);
66
+ socket_handle = add_fd (socket_fd);
67
+ pipe_handle = add_fd (waiting_pipe_fd);
68
+ set_pollin (pipe_handle);
69
+ set_pollin (socket_handle);
70
+
71
+ inout = inout_;
72
+ }
73
+
74
+ void zmq::pgm_receiver_t::unplug ()
75
+ {
76
+ // Delete decoders.
77
+ for (peers_t::iterator it = peers.begin (); it != peers.end (); ++it) {
78
+ if (it->second.decoder != NULL)
79
+ delete it->second.decoder;
80
+ }
81
+ peers.clear ();
82
+
83
+ mru_decoder = NULL;
84
+ pending_bytes = 0;
85
+
86
+ if (has_rx_timer) {
87
+ cancel_timer (rx_timer_id);
88
+ has_rx_timer = false;
89
+ }
90
+
91
+ rm_fd (socket_handle);
92
+ rm_fd (pipe_handle);
93
+
94
+ inout = NULL;
95
+ }
96
+
97
+ void zmq::pgm_receiver_t::terminate ()
98
+ {
99
+ unplug ();
100
+ delete this;
101
+ }
102
+
103
+ void zmq::pgm_receiver_t::activate_out ()
104
+ {
105
+ zmq_assert (false);
106
+ }
107
+
108
+ void zmq::pgm_receiver_t::activate_in ()
109
+ {
110
+ // It is possible that the most recently used decoder
111
+ // processed the whole buffer but failed to write
112
+ // the last message into the pipe.
113
+ if (pending_bytes == 0) {
114
+ if (mru_decoder != NULL)
115
+ mru_decoder->process_buffer (NULL, 0);
116
+ return;
117
+ }
118
+
119
+ zmq_assert (mru_decoder != NULL);
120
+ zmq_assert (pending_ptr != NULL);
121
+
122
+ // Ask the decoder to process remaining data.
123
+ size_t n = mru_decoder->process_buffer (pending_ptr, pending_bytes);
124
+ pending_bytes -= n;
125
+
126
+ if (pending_bytes > 0)
127
+ return;
128
+
129
+ // Resume polling.
130
+ set_pollin (pipe_handle);
131
+ set_pollin (socket_handle);
132
+
133
+ in_event ();
134
+ }
135
+
136
+ void zmq::pgm_receiver_t::in_event ()
137
+ {
138
+ // Read data from the underlying pgm_socket.
139
+ unsigned char *data = NULL;
140
+ const pgm_tsi_t *tsi = NULL;
141
+
142
+ zmq_assert (pending_bytes == 0);
143
+
144
+ if (has_rx_timer) {
145
+ cancel_timer (rx_timer_id);
146
+ has_rx_timer = false;
147
+ }
148
+
149
+ // TODO: This loop can effectively block other engines in the same I/O
150
+ // thread in the case of high load.
151
+ while (true) {
152
+
153
+ // Get new batch of data.
154
+ // Note the workaround made not to break strict-aliasing rules.
155
+ void *tmp = NULL;
156
+ ssize_t received = pgm_socket.receive (&tmp, &tsi);
157
+ data = (unsigned char*) tmp;
158
+
159
+ // No data to process. This may happen if the packet received is
160
+ // neither ODATA nor ODATA.
161
+ if (received == 0) {
162
+ if (errno == ENOMEM || errno == EBUSY) {
163
+ const long timeout = pgm_socket.get_rx_timeout ();
164
+ add_timer (timeout, rx_timer_id);
165
+ has_rx_timer = true;
166
+ }
167
+ break;
168
+ }
169
+
170
+ // Find the peer based on its TSI.
171
+ peers_t::iterator it = peers.find (*tsi);
172
+
173
+ // Data loss. Delete decoder and mark the peer as disjoint.
174
+ if (received == -1) {
175
+ if (it != peers.end ()) {
176
+ it->second.joined = false;
177
+ if (it->second.decoder == mru_decoder)
178
+ mru_decoder = NULL;
179
+ if (it->second.decoder != NULL) {
180
+ delete it->second.decoder;
181
+ it->second.decoder = NULL;
182
+ }
183
+ }
184
+ break;
185
+ }
186
+
187
+ // New peer. Add it to the list of know but unjoint peers.
188
+ if (it == peers.end ()) {
189
+ peer_info_t peer_info = {false, NULL};
190
+ it = peers.insert (peers_t::value_type (*tsi, peer_info)).first;
191
+ }
192
+
193
+ // Read the offset of the fist message in the current packet.
194
+ zmq_assert ((size_t) received >= sizeof (uint16_t));
195
+ uint16_t offset = get_uint16 (data);
196
+ data += sizeof (uint16_t);
197
+ received -= sizeof (uint16_t);
198
+
199
+ // Join the stream if needed.
200
+ if (!it->second.joined) {
201
+
202
+ // There is no beginning of the message in current packet.
203
+ // Ignore the data.
204
+ if (offset == 0xffff)
205
+ continue;
206
+
207
+ zmq_assert (offset <= received);
208
+ zmq_assert (it->second.decoder == NULL);
209
+
210
+ // We have to move data to the begining of the first message.
211
+ data += offset;
212
+ received -= offset;
213
+
214
+ // Mark the stream as joined.
215
+ it->second.joined = true;
216
+
217
+ // Create and connect decoder for the peer.
218
+ it->second.decoder = new (std::nothrow) decoder_t (0);
219
+ alloc_assert (it->second.decoder);
220
+ it->second.decoder->set_inout (inout);
221
+ }
222
+
223
+ mru_decoder = it->second.decoder;
224
+
225
+ // Push all the data to the decoder.
226
+ ssize_t processed = it->second.decoder->process_buffer (data, received);
227
+ if (processed < received) {
228
+ // Save some state so we can resume the decoding process later.
229
+ pending_bytes = received - processed;
230
+ pending_ptr = data + processed;
231
+ // Stop polling.
232
+ reset_pollin (pipe_handle);
233
+ reset_pollin (socket_handle);
234
+
235
+ // Reset outstanding timer.
236
+ if (has_rx_timer) {
237
+ cancel_timer (rx_timer_id);
238
+ has_rx_timer = false;
239
+ }
240
+
241
+ break;
242
+ }
243
+ }
244
+
245
+ // Flush any messages decoder may have produced.
246
+ inout->flush ();
247
+ }
248
+
249
+ void zmq::pgm_receiver_t::timer_event (int token)
250
+ {
251
+ zmq_assert (token == rx_timer_id);
252
+
253
+ // Timer cancels on return by poller_base.
254
+ has_rx_timer = false;
255
+ in_event ();
256
+ }
257
+
258
+ #endif
259
+
@@ -0,0 +1,129 @@
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_PGM_RECEIVER_HPP_INCLUDED__
22
+ #define __ZMQ_PGM_RECEIVER_HPP_INCLUDED__
23
+
24
+ #include "platform.hpp"
25
+
26
+ #if defined ZMQ_HAVE_OPENPGM
27
+
28
+ #ifdef ZMQ_HAVE_WINDOWS
29
+ #include "windows.hpp"
30
+ #endif
31
+
32
+ #include <map>
33
+ #include <algorithm>
34
+
35
+ #include "io_object.hpp"
36
+ #include "i_engine.hpp"
37
+ #include "options.hpp"
38
+ #include "decoder.hpp"
39
+ #include "pgm_socket.hpp"
40
+
41
+ namespace zmq
42
+ {
43
+
44
+ class pgm_receiver_t : public io_object_t, public i_engine
45
+ {
46
+
47
+ public:
48
+
49
+ pgm_receiver_t (class io_thread_t *parent_, const options_t &options_);
50
+ ~pgm_receiver_t ();
51
+
52
+ int init (bool udp_encapsulation_, const char *network_);
53
+
54
+ // i_engine interface implementation.
55
+ void plug (class io_thread_t *io_thread_, struct i_inout *inout_);
56
+ void unplug ();
57
+ void terminate ();
58
+ void activate_in ();
59
+ void activate_out ();
60
+
61
+ // i_poll_events interface implementation.
62
+ void in_event ();
63
+ void timer_event (int token);
64
+
65
+ private:
66
+
67
+ // RX timeout timer ID.
68
+ enum {rx_timer_id = 0xa1};
69
+
70
+ // RX timer is running.
71
+ bool has_rx_timer;
72
+
73
+ // If joined is true we are already getting messages from the peer.
74
+ // It it's false, we are getting data but still we haven't seen
75
+ // beginning of a message.
76
+ struct peer_info_t
77
+ {
78
+ bool joined;
79
+ decoder_t *decoder;
80
+ };
81
+
82
+ struct tsi_comp
83
+ {
84
+ bool operator () (const pgm_tsi_t &ltsi,
85
+ const pgm_tsi_t &rtsi) const
86
+ {
87
+ uint32_t ll[2], rl[2];
88
+ memcpy (ll, &ltsi, sizeof (ll));
89
+ memcpy (rl, &rtsi, sizeof (rl));
90
+ return (ll[0] < rl[0]) || (ll[0] == rl[0] && ll[1] < rl[1]);
91
+ }
92
+ };
93
+
94
+ typedef std::map <pgm_tsi_t, peer_info_t, tsi_comp> peers_t;
95
+ peers_t peers;
96
+
97
+ // PGM socket.
98
+ pgm_socket_t pgm_socket;
99
+
100
+ // Socket options.
101
+ options_t options;
102
+
103
+ // Parent session.
104
+ i_inout *inout;
105
+
106
+ // Most recently used decoder.
107
+ decoder_t *mru_decoder;
108
+
109
+ // Number of bytes not consumed by the decoder due to pipe overflow.
110
+ size_t pending_bytes;
111
+
112
+ // Pointer to data still waiting to be processed by the decoder.
113
+ unsigned char *pending_ptr;
114
+
115
+ // Poll handle associated with PGM socket.
116
+ handle_t socket_handle;
117
+
118
+ // Poll handle associated with engine PGM waiting pipe.
119
+ handle_t pipe_handle;
120
+
121
+ pgm_receiver_t (const pgm_receiver_t&);
122
+ const pgm_receiver_t &operator = (const pgm_receiver_t&);
123
+ };
124
+
125
+ }
126
+
127
+ #endif
128
+
129
+ #endif