rbczmq 1.6.2 → 1.6.4
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +4 -3
- data/.gitmodules +6 -0
- data/.travis.yml +5 -1
- data/CHANGELOG.rdoc +15 -0
- data/Gemfile.lock +2 -2
- data/README.rdoc +5 -2
- data/Rakefile +8 -3
- data/ext/czmq/.gitignore +52 -0
- data/ext/czmq/.travis.yml +18 -0
- data/ext/czmq/AUTHORS +9 -0
- data/ext/czmq/COPYING +674 -0
- data/ext/czmq/COPYING.LESSER +178 -0
- data/ext/czmq/ChangeLog +0 -0
- data/ext/czmq/Makefile.am +22 -0
- data/ext/czmq/NEWS +263 -0
- data/ext/czmq/README +0 -0
- data/ext/czmq/README.md +1122 -0
- data/ext/czmq/README.txt +327 -0
- data/ext/czmq/autogen.sh +46 -0
- data/ext/czmq/builds/android/Android.mk +35 -0
- data/ext/czmq/builds/android/Application.mk +1 -0
- data/ext/czmq/builds/android/build.sh +59 -0
- data/ext/czmq/builds/android/clean.sh +26 -0
- data/ext/czmq/builds/mingw32/Makefile.mingw32 +38 -0
- data/ext/czmq/builds/mingw32/platform.h +0 -0
- data/ext/czmq/builds/msvc/.gitignore +18 -0
- data/ext/czmq/builds/msvc/README.txt +17 -0
- data/ext/czmq/builds/msvc/czmq.sln +69 -0
- data/ext/czmq/builds/msvc/czmq.vcproj +2246 -0
- data/ext/czmq/builds/msvc/czmq.vcxproj +329 -0
- data/ext/czmq/builds/msvc/czmq.vcxproj.filters +117 -0
- data/ext/czmq/builds/msvc/czmq11.sln +36 -0
- data/ext/czmq/builds/msvc/czmq_selftest.vcproj +840 -0
- data/ext/czmq/builds/msvc/czmq_selftest.vcxproj +189 -0
- data/ext/czmq/builds/msvc/czmq_selftest.vcxproj.filters +14 -0
- data/ext/czmq/c +520 -0
- data/ext/czmq/configure.ac +229 -0
- data/ext/czmq/doc/Makefile.am +49 -0
- data/ext/czmq/doc/asciidoc.conf +57 -0
- data/ext/czmq/doc/czmq.txt +334 -0
- data/ext/czmq/doc/mkman +100 -0
- data/ext/czmq/doc/mksite +65 -0
- data/ext/czmq/doc/wdput +43 -0
- data/ext/czmq/doc/xml2wd.pl +242 -0
- data/ext/czmq/doc/zbeacon.txt +173 -0
- data/ext/czmq/doc/zclock.txt +51 -0
- data/ext/czmq/doc/zconfig.txt +92 -0
- data/ext/czmq/doc/zctx.txt +111 -0
- data/ext/czmq/doc/zfile.txt +77 -0
- data/ext/czmq/doc/zframe.txt +222 -0
- data/ext/czmq/doc/zhash.txt +225 -0
- data/ext/czmq/doc/zlist.txt +176 -0
- data/ext/czmq/doc/zloop.txt +106 -0
- data/ext/czmq/doc/zmsg.txt +315 -0
- data/ext/czmq/doc/zmutex.txt +54 -0
- data/ext/czmq/doc/zsocket.txt +110 -0
- data/ext/czmq/doc/zsockopt.txt +528 -0
- data/ext/czmq/doc/zstr.txt +80 -0
- data/ext/czmq/doc/zsys.txt +44 -0
- data/ext/czmq/doc/zthread.txt +126 -0
- data/ext/czmq/doc/ztree.txt +236 -0
- data/ext/czmq/images/README_1.png +0 -0
- data/ext/czmq/images/README_2.png +0 -0
- data/ext/czmq/include/czmq.h +64 -0
- data/ext/czmq/include/czmq_prelude.h +504 -0
- data/ext/czmq/include/zbeacon.h +91 -0
- data/ext/czmq/include/zclock.h +56 -0
- data/ext/czmq/include/zconfig.h +117 -0
- data/ext/czmq/include/zctx.h +96 -0
- data/ext/czmq/include/zfile.h +82 -0
- data/ext/czmq/include/zframe.h +145 -0
- data/ext/czmq/include/zhash.h +127 -0
- data/ext/czmq/include/zlist.h +113 -0
- data/ext/czmq/include/zloop.h +98 -0
- data/ext/czmq/include/zmsg.h +165 -0
- data/ext/czmq/include/zmutex.h +62 -0
- data/ext/czmq/include/zsocket.h +104 -0
- data/ext/czmq/include/zsockopt.h +249 -0
- data/ext/czmq/include/zstr.h +69 -0
- data/ext/czmq/include/zsys.h +66 -0
- data/ext/czmq/include/zthread.h +62 -0
- data/ext/czmq/include/ztree.h +133 -0
- data/ext/czmq/mkdoc +14 -0
- data/ext/czmq/model/generate +2 -0
- data/ext/czmq/model/sockopts.xml +101 -0
- data/ext/czmq/notes.txt +21 -0
- data/ext/czmq/scripts/sockopts.gsl +325 -0
- data/ext/czmq/src/Makefile.am +61 -0
- data/ext/czmq/src/czmq_selftest.c +60 -0
- data/ext/czmq/src/libczmq.pc.in +11 -0
- data/ext/czmq/src/selftest +7 -0
- data/ext/czmq/src/selftest.cfg +5 -0
- data/ext/czmq/src/valgrind.supp +14 -0
- data/ext/czmq/src/vg +2 -0
- data/ext/czmq/src/zbeacon.c +787 -0
- data/ext/czmq/src/zclock.c +143 -0
- data/ext/czmq/src/zconfig.c +691 -0
- data/ext/czmq/src/zctx.c +287 -0
- data/ext/czmq/src/zfile.c +237 -0
- data/ext/czmq/src/zframe.c +551 -0
- data/ext/czmq/src/zhash.c +664 -0
- data/ext/czmq/src/zlist.c +459 -0
- data/ext/czmq/src/zloop.c +496 -0
- data/ext/czmq/src/zmsg.c +854 -0
- data/ext/czmq/src/zmutex.c +134 -0
- data/ext/czmq/src/zsocket.c +313 -0
- data/ext/czmq/src/zsockopt.c +1756 -0
- data/ext/czmq/src/zstr.c +297 -0
- data/ext/czmq/src/zsys.c +136 -0
- data/ext/czmq/src/zthread.c +269 -0
- data/ext/czmq/src/ztree.c +888 -0
- data/ext/czmq/version.sh +21 -0
- data/ext/rbczmq/extconf.rb +1 -18
- data/ext/rbczmq/poller.c +4 -1
- data/ext/rbczmq/socket.c +28 -5
- data/ext/rbczmq/socket.h +1 -0
- data/ext/zeromq/AUTHORS +110 -0
- data/ext/zeromq/CMakeLists.txt +392 -0
- data/ext/zeromq/COPYING +674 -0
- data/ext/zeromq/COPYING.LESSER +179 -0
- data/ext/zeromq/INSTALL +246 -0
- data/ext/zeromq/MAINTAINERS +56 -0
- data/ext/zeromq/Makefile.am +40 -0
- data/ext/zeromq/NEWS +333 -0
- data/ext/zeromq/README +39 -0
- data/ext/zeromq/acinclude.m4 +930 -0
- data/ext/zeromq/autogen.sh +45 -0
- data/ext/zeromq/branding.bmp +0 -0
- data/ext/zeromq/builds/msvc/Makefile.am +33 -0
- data/ext/zeromq/builds/msvc/c_local_lat/c_local_lat.vcproj +176 -0
- data/ext/zeromq/builds/msvc/c_local_lat/c_local_lat.vcxproj +87 -0
- data/ext/zeromq/builds/msvc/c_local_thr/c_local_thr.vcproj +176 -0
- data/ext/zeromq/builds/msvc/c_local_thr/c_local_thr.vcxproj +87 -0
- data/ext/zeromq/builds/msvc/c_remote_lat/c_remote_lat.vcproj +176 -0
- data/ext/zeromq/builds/msvc/c_remote_lat/c_remote_lat.vcxproj +87 -0
- data/ext/zeromq/builds/msvc/c_remote_thr/c_remote_thr.vcproj +176 -0
- data/ext/zeromq/builds/msvc/c_remote_thr/c_remote_thr.vcxproj +87 -0
- data/ext/zeromq/builds/msvc/errno.cpp +32 -0
- data/ext/zeromq/builds/msvc/errno.hpp +56 -0
- data/ext/zeromq/builds/msvc/inproc_lat/inproc_lat.vcproj +174 -0
- data/ext/zeromq/builds/msvc/inproc_lat/inproc_lat.vcxproj +86 -0
- data/ext/zeromq/builds/msvc/inproc_thr/inproc_thr.vcproj +174 -0
- data/ext/zeromq/builds/msvc/inproc_thr/inproc_thr.vcxproj +86 -0
- data/ext/zeromq/builds/msvc/libzmq/libzmq.vcproj +804 -0
- data/ext/zeromq/builds/msvc/libzmq/libzmq.vcxproj +252 -0
- data/ext/zeromq/builds/msvc/libzmq/libzmq.vcxproj.filters +431 -0
- data/ext/zeromq/builds/msvc/msvc.sln +89 -0
- data/ext/zeromq/builds/msvc/msvc10.sln +116 -0
- data/ext/zeromq/builds/msvc/platform.hpp +32 -0
- data/ext/zeromq/builds/msvc/properties/Common.props +21 -0
- data/ext/zeromq/builds/msvc/properties/Debug.props +19 -0
- data/ext/zeromq/builds/msvc/properties/Dynamic.props +20 -0
- data/ext/zeromq/builds/msvc/properties/Executable.props +19 -0
- data/ext/zeromq/builds/msvc/properties/Precompiled.props +14 -0
- data/ext/zeromq/builds/msvc/properties/Release.props +22 -0
- data/ext/zeromq/builds/msvc/properties/Win32.props +12 -0
- data/ext/zeromq/builds/msvc/properties/Win32_Release.props +17 -0
- data/ext/zeromq/builds/msvc/properties/WithOpenPGM.props +12 -0
- data/ext/zeromq/builds/msvc/properties/ZeroMQ.props +23 -0
- data/ext/zeromq/builds/msvc/properties/x64.props +12 -0
- data/ext/zeromq/builds/redhat/zeromq.spec.in +160 -0
- data/ext/zeromq/builds/valgrind/valgrind.supp +14 -0
- data/ext/zeromq/builds/valgrind/vg +1 -0
- data/ext/zeromq/cmake/Modules/TestZMQVersion.cmake +35 -0
- data/ext/zeromq/cmake/Modules/zmq_version.cpp +31 -0
- data/ext/zeromq/cmake/NSIS.template32.in +952 -0
- data/ext/zeromq/cmake/NSIS.template64.in +960 -0
- data/ext/zeromq/configure.in +428 -0
- data/ext/zeromq/doc/Makefile.am +51 -0
- data/ext/zeromq/doc/asciidoc.conf +56 -0
- data/ext/zeromq/doc/zmq.txt +233 -0
- data/ext/zeromq/doc/zmq_bind.txt +102 -0
- data/ext/zeromq/doc/zmq_close.txt +52 -0
- data/ext/zeromq/doc/zmq_connect.txt +98 -0
- data/ext/zeromq/doc/zmq_ctx_destroy.txt +66 -0
- data/ext/zeromq/doc/zmq_ctx_get.txt +67 -0
- data/ext/zeromq/doc/zmq_ctx_new.txt +49 -0
- data/ext/zeromq/doc/zmq_ctx_set.txt +75 -0
- data/ext/zeromq/doc/zmq_disconnect.txt +67 -0
- data/ext/zeromq/doc/zmq_epgm.txt +162 -0
- data/ext/zeromq/doc/zmq_errno.txt +50 -0
- data/ext/zeromq/doc/zmq_getsockopt.txt +516 -0
- data/ext/zeromq/doc/zmq_init.txt +52 -0
- data/ext/zeromq/doc/zmq_inproc.txt +85 -0
- data/ext/zeromq/doc/zmq_ipc.txt +85 -0
- data/ext/zeromq/doc/zmq_msg_close.txt +55 -0
- data/ext/zeromq/doc/zmq_msg_copy.txt +57 -0
- data/ext/zeromq/doc/zmq_msg_data.txt +48 -0
- data/ext/zeromq/doc/zmq_msg_get.txt +72 -0
- data/ext/zeromq/doc/zmq_msg_init.txt +65 -0
- data/ext/zeromq/doc/zmq_msg_init_data.txt +85 -0
- data/ext/zeromq/doc/zmq_msg_init_size.txt +58 -0
- data/ext/zeromq/doc/zmq_msg_more.txt +63 -0
- data/ext/zeromq/doc/zmq_msg_move.txt +52 -0
- data/ext/zeromq/doc/zmq_msg_recv.txt +125 -0
- data/ext/zeromq/doc/zmq_msg_send.txt +122 -0
- data/ext/zeromq/doc/zmq_msg_set.txt +45 -0
- data/ext/zeromq/doc/zmq_msg_size.txt +48 -0
- data/ext/zeromq/doc/zmq_pgm.txt +162 -0
- data/ext/zeromq/doc/zmq_poll.txt +132 -0
- data/ext/zeromq/doc/zmq_proxy.txt +97 -0
- data/ext/zeromq/doc/zmq_recv.txt +93 -0
- data/ext/zeromq/doc/zmq_recvmsg.txt +123 -0
- data/ext/zeromq/doc/zmq_send.txt +100 -0
- data/ext/zeromq/doc/zmq_sendmsg.txt +119 -0
- data/ext/zeromq/doc/zmq_setsockopt.txt +523 -0
- data/ext/zeromq/doc/zmq_socket.txt +369 -0
- data/ext/zeromq/doc/zmq_socket_monitor.txt +288 -0
- data/ext/zeromq/doc/zmq_strerror.txt +55 -0
- data/ext/zeromq/doc/zmq_tcp.txt +101 -0
- data/ext/zeromq/doc/zmq_term.txt +66 -0
- data/ext/zeromq/doc/zmq_unbind.txt +65 -0
- data/ext/zeromq/doc/zmq_version.txt +53 -0
- data/ext/zeromq/foreign/openpgm/Makefile.am +8 -0
- data/ext/zeromq/foreign/openpgm/libpgm-5.1.118~dfsg.tar.gz +0 -0
- data/ext/zeromq/include/zmq.h +402 -0
- data/ext/zeromq/include/zmq_utils.h +64 -0
- data/ext/zeromq/installer.ico +0 -0
- data/ext/zeromq/perf/Makefile.am +22 -0
- data/ext/zeromq/perf/inproc_lat.cpp +233 -0
- data/ext/zeromq/perf/inproc_thr.cpp +241 -0
- data/ext/zeromq/perf/local_lat.cpp +109 -0
- data/ext/zeromq/perf/local_thr.cpp +133 -0
- data/ext/zeromq/perf/remote_lat.cpp +122 -0
- data/ext/zeromq/perf/remote_thr.cpp +105 -0
- data/ext/zeromq/src/Makefile.am +171 -0
- data/ext/zeromq/src/address.cpp +78 -0
- data/ext/zeromq/src/address.hpp +52 -0
- data/ext/zeromq/src/array.hpp +155 -0
- data/ext/zeromq/src/atomic_counter.hpp +197 -0
- data/ext/zeromq/src/atomic_ptr.hpp +196 -0
- data/ext/zeromq/src/blob.hpp +129 -0
- data/ext/zeromq/src/clock.cpp +147 -0
- data/ext/zeromq/src/clock.hpp +60 -0
- data/ext/zeromq/src/command.hpp +154 -0
- data/ext/zeromq/src/config.hpp +89 -0
- data/ext/zeromq/src/ctx.cpp +352 -0
- data/ext/zeromq/src/ctx.hpp +173 -0
- data/ext/zeromq/src/dealer.cpp +133 -0
- data/ext/zeromq/src/dealer.hpp +92 -0
- data/ext/zeromq/src/decoder.cpp +166 -0
- data/ext/zeromq/src/decoder.hpp +248 -0
- data/ext/zeromq/src/devpoll.cpp +190 -0
- data/ext/zeromq/src/devpoll.hpp +105 -0
- data/ext/zeromq/src/dist.cpp +194 -0
- data/ext/zeromq/src/dist.hpp +105 -0
- data/ext/zeromq/src/encoder.cpp +102 -0
- data/ext/zeromq/src/encoder.hpp +200 -0
- data/ext/zeromq/src/epoll.cpp +178 -0
- data/ext/zeromq/src/epoll.hpp +101 -0
- data/ext/zeromq/src/err.cpp +291 -0
- data/ext/zeromq/src/err.hpp +155 -0
- data/ext/zeromq/src/fd.hpp +45 -0
- data/ext/zeromq/src/fq.cpp +141 -0
- data/ext/zeromq/src/fq.hpp +74 -0
- data/ext/zeromq/src/i_decoder.hpp +49 -0
- data/ext/zeromq/src/i_encoder.hpp +55 -0
- data/ext/zeromq/src/i_engine.hpp +55 -0
- data/ext/zeromq/src/i_msg_sink.hpp +43 -0
- data/ext/zeromq/src/i_msg_source.hpp +44 -0
- data/ext/zeromq/src/i_poll_events.hpp +47 -0
- data/ext/zeromq/src/io_object.cpp +108 -0
- data/ext/zeromq/src/io_object.hpp +81 -0
- data/ext/zeromq/src/io_thread.cpp +104 -0
- data/ext/zeromq/src/io_thread.hpp +91 -0
- data/ext/zeromq/src/ip.cpp +109 -0
- data/ext/zeromq/src/ip.hpp +41 -0
- data/ext/zeromq/src/ipc_address.cpp +84 -0
- data/ext/zeromq/src/ipc_address.hpp +67 -0
- data/ext/zeromq/src/ipc_connecter.cpp +265 -0
- data/ext/zeromq/src/ipc_connecter.hpp +128 -0
- data/ext/zeromq/src/ipc_listener.cpp +206 -0
- data/ext/zeromq/src/ipc_listener.hpp +99 -0
- data/ext/zeromq/src/kqueue.cpp +201 -0
- data/ext/zeromq/src/kqueue.hpp +107 -0
- data/ext/zeromq/src/lb.cpp +148 -0
- data/ext/zeromq/src/lb.hpp +73 -0
- data/ext/zeromq/src/libzmq.pc.in +10 -0
- data/ext/zeromq/src/likely.hpp +33 -0
- data/ext/zeromq/src/mailbox.cpp +87 -0
- data/ext/zeromq/src/mailbox.hpp +75 -0
- data/ext/zeromq/src/msg.cpp +299 -0
- data/ext/zeromq/src/msg.hpp +148 -0
- data/ext/zeromq/src/mtrie.cpp +428 -0
- data/ext/zeromq/src/mtrie.hpp +93 -0
- data/ext/zeromq/src/mutex.hpp +118 -0
- data/ext/zeromq/src/object.cpp +393 -0
- data/ext/zeromq/src/object.hpp +134 -0
- data/ext/zeromq/src/options.cpp +562 -0
- data/ext/zeromq/src/options.hpp +135 -0
- data/ext/zeromq/src/own.cpp +206 -0
- data/ext/zeromq/src/own.hpp +145 -0
- data/ext/zeromq/src/pair.cpp +136 -0
- data/ext/zeromq/src/pair.hpp +79 -0
- data/ext/zeromq/src/pgm_receiver.cpp +283 -0
- data/ext/zeromq/src/pgm_receiver.hpp +141 -0
- data/ext/zeromq/src/pgm_sender.cpp +218 -0
- data/ext/zeromq/src/pgm_sender.hpp +113 -0
- data/ext/zeromq/src/pgm_socket.cpp +706 -0
- data/ext/zeromq/src/pgm_socket.hpp +124 -0
- data/ext/zeromq/src/pipe.cpp +447 -0
- data/ext/zeromq/src/pipe.hpp +207 -0
- data/ext/zeromq/src/poll.cpp +176 -0
- data/ext/zeromq/src/poll.hpp +105 -0
- data/ext/zeromq/src/poller.hpp +82 -0
- data/ext/zeromq/src/poller_base.cpp +99 -0
- data/ext/zeromq/src/poller_base.hpp +86 -0
- data/ext/zeromq/src/precompiled.cpp +21 -0
- data/ext/zeromq/src/precompiled.hpp +47 -0
- data/ext/zeromq/src/proxy.cpp +150 -0
- data/ext/zeromq/src/proxy.hpp +32 -0
- data/ext/zeromq/src/pub.cpp +57 -0
- data/ext/zeromq/src/pub.hpp +69 -0
- data/ext/zeromq/src/pull.cpp +79 -0
- data/ext/zeromq/src/pull.hpp +81 -0
- data/ext/zeromq/src/push.cpp +76 -0
- data/ext/zeromq/src/push.hpp +80 -0
- data/ext/zeromq/src/random.cpp +52 -0
- data/ext/zeromq/src/random.hpp +37 -0
- data/ext/zeromq/src/reaper.cpp +117 -0
- data/ext/zeromq/src/reaper.hpp +80 -0
- data/ext/zeromq/src/rep.cpp +137 -0
- data/ext/zeromq/src/rep.hpp +80 -0
- data/ext/zeromq/src/req.cpp +185 -0
- data/ext/zeromq/src/req.hpp +91 -0
- data/ext/zeromq/src/router.cpp +364 -0
- data/ext/zeromq/src/router.hpp +138 -0
- data/ext/zeromq/src/select.cpp +216 -0
- data/ext/zeromq/src/select.hpp +126 -0
- data/ext/zeromq/src/session_base.cpp +503 -0
- data/ext/zeromq/src/session_base.hpp +156 -0
- data/ext/zeromq/src/signaler.cpp +406 -0
- data/ext/zeromq/src/signaler.hpp +63 -0
- data/ext/zeromq/src/socket_base.cpp +1236 -0
- data/ext/zeromq/src/socket_base.hpp +255 -0
- data/ext/zeromq/src/stdint.hpp +63 -0
- data/ext/zeromq/src/stream_engine.cpp +594 -0
- data/ext/zeromq/src/stream_engine.hpp +149 -0
- data/ext/zeromq/src/sub.cpp +93 -0
- data/ext/zeromq/src/sub.hpp +71 -0
- data/ext/zeromq/src/tcp.cpp +131 -0
- data/ext/zeromq/src/tcp.hpp +38 -0
- data/ext/zeromq/src/tcp_address.cpp +613 -0
- data/ext/zeromq/src/tcp_address.hpp +100 -0
- data/ext/zeromq/src/tcp_connecter.cpp +319 -0
- data/ext/zeromq/src/tcp_connecter.hpp +123 -0
- data/ext/zeromq/src/tcp_listener.cpp +293 -0
- data/ext/zeromq/src/tcp_listener.hpp +91 -0
- data/ext/zeromq/src/thread.cpp +107 -0
- data/ext/zeromq/src/thread.hpp +79 -0
- data/ext/zeromq/src/trie.cpp +337 -0
- data/ext/zeromq/src/trie.hpp +79 -0
- data/ext/zeromq/src/v1_decoder.cpp +162 -0
- data/ext/zeromq/src/v1_decoder.hpp +68 -0
- data/ext/zeromq/src/v1_encoder.cpp +103 -0
- data/ext/zeromq/src/v1_encoder.hpp +60 -0
- data/ext/zeromq/src/v1_protocol.hpp +43 -0
- data/ext/zeromq/src/version.rc.in +93 -0
- data/ext/zeromq/src/windows.hpp +181 -0
- data/ext/zeromq/src/wire.hpp +99 -0
- data/ext/zeromq/src/xpub.cpp +200 -0
- data/ext/zeromq/src/xpub.hpp +110 -0
- data/ext/zeromq/src/xsub.cpp +242 -0
- data/ext/zeromq/src/xsub.hpp +108 -0
- data/ext/zeromq/src/ypipe.hpp +210 -0
- data/ext/zeromq/src/yqueue.hpp +199 -0
- data/ext/zeromq/src/zmq.cpp +1058 -0
- data/ext/zeromq/src/zmq_utils.cpp +61 -0
- data/ext/zeromq/tests/Makefile.am +55 -0
- data/ext/zeromq/tests/test_connect_delay.cpp +260 -0
- data/ext/zeromq/tests/test_connect_resolve.cpp +54 -0
- data/ext/zeromq/tests/test_disconnect_inproc.cpp +120 -0
- data/ext/zeromq/tests/test_hwm.cpp +83 -0
- data/ext/zeromq/tests/test_invalid_rep.cpp +92 -0
- data/ext/zeromq/tests/test_last_endpoint.cpp +60 -0
- data/ext/zeromq/tests/test_monitor.cpp +289 -0
- data/ext/zeromq/tests/test_msg_flags.cpp +78 -0
- data/ext/zeromq/tests/test_pair_inproc.cpp +53 -0
- data/ext/zeromq/tests/test_pair_ipc.cpp +53 -0
- data/ext/zeromq/tests/test_pair_tcp.cpp +54 -0
- data/ext/zeromq/tests/test_reqrep_device.cpp +143 -0
- data/ext/zeromq/tests/test_reqrep_inproc.cpp +53 -0
- data/ext/zeromq/tests/test_reqrep_ipc.cpp +53 -0
- data/ext/zeromq/tests/test_reqrep_tcp.cpp +54 -0
- data/ext/zeromq/tests/test_router_mandatory.cpp +62 -0
- data/ext/zeromq/tests/test_shutdown_stress.cpp +93 -0
- data/ext/zeromq/tests/test_sub_forward.cpp +99 -0
- data/ext/zeromq/tests/test_term_endpoint.cpp +118 -0
- data/ext/zeromq/tests/test_timeo.cpp +119 -0
- data/ext/zeromq/tests/testutil.hpp +77 -0
- data/ext/zeromq/version.sh +21 -0
- data/lib/zmq/version.rb +1 -1
- data/rbczmq.gemspec +16 -3
- data/test/test_socket.rb +13 -1
- metadata +398 -9
- checksums.yaml +0 -15
- data/ext/czmq-1.4.1.tar.gz +0 -0
- data/ext/zeromq-3.2.3.tar.gz +0 -0
@@ -0,0 +1,222 @@
|
|
1
|
+
zframe(3)
|
2
|
+
=========
|
3
|
+
|
4
|
+
NAME
|
5
|
+
----
|
6
|
+
zframe - working with single message frames
|
7
|
+
|
8
|
+
SYNOPSIS
|
9
|
+
--------
|
10
|
+
----
|
11
|
+
#define ZFRAME_MORE 1
|
12
|
+
#define ZFRAME_REUSE 2
|
13
|
+
#define ZFRAME_DONTWAIT 4
|
14
|
+
|
15
|
+
// Create a new frame with optional size, and optional data
|
16
|
+
CZMQ_EXPORT zframe_t *
|
17
|
+
zframe_new (const void *data, size_t size);
|
18
|
+
|
19
|
+
// Create an empty (zero-sized) frame
|
20
|
+
CZMQ_EXPORT zframe_t *
|
21
|
+
zframe_new_empty (void);
|
22
|
+
|
23
|
+
// Destroy a frame
|
24
|
+
CZMQ_EXPORT void
|
25
|
+
zframe_destroy (zframe_t **self_p);
|
26
|
+
|
27
|
+
// Receive frame from socket, returns zframe_t object or NULL if the recv
|
28
|
+
// was interrupted. Does a blocking recv, if you want to not block then use
|
29
|
+
// zframe_recv_nowait().
|
30
|
+
CZMQ_EXPORT zframe_t *
|
31
|
+
zframe_recv (void *socket);
|
32
|
+
|
33
|
+
// Receive a new frame off the socket. Returns newly allocated frame, or
|
34
|
+
// NULL if there was no input waiting, or if the read was interrupted.
|
35
|
+
CZMQ_EXPORT zframe_t *
|
36
|
+
zframe_recv_nowait (void *socket);
|
37
|
+
|
38
|
+
// Send a frame to a socket, destroy frame after sending.
|
39
|
+
// Return -1 on error, 0 on success.
|
40
|
+
CZMQ_EXPORT int
|
41
|
+
zframe_send (zframe_t **self_p, void *socket, int flags);
|
42
|
+
|
43
|
+
// Return number of bytes in frame data
|
44
|
+
CZMQ_EXPORT size_t
|
45
|
+
zframe_size (zframe_t *self);
|
46
|
+
|
47
|
+
// Return address of frame data
|
48
|
+
CZMQ_EXPORT byte *
|
49
|
+
zframe_data (zframe_t *self);
|
50
|
+
|
51
|
+
// Create a new frame that duplicates an existing frame
|
52
|
+
CZMQ_EXPORT zframe_t *
|
53
|
+
zframe_dup (zframe_t *self);
|
54
|
+
|
55
|
+
// Return frame data encoded as printable hex string
|
56
|
+
CZMQ_EXPORT char *
|
57
|
+
zframe_strhex (zframe_t *self);
|
58
|
+
|
59
|
+
// Return frame data copied into freshly allocated string
|
60
|
+
CZMQ_EXPORT char *
|
61
|
+
zframe_strdup (zframe_t *self);
|
62
|
+
|
63
|
+
// Return TRUE if frame body is equal to string, excluding terminator
|
64
|
+
CZMQ_EXPORT bool
|
65
|
+
zframe_streq (zframe_t *self, const char *string);
|
66
|
+
|
67
|
+
// Return frame MORE indicator (1 or 0), set when reading frame from socket
|
68
|
+
// or by the zframe_set_more() method
|
69
|
+
CZMQ_EXPORT int
|
70
|
+
zframe_more (zframe_t *self);
|
71
|
+
|
72
|
+
// Set frame MORE indicator (1 or 0). Note this is NOT used when sending
|
73
|
+
// frame to socket, you have to specify flag explicitly.
|
74
|
+
CZMQ_EXPORT void
|
75
|
+
zframe_set_more (zframe_t *self, int more);
|
76
|
+
|
77
|
+
// Return TRUE if two frames have identical size and data
|
78
|
+
// If either frame is NULL, equality is always false.
|
79
|
+
CZMQ_EXPORT bool
|
80
|
+
zframe_eq (zframe_t *self, zframe_t *other);
|
81
|
+
|
82
|
+
// Print contents of frame to stderr
|
83
|
+
CZMQ_EXPORT void
|
84
|
+
zframe_print (zframe_t *self, const char *prefix);
|
85
|
+
|
86
|
+
// Set new contents for frame
|
87
|
+
CZMQ_EXPORT void
|
88
|
+
zframe_reset (zframe_t *self, const void *data, size_t size);
|
89
|
+
|
90
|
+
// Callback function for zframe_free_fn method
|
91
|
+
// DEPRECATED - will be removed for next stable release
|
92
|
+
typedef void (zframe_free_fn) (void *data, void *arg);
|
93
|
+
|
94
|
+
// Create a zero-copy frame
|
95
|
+
// DEPRECATED - will be removed for next stable release
|
96
|
+
CZMQ_EXPORT zframe_t *
|
97
|
+
zframe_new_zero_copy (void *data, size_t size,
|
98
|
+
zframe_free_fn *free_fn, void *arg);
|
99
|
+
|
100
|
+
// Return frame zero copy indicator (1 or 0)
|
101
|
+
// DEPRECATED - will be removed for next stable release
|
102
|
+
CZMQ_EXPORT int
|
103
|
+
zframe_zero_copy (zframe_t *self);
|
104
|
+
|
105
|
+
// Set the free callback for frame
|
106
|
+
// DEPRECATED - will be removed at next stable release
|
107
|
+
CZMQ_EXPORT void
|
108
|
+
zframe_freefn (zframe_t *self, zframe_free_fn *free_fn, void *arg);
|
109
|
+
|
110
|
+
// Self test of this class
|
111
|
+
CZMQ_EXPORT int
|
112
|
+
zframe_test (bool verbose);
|
113
|
+
----
|
114
|
+
|
115
|
+
DESCRIPTION
|
116
|
+
-----------
|
117
|
+
|
118
|
+
The zframe class provides methods to send and receive single message
|
119
|
+
frames across 0MQ sockets. A 'frame' corresponds to one zmq_msg_t. When
|
120
|
+
you read a frame from a socket, the zframe_more() method indicates if the
|
121
|
+
frame is part of an unfinished multipart message. The zframe_send method
|
122
|
+
normally destroys the frame, but with the ZFRAME_REUSE flag, you can send
|
123
|
+
the same frame many times. Frames are binary, and this class has no
|
124
|
+
special support for text data.
|
125
|
+
|
126
|
+
|
127
|
+
EXAMPLE
|
128
|
+
-------
|
129
|
+
.From zframe_test method
|
130
|
+
----
|
131
|
+
zctx_t *ctx = zctx_new ();
|
132
|
+
assert (ctx);
|
133
|
+
|
134
|
+
void *output = zsocket_new (ctx, ZMQ_PAIR);
|
135
|
+
assert (output);
|
136
|
+
zsocket_bind (output, "inproc://zframe.test");
|
137
|
+
void *input = zsocket_new (ctx, ZMQ_PAIR);
|
138
|
+
assert (input);
|
139
|
+
zsocket_connect (input, "inproc://zframe.test");
|
140
|
+
|
141
|
+
// Send five different frames, test ZFRAME_MORE
|
142
|
+
int frame_nbr;
|
143
|
+
for (frame_nbr = 0; frame_nbr < 5; frame_nbr++) {
|
144
|
+
frame = zframe_new ("Hello", 5);
|
145
|
+
rc = zframe_send (&frame, output, ZFRAME_MORE);
|
146
|
+
assert (rc == 0);
|
147
|
+
}
|
148
|
+
// Send same frame five times, test ZFRAME_REUSE
|
149
|
+
frame = zframe_new ("Hello", 5);
|
150
|
+
assert (frame);
|
151
|
+
for (frame_nbr = 0; frame_nbr < 5; frame_nbr++) {
|
152
|
+
rc = zframe_send (&frame, output, ZFRAME_MORE + ZFRAME_REUSE);
|
153
|
+
assert (rc == 0);
|
154
|
+
}
|
155
|
+
assert (frame);
|
156
|
+
zframe_t *copy = zframe_dup (frame);
|
157
|
+
assert (zframe_eq (frame, copy));
|
158
|
+
zframe_destroy (&frame);
|
159
|
+
assert (!zframe_eq (frame, copy));
|
160
|
+
assert (zframe_size (copy) == 5);
|
161
|
+
zframe_destroy (©);
|
162
|
+
assert (!zframe_eq (frame, copy));
|
163
|
+
|
164
|
+
// Test zframe_new_empty
|
165
|
+
frame = zframe_new_empty ();
|
166
|
+
assert (frame);
|
167
|
+
assert (zframe_size (frame) == 0);
|
168
|
+
zframe_destroy (&frame);
|
169
|
+
|
170
|
+
// Send END frame
|
171
|
+
frame = zframe_new ("NOT", 3);
|
172
|
+
assert (frame);
|
173
|
+
zframe_reset (frame, "END", 3);
|
174
|
+
char *string = zframe_strhex (frame);
|
175
|
+
assert (streq (string, "454E44"));
|
176
|
+
free (string);
|
177
|
+
string = zframe_strdup (frame);
|
178
|
+
assert (streq (string, "END"));
|
179
|
+
free (string);
|
180
|
+
rc = zframe_send (&frame, output, 0);
|
181
|
+
assert (rc == 0);
|
182
|
+
|
183
|
+
// Read and count until we receive END
|
184
|
+
frame_nbr = 0;
|
185
|
+
for (frame_nbr = 0;; frame_nbr++) {
|
186
|
+
zframe_t *frame = zframe_recv (input);
|
187
|
+
if (zframe_streq (frame, "END")) {
|
188
|
+
zframe_destroy (&frame);
|
189
|
+
break;
|
190
|
+
}
|
191
|
+
assert (zframe_more (frame));
|
192
|
+
zframe_set_more (frame, 0);
|
193
|
+
assert (zframe_more (frame) == 0);
|
194
|
+
zframe_destroy (&frame);
|
195
|
+
}
|
196
|
+
assert (frame_nbr == 10);
|
197
|
+
frame = zframe_recv_nowait (input);
|
198
|
+
assert (frame == NULL);
|
199
|
+
|
200
|
+
// Test zero copy
|
201
|
+
char *buffer = (char *) malloc (1024);
|
202
|
+
memset (buffer, 'A', 1024);
|
203
|
+
|
204
|
+
frame = zframe_new_zero_copy (buffer, 1024, s_test_free_cb, NULL);
|
205
|
+
zframe_t *frame_copy = zframe_dup (frame);
|
206
|
+
|
207
|
+
assert (zframe_zero_copy (frame) == 1);
|
208
|
+
assert (zframe_zero_copy (frame_copy) == 0);
|
209
|
+
|
210
|
+
zframe_destroy (&frame);
|
211
|
+
zframe_destroy (&frame_copy);
|
212
|
+
|
213
|
+
frame = zframe_new ("callback", 8);
|
214
|
+
zframe_freefn (frame, s_test_free_frame_cb, NULL);
|
215
|
+
zframe_destroy (&frame);
|
216
|
+
|
217
|
+
zctx_destroy (&ctx);
|
218
|
+
----
|
219
|
+
|
220
|
+
SEE ALSO
|
221
|
+
--------
|
222
|
+
linkczmq:czmq[7]
|
@@ -0,0 +1,225 @@
|
|
1
|
+
zhash(3)
|
2
|
+
========
|
3
|
+
|
4
|
+
NAME
|
5
|
+
----
|
6
|
+
zhash - generic type-free hash container
|
7
|
+
|
8
|
+
SYNOPSIS
|
9
|
+
--------
|
10
|
+
----
|
11
|
+
// Callback function for zhash_foreach method
|
12
|
+
typedef int (zhash_foreach_fn) (const char *key, void *item, void *argument);
|
13
|
+
// Callback function for zhash_freefn method
|
14
|
+
typedef void (zhash_free_fn) (void *data);
|
15
|
+
|
16
|
+
// Create a new, empty hash container
|
17
|
+
CZMQ_EXPORT zhash_t *
|
18
|
+
zhash_new (void);
|
19
|
+
|
20
|
+
// Destroy a hash container and all items in it
|
21
|
+
CZMQ_EXPORT void
|
22
|
+
zhash_destroy (zhash_t **self_p);
|
23
|
+
|
24
|
+
// Insert item into hash table with specified key and item.
|
25
|
+
// If key is already present returns -1 and leaves existing item unchanged
|
26
|
+
// Returns 0 on success.
|
27
|
+
CZMQ_EXPORT int
|
28
|
+
zhash_insert (zhash_t *self, const char *key, void *item);
|
29
|
+
|
30
|
+
// Update item into hash table with specified key and item.
|
31
|
+
// If key is already present, destroys old item and inserts new one.
|
32
|
+
// Use free_fn method to ensure deallocator is properly called on item.
|
33
|
+
CZMQ_EXPORT void
|
34
|
+
zhash_update (zhash_t *self, const char *key, void *item);
|
35
|
+
|
36
|
+
// Remove an item specified by key from the hash table. If there was no such
|
37
|
+
// item, this function does nothing.
|
38
|
+
CZMQ_EXPORT void
|
39
|
+
zhash_delete (zhash_t *self, const char *key);
|
40
|
+
|
41
|
+
// Return the item at the specified key, or null
|
42
|
+
CZMQ_EXPORT void *
|
43
|
+
zhash_lookup (zhash_t *self, const char *key);
|
44
|
+
|
45
|
+
// Reindexes an item from an old key to a new key. If there was no such
|
46
|
+
// item, does nothing. Returns 0 if successful, else -1.
|
47
|
+
CZMQ_EXPORT int
|
48
|
+
zhash_rename (zhash_t *self, const char *old_key, const char *new_key);
|
49
|
+
|
50
|
+
// Set a free function for the specified hash table item. When the item is
|
51
|
+
// destroyed, the free function, if any, is called on that item.
|
52
|
+
// Use this when hash items are dynamically allocated, to ensure that
|
53
|
+
// you don't have memory leaks. You can pass 'free' or NULL as a free_fn.
|
54
|
+
// Returns the item, or NULL if there is no such item.
|
55
|
+
CZMQ_EXPORT void *
|
56
|
+
zhash_freefn (zhash_t *self, const char *key, zhash_free_fn *free_fn);
|
57
|
+
|
58
|
+
// Return the number of keys/items in the hash table
|
59
|
+
CZMQ_EXPORT size_t
|
60
|
+
zhash_size (zhash_t *self);
|
61
|
+
|
62
|
+
// Make copy of hash table
|
63
|
+
CZMQ_EXPORT zhash_t *
|
64
|
+
zhash_dup (zhash_t *self);
|
65
|
+
|
66
|
+
// Return keys for items in table
|
67
|
+
CZMQ_EXPORT zlist_t *
|
68
|
+
zhash_keys (zhash_t *self);
|
69
|
+
|
70
|
+
// Apply function to each item in the hash table. Items are iterated in no
|
71
|
+
// defined order. Stops if callback function returns non-zero and returns
|
72
|
+
// final return code from callback function (zero = success).
|
73
|
+
CZMQ_EXPORT int
|
74
|
+
zhash_foreach (zhash_t *self, zhash_foreach_fn *callback, void *argument);
|
75
|
+
|
76
|
+
// Save hash table to a text file in name=value format. Hash values must be
|
77
|
+
// printable strings; keys may not contain '=' character. Returns 0 if OK,
|
78
|
+
// else -1 if a file error occurred.
|
79
|
+
CZMQ_EXPORT int
|
80
|
+
zhash_save (zhash_t *self, char *filename);
|
81
|
+
|
82
|
+
// Load hash table from a text file in name=value format; hash table must
|
83
|
+
// already exist. Hash values must printable strings; keys may not contain
|
84
|
+
// '=' character. Returns 0 if OK, else -1 if a file was not readable.
|
85
|
+
CZMQ_EXPORT int
|
86
|
+
zhash_load (zhash_t *self, char *filename);
|
87
|
+
|
88
|
+
// Set hash for automatic value destruction
|
89
|
+
CZMQ_EXPORT void
|
90
|
+
zhash_autofree (zhash_t *self);
|
91
|
+
|
92
|
+
// Self test of this class
|
93
|
+
CZMQ_EXPORT void
|
94
|
+
zhash_test (int verbose);
|
95
|
+
----
|
96
|
+
|
97
|
+
DESCRIPTION
|
98
|
+
-----------
|
99
|
+
|
100
|
+
Expandable hash table container
|
101
|
+
|
102
|
+
Note that it's relatively slow (~50k insertions/deletes per second), so
|
103
|
+
don't do inserts/updates on the critical path for message I/O. It can
|
104
|
+
do ~2.5M lookups per second for 16-char keys. Timed on a 1.6GHz CPU.
|
105
|
+
|
106
|
+
EXAMPLE
|
107
|
+
-------
|
108
|
+
.From zhash_test method
|
109
|
+
----
|
110
|
+
zhash_t *hash = zhash_new ();
|
111
|
+
assert (hash);
|
112
|
+
assert (zhash_size (hash) == 0);
|
113
|
+
|
114
|
+
// Insert some items
|
115
|
+
int rc;
|
116
|
+
rc = zhash_insert (hash, "DEADBEEF", "dead beef");
|
117
|
+
assert (rc == 0);
|
118
|
+
rc = zhash_insert (hash, "ABADCAFE", "a bad cafe");
|
119
|
+
assert (rc == 0);
|
120
|
+
rc = zhash_insert (hash, "C0DEDBAD", "coded bad");
|
121
|
+
assert (rc == 0);
|
122
|
+
rc = zhash_insert (hash, "DEADF00D", "dead food");
|
123
|
+
assert (rc == 0);
|
124
|
+
assert (zhash_size (hash) == 4);
|
125
|
+
|
126
|
+
// Look for existing items
|
127
|
+
char *item;
|
128
|
+
item = (char *) zhash_lookup (hash, "DEADBEEF");
|
129
|
+
assert (streq (item, "dead beef"));
|
130
|
+
item = (char *) zhash_lookup (hash, "ABADCAFE");
|
131
|
+
assert (streq (item, "a bad cafe"));
|
132
|
+
item = (char *) zhash_lookup (hash, "C0DEDBAD");
|
133
|
+
assert (streq (item, "coded bad"));
|
134
|
+
item = (char *) zhash_lookup (hash, "DEADF00D");
|
135
|
+
assert (streq (item, "dead food"));
|
136
|
+
|
137
|
+
// Look for non-existent items
|
138
|
+
item = (char *) zhash_lookup (hash, "foo");
|
139
|
+
assert (item == NULL);
|
140
|
+
|
141
|
+
// Try to insert duplicate items
|
142
|
+
rc = zhash_insert (hash, "DEADBEEF", "foo");
|
143
|
+
assert (rc == -1);
|
144
|
+
item = (char *) zhash_lookup (hash, "DEADBEEF");
|
145
|
+
assert (streq (item, "dead beef"));
|
146
|
+
|
147
|
+
// Rename an item
|
148
|
+
rc = zhash_rename (hash, "DEADBEEF", "LIVEBEEF");
|
149
|
+
assert (rc == 0);
|
150
|
+
rc = zhash_rename (hash, "WHATBEEF", "LIVEBEEF");
|
151
|
+
assert (rc == -1);
|
152
|
+
|
153
|
+
// Test keys method
|
154
|
+
zlist_t *keys = zhash_keys (hash);
|
155
|
+
assert (zlist_size (keys) == 4);
|
156
|
+
zlist_destroy (&keys);
|
157
|
+
|
158
|
+
// Test dup method
|
159
|
+
zhash_t *copy = zhash_dup (hash);
|
160
|
+
assert (zhash_size (copy) == 4);
|
161
|
+
item = (char *) zhash_lookup (copy, "LIVEBEEF");
|
162
|
+
assert (item);
|
163
|
+
assert (streq (item, "dead beef"));
|
164
|
+
zhash_destroy (©);
|
165
|
+
|
166
|
+
// Test foreach
|
167
|
+
assert (0 == zhash_foreach (hash, test_foreach, hash));
|
168
|
+
assert (-1 == zhash_foreach (hash, test_foreach_error, hash));
|
169
|
+
|
170
|
+
// Test save and load
|
171
|
+
zhash_save (hash, ".cache");
|
172
|
+
copy = zhash_new ();
|
173
|
+
zhash_load (copy, ".cache");
|
174
|
+
item = (char *) zhash_lookup (copy, "LIVEBEEF");
|
175
|
+
assert (item);
|
176
|
+
assert (streq (item, "dead beef"));
|
177
|
+
zhash_destroy (©);
|
178
|
+
#if (defined (WIN32))
|
179
|
+
DeleteFile (".cache");
|
180
|
+
#else
|
181
|
+
unlink (".cache");
|
182
|
+
#endif
|
183
|
+
|
184
|
+
// Delete a item
|
185
|
+
zhash_delete (hash, "LIVEBEEF");
|
186
|
+
item = (char *) zhash_lookup (hash, "LIVEBEEF");
|
187
|
+
assert (item == NULL);
|
188
|
+
assert (zhash_size (hash) == 3);
|
189
|
+
|
190
|
+
// Check that the queue is robust against random usage
|
191
|
+
struct {
|
192
|
+
char name [100];
|
193
|
+
bool exists;
|
194
|
+
} testset [200];
|
195
|
+
memset (testset, 0, sizeof (testset));
|
196
|
+
int testmax = 200, testnbr, iteration;
|
197
|
+
|
198
|
+
srandom ((unsigned) time (NULL));
|
199
|
+
for (iteration = 0; iteration < 25000; iteration++) {
|
200
|
+
testnbr = randof (testmax);
|
201
|
+
if (testset [testnbr].exists) {
|
202
|
+
item = (char *) zhash_lookup (hash, testset [testnbr].name);
|
203
|
+
assert (item);
|
204
|
+
zhash_delete (hash, testset [testnbr].name);
|
205
|
+
testset [testnbr].exists = false;
|
206
|
+
}
|
207
|
+
else {
|
208
|
+
sprintf (testset [testnbr].name, "%x-%x", rand (), rand ());
|
209
|
+
if (zhash_insert (hash, testset [testnbr].name, "") == 0)
|
210
|
+
testset [testnbr].exists = true;
|
211
|
+
}
|
212
|
+
}
|
213
|
+
// Test 10K lookups
|
214
|
+
for (iteration = 0; iteration < 10000; iteration++)
|
215
|
+
item = (char *) zhash_lookup (hash, "DEADBEEFABADCAFE");
|
216
|
+
|
217
|
+
// Destructor should be safe to call twice
|
218
|
+
zhash_destroy (&hash);
|
219
|
+
zhash_destroy (&hash);
|
220
|
+
assert (hash == NULL);
|
221
|
+
----
|
222
|
+
|
223
|
+
SEE ALSO
|
224
|
+
--------
|
225
|
+
linkczmq:czmq[7]
|
@@ -0,0 +1,176 @@
|
|
1
|
+
zlist(3)
|
2
|
+
========
|
3
|
+
|
4
|
+
NAME
|
5
|
+
----
|
6
|
+
zlist - generic type-free list container
|
7
|
+
|
8
|
+
SYNOPSIS
|
9
|
+
--------
|
10
|
+
----
|
11
|
+
// Comparison function for zlist_sort method
|
12
|
+
typedef bool (zlist_compare_fn) (void *item1, void *item2);
|
13
|
+
|
14
|
+
// Create a new list container
|
15
|
+
CZMQ_EXPORT zlist_t *
|
16
|
+
zlist_new (void);
|
17
|
+
|
18
|
+
// Destroy a list container
|
19
|
+
CZMQ_EXPORT void
|
20
|
+
zlist_destroy (zlist_t **self_p);
|
21
|
+
|
22
|
+
// Return first item in the list, or null
|
23
|
+
CZMQ_EXPORT void *
|
24
|
+
zlist_first (zlist_t *self);
|
25
|
+
|
26
|
+
// Return last item in the list, or null
|
27
|
+
CZMQ_EXPORT void *
|
28
|
+
zlist_last (zlist_t *self);
|
29
|
+
|
30
|
+
// Return first item in the list, or null, leaves the cursor
|
31
|
+
CZMQ_EXPORT void *
|
32
|
+
zlist_head (zlist_t *self);
|
33
|
+
|
34
|
+
// Return last item in the list, or null, leaves the cursor
|
35
|
+
CZMQ_EXPORT void *
|
36
|
+
zlist_tail (zlist_t *self);
|
37
|
+
|
38
|
+
// Return next item in the list, or null
|
39
|
+
CZMQ_EXPORT void *
|
40
|
+
zlist_next (zlist_t *self);
|
41
|
+
|
42
|
+
// Append an item to the end of the list
|
43
|
+
CZMQ_EXPORT int
|
44
|
+
zlist_append (zlist_t *self, void *item);
|
45
|
+
|
46
|
+
// Push an item to the start of the list
|
47
|
+
CZMQ_EXPORT int
|
48
|
+
zlist_push (zlist_t *self, void *item);
|
49
|
+
|
50
|
+
// Pop the item off the start of the list, if any
|
51
|
+
CZMQ_EXPORT void *
|
52
|
+
zlist_pop (zlist_t *self);
|
53
|
+
|
54
|
+
// Remove the specified item from the list if present
|
55
|
+
CZMQ_EXPORT void
|
56
|
+
zlist_remove (zlist_t *self, void *item);
|
57
|
+
|
58
|
+
// Copy the entire list, return the copy
|
59
|
+
CZMQ_EXPORT zlist_t *
|
60
|
+
zlist_dup (zlist_t *self);
|
61
|
+
|
62
|
+
// Copy the entire list, return the copy (deprecated)
|
63
|
+
CZMQ_EXPORT zlist_t *
|
64
|
+
zlist_copy (zlist_t *self);
|
65
|
+
|
66
|
+
// Return number of items in the list
|
67
|
+
CZMQ_EXPORT size_t
|
68
|
+
zlist_size (zlist_t *self);
|
69
|
+
|
70
|
+
// Sort list
|
71
|
+
CZMQ_EXPORT void
|
72
|
+
zlist_sort (zlist_t *self, zlist_compare_fn *compare);
|
73
|
+
|
74
|
+
// Set list for automatic item destruction
|
75
|
+
CZMQ_EXPORT void
|
76
|
+
zlist_autofree (zlist_t *self);
|
77
|
+
|
78
|
+
// Self test of this class
|
79
|
+
CZMQ_EXPORT void
|
80
|
+
zlist_test (int verbose);
|
81
|
+
----
|
82
|
+
|
83
|
+
DESCRIPTION
|
84
|
+
-----------
|
85
|
+
|
86
|
+
Provides a generic container implementing a fast singly-linked list. You
|
87
|
+
can use this to construct multi-dimensional lists, and other structures
|
88
|
+
together with other generic containers like zhash.
|
89
|
+
|
90
|
+
|
91
|
+
EXAMPLE
|
92
|
+
-------
|
93
|
+
.From zlist_test method
|
94
|
+
----
|
95
|
+
zlist_t *list = zlist_new ();
|
96
|
+
assert (list);
|
97
|
+
assert (zlist_size (list) == 0);
|
98
|
+
|
99
|
+
// Three items we'll use as test data
|
100
|
+
// List items are void *, not particularly strings
|
101
|
+
char *cheese = "boursin";
|
102
|
+
char *bread = "baguette";
|
103
|
+
char *wine = "bordeaux";
|
104
|
+
|
105
|
+
zlist_append (list, cheese);
|
106
|
+
assert (zlist_size (list) == 1);
|
107
|
+
zlist_append (list, bread);
|
108
|
+
assert (zlist_size (list) == 2);
|
109
|
+
zlist_append (list, wine);
|
110
|
+
assert (zlist_size (list) == 3);
|
111
|
+
|
112
|
+
assert (zlist_head (list) == cheese);
|
113
|
+
assert (zlist_next (list) == cheese);
|
114
|
+
|
115
|
+
assert (zlist_first (list) == cheese);
|
116
|
+
assert (zlist_tail (list) == wine);
|
117
|
+
assert (zlist_next (list) == bread);
|
118
|
+
|
119
|
+
assert (zlist_first (list) == cheese);
|
120
|
+
assert (zlist_next (list) == bread);
|
121
|
+
assert (zlist_next (list) == wine);
|
122
|
+
assert (zlist_next (list) == NULL);
|
123
|
+
// After we reach end of list, next wraps around
|
124
|
+
assert (zlist_next (list) == cheese);
|
125
|
+
assert (zlist_size (list) == 3);
|
126
|
+
|
127
|
+
zlist_remove (list, wine);
|
128
|
+
assert (zlist_size (list) == 2);
|
129
|
+
|
130
|
+
assert (zlist_first (list) == cheese);
|
131
|
+
zlist_remove (list, cheese);
|
132
|
+
assert (zlist_size (list) == 1);
|
133
|
+
assert (zlist_first (list) == bread);
|
134
|
+
|
135
|
+
zlist_remove (list, bread);
|
136
|
+
assert (zlist_size (list) == 0);
|
137
|
+
|
138
|
+
zlist_append (list, cheese);
|
139
|
+
zlist_append (list, bread);
|
140
|
+
assert (zlist_last (list) == bread);
|
141
|
+
zlist_remove (list, bread);
|
142
|
+
assert (zlist_last (list) == cheese);
|
143
|
+
zlist_remove (list, cheese);
|
144
|
+
assert (zlist_last (list) == NULL);
|
145
|
+
|
146
|
+
zlist_push (list, cheese);
|
147
|
+
assert (zlist_size (list) == 1);
|
148
|
+
assert (zlist_first (list) == cheese);
|
149
|
+
|
150
|
+
zlist_push (list, bread);
|
151
|
+
assert (zlist_size (list) == 2);
|
152
|
+
assert (zlist_first (list) == bread);
|
153
|
+
|
154
|
+
zlist_append (list, wine);
|
155
|
+
assert (zlist_size (list) == 3);
|
156
|
+
assert (zlist_first (list) == bread);
|
157
|
+
|
158
|
+
zlist_sort (list, s_compare);
|
159
|
+
char *item;
|
160
|
+
item = (char *) zlist_pop (list);
|
161
|
+
assert (item == bread);
|
162
|
+
item = (char *) zlist_pop (list);
|
163
|
+
assert (item == wine);
|
164
|
+
item = (char *) zlist_pop (list);
|
165
|
+
assert (item == cheese);
|
166
|
+
assert (zlist_size (list) == 0);
|
167
|
+
|
168
|
+
// Destructor should be safe to call twice
|
169
|
+
zlist_destroy (&list);
|
170
|
+
zlist_destroy (&list);
|
171
|
+
assert (list == NULL);
|
172
|
+
----
|
173
|
+
|
174
|
+
SEE ALSO
|
175
|
+
--------
|
176
|
+
linkczmq:czmq[7]
|