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,232 @@
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
+ #include "../include/zmq_utils.h"
23
+
24
+ #include <stdio.h>
25
+ #include <stdlib.h>
26
+ #include <string.h>
27
+
28
+ #include "../src/platform.hpp"
29
+
30
+ #if defined ZMQ_HAVE_WINDOWS
31
+ #include <windows.h>
32
+ #include <process.h>
33
+ #else
34
+ #include <pthread.h>
35
+ #endif
36
+
37
+ static size_t message_size;
38
+ static int roundtrip_count;
39
+
40
+ #if defined ZMQ_HAVE_WINDOWS
41
+ static unsigned int __stdcall worker (void *ctx_)
42
+ #else
43
+ static void *worker (void *ctx_)
44
+ #endif
45
+ {
46
+ void *s;
47
+ int rc;
48
+ int i;
49
+ zmq_msg_t msg;
50
+
51
+ s = zmq_socket (ctx_, ZMQ_REP);
52
+ if (!s) {
53
+ printf ("error in zmq_socket: %s\n", zmq_strerror (errno));
54
+ exit (1);
55
+ }
56
+
57
+ rc = zmq_connect (s, "inproc://lat_test");
58
+ if (rc != 0) {
59
+ printf ("error in zmq_connect: %s\n", zmq_strerror (errno));
60
+ exit (1);
61
+ }
62
+
63
+ rc = zmq_msg_init (&msg);
64
+ if (rc != 0) {
65
+ printf ("error in zmq_msg_init: %s\n", zmq_strerror (errno));
66
+ exit (1);
67
+ }
68
+
69
+ for (i = 0; i != roundtrip_count; i++) {
70
+ rc = zmq_recv (s, &msg, 0);
71
+ if (rc < 0) {
72
+ printf ("error in zmq_recv: %s\n", zmq_strerror (errno));
73
+ exit (1);
74
+ }
75
+ rc = zmq_send (s, &msg, 0);
76
+ if (rc < 0) {
77
+ printf ("error in zmq_send: %s\n", zmq_strerror (errno));
78
+ exit (1);
79
+ }
80
+ }
81
+
82
+ rc = zmq_msg_close (&msg);
83
+ if (rc != 0) {
84
+ printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
85
+ exit (1);
86
+ }
87
+
88
+ rc = zmq_close (s);
89
+ if (rc != 0) {
90
+ printf ("error in zmq_close: %s\n", zmq_strerror (errno));
91
+ exit (1);
92
+ }
93
+
94
+ #if defined ZMQ_HAVE_WINDOWS
95
+ return 0;
96
+ #else
97
+ return NULL;
98
+ #endif
99
+ }
100
+
101
+ int main (int argc, char *argv [])
102
+ {
103
+ #if defined ZMQ_HAVE_WINDOWS
104
+ HANDLE local_thread;
105
+ #else
106
+ pthread_t local_thread;
107
+ #endif
108
+ void *ctx;
109
+ void *s;
110
+ int rc;
111
+ int i;
112
+ zmq_msg_t msg;
113
+ void *watch;
114
+ unsigned long elapsed;
115
+ double latency;
116
+
117
+ if (argc != 3) {
118
+ printf ("usage: inproc_lat <message-size> <roundtrip-count>\n");
119
+ return 1;
120
+ }
121
+
122
+ message_size = atoi (argv [1]);
123
+ roundtrip_count = atoi (argv [2]);
124
+
125
+ ctx = zmq_init (1);
126
+ if (!ctx) {
127
+ printf ("error in zmq_init: %s\n", zmq_strerror (errno));
128
+ return -1;
129
+ }
130
+
131
+ s = zmq_socket (ctx, ZMQ_REQ);
132
+ if (!s) {
133
+ printf ("error in zmq_socket: %s\n", zmq_strerror (errno));
134
+ return -1;
135
+ }
136
+
137
+ rc = zmq_bind (s, "inproc://lat_test");
138
+ if (rc != 0) {
139
+ printf ("error in zmq_bind: %s\n", zmq_strerror (errno));
140
+ return -1;
141
+ }
142
+
143
+ #if defined ZMQ_HAVE_WINDOWS
144
+ local_thread = (HANDLE) _beginthreadex (NULL, 0,
145
+ worker, ctx, 0 , NULL);
146
+ if (local_thread == 0) {
147
+ printf ("error in _beginthreadex\n");
148
+ return -1;
149
+ }
150
+ #else
151
+ rc = pthread_create (&local_thread, NULL, worker, ctx);
152
+ if (rc != 0) {
153
+ printf ("error in pthread_create: %s\n", zmq_strerror (rc));
154
+ return -1;
155
+ }
156
+ #endif
157
+
158
+ rc = zmq_msg_init_size (&msg, message_size);
159
+ if (rc != 0) {
160
+ printf ("error in zmq_msg_init_size: %s\n", zmq_strerror (errno));
161
+ return -1;
162
+ }
163
+ memset (zmq_msg_data (&msg), 0, message_size);
164
+
165
+ printf ("message size: %d [B]\n", (int) message_size);
166
+ printf ("roundtrip count: %d\n", (int) roundtrip_count);
167
+
168
+ watch = zmq_stopwatch_start ();
169
+
170
+ for (i = 0; i != roundtrip_count; i++) {
171
+ rc = zmq_send (s, &msg, 0);
172
+ if (rc < 0) {
173
+ printf ("error in zmq_send: %s\n", zmq_strerror (errno));
174
+ return -1;
175
+ }
176
+ rc = zmq_recv (s, &msg, 0);
177
+ if (rc < 0) {
178
+ printf ("error in zmq_recv: %s\n", zmq_strerror (errno));
179
+ return -1;
180
+ }
181
+ if (zmq_msg_size (&msg) != message_size) {
182
+ printf ("message of incorrect size received\n");
183
+ return -1;
184
+ }
185
+ }
186
+
187
+ elapsed = zmq_stopwatch_stop (watch);
188
+
189
+ rc = zmq_msg_close (&msg);
190
+ if (rc != 0) {
191
+ printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
192
+ return -1;
193
+ }
194
+
195
+ latency = (double) elapsed / (roundtrip_count * 2);
196
+
197
+ #if defined ZMQ_HAVE_WINDOWS
198
+ DWORD rc2 = WaitForSingleObject (local_thread, INFINITE);
199
+ if (rc2 == WAIT_FAILED) {
200
+ printf ("error in WaitForSingleObject\n");
201
+ return -1;
202
+ }
203
+ BOOL rc3 = CloseHandle (local_thread);
204
+ if (rc3 == 0) {
205
+ printf ("error in CloseHandle\n");
206
+ return -1;
207
+ }
208
+ #else
209
+ rc = pthread_join (local_thread, NULL);
210
+ if (rc != 0) {
211
+ printf ("error in pthread_join: %s\n", zmq_strerror (rc));
212
+ return -1;
213
+ }
214
+ #endif
215
+
216
+ printf ("average latency: %.3f [us]\n", (double) latency);
217
+
218
+ rc = zmq_close (s);
219
+ if (rc != 0) {
220
+ printf ("error in zmq_close: %s\n", zmq_strerror (errno));
221
+ return -1;
222
+ }
223
+
224
+ rc = zmq_term (ctx);
225
+ if (rc != 0) {
226
+ printf ("error in zmq_term: %s\n", zmq_strerror (errno));
227
+ return -1;
228
+ }
229
+
230
+ return 0;
231
+ }
232
+
@@ -0,0 +1,246 @@
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
+ #include "../include/zmq_utils.h"
23
+
24
+ #include <stdio.h>
25
+ #include <stdlib.h>
26
+ #include <string.h>
27
+
28
+ #include "../src/platform.hpp"
29
+
30
+ #if defined ZMQ_HAVE_WINDOWS
31
+ #include <windows.h>
32
+ #include <process.h>
33
+ #else
34
+ #include <pthread.h>
35
+ #endif
36
+
37
+ static int message_count;
38
+ static size_t message_size;
39
+
40
+ #if defined ZMQ_HAVE_WINDOWS
41
+ static unsigned int __stdcall worker (void *ctx_)
42
+ #else
43
+ static void *worker (void *ctx_)
44
+ #endif
45
+ {
46
+ void *s;
47
+ int rc;
48
+ int i;
49
+ zmq_msg_t msg;
50
+
51
+ s = zmq_socket (ctx_, ZMQ_PUB);
52
+ if (!s) {
53
+ printf ("error in zmq_socket: %s\n", zmq_strerror (errno));
54
+ exit (1);
55
+ }
56
+
57
+ rc = zmq_connect (s, "inproc://thr_test");
58
+ if (rc != 0) {
59
+ printf ("error in zmq_connect: %s\n", zmq_strerror (errno));
60
+ exit (1);
61
+ }
62
+
63
+ for (i = 0; i != message_count; i++) {
64
+
65
+ rc = zmq_msg_init_size (&msg, message_size);
66
+ if (rc != 0) {
67
+ printf ("error in zmq_msg_init_size: %s\n", zmq_strerror (errno));
68
+ exit (1);
69
+ }
70
+ #if defined ZMQ_MAKE_VALGRIND_HAPPY
71
+ memset (zmq_msg_data (&msg), 0, message_size);
72
+ #endif
73
+
74
+ rc = zmq_send (s, &msg, 0);
75
+ if (rc < 0) {
76
+ printf ("error in zmq_send: %s\n", zmq_strerror (errno));
77
+ exit (1);
78
+ }
79
+ rc = zmq_msg_close (&msg);
80
+ if (rc != 0) {
81
+ printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
82
+ exit (1);
83
+ }
84
+ }
85
+
86
+ rc = zmq_close (s);
87
+ if (rc != 0) {
88
+ printf ("error in zmq_close: %s\n", zmq_strerror (errno));
89
+ exit (1);
90
+ }
91
+
92
+ #if defined ZMQ_HAVE_WINDOWS
93
+ return 0;
94
+ #else
95
+ return NULL;
96
+ #endif
97
+ }
98
+
99
+ int main (int argc, char *argv [])
100
+ {
101
+ #if defined ZMQ_HAVE_WINDOWS
102
+ HANDLE local_thread;
103
+ #else
104
+ pthread_t local_thread;
105
+ #endif
106
+ void *ctx;
107
+ void *s;
108
+ int rc;
109
+ int i;
110
+ zmq_msg_t msg;
111
+ void *watch;
112
+ unsigned long elapsed;
113
+ unsigned long throughput;
114
+ double megabits;
115
+
116
+ if (argc != 3) {
117
+ printf ("usage: thread_thr <message-size> <message-count>\n");
118
+ return 1;
119
+ }
120
+
121
+ message_size = atoi (argv [1]);
122
+ message_count = atoi (argv [2]);
123
+
124
+ ctx = zmq_init (1);
125
+ if (!ctx) {
126
+ printf ("error in zmq_init: %s\n", zmq_strerror (errno));
127
+ return -1;
128
+ }
129
+
130
+ s = zmq_socket (ctx, ZMQ_SUB);
131
+ if (!s) {
132
+ printf ("error in zmq_socket: %s\n", zmq_strerror (errno));
133
+ return -1;
134
+ }
135
+
136
+ rc = zmq_setsockopt (s, ZMQ_SUBSCRIBE , "", 0);
137
+ if (rc != 0) {
138
+ printf ("error in zmq_setsockopt: %s\n", zmq_strerror (errno));
139
+ return -1;
140
+ }
141
+
142
+ rc = zmq_bind (s, "inproc://thr_test");
143
+ if (rc != 0) {
144
+ printf ("error in zmq_bind: %s\n", zmq_strerror (errno));
145
+ return -1;
146
+ }
147
+
148
+ #if defined ZMQ_HAVE_WINDOWS
149
+ local_thread = (HANDLE) _beginthreadex (NULL, 0,
150
+ worker, ctx, 0 , NULL);
151
+ if (local_thread == 0) {
152
+ printf ("error in _beginthreadex\n");
153
+ return -1;
154
+ }
155
+ #else
156
+ rc = pthread_create (&local_thread, NULL, worker, ctx);
157
+ if (rc != 0) {
158
+ printf ("error in pthread_create: %s\n", zmq_strerror (rc));
159
+ return -1;
160
+ }
161
+ #endif
162
+
163
+ rc = zmq_msg_init (&msg);
164
+ if (rc != 0) {
165
+ printf ("error in zmq_msg_init: %s\n", zmq_strerror (errno));
166
+ return -1;
167
+ }
168
+
169
+ printf ("message size: %d [B]\n", (int) message_size);
170
+ printf ("message count: %d\n", (int) message_count);
171
+
172
+ rc = zmq_recv (s, &msg, 0);
173
+ if (rc < 0) {
174
+ printf ("error in zmq_recv: %s\n", zmq_strerror (errno));
175
+ return -1;
176
+ }
177
+ if (zmq_msg_size (&msg) != message_size) {
178
+ printf ("message of incorrect size received\n");
179
+ return -1;
180
+ }
181
+
182
+ watch = zmq_stopwatch_start ();
183
+
184
+ for (i = 0; i != message_count - 1; i++) {
185
+ rc = zmq_recv (s, &msg, 0);
186
+ if (rc < 0) {
187
+ printf ("error in zmq_recv: %s\n", zmq_strerror (errno));
188
+ return -1;
189
+ }
190
+ if (zmq_msg_size (&msg) != message_size) {
191
+ printf ("message of incorrect size received\n");
192
+ return -1;
193
+ }
194
+ }
195
+
196
+ elapsed = zmq_stopwatch_stop (watch);
197
+ if (elapsed == 0)
198
+ elapsed = 1;
199
+
200
+ rc = zmq_msg_close (&msg);
201
+ if (rc != 0) {
202
+ printf ("error in zmq_msg_close: %s\n", zmq_strerror (errno));
203
+ return -1;
204
+ }
205
+
206
+ #if defined ZMQ_HAVE_WINDOWS
207
+ DWORD rc2 = WaitForSingleObject (local_thread, INFINITE);
208
+ if (rc2 == WAIT_FAILED) {
209
+ printf ("error in WaitForSingleObject\n");
210
+ return -1;
211
+ }
212
+ BOOL rc3 = CloseHandle (local_thread);
213
+ if (rc3 == 0) {
214
+ printf ("error in CloseHandle\n");
215
+ return -1;
216
+ }
217
+ #else
218
+ rc = pthread_join (local_thread, NULL);
219
+ if (rc != 0) {
220
+ printf ("error in pthread_join: %s\n", zmq_strerror (rc));
221
+ return -1;
222
+ }
223
+ #endif
224
+
225
+ rc = zmq_close (s);
226
+ if (rc != 0) {
227
+ printf ("error in zmq_close: %s\n", zmq_strerror (errno));
228
+ return -1;
229
+ }
230
+
231
+ rc = zmq_term (ctx);
232
+ if (rc != 0) {
233
+ printf ("error in zmq_term: %s\n", zmq_strerror (errno));
234
+ return -1;
235
+ }
236
+
237
+ throughput = (unsigned long)
238
+ ((double) message_count / (double) elapsed * 1000000);
239
+ megabits = (double) (throughput * message_size * 8) / 1000000;
240
+
241
+ printf ("mean throughput: %d [msg/s]\n", (int) throughput);
242
+ printf ("mean throughput: %.3f [Mb/s]\n", (double) megabits);
243
+
244
+ return 0;
245
+ }
246
+