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.
- data/LICENSE +703 -0
- data/README.md +31 -0
- data/lib/libzmq.rb +17 -0
- data/lib/libzmq/ffi-rzmq.rb +3 -0
- data/libzmq/Makefile +5 -0
- data/libzmq/extconf.rb +24 -0
- data/libzmq/zeromq-2.1.7/AUTHORS +92 -0
- data/libzmq/zeromq-2.1.7/COPYING +674 -0
- data/libzmq/zeromq-2.1.7/COPYING.LESSER +206 -0
- data/libzmq/zeromq-2.1.7/ChangeLog +15620 -0
- data/libzmq/zeromq-2.1.7/INSTALL +237 -0
- data/libzmq/zeromq-2.1.7/MAINTAINERS +56 -0
- data/libzmq/zeromq-2.1.7/Makefile.am +42 -0
- data/libzmq/zeromq-2.1.7/Makefile.in +779 -0
- data/libzmq/zeromq-2.1.7/NEWS +275 -0
- data/libzmq/zeromq-2.1.7/README +39 -0
- data/libzmq/zeromq-2.1.7/acinclude.m4 +582 -0
- data/libzmq/zeromq-2.1.7/aclocal.m4 +1206 -0
- data/libzmq/zeromq-2.1.7/autogen.sh +45 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/Makefile.am +8 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/Makefile.in +390 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/c_local_lat/c_local_lat.vcproj +176 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/c_local_thr/c_local_thr.vcproj +176 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/c_remote_lat/c_remote_lat.vcproj +176 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/c_remote_thr/c_remote_thr.vcproj +176 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/libzmq/libzmq.vcproj +783 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/msvc.sln +89 -0
- data/libzmq/zeromq-2.1.7/builds/msvc/platform.hpp +32 -0
- data/libzmq/zeromq-2.1.7/builds/redhat/zeromq.spec.in +139 -0
- data/libzmq/zeromq-2.1.7/config/compile +143 -0
- data/libzmq/zeromq-2.1.7/config/config.guess +1502 -0
- data/libzmq/zeromq-2.1.7/config/config.sub +1714 -0
- data/libzmq/zeromq-2.1.7/config/depcomp +630 -0
- data/libzmq/zeromq-2.1.7/config/install-sh +520 -0
- data/libzmq/zeromq-2.1.7/config/libtool.m4 +7377 -0
- data/libzmq/zeromq-2.1.7/config/ltmain.sh +8413 -0
- data/libzmq/zeromq-2.1.7/config/ltoptions.m4 +368 -0
- data/libzmq/zeromq-2.1.7/config/ltsugar.m4 +123 -0
- data/libzmq/zeromq-2.1.7/config/ltversion.m4 +23 -0
- data/libzmq/zeromq-2.1.7/config/lt~obsolete.m4 +92 -0
- data/libzmq/zeromq-2.1.7/config/missing +376 -0
- data/libzmq/zeromq-2.1.7/configure +21645 -0
- data/libzmq/zeromq-2.1.7/configure.in +380 -0
- data/libzmq/zeromq-2.1.7/doc/Makefile.am +46 -0
- data/libzmq/zeromq-2.1.7/doc/Makefile.in +546 -0
- data/libzmq/zeromq-2.1.7/doc/asciidoc.conf +56 -0
- data/libzmq/zeromq-2.1.7/doc/zmq.7 +242 -0
- data/libzmq/zeromq-2.1.7/doc/zmq.html +846 -0
- data/libzmq/zeromq-2.1.7/doc/zmq.txt +218 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_bind.3 +166 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_bind.html +746 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_bind.txt +91 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_close.3 +81 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_close.html +645 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_close.txt +52 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_connect.3 +161 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_connect.html +732 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_connect.txt +89 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_cpp.7 +410 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_cpp.html +765 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_cpp.txt +212 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_device.3 +140 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_device.html +736 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_device.txt +138 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_epgm.7 +209 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_epgm.html +749 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_epgm.txt +162 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_errno.3 +78 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_errno.html +634 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_errno.txt +50 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_getsockopt.3 +944 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_getsockopt.html +1713 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_getsockopt.txt +407 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_init.3 +71 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_init.html +635 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_init.txt +51 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_inproc.7 +115 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_inproc.html +669 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_inproc.txt +89 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_ipc.7 +109 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_ipc.html +662 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_ipc.txt +80 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_close.3 +81 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_close.html +647 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_close.txt +55 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_copy.3 +95 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_copy.html +656 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_copy.txt +57 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_data.3 +76 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_data.html +633 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_data.txt +48 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init.3 +110 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init.html +656 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init.txt +65 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_data.3 +138 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_data.html +678 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_data.txt +83 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_size.3 +97 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_size.html +656 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_init_size.txt +58 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_move.3 +79 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_move.html +645 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_move.txt +52 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_size.3 +76 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_size.html +633 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_msg_size.txt +48 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_pgm.7 +209 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_pgm.html +749 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_pgm.txt +162 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_poll.3 +204 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_poll.html +755 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_poll.txt +132 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_recv.3 +172 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_recv.html +746 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_recv.txt +121 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_send.3 +185 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_send.html +755 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_send.txt +120 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_setsockopt.3 +878 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_setsockopt.html +1603 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_setsockopt.txt +382 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_socket.3 +779 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_socket.html +1424 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_socket.txt +342 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_strerror.3 +78 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_strerror.html +634 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_strerror.txt +55 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_tcp.7 +244 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_tcp.html +755 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_tcp.txt +162 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_term.3 +135 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_term.html +672 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_term.txt +65 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_version.3 +78 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_version.html +632 -0
- data/libzmq/zeromq-2.1.7/doc/zmq_version.txt +53 -0
- data/libzmq/zeromq-2.1.7/foreign/openpgm/Makefile.am +8 -0
- data/libzmq/zeromq-2.1.7/foreign/openpgm/Makefile.in +588 -0
- data/libzmq/zeromq-2.1.7/foreign/openpgm/libpgm-5.1.115~dfsg.tar.gz +0 -0
- data/libzmq/zeromq-2.1.7/foreign/xmlParser/xmlParser.cpp +2923 -0
- data/libzmq/zeromq-2.1.7/foreign/xmlParser/xmlParser.hpp +762 -0
- data/libzmq/zeromq-2.1.7/include/zmq.h +269 -0
- data/libzmq/zeromq-2.1.7/include/zmq.hpp +301 -0
- data/libzmq/zeromq-2.1.7/include/zmq_utils.h +64 -0
- data/libzmq/zeromq-2.1.7/perf/Makefile.am +21 -0
- data/libzmq/zeromq-2.1.7/perf/Makefile.in +566 -0
- data/libzmq/zeromq-2.1.7/perf/inproc_lat.cpp +232 -0
- data/libzmq/zeromq-2.1.7/perf/inproc_thr.cpp +246 -0
- data/libzmq/zeromq-2.1.7/perf/local_lat.cpp +108 -0
- data/libzmq/zeromq-2.1.7/perf/local_thr.cpp +138 -0
- data/libzmq/zeromq-2.1.7/perf/remote_lat.cpp +121 -0
- data/libzmq/zeromq-2.1.7/perf/remote_thr.cpp +104 -0
- data/libzmq/zeromq-2.1.7/src/Makefile.am +155 -0
- data/libzmq/zeromq-2.1.7/src/Makefile.in +1320 -0
- data/libzmq/zeromq-2.1.7/src/array.hpp +147 -0
- data/libzmq/zeromq-2.1.7/src/atomic_counter.hpp +164 -0
- data/libzmq/zeromq-2.1.7/src/atomic_ptr.hpp +159 -0
- data/libzmq/zeromq-2.1.7/src/blob.hpp +34 -0
- data/libzmq/zeromq-2.1.7/src/clock.cpp +118 -0
- data/libzmq/zeromq-2.1.7/src/clock.hpp +60 -0
- data/libzmq/zeromq-2.1.7/src/command.cpp +39 -0
- data/libzmq/zeromq-2.1.7/src/command.hpp +147 -0
- data/libzmq/zeromq-2.1.7/src/config.hpp +88 -0
- data/libzmq/zeromq-2.1.7/src/connect_session.cpp +119 -0
- data/libzmq/zeromq-2.1.7/src/connect_session.hpp +65 -0
- data/libzmq/zeromq-2.1.7/src/ctx.cpp +322 -0
- data/libzmq/zeromq-2.1.7/src/ctx.hpp +159 -0
- data/libzmq/zeromq-2.1.7/src/decoder.cpp +129 -0
- data/libzmq/zeromq-2.1.7/src/decoder.hpp +207 -0
- data/libzmq/zeromq-2.1.7/src/device.cpp +120 -0
- data/libzmq/zeromq-2.1.7/src/device.hpp +32 -0
- data/libzmq/zeromq-2.1.7/src/devpoll.cpp +190 -0
- data/libzmq/zeromq-2.1.7/src/devpoll.hpp +100 -0
- data/libzmq/zeromq-2.1.7/src/dist.cpp +200 -0
- data/libzmq/zeromq-2.1.7/src/dist.hpp +90 -0
- data/libzmq/zeromq-2.1.7/src/encoder.cpp +90 -0
- data/libzmq/zeromq-2.1.7/src/encoder.hpp +184 -0
- data/libzmq/zeromq-2.1.7/src/epoll.cpp +177 -0
- data/libzmq/zeromq-2.1.7/src/epoll.hpp +96 -0
- data/libzmq/zeromq-2.1.7/src/err.cpp +238 -0
- data/libzmq/zeromq-2.1.7/src/err.hpp +145 -0
- data/libzmq/zeromq-2.1.7/src/fd.hpp +45 -0
- data/libzmq/zeromq-2.1.7/src/fq.cpp +164 -0
- data/libzmq/zeromq-2.1.7/src/fq.hpp +80 -0
- data/libzmq/zeromq-2.1.7/src/i_engine.hpp +53 -0
- data/libzmq/zeromq-2.1.7/src/i_inout.hpp +50 -0
- data/libzmq/zeromq-2.1.7/src/i_poll_events.hpp +46 -0
- data/libzmq/zeromq-2.1.7/src/io_object.cpp +107 -0
- data/libzmq/zeromq-2.1.7/src/io_object.hpp +78 -0
- data/libzmq/zeromq-2.1.7/src/io_thread.cpp +109 -0
- data/libzmq/zeromq-2.1.7/src/io_thread.hpp +88 -0
- data/libzmq/zeromq-2.1.7/src/ip.cpp +339 -0
- data/libzmq/zeromq-2.1.7/src/ip.hpp +68 -0
- data/libzmq/zeromq-2.1.7/src/kqueue.cpp +194 -0
- data/libzmq/zeromq-2.1.7/src/kqueue.hpp +103 -0
- data/libzmq/zeromq-2.1.7/src/lb.cpp +174 -0
- data/libzmq/zeromq-2.1.7/src/lb.hpp +79 -0
- data/libzmq/zeromq-2.1.7/src/libzmq.pc.in +10 -0
- data/libzmq/zeromq-2.1.7/src/likely.hpp +33 -0
- data/libzmq/zeromq-2.1.7/src/mailbox.cpp +382 -0
- data/libzmq/zeromq-2.1.7/src/mailbox.hpp +62 -0
- data/libzmq/zeromq-2.1.7/src/msg_content.hpp +52 -0
- data/libzmq/zeromq-2.1.7/src/mutex.hpp +121 -0
- data/libzmq/zeromq-2.1.7/src/named_session.cpp +85 -0
- data/libzmq/zeromq-2.1.7/src/named_session.hpp +57 -0
- data/libzmq/zeromq-2.1.7/src/object.cpp +467 -0
- data/libzmq/zeromq-2.1.7/src/object.hpp +127 -0
- data/libzmq/zeromq-2.1.7/src/options.cpp +336 -0
- data/libzmq/zeromq-2.1.7/src/options.hpp +87 -0
- data/libzmq/zeromq-2.1.7/src/own.cpp +214 -0
- data/libzmq/zeromq-2.1.7/src/own.hpp +140 -0
- data/libzmq/zeromq-2.1.7/src/pair.cpp +180 -0
- data/libzmq/zeromq-2.1.7/src/pair.hpp +76 -0
- data/libzmq/zeromq-2.1.7/src/pgm_receiver.cpp +259 -0
- data/libzmq/zeromq-2.1.7/src/pgm_receiver.hpp +129 -0
- data/libzmq/zeromq-2.1.7/src/pgm_sender.cpp +215 -0
- data/libzmq/zeromq-2.1.7/src/pgm_sender.hpp +105 -0
- data/libzmq/zeromq-2.1.7/src/pgm_socket.cpp +705 -0
- data/libzmq/zeromq-2.1.7/src/pgm_socket.hpp +118 -0
- data/libzmq/zeromq-2.1.7/src/pipe.cpp +409 -0
- data/libzmq/zeromq-2.1.7/src/pipe.hpp +214 -0
- data/libzmq/zeromq-2.1.7/src/platform.hpp.in +228 -0
- data/libzmq/zeromq-2.1.7/src/poll.cpp +180 -0
- data/libzmq/zeromq-2.1.7/src/poll.hpp +104 -0
- data/libzmq/zeromq-2.1.7/src/poller.hpp +73 -0
- data/libzmq/zeromq-2.1.7/src/poller_base.cpp +99 -0
- data/libzmq/zeromq-2.1.7/src/poller_base.hpp +84 -0
- data/libzmq/zeromq-2.1.7/src/pub.cpp +31 -0
- data/libzmq/zeromq-2.1.7/src/pub.hpp +44 -0
- data/libzmq/zeromq-2.1.7/src/pull.cpp +61 -0
- data/libzmq/zeromq-2.1.7/src/pull.hpp +60 -0
- data/libzmq/zeromq-2.1.7/src/push.cpp +62 -0
- data/libzmq/zeromq-2.1.7/src/push.hpp +59 -0
- data/libzmq/zeromq-2.1.7/src/reaper.cpp +121 -0
- data/libzmq/zeromq-2.1.7/src/reaper.hpp +77 -0
- data/libzmq/zeromq-2.1.7/src/rep.cpp +131 -0
- data/libzmq/zeromq-2.1.7/src/rep.hpp +59 -0
- data/libzmq/zeromq-2.1.7/src/req.cpp +121 -0
- data/libzmq/zeromq-2.1.7/src/req.hpp +58 -0
- data/libzmq/zeromq-2.1.7/src/select.cpp +211 -0
- data/libzmq/zeromq-2.1.7/src/select.hpp +116 -0
- data/libzmq/zeromq-2.1.7/src/semaphore.hpp +189 -0
- data/libzmq/zeromq-2.1.7/src/session.cpp +347 -0
- data/libzmq/zeromq-2.1.7/src/session.hpp +150 -0
- data/libzmq/zeromq-2.1.7/src/socket_base.cpp +811 -0
- data/libzmq/zeromq-2.1.7/src/socket_base.hpp +207 -0
- data/libzmq/zeromq-2.1.7/src/stdint.hpp +63 -0
- data/libzmq/zeromq-2.1.7/src/sub.cpp +75 -0
- data/libzmq/zeromq-2.1.7/src/sub.hpp +50 -0
- data/libzmq/zeromq-2.1.7/src/swap.cpp +325 -0
- data/libzmq/zeromq-2.1.7/src/swap.hpp +123 -0
- data/libzmq/zeromq-2.1.7/src/tcp_connecter.cpp +310 -0
- data/libzmq/zeromq-2.1.7/src/tcp_connecter.hpp +81 -0
- data/libzmq/zeromq-2.1.7/src/tcp_listener.cpp +371 -0
- data/libzmq/zeromq-2.1.7/src/tcp_listener.hpp +73 -0
- data/libzmq/zeromq-2.1.7/src/tcp_socket.cpp +228 -0
- data/libzmq/zeromq-2.1.7/src/tcp_socket.hpp +72 -0
- data/libzmq/zeromq-2.1.7/src/thread.cpp +97 -0
- data/libzmq/zeromq-2.1.7/src/thread.hpp +78 -0
- data/libzmq/zeromq-2.1.7/src/transient_session.cpp +41 -0
- data/libzmq/zeromq-2.1.7/src/transient_session.hpp +52 -0
- data/libzmq/zeromq-2.1.7/src/trie.cpp +181 -0
- data/libzmq/zeromq-2.1.7/src/trie.hpp +59 -0
- data/libzmq/zeromq-2.1.7/src/uuid.cpp +233 -0
- data/libzmq/zeromq-2.1.7/src/uuid.hpp +111 -0
- data/libzmq/zeromq-2.1.7/src/windows.hpp +79 -0
- data/libzmq/zeromq-2.1.7/src/wire.hpp +99 -0
- data/libzmq/zeromq-2.1.7/src/xpub.cpp +76 -0
- data/libzmq/zeromq-2.1.7/src/xpub.hpp +61 -0
- data/libzmq/zeromq-2.1.7/src/xrep.cpp +337 -0
- data/libzmq/zeromq-2.1.7/src/xrep.hpp +116 -0
- data/libzmq/zeromq-2.1.7/src/xreq.cpp +74 -0
- data/libzmq/zeromq-2.1.7/src/xreq.hpp +65 -0
- data/libzmq/zeromq-2.1.7/src/xsub.cpp +172 -0
- data/libzmq/zeromq-2.1.7/src/xsub.hpp +80 -0
- data/libzmq/zeromq-2.1.7/src/ypipe.hpp +209 -0
- data/libzmq/zeromq-2.1.7/src/yqueue.hpp +198 -0
- data/libzmq/zeromq-2.1.7/src/zmq.cpp +798 -0
- data/libzmq/zeromq-2.1.7/src/zmq_connecter.cpp +166 -0
- data/libzmq/zeromq-2.1.7/src/zmq_connecter.hpp +92 -0
- data/libzmq/zeromq-2.1.7/src/zmq_engine.cpp +220 -0
- data/libzmq/zeromq-2.1.7/src/zmq_engine.hpp +87 -0
- data/libzmq/zeromq-2.1.7/src/zmq_init.cpp +216 -0
- data/libzmq/zeromq-2.1.7/src/zmq_init.hpp +93 -0
- data/libzmq/zeromq-2.1.7/src/zmq_listener.cpp +78 -0
- data/libzmq/zeromq-2.1.7/src/zmq_listener.hpp +67 -0
- data/libzmq/zeromq-2.1.7/tests/Makefile.am +30 -0
- data/libzmq/zeromq-2.1.7/tests/Makefile.in +713 -0
- data/libzmq/zeromq-2.1.7/tests/test_hwm.cpp +68 -0
- data/libzmq/zeromq-2.1.7/tests/test_pair_inproc.cpp +31 -0
- data/libzmq/zeromq-2.1.7/tests/test_pair_ipc.cpp +31 -0
- data/libzmq/zeromq-2.1.7/tests/test_pair_tcp.cpp +31 -0
- data/libzmq/zeromq-2.1.7/tests/test_reqrep_inproc.cpp +31 -0
- data/libzmq/zeromq-2.1.7/tests/test_reqrep_ipc.cpp +31 -0
- data/libzmq/zeromq-2.1.7/tests/test_reqrep_tcp.cpp +31 -0
- data/libzmq/zeromq-2.1.7/tests/test_shutdown_stress.cpp +87 -0
- data/libzmq/zeromq-2.1.7/tests/testutil.hpp +130 -0
- data/libzmq/zeromq-2.1.7/version.sh +21 -0
- data/libzmq/zeromq-2.1.7/zeromq.spec +139 -0
- 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
|
+
|