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,68 @@
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_IP_HPP_INCLUDED__
22
+ #define __ZMQ_IP_HPP_INCLUDED__
23
+
24
+ #include "platform.hpp"
25
+
26
+ #ifdef ZMQ_HAVE_WINDOWS
27
+ #include "windows.hpp"
28
+ #else
29
+ #include <sys/types.h>
30
+ #include <sys/socket.h>
31
+ #include <arpa/inet.h>
32
+ #include <netinet/in.h>
33
+ #include <netdb.h>
34
+ #endif
35
+
36
+ #if !defined ZMQ_HAVE_WINDOWS && !defined ZMQ_HAVE_OPENVMS
37
+ #include <sys/un.h>
38
+ #endif
39
+
40
+ // Some platforms (notably Darwin/OSX and NetBSD) do not define all AI_
41
+ // flags for getaddrinfo(). This can be worked around safely by defining
42
+ // these to 0.
43
+ #ifndef AI_ADDRCONFIG
44
+ #define AI_ADDRCONFIG 0
45
+ #endif
46
+ #ifndef AI_NUMERICSERV
47
+ #define AI_NUMERICSERV 0
48
+ #endif
49
+
50
+ namespace zmq
51
+ {
52
+
53
+ // Resolves network interface name in <nic-name>:<port> format. Symbol "*"
54
+ // (asterisk) resolves to INADDR_ANY (all network interfaces).
55
+ int resolve_ip_interface (sockaddr_storage *addr_, socklen_t *addr_len_,
56
+ char const *interface_);
57
+
58
+ // This function resolves a string in <hostname>:<port-number> format.
59
+ // Hostname can be either the name of the host or its IP address.
60
+ int resolve_ip_hostname (sockaddr_storage *addr_, socklen_t *addr_len_,
61
+ const char *hostname_);
62
+
63
+ // This function sets up address for UNIX domain transport.
64
+ int resolve_local_path (sockaddr_storage *addr_, socklen_t *addr_len_,
65
+ const char* pathname_);
66
+ }
67
+
68
+ #endif
@@ -0,0 +1,194 @@
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_FREEBSD || defined ZMQ_HAVE_OPENBSD ||\
24
+ defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_NETBSD
25
+
26
+ #include <sys/time.h>
27
+ #include <sys/types.h>
28
+ #include <sys/event.h>
29
+ #include <stdlib.h>
30
+ #include <unistd.h>
31
+ #include <algorithm>
32
+ #include <new>
33
+
34
+ #include "kqueue.hpp"
35
+ #include "err.hpp"
36
+ #include "config.hpp"
37
+ #include "i_poll_events.hpp"
38
+
39
+ // NetBSD defines (struct kevent).udata as intptr_t, everyone else
40
+ // as void *.
41
+ #if defined ZMQ_HAVE_NETBSD
42
+ #define kevent_udata_t intptr_t
43
+ #else
44
+ #define kevent_udata_t void *
45
+ #endif
46
+
47
+ zmq::kqueue_t::kqueue_t () :
48
+ stopping (false)
49
+ {
50
+ // Create event queue
51
+ kqueue_fd = kqueue ();
52
+ errno_assert (kqueue_fd != -1);
53
+ }
54
+
55
+ zmq::kqueue_t::~kqueue_t ()
56
+ {
57
+ worker.stop ();
58
+ close (kqueue_fd);
59
+ }
60
+
61
+ void zmq::kqueue_t::kevent_add (fd_t fd_, short filter_, void *udata_)
62
+ {
63
+ struct kevent ev;
64
+
65
+ EV_SET (&ev, fd_, filter_, EV_ADD, 0, 0, (kevent_udata_t)udata_);
66
+ int rc = kevent (kqueue_fd, &ev, 1, NULL, 0, NULL);
67
+ errno_assert (rc != -1);
68
+ }
69
+
70
+ void zmq::kqueue_t::kevent_delete (fd_t fd_, short filter_)
71
+ {
72
+ struct kevent ev;
73
+
74
+ EV_SET (&ev, fd_, filter_, EV_DELETE, 0, 0, 0);
75
+ int rc = kevent (kqueue_fd, &ev, 1, NULL, 0, NULL);
76
+ errno_assert (rc != -1);
77
+ }
78
+
79
+ zmq::kqueue_t::handle_t zmq::kqueue_t::add_fd (fd_t fd_,
80
+ i_poll_events *reactor_)
81
+ {
82
+ poll_entry_t *pe = new (std::nothrow) poll_entry_t;
83
+ alloc_assert (pe);
84
+
85
+ pe->fd = fd_;
86
+ pe->flag_pollin = 0;
87
+ pe->flag_pollout = 0;
88
+ pe->reactor = reactor_;
89
+
90
+ adjust_load (1);
91
+
92
+ return pe;
93
+ }
94
+
95
+ void zmq::kqueue_t::rm_fd (handle_t handle_)
96
+ {
97
+ poll_entry_t *pe = (poll_entry_t*) handle_;
98
+ if (pe->flag_pollin)
99
+ kevent_delete (pe->fd, EVFILT_READ);
100
+ if (pe->flag_pollout)
101
+ kevent_delete (pe->fd, EVFILT_WRITE);
102
+ pe->fd = retired_fd;
103
+ retired.push_back (pe);
104
+
105
+ adjust_load (-1);
106
+ }
107
+
108
+ void zmq::kqueue_t::set_pollin (handle_t handle_)
109
+ {
110
+ poll_entry_t *pe = (poll_entry_t*) handle_;
111
+ pe->flag_pollin = true;
112
+ kevent_add (pe->fd, EVFILT_READ, pe);
113
+ }
114
+
115
+ void zmq::kqueue_t::reset_pollin (handle_t handle_)
116
+ {
117
+ poll_entry_t *pe = (poll_entry_t*) handle_;
118
+ pe->flag_pollin = false;
119
+ kevent_delete (pe->fd, EVFILT_READ);
120
+ }
121
+
122
+ void zmq::kqueue_t::set_pollout (handle_t handle_)
123
+ {
124
+ poll_entry_t *pe = (poll_entry_t*) handle_;
125
+ pe->flag_pollout = true;
126
+ kevent_add (pe->fd, EVFILT_WRITE, pe);
127
+ }
128
+
129
+ void zmq::kqueue_t::reset_pollout (handle_t handle_)
130
+ {
131
+ poll_entry_t *pe = (poll_entry_t*) handle_;
132
+ pe->flag_pollout = false;
133
+ kevent_delete (pe->fd, EVFILT_WRITE);
134
+ }
135
+
136
+ void zmq::kqueue_t::start ()
137
+ {
138
+ worker.start (worker_routine, this);
139
+ }
140
+
141
+ void zmq::kqueue_t::stop ()
142
+ {
143
+ stopping = true;
144
+ }
145
+
146
+ void zmq::kqueue_t::loop ()
147
+ {
148
+ while (!stopping) {
149
+
150
+ // Execute any due timers.
151
+ int timeout = (int) execute_timers ();
152
+
153
+ // Wait for events.
154
+ struct kevent ev_buf [max_io_events];
155
+ timespec ts = {timeout / 1000, (timeout % 1000) * 1000000};
156
+ int n = kevent (kqueue_fd, NULL, 0, &ev_buf [0], max_io_events,
157
+ timeout ? &ts: NULL);
158
+ if (n == -1 && errno == EINTR)
159
+ continue;
160
+ errno_assert (n != -1);
161
+
162
+ for (int i = 0; i < n; i ++) {
163
+ poll_entry_t *pe = (poll_entry_t*) ev_buf [i].udata;
164
+
165
+ if (pe->fd == retired_fd)
166
+ continue;
167
+ if (ev_buf [i].flags & EV_EOF)
168
+ pe->reactor->in_event ();
169
+ if (pe->fd == retired_fd)
170
+ continue;
171
+ if (ev_buf [i].filter == EVFILT_WRITE)
172
+ pe->reactor->out_event ();
173
+ if (pe->fd == retired_fd)
174
+ continue;
175
+ if (ev_buf [i].filter == EVFILT_READ)
176
+ pe->reactor->in_event ();
177
+ }
178
+
179
+ // Destroy retired event sources.
180
+ for (retired_t::iterator it = retired.begin (); it != retired.end ();
181
+ ++it)
182
+ delete *it;
183
+ retired.clear ();
184
+ }
185
+ }
186
+
187
+ void zmq::kqueue_t::worker_routine (void *arg_)
188
+ {
189
+ ((kqueue_t*) arg_)->loop ();
190
+ }
191
+
192
+ // Don't pollute namespace with defines local to this file
193
+ #undef kevent_udata_t
194
+ #endif
@@ -0,0 +1,103 @@
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_KQUEUE_HPP_INCLUDED__
22
+ #define __ZMQ_KQUEUE_HPP_INCLUDED__
23
+
24
+ #include "platform.hpp"
25
+
26
+ #if defined ZMQ_HAVE_FREEBSD || defined ZMQ_HAVE_OPENBSD ||\
27
+ defined ZMQ_HAVE_OSX || defined ZMQ_HAVE_NETBSD
28
+
29
+ #include <vector>
30
+
31
+ #include "fd.hpp"
32
+ #include "thread.hpp"
33
+ #include "poller_base.hpp"
34
+
35
+ namespace zmq
36
+ {
37
+
38
+ // Implements socket polling mechanism using the BSD-specific
39
+ // kqueue interface.
40
+
41
+ class kqueue_t : public poller_base_t
42
+ {
43
+ public:
44
+
45
+ typedef void* handle_t;
46
+
47
+ kqueue_t ();
48
+ ~kqueue_t ();
49
+
50
+ // "poller" concept.
51
+ handle_t add_fd (fd_t fd_, struct i_poll_events *events_);
52
+ void rm_fd (handle_t handle_);
53
+ void set_pollin (handle_t handle_);
54
+ void reset_pollin (handle_t handle_);
55
+ void set_pollout (handle_t handle_);
56
+ void reset_pollout (handle_t handle_);
57
+ void start ();
58
+ void stop ();
59
+
60
+ private:
61
+
62
+ // Main worker thread routine.
63
+ static void worker_routine (void *arg_);
64
+
65
+ // Main event loop.
66
+ void loop ();
67
+
68
+ // File descriptor referring to the kernel event queue.
69
+ fd_t kqueue_fd;
70
+
71
+ // Adds the event to the kqueue.
72
+ void kevent_add (fd_t fd_, short filter_, void *udata_);
73
+
74
+ // Deletes the event from the kqueue.
75
+ void kevent_delete (fd_t fd_, short filter_);
76
+
77
+ struct poll_entry_t
78
+ {
79
+ fd_t fd;
80
+ bool flag_pollin;
81
+ bool flag_pollout;
82
+ i_poll_events *reactor;
83
+ };
84
+
85
+ // List of retired event sources.
86
+ typedef std::vector <poll_entry_t*> retired_t;
87
+ retired_t retired;
88
+
89
+ // If true, thread is in the process of shutting down.
90
+ bool stopping;
91
+
92
+ // Handle of the physical thread doing the I/O work.
93
+ thread_t worker;
94
+
95
+ kqueue_t (const kqueue_t&);
96
+ const kqueue_t &operator = (const kqueue_t&);
97
+ };
98
+
99
+ }
100
+
101
+ #endif
102
+
103
+ #endif
@@ -0,0 +1,174 @@
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 "../include/zmq.h"
22
+
23
+ #include "lb.hpp"
24
+ #include "pipe.hpp"
25
+ #include "err.hpp"
26
+ #include "own.hpp"
27
+
28
+ zmq::lb_t::lb_t (own_t *sink_) :
29
+ active (0),
30
+ current (0),
31
+ more (false),
32
+ dropping (false),
33
+ sink (sink_),
34
+ terminating (false)
35
+ {
36
+ }
37
+
38
+ zmq::lb_t::~lb_t ()
39
+ {
40
+ zmq_assert (pipes.empty ());
41
+ }
42
+
43
+ void zmq::lb_t::attach (writer_t *pipe_)
44
+ {
45
+ pipe_->set_event_sink (this);
46
+
47
+ pipes.push_back (pipe_);
48
+ pipes.swap (active, pipes.size () - 1);
49
+ active++;
50
+
51
+ if (terminating) {
52
+ sink->register_term_acks (1);
53
+ pipe_->terminate ();
54
+ }
55
+ }
56
+
57
+ void zmq::lb_t::terminate ()
58
+ {
59
+ zmq_assert (!terminating);
60
+ terminating = true;
61
+
62
+ sink->register_term_acks (pipes.size ());
63
+ for (pipes_t::size_type i = 0; i != pipes.size (); i++)
64
+ pipes [i]->terminate ();
65
+ }
66
+
67
+ void zmq::lb_t::terminated (writer_t *pipe_)
68
+ {
69
+ pipes_t::size_type index = pipes.index (pipe_);
70
+
71
+ // If we are in the middle of multipart message and current pipe
72
+ // have disconnected, we have to drop the remainder of the message.
73
+ if (index == current && more)
74
+ dropping = true;
75
+
76
+ // Remove the pipe from the list; adjust number of active pipes
77
+ // accordingly.
78
+ if (index < active) {
79
+ active--;
80
+ if (current == active)
81
+ current = 0;
82
+ }
83
+ pipes.erase (pipe_);
84
+
85
+ if (terminating)
86
+ sink->unregister_term_ack ();
87
+ }
88
+
89
+ void zmq::lb_t::activated (writer_t *pipe_)
90
+ {
91
+ // Move the pipe to the list of active pipes.
92
+ pipes.swap (pipes.index (pipe_), active);
93
+ active++;
94
+ }
95
+
96
+ int zmq::lb_t::send (zmq_msg_t *msg_, int flags_)
97
+ {
98
+ // Drop the message if required. If we are at the end of the message
99
+ // switch back to non-dropping mode.
100
+ if (dropping) {
101
+
102
+ more = msg_->flags & ZMQ_MSG_MORE;
103
+ if (!more)
104
+ dropping = false;
105
+
106
+ int rc = zmq_msg_close (msg_);
107
+ errno_assert (rc == 0);
108
+ rc = zmq_msg_init (msg_);
109
+ zmq_assert (rc == 0);
110
+ return 0;
111
+ }
112
+
113
+ while (active > 0) {
114
+ if (pipes [current]->write (msg_)) {
115
+ more = msg_->flags & ZMQ_MSG_MORE;
116
+ break;
117
+ }
118
+
119
+ zmq_assert (!more);
120
+ active--;
121
+ if (current < active)
122
+ pipes.swap (current, active);
123
+ else
124
+ current = 0;
125
+ }
126
+
127
+ // If there are no pipes we cannot send the message.
128
+ if (active == 0) {
129
+ errno = EAGAIN;
130
+ return -1;
131
+ }
132
+
133
+ // If it's final part of the message we can fluch it downstream and
134
+ // continue round-robinning (load balance).
135
+ if (!more) {
136
+ pipes [current]->flush ();
137
+ current = (current + 1) % active;
138
+ }
139
+
140
+ // Detach the message from the data buffer.
141
+ int rc = zmq_msg_init (msg_);
142
+ zmq_assert (rc == 0);
143
+
144
+ return 0;
145
+ }
146
+
147
+ bool zmq::lb_t::has_out ()
148
+ {
149
+ // If one part of the message was already written we can definitely
150
+ // write the rest of the message.
151
+ if (more)
152
+ return true;
153
+
154
+ while (active > 0) {
155
+
156
+ // Check whether zero-sized message can be written to the pipe.
157
+ zmq_msg_t msg;
158
+ zmq_msg_init (&msg);
159
+ if (pipes [current]->check_write (&msg)) {
160
+ zmq_msg_close (&msg);
161
+ return true;
162
+ }
163
+ zmq_msg_close (&msg);
164
+
165
+ // Deactivate the pipe.
166
+ active--;
167
+ pipes.swap (current, active);
168
+ if (current == active)
169
+ current = 0;
170
+ }
171
+
172
+ return false;
173
+ }
174
+