laag-libzmq 4.2.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +57 -0
- data/LICENSE.txt +181 -0
- data/README.org +34 -0
- data/ext/laag/libzmq/extconf.rb +22 -0
- data/laag-libzmq.gemspec +21 -0
- data/lib/laag/libzmq.rb +31 -0
- data/vendor/github.com/zeromq/libzmq/.github/PULL_REQUEST_TEMPLATE.md +28 -0
- data/vendor/github.com/zeromq/libzmq/.github/issue_template.md +22 -0
- data/vendor/github.com/zeromq/libzmq/.gitignore +180 -0
- data/vendor/github.com/zeromq/libzmq/.hgeol +2 -0
- data/vendor/github.com/zeromq/libzmq/.mailmap +81 -0
- data/vendor/github.com/zeromq/libzmq/.travis.yml +115 -0
- data/vendor/github.com/zeromq/libzmq/AUTHORS +151 -0
- data/vendor/github.com/zeromq/libzmq/CMakeLists.txt +1104 -0
- data/vendor/github.com/zeromq/libzmq/COPYING +674 -0
- data/vendor/github.com/zeromq/libzmq/COPYING.LESSER +181 -0
- data/vendor/github.com/zeromq/libzmq/Dockerfile +11 -0
- data/vendor/github.com/zeromq/libzmq/Doxygen.cfg +2320 -0
- data/vendor/github.com/zeromq/libzmq/FindSodium.cmake +40 -0
- data/vendor/github.com/zeromq/libzmq/INSTALL +311 -0
- data/vendor/github.com/zeromq/libzmq/Jenkinsfile +369 -0
- data/vendor/github.com/zeromq/libzmq/Makefile.am +908 -0
- data/vendor/github.com/zeromq/libzmq/NEWS +1582 -0
- data/vendor/github.com/zeromq/libzmq/README.cygwin.md +15 -0
- data/vendor/github.com/zeromq/libzmq/README.doxygen.md +48 -0
- data/vendor/github.com/zeromq/libzmq/README.md +102 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/AndreLouisCaron.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/Asmod4n.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/BerndPrager.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/Bklyn.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/BrianBuchanan.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ChuckRemes.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/FrancoFichtner.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/GavinMcNiff.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/GhislainPutois.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/GiuseppeCorbelli.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/HaraldAchitz.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/Hugne.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/JimHague.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/JohanMabille.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/LeonardMichelet +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/LeonardoConsoni.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/LionelOrry.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/OsirisPedroso.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/README.md +23 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/RobGagnon.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/SebastienRombauts.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/StoianIvanov.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/SylvainCorlay.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/TimotheeBesset.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/VincentTellier.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/VolodymyrKorniichuk.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/abbradar.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/agronholm.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/amuraru.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/arsenm.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/aseering.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/bjorntopel.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/bjovke.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/brocade_communications_systems.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/brunobodin.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/c-rack.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/camachat.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/cdolan.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/chrisstaite.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/chugga_fan.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/cjuniet.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ckamm.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/clkao.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/danielhtshih.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/danriegsecker.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/dfons.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/djelenc.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/drodri.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/eburkitt.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/egomotion.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/evoskuil.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/febeling.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/fidlej.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/flub.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/gena-moscow.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/gonzus.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/goodfella_ltd.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/google.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ianbarber.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/imatix.md +23 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jakecobb.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jemc.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jimklimov.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jkryl.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/johntconklin.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/jruffin.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kentzo.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kevinsapper.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kobolog.md +12 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/kurdybacha.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/linville.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/loachfish.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/lodagro.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/madebr.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mattconnolly.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mauri-melato.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mditzel.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/meox.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/michael-fox.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/michicc.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/minrk.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mipaaa.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/mkluwe.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/montoyaedu.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/naos_ltd.md +19 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/natano.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/olafmandel.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/pijyoi.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ptroja.md +14 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/reunanen.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/reza-ebrahimi.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rikvdh.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rlenferink.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/roalz.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rodgert.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/rotty.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/sabae.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/scemama.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/sheremetyev.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/shripchenko.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/sigiesec.md +17 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/soulik.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/swansontec.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/t-b.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/tSed.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/tabe.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/tailhook.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/taotetek.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2-any-osi.txt +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2-share-alike-osi.txt +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2.txt +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/thompsa.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/torehalvorsen.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/twhittock.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/ulikoehler.md +16 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/vyskocilm.md +7 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/willstrang.md +15 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/xaqq.md +13 -0
- data/vendor/github.com/zeromq/libzmq/RELICENSE/yuvallanger.md +15 -0
- data/vendor/github.com/zeromq/libzmq/ZeroMQConfig.cmake.in +25 -0
- data/vendor/github.com/zeromq/libzmq/acinclude.m4 +1122 -0
- data/vendor/github.com/zeromq/libzmq/appveyor.yml +97 -0
- data/vendor/github.com/zeromq/libzmq/autogen.sh +49 -0
- data/vendor/github.com/zeromq/libzmq/branding.bmp +0 -0
- data/vendor/github.com/zeromq/libzmq/builds/Makefile.am +31 -0
- data/vendor/github.com/zeromq/libzmq/builds/README +4 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/Dockerfile +22 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/README.md +78 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/android_build_helper.sh +316 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/build.sh +70 -0
- data/vendor/github.com/zeromq/libzmq/builds/android/ci_build.sh +30 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/FindAsciiDoc.cmake +26 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/TestZMQVersion.cmake +8 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/ZMQSourceRunChecks.cmake +301 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/NSIS.template32.in +952 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/NSIS.template64.in +960 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/ci_build.sh +34 -0
- data/vendor/github.com/zeromq/libzmq/builds/cmake/platform.hpp.in +104 -0
- data/vendor/github.com/zeromq/libzmq/builds/coverage/ci_build.sh +32 -0
- data/vendor/github.com/zeromq/libzmq/builds/cygwin/Makefile.cygwin +48 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/.gitignore +5 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/build.bat +4 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/platform.hpp +80 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.gsl +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.gypi +895 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.xml +83 -0
- data/vendor/github.com/zeromq/libzmq/builds/gyp/project.gyp +295 -0
- data/vendor/github.com/zeromq/libzmq/builds/mingw32/Makefile.mingw32 +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/mingw32/platform.hpp +43 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/.gitignore +256 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/Makefile.am +94 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/build/build.bat +33 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/build/buildall.bat +16 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/build/buildbase.bat +73 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/errno.cpp +32 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/errno.hpp +56 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/platform.hpp +14 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Common.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DLL.props +16 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Debug.props +29 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugDEXE.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugDLL.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLIB.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLTCG.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugSEXE.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/EXE.props +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/LIB.props +16 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/LTCG.props +13 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Link.props +21 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Messages.props +15 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Output.props +30 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Release.props +41 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseDEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseDLL.props +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLIB.props +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLTCG.props +19 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseSEXE.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Win32.props +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/x64.props +23 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/readme.txt +27 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/resource.h +14 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/resource.rc +0 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/inproc_lat/inproc_lat.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/inproc_thr/inproc_thr.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/libzmq.sln +95 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/libzmq/libzmq.vcproj +338 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/local_lat/local_lat.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/local_thr/local_thr.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/remote_lat/remote_lat.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/remote_thr/remote_thr.vcproj +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.sln +206 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.sln +206 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.sln +208 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.sln +208 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/libzmq.vcxproj +258 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/platform.hpp +15 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/test_zmq/test_multithread.cpp +229 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/test_zmq/test_zmq.vcxproj +155 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_lat/inproc_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_lat/inproc_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_thr/inproc_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_thr/inproc_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libsodium.import.props +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libsodium.import.xml +17 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.import.props +64 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.import.xml +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.sln +208 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.props +76 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.vcxproj +289 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.vcxproj.filters +627 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.xml +40 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_lat/local_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_lat/local_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_thr/local_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_thr/local_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_lat/remote_lat.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_lat/remote_lat.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_thr/remote_thr.props +49 -0
- data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_thr/remote_thr.vcxproj +82 -0
- data/vendor/github.com/zeromq/libzmq/builds/nuget/libzmq.autopkg +52 -0
- data/vendor/github.com/zeromq/libzmq/builds/nuget/readme.nuget +20 -0
- data/vendor/github.com/zeromq/libzmq/builds/openwrt/Makefile +70 -0
- data/vendor/github.com/zeromq/libzmq/builds/valgrind/ci_build.sh +30 -0
- data/vendor/github.com/zeromq/libzmq/builds/valgrind/valgrind.supp +22 -0
- data/vendor/github.com/zeromq/libzmq/builds/valgrind/vg +1 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/README.md +463 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/cxxall +62 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/makeclean +36 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/makelibzmq +54 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/maketests +102 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/platform.hpp +300 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/runtests +188 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/test_fork.cpp +95 -0
- data/vendor/github.com/zeromq/libzmq/builds/zos/zc++ +42 -0
- data/vendor/github.com/zeromq/libzmq/ci_build.sh +66 -0
- data/vendor/github.com/zeromq/libzmq/ci_deploy.sh +34 -0
- data/vendor/github.com/zeromq/libzmq/configure.ac +827 -0
- data/vendor/github.com/zeromq/libzmq/doc/Makefile.am +64 -0
- data/vendor/github.com/zeromq/libzmq/doc/asciidoc.conf +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq.txt +276 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_dec.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_destroy.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_inc.txt +61 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_new.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_set.txt +61 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_value.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_bind.txt +103 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_close.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_connect.txt +101 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_destroy.txt +67 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_get.txt +105 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_new.txt +50 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_set.txt +184 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_shutdown.txt +52 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_term.txt +68 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_curve.txt +92 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_curve_keypair.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_curve_public.txt +62 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_disconnect.txt +75 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_errno.txt +50 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_getsockopt.txt +944 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_gssapi.txt +78 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_has.txt +44 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_init.txt +52 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_inproc.txt +88 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_ipc.txt +106 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_close.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_copy.txt +72 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_data.txt +48 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_get.txt +83 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_gets.txt +81 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init.txt +64 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init_data.txt +89 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init_size.txt +58 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_more.txt +65 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_move.txt +52 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_recv.txt +124 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_routing_id.txt +61 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_send.txt +127 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_set.txt +46 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_set_routing_id.txt +46 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_size.txt +48 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_null.txt +27 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_pgm.txt +164 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_plain.txt +37 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_poll.txt +135 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_proxy.txt +99 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_proxy_steerable.txt +111 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_recv.txt +91 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_recvmsg.txt +121 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_send.txt +104 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_send_const.txt +103 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_sendmsg.txt +121 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_setsockopt.txt +1318 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_socket.txt +609 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_socket_monitor.txt +294 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_strerror.txt +56 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_tcp.txt +118 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_term.txt +66 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_tipc.txt +83 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_udp.txt +99 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_unbind.txt +90 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_version.txt +54 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_vmci.txt +97 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_z85_decode.txt +51 -0
- data/vendor/github.com/zeromq/libzmq/doc/zmq_z85_encode.txt +58 -0
- data/vendor/github.com/zeromq/libzmq/include/zmq.h +708 -0
- data/vendor/github.com/zeromq/libzmq/include/zmq_utils.h +48 -0
- data/vendor/github.com/zeromq/libzmq/installer.ico +0 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_check_compile_flag.m4 +74 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_code_coverage.m4 +264 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_cxx_compile_stdcxx.m4 +562 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_cxx_compile_stdcxx_11.m4 +40 -0
- data/vendor/github.com/zeromq/libzmq/m4/ax_valgrind_check.m4 +233 -0
- data/vendor/github.com/zeromq/libzmq/packaging/README +4 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/changelog +5 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/compat +1 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/control +64 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/copyright +93 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq3-dev.install +4 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq3-dev.manpages +2 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq5.docs +2 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq5.install +1 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/rules +67 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/source/format +1 -0
- data/vendor/github.com/zeromq/libzmq/packaging/debian/zeromq.dsc.obs +15 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.bat +14 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.config +6 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.gsl +264 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.nuspec +98 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.targets +129 -0
- data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.xml +22 -0
- data/vendor/github.com/zeromq/libzmq/packaging/obs/_service +98 -0
- data/vendor/github.com/zeromq/libzmq/packaging/redhat/zeromq.spec +234 -0
- data/vendor/github.com/zeromq/libzmq/perf/inproc_lat.cpp +240 -0
- data/vendor/github.com/zeromq/libzmq/perf/inproc_thr.cpp +250 -0
- data/vendor/github.com/zeromq/libzmq/perf/local_lat.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/perf/local_thr.cpp +160 -0
- data/vendor/github.com/zeromq/libzmq/perf/remote_lat.cpp +129 -0
- data/vendor/github.com/zeromq/libzmq/perf/remote_thr.cpp +135 -0
- data/vendor/github.com/zeromq/libzmq/src/address.cpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/address.hpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/array.hpp +167 -0
- data/vendor/github.com/zeromq/libzmq/src/atomic_counter.hpp +249 -0
- data/vendor/github.com/zeromq/libzmq/src/atomic_ptr.hpp +227 -0
- data/vendor/github.com/zeromq/libzmq/src/blob.hpp +186 -0
- data/vendor/github.com/zeromq/libzmq/src/client.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/src/client.hpp +81 -0
- data/vendor/github.com/zeromq/libzmq/src/clock.cpp +253 -0
- data/vendor/github.com/zeromq/libzmq/src/clock.hpp +83 -0
- data/vendor/github.com/zeromq/libzmq/src/command.hpp +188 -0
- data/vendor/github.com/zeromq/libzmq/src/condition_variable.hpp +279 -0
- data/vendor/github.com/zeromq/libzmq/src/config.hpp +98 -0
- data/vendor/github.com/zeromq/libzmq/src/ctx.cpp +644 -0
- data/vendor/github.com/zeromq/libzmq/src/ctx.hpp +242 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_client.cpp +297 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_client.hpp +87 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_client_tools.hpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_mechanism_base.cpp +181 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_mechanism_base.hpp +79 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_server.cpp +492 -0
- data/vendor/github.com/zeromq/libzmq/src/curve_server.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/dbuffer.hpp +144 -0
- data/vendor/github.com/zeromq/libzmq/src/dealer.cpp +143 -0
- data/vendor/github.com/zeromq/libzmq/src/dealer.hpp +89 -0
- data/vendor/github.com/zeromq/libzmq/src/decoder.hpp +198 -0
- data/vendor/github.com/zeromq/libzmq/src/decoder_allocators.cpp +144 -0
- data/vendor/github.com/zeromq/libzmq/src/decoder_allocators.hpp +155 -0
- data/vendor/github.com/zeromq/libzmq/src/devpoll.cpp +205 -0
- data/vendor/github.com/zeromq/libzmq/src/devpoll.hpp +119 -0
- data/vendor/github.com/zeromq/libzmq/src/dgram.cpp +177 -0
- data/vendor/github.com/zeromq/libzmq/src/dgram.hpp +81 -0
- data/vendor/github.com/zeromq/libzmq/src/dish.cpp +360 -0
- data/vendor/github.com/zeromq/libzmq/src/dish.hpp +125 -0
- data/vendor/github.com/zeromq/libzmq/src/dist.cpp +235 -0
- data/vendor/github.com/zeromq/libzmq/src/dist.hpp +120 -0
- data/vendor/github.com/zeromq/libzmq/src/encoder.hpp +189 -0
- data/vendor/github.com/zeromq/libzmq/src/epoll.cpp +206 -0
- data/vendor/github.com/zeromq/libzmq/src/epoll.hpp +119 -0
- data/vendor/github.com/zeromq/libzmq/src/err.cpp +447 -0
- data/vendor/github.com/zeromq/libzmq/src/err.hpp +173 -0
- data/vendor/github.com/zeromq/libzmq/src/fd.hpp +52 -0
- data/vendor/github.com/zeromq/libzmq/src/fq.cpp +163 -0
- data/vendor/github.com/zeromq/libzmq/src/fq.hpp +92 -0
- data/vendor/github.com/zeromq/libzmq/src/gather.cpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/gather.hpp +75 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_client.cpp +237 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_client.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_mechanism_base.cpp +402 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_mechanism_base.hpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_server.cpp +249 -0
- data/vendor/github.com/zeromq/libzmq/src/gssapi_server.hpp +95 -0
- data/vendor/github.com/zeromq/libzmq/src/i_decoder.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/i_encoder.hpp +60 -0
- data/vendor/github.com/zeromq/libzmq/src/i_engine.hpp +68 -0
- data/vendor/github.com/zeromq/libzmq/src/i_mailbox.hpp +60 -0
- data/vendor/github.com/zeromq/libzmq/src/i_poll_events.hpp +55 -0
- data/vendor/github.com/zeromq/libzmq/src/io_object.cpp +117 -0
- data/vendor/github.com/zeromq/libzmq/src/io_object.hpp +89 -0
- data/vendor/github.com/zeromq/libzmq/src/io_thread.cpp +114 -0
- data/vendor/github.com/zeromq/libzmq/src/io_thread.hpp +99 -0
- data/vendor/github.com/zeromq/libzmq/src/ip.cpp +235 -0
- data/vendor/github.com/zeromq/libzmq/src/ip.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_address.cpp +106 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_address.hpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_connecter.cpp +278 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_connecter.hpp +135 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_listener.cpp +427 -0
- data/vendor/github.com/zeromq/libzmq/src/ipc_listener.hpp +123 -0
- data/vendor/github.com/zeromq/libzmq/src/kqueue.cpp +227 -0
- data/vendor/github.com/zeromq/libzmq/src/kqueue.hpp +127 -0
- data/vendor/github.com/zeromq/libzmq/src/lb.cpp +173 -0
- data/vendor/github.com/zeromq/libzmq/src/lb.hpp +88 -0
- data/vendor/github.com/zeromq/libzmq/src/libzmq.pc.cmake.in +11 -0
- data/vendor/github.com/zeromq/libzmq/src/libzmq.pc.in +11 -0
- data/vendor/github.com/zeromq/libzmq/src/libzmq.vers +4 -0
- data/vendor/github.com/zeromq/libzmq/src/likely.hpp +42 -0
- data/vendor/github.com/zeromq/libzmq/src/macros.hpp +12 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox.cpp +101 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox.hpp +90 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox_safe.cpp +117 -0
- data/vendor/github.com/zeromq/libzmq/src/mailbox_safe.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism.cpp +285 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism.hpp +152 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism_base.cpp +70 -0
- data/vendor/github.com/zeromq/libzmq/src/mechanism_base.hpp +53 -0
- data/vendor/github.com/zeromq/libzmq/src/metadata.cpp +62 -0
- data/vendor/github.com/zeromq/libzmq/src/metadata.hpp +70 -0
- data/vendor/github.com/zeromq/libzmq/src/msg.cpp +578 -0
- data/vendor/github.com/zeromq/libzmq/src/msg.hpp +268 -0
- data/vendor/github.com/zeromq/libzmq/src/mtrie.cpp +434 -0
- data/vendor/github.com/zeromq/libzmq/src/mtrie.hpp +102 -0
- data/vendor/github.com/zeromq/libzmq/src/mutex.hpp +213 -0
- data/vendor/github.com/zeromq/libzmq/src/norm_engine.cpp +736 -0
- data/vendor/github.com/zeromq/libzmq/src/norm_engine.hpp +190 -0
- data/vendor/github.com/zeromq/libzmq/src/null_mechanism.cpp +220 -0
- data/vendor/github.com/zeromq/libzmq/src/null_mechanism.hpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/object.cpp +476 -0
- data/vendor/github.com/zeromq/libzmq/src/object.hpp +156 -0
- data/vendor/github.com/zeromq/libzmq/src/options.cpp +1089 -0
- data/vendor/github.com/zeromq/libzmq/src/options.hpp +251 -0
- data/vendor/github.com/zeromq/libzmq/src/own.cpp +216 -0
- data/vendor/github.com/zeromq/libzmq/src/own.hpp +154 -0
- data/vendor/github.com/zeromq/libzmq/src/pair.cpp +142 -0
- data/vendor/github.com/zeromq/libzmq/src/pair.hpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_receiver.cpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_receiver.hpp +147 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_sender.cpp +257 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_sender.hpp +124 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_socket.cpp +712 -0
- data/vendor/github.com/zeromq/libzmq/src/pgm_socket.hpp +128 -0
- data/vendor/github.com/zeromq/libzmq/src/pipe.cpp +547 -0
- data/vendor/github.com/zeromq/libzmq/src/pipe.hpp +253 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_client.cpp +220 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_client.hpp +79 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_server.cpp +253 -0
- data/vendor/github.com/zeromq/libzmq/src/plain_server.hpp +71 -0
- data/vendor/github.com/zeromq/libzmq/src/poll.cpp +193 -0
- data/vendor/github.com/zeromq/libzmq/src/poll.hpp +121 -0
- data/vendor/github.com/zeromq/libzmq/src/poller.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/poller_base.cpp +110 -0
- data/vendor/github.com/zeromq/libzmq/src/poller_base.hpp +95 -0
- data/vendor/github.com/zeromq/libzmq/src/pollset.cpp +254 -0
- data/vendor/github.com/zeromq/libzmq/src/pollset.hpp +121 -0
- data/vendor/github.com/zeromq/libzmq/src/precompiled.cpp +30 -0
- data/vendor/github.com/zeromq/libzmq/src/precompiled.hpp +120 -0
- data/vendor/github.com/zeromq/libzmq/src/proxy.cpp +622 -0
- data/vendor/github.com/zeromq/libzmq/src/proxy.hpp +42 -0
- data/vendor/github.com/zeromq/libzmq/src/pub.cpp +67 -0
- data/vendor/github.com/zeromq/libzmq/src/pub.hpp +63 -0
- data/vendor/github.com/zeromq/libzmq/src/pull.cpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/pull.hpp +75 -0
- data/vendor/github.com/zeromq/libzmq/src/push.cpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/push.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/radio.cpp +252 -0
- data/vendor/github.com/zeromq/libzmq/src/radio.hpp +112 -0
- data/vendor/github.com/zeromq/libzmq/src/random.cpp +118 -0
- data/vendor/github.com/zeromq/libzmq/src/random.hpp +52 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_decoder.cpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_decoder.hpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_encoder.cpp +51 -0
- data/vendor/github.com/zeromq/libzmq/src/raw_encoder.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/reaper.cpp +142 -0
- data/vendor/github.com/zeromq/libzmq/src/reaper.hpp +94 -0
- data/vendor/github.com/zeromq/libzmq/src/rep.cpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/rep.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/req.cpp +323 -0
- data/vendor/github.com/zeromq/libzmq/src/req.hpp +121 -0
- data/vendor/github.com/zeromq/libzmq/src/router.cpp +551 -0
- data/vendor/github.com/zeromq/libzmq/src/router.hpp +147 -0
- data/vendor/github.com/zeromq/libzmq/src/scatter.cpp +83 -0
- data/vendor/github.com/zeromq/libzmq/src/scatter.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/select.cpp +567 -0
- data/vendor/github.com/zeromq/libzmq/src/select.hpp +184 -0
- data/vendor/github.com/zeromq/libzmq/src/server.cpp +184 -0
- data/vendor/github.com/zeromq/libzmq/src/server.hpp +96 -0
- data/vendor/github.com/zeromq/libzmq/src/session_base.cpp +716 -0
- data/vendor/github.com/zeromq/libzmq/src/session_base.hpp +173 -0
- data/vendor/github.com/zeromq/libzmq/src/signaler.cpp +682 -0
- data/vendor/github.com/zeromq/libzmq/src/signaler.hpp +91 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_base.cpp +1778 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_base.hpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_poller.cpp +697 -0
- data/vendor/github.com/zeromq/libzmq/src/socket_poller.hpp +145 -0
- data/vendor/github.com/zeromq/libzmq/src/socks.cpp +286 -0
- data/vendor/github.com/zeromq/libzmq/src/socks.hpp +135 -0
- data/vendor/github.com/zeromq/libzmq/src/socks_connecter.cpp +482 -0
- data/vendor/github.com/zeromq/libzmq/src/socks_connecter.hpp +163 -0
- data/vendor/github.com/zeromq/libzmq/src/stdint.hpp +77 -0
- data/vendor/github.com/zeromq/libzmq/src/stream.cpp +321 -0
- data/vendor/github.com/zeromq/libzmq/src/stream.hpp +107 -0
- data/vendor/github.com/zeromq/libzmq/src/stream_engine.cpp +1110 -0
- data/vendor/github.com/zeromq/libzmq/src/stream_engine.hpp +233 -0
- data/vendor/github.com/zeromq/libzmq/src/sub.cpp +87 -0
- data/vendor/github.com/zeromq/libzmq/src/sub.hpp +64 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp.cpp +356 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp.hpp +69 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_address.cpp +897 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_address.hpp +117 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_connecter.cpp +426 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_connecter.hpp +134 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_listener.cpp +357 -0
- data/vendor/github.com/zeromq/libzmq/src/tcp_listener.hpp +98 -0
- data/vendor/github.com/zeromq/libzmq/src/thread.cpp +238 -0
- data/vendor/github.com/zeromq/libzmq/src/thread.hpp +102 -0
- data/vendor/github.com/zeromq/libzmq/src/timers.cpp +199 -0
- data/vendor/github.com/zeromq/libzmq/src/timers.hpp +110 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_address.cpp +124 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_address.hpp +75 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_connecter.cpp +268 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_connecter.hpp +137 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_listener.cpp +190 -0
- data/vendor/github.com/zeromq/libzmq/src/tipc_listener.hpp +107 -0
- data/vendor/github.com/zeromq/libzmq/src/trie.cpp +340 -0
- data/vendor/github.com/zeromq/libzmq/src/trie.hpp +86 -0
- data/vendor/github.com/zeromq/libzmq/src/tweetnacl.c +988 -0
- data/vendor/github.com/zeromq/libzmq/src/tweetnacl.h +75 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_address.cpp +172 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_address.hpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_engine.cpp +394 -0
- data/vendor/github.com/zeromq/libzmq/src/udp_engine.hpp +73 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_decoder.cpp +153 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_decoder.hpp +69 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_encoder.cpp +76 -0
- data/vendor/github.com/zeromq/libzmq/src/v1_encoder.hpp +59 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_decoder.cpp +161 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_decoder.hpp +74 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_encoder.cpp +78 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_encoder.hpp +59 -0
- data/vendor/github.com/zeromq/libzmq/src/v2_protocol.hpp +49 -0
- data/vendor/github.com/zeromq/libzmq/src/version.rc.in +93 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci.cpp +88 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci.hpp +60 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_address.cpp +170 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_address.hpp +71 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_connecter.cpp +307 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_connecter.hpp +136 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_listener.cpp +262 -0
- data/vendor/github.com/zeromq/libzmq/src/vmci_listener.hpp +102 -0
- data/vendor/github.com/zeromq/libzmq/src/windows.hpp +93 -0
- data/vendor/github.com/zeromq/libzmq/src/wire.hpp +108 -0
- data/vendor/github.com/zeromq/libzmq/src/xpub.cpp +340 -0
- data/vendor/github.com/zeromq/libzmq/src/xpub.hpp +126 -0
- data/vendor/github.com/zeromq/libzmq/src/xsub.cpp +251 -0
- data/vendor/github.com/zeromq/libzmq/src/xsub.hpp +103 -0
- data/vendor/github.com/zeromq/libzmq/src/ypipe.hpp +218 -0
- data/vendor/github.com/zeromq/libzmq/src/ypipe_base.hpp +54 -0
- data/vendor/github.com/zeromq/libzmq/src/ypipe_conflate.hpp +137 -0
- data/vendor/github.com/zeromq/libzmq/src/yqueue.hpp +225 -0
- data/vendor/github.com/zeromq/libzmq/src/zap_client.cpp +305 -0
- data/vendor/github.com/zeromq/libzmq/src/zap_client.hpp +100 -0
- data/vendor/github.com/zeromq/libzmq/src/zmq.cpp +1527 -0
- data/vendor/github.com/zeromq/libzmq/src/zmq_draft.h +178 -0
- data/vendor/github.com/zeromq/libzmq/src/zmq_utils.cpp +318 -0
- data/vendor/github.com/zeromq/libzmq/tests/CMakeLists.txt +218 -0
- data/vendor/github.com/zeromq/libzmq/tests/README.md +28 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_abstract_ipc.cpp +67 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ancillaries.cpp +51 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_atomics.cpp +48 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_base85.cpp +162 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_bind_after_connect_tcp.cpp +97 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_bind_src_address.cpp +57 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_capabilities.cpp +82 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_client_server.cpp +106 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_conflate.cpp +86 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_connect_delay_tipc.cpp +238 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_connect_resolve.cpp +70 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_connect_rid.cpp +199 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ctx_destroy.cpp +110 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ctx_options.cpp +204 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_dgram.cpp +99 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_diffserv.cpp +85 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_disconnect_inproc.cpp +136 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_filter_ipc.cpp +166 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_fork.cpp +99 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_getsockopt_memset.cpp +64 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_heartbeats.cpp +341 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_hwm.cpp +312 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_hwm_pubsub.cpp +253 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_immediate.cpp +250 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_inproc_connect.cpp +536 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_invalid_rep.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_iov.cpp +157 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_ipc_wildcard.cpp +65 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_issue_566.cpp +99 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_last_endpoint.cpp +66 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_many_sockets.cpp +100 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_metadata.cpp +134 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_monitor.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_msg_ffn.cpp +145 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_msg_flags.cpp +127 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_inproc.cpp +81 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_ipc.cpp +60 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_tcp.cpp +64 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_tipc.cpp +62 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pair_vmci.cpp +68 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_poller.cpp +404 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_probe_router.cpp +86 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_proxy.cpp +486 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_proxy_single_socket.cpp +121 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_proxy_terminate.cpp +132 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_pub_invert_matching.cpp +136 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_radio_dish.cpp +191 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_rebind_ipc.cpp +84 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reconnect_ivl.cpp +149 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_req_correlate.cpp +140 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_req_relaxed.cpp +220 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_device.cpp +153 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_device_tipc.cpp +146 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_inproc.cpp +60 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_ipc.cpp +112 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_tcp.cpp +336 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_tipc.cpp +61 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_vmci.cpp +68 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_handover.cpp +116 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory.cpp +292 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory_hwm.cpp +129 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory_tipc.cpp +70 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_scatter_gather.cpp +84 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_curve.cpp +792 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_gssapi.cpp +362 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_null.cpp +209 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_plain.cpp +212 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_security_zap.cpp +417 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_setsockopt.cpp +153 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_shutdown_stress.cpp +101 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_shutdown_stress_tipc.cpp +95 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_socket_null.cpp +82 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sockopt_hwm.cpp +190 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sodium.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_dealer.cpp +266 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_pushpull.cpp +304 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_rep.cpp +169 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_req.cpp +266 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_spec_router.cpp +217 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_srcfd.cpp +127 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream.cpp +342 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_disconnect.cpp +295 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_empty.cpp +74 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_exceeds_buffer.cpp +124 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_stream_timeout.cpp +235 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sub_forward.cpp +109 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_sub_forward_tipc.cpp +102 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_system.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_term_endpoint.cpp +226 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_term_endpoint_tipc.cpp +120 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_thread_safe.cpp +90 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_timeo.cpp +85 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_timers.cpp +226 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_udp.cpp +133 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_unbind_inproc.cpp +43 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_unbind_wildcard.cpp +216 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_use_fd_ipc.cpp +223 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_use_fd_tcp.cpp +238 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_xpub_manual.cpp +597 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_xpub_nodrop.cpp +118 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_xpub_welcome_msg.cpp +81 -0
- data/vendor/github.com/zeromq/libzmq/tests/test_zmq_poll_fd.cpp +98 -0
- data/vendor/github.com/zeromq/libzmq/tests/testutil.hpp +408 -0
- data/vendor/github.com/zeromq/libzmq/tests/testutil_security.hpp +684 -0
- data/vendor/github.com/zeromq/libzmq/tools/curve_keygen.cpp +58 -0
- data/vendor/github.com/zeromq/libzmq/version.sh +21 -0
- metadata +875 -0
@@ -0,0 +1,147 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
|
3
|
+
|
4
|
+
This file is part of libzmq, the ZeroMQ core engine in C++.
|
5
|
+
|
6
|
+
libzmq is free software; you can redistribute it and/or modify it under
|
7
|
+
the terms of the GNU Lesser General Public License (LGPL) as published
|
8
|
+
by the Free Software Foundation; either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
As a special exception, the Contributors give you permission to link
|
12
|
+
this library with independent modules to produce an executable,
|
13
|
+
regardless of the license terms of these independent modules, and to
|
14
|
+
copy and distribute the resulting executable under terms of your choice,
|
15
|
+
provided that you also meet, for each linked independent module, the
|
16
|
+
terms and conditions of the license of that module. An independent
|
17
|
+
module is a module which is not derived from or based on this library.
|
18
|
+
If you modify this library, you must extend this exception to your
|
19
|
+
version of the library.
|
20
|
+
|
21
|
+
libzmq is distributed in the hope that it will be useful, but WITHOUT
|
22
|
+
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
23
|
+
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
24
|
+
License for more details.
|
25
|
+
|
26
|
+
You should have received a copy of the GNU Lesser General Public License
|
27
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
28
|
+
*/
|
29
|
+
|
30
|
+
#ifndef __ZMQ_ROUTER_HPP_INCLUDED__
|
31
|
+
#define __ZMQ_ROUTER_HPP_INCLUDED__
|
32
|
+
|
33
|
+
#include <map>
|
34
|
+
|
35
|
+
#include "socket_base.hpp"
|
36
|
+
#include "session_base.hpp"
|
37
|
+
#include "stdint.hpp"
|
38
|
+
#include "blob.hpp"
|
39
|
+
#include "msg.hpp"
|
40
|
+
#include "fq.hpp"
|
41
|
+
|
42
|
+
namespace zmq
|
43
|
+
{
|
44
|
+
|
45
|
+
class ctx_t;
|
46
|
+
class pipe_t;
|
47
|
+
|
48
|
+
// TODO: This class uses O(n) scheduling. Rewrite it to use O(1) algorithm.
|
49
|
+
class router_t :
|
50
|
+
public socket_base_t
|
51
|
+
{
|
52
|
+
public:
|
53
|
+
|
54
|
+
router_t (zmq::ctx_t *parent_, uint32_t tid_, int sid);
|
55
|
+
~router_t ();
|
56
|
+
|
57
|
+
// Overrides of functions from socket_base_t.
|
58
|
+
void xattach_pipe (zmq::pipe_t *pipe_, bool subscribe_to_all_);
|
59
|
+
int xsetsockopt (int option_, const void *optval_, size_t optvallen_);
|
60
|
+
int xsend (zmq::msg_t *msg_);
|
61
|
+
int xrecv (zmq::msg_t *msg_);
|
62
|
+
bool xhas_in ();
|
63
|
+
bool xhas_out ();
|
64
|
+
void xread_activated (zmq::pipe_t *pipe_);
|
65
|
+
void xwrite_activated (zmq::pipe_t *pipe_);
|
66
|
+
void xpipe_terminated (zmq::pipe_t *pipe_);
|
67
|
+
int get_peer_state (const void *identity, size_t identity_size) const;
|
68
|
+
|
69
|
+
protected:
|
70
|
+
|
71
|
+
// Rollback any message parts that were sent but not yet flushed.
|
72
|
+
int rollback ();
|
73
|
+
const blob_t &get_credential () const;
|
74
|
+
|
75
|
+
private:
|
76
|
+
|
77
|
+
// Receive peer id and update lookup map
|
78
|
+
bool identify_peer (pipe_t *pipe_);
|
79
|
+
|
80
|
+
// Fair queueing object for inbound pipes.
|
81
|
+
fq_t fq;
|
82
|
+
|
83
|
+
// True iff there is a message held in the pre-fetch buffer.
|
84
|
+
bool prefetched;
|
85
|
+
|
86
|
+
// If true, the receiver got the message part with
|
87
|
+
// the peer's identity.
|
88
|
+
bool routing_id_sent;
|
89
|
+
|
90
|
+
// Holds the prefetched identity.
|
91
|
+
msg_t prefetched_id;
|
92
|
+
|
93
|
+
// Holds the prefetched message.
|
94
|
+
msg_t prefetched_msg;
|
95
|
+
|
96
|
+
// The pipe we are currently reading from
|
97
|
+
zmq::pipe_t *current_in;
|
98
|
+
|
99
|
+
// Should current_in should be terminate after all parts received?
|
100
|
+
bool terminate_current_in;
|
101
|
+
|
102
|
+
// If true, more incoming message parts are expected.
|
103
|
+
bool more_in;
|
104
|
+
|
105
|
+
struct outpipe_t
|
106
|
+
{
|
107
|
+
zmq::pipe_t *pipe;
|
108
|
+
bool active;
|
109
|
+
};
|
110
|
+
|
111
|
+
// We keep a set of pipes that have not been identified yet.
|
112
|
+
std::set <pipe_t*> anonymous_pipes;
|
113
|
+
|
114
|
+
// Outbound pipes indexed by the peer IDs.
|
115
|
+
typedef std::map <blob_t, outpipe_t> outpipes_t;
|
116
|
+
outpipes_t outpipes;
|
117
|
+
|
118
|
+
// The pipe we are currently writing to.
|
119
|
+
zmq::pipe_t *current_out;
|
120
|
+
|
121
|
+
// If true, more outgoing message parts are expected.
|
122
|
+
bool more_out;
|
123
|
+
|
124
|
+
// Routing IDs are generated. It's a simple increment and wrap-over
|
125
|
+
// algorithm. This value is the next ID to use (if not used already).
|
126
|
+
uint32_t next_integral_routing_id;
|
127
|
+
|
128
|
+
// If true, report EAGAIN to the caller instead of silently dropping
|
129
|
+
// the message targeting an unknown peer.
|
130
|
+
bool mandatory;
|
131
|
+
bool raw_socket;
|
132
|
+
|
133
|
+
// if true, send an empty message to every connected router peer
|
134
|
+
bool probe_router;
|
135
|
+
|
136
|
+
// If true, the router will reassign an identity upon encountering a
|
137
|
+
// name collision. The new pipe will take the identity, the old pipe
|
138
|
+
// will be terminated.
|
139
|
+
bool handover;
|
140
|
+
|
141
|
+
router_t (const router_t&);
|
142
|
+
const router_t &operator = (const router_t&);
|
143
|
+
};
|
144
|
+
|
145
|
+
}
|
146
|
+
|
147
|
+
#endif
|
@@ -0,0 +1,83 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
|
3
|
+
|
4
|
+
This file is part of libzmq, the ZeroMQ core engine in C++.
|
5
|
+
|
6
|
+
libzmq is free software; you can redistribute it and/or modify it under
|
7
|
+
the terms of the GNU Lesser General Public License (LGPL) as published
|
8
|
+
by the Free Software Foundation; either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
As a special exception, the Contributors give you permission to link
|
12
|
+
this library with independent modules to produce an executable,
|
13
|
+
regardless of the license terms of these independent modules, and to
|
14
|
+
copy and distribute the resulting executable under terms of your choice,
|
15
|
+
provided that you also meet, for each linked independent module, the
|
16
|
+
terms and conditions of the license of that module. An independent
|
17
|
+
module is a module which is not derived from or based on this library.
|
18
|
+
If you modify this library, you must extend this exception to your
|
19
|
+
version of the library.
|
20
|
+
|
21
|
+
libzmq is distributed in the hope that it will be useful, but WITHOUT
|
22
|
+
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
23
|
+
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
24
|
+
License for more details.
|
25
|
+
|
26
|
+
You should have received a copy of the GNU Lesser General Public License
|
27
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
28
|
+
*/
|
29
|
+
|
30
|
+
#include "precompiled.hpp"
|
31
|
+
#include "macros.hpp"
|
32
|
+
#include "scatter.hpp"
|
33
|
+
#include "pipe.hpp"
|
34
|
+
#include "err.hpp"
|
35
|
+
#include "msg.hpp"
|
36
|
+
|
37
|
+
zmq::scatter_t::scatter_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
|
38
|
+
socket_base_t (parent_, tid_, sid_, true)
|
39
|
+
{
|
40
|
+
options.type = ZMQ_SCATTER;
|
41
|
+
}
|
42
|
+
|
43
|
+
zmq::scatter_t::~scatter_t ()
|
44
|
+
{
|
45
|
+
}
|
46
|
+
|
47
|
+
void zmq::scatter_t::xattach_pipe (pipe_t *pipe_, bool subscribe_to_all_)
|
48
|
+
{
|
49
|
+
LIBZMQ_UNUSED (subscribe_to_all_);
|
50
|
+
|
51
|
+
// Don't delay pipe termination as there is no one
|
52
|
+
// to receive the delimiter.
|
53
|
+
pipe_->set_nodelay ();
|
54
|
+
|
55
|
+
zmq_assert (pipe_);
|
56
|
+
lb.attach (pipe_);
|
57
|
+
}
|
58
|
+
|
59
|
+
void zmq::scatter_t::xwrite_activated (pipe_t *pipe_)
|
60
|
+
{
|
61
|
+
lb.activated (pipe_);
|
62
|
+
}
|
63
|
+
|
64
|
+
void zmq::scatter_t::xpipe_terminated (pipe_t *pipe_)
|
65
|
+
{
|
66
|
+
lb.pipe_terminated (pipe_);
|
67
|
+
}
|
68
|
+
|
69
|
+
int zmq::scatter_t::xsend (msg_t *msg_)
|
70
|
+
{
|
71
|
+
// SCATTER sockets do not allow multipart data (ZMQ_SNDMORE)
|
72
|
+
if (msg_->flags () & msg_t::more) {
|
73
|
+
errno = EINVAL;
|
74
|
+
return -1;
|
75
|
+
}
|
76
|
+
|
77
|
+
return lb.send (msg_);
|
78
|
+
}
|
79
|
+
|
80
|
+
bool zmq::scatter_t::xhas_out ()
|
81
|
+
{
|
82
|
+
return lb.has_out ();
|
83
|
+
}
|
@@ -0,0 +1,73 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
|
3
|
+
|
4
|
+
This file is part of libzmq, the ZeroMQ core engine in C++.
|
5
|
+
|
6
|
+
libzmq is free software; you can redistribute it and/or modify it under
|
7
|
+
the terms of the GNU Lesser General Public License (LGPL) as published
|
8
|
+
by the Free Software Foundation; either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
As a special exception, the Contributors give you permission to link
|
12
|
+
this library with independent modules to produce an executable,
|
13
|
+
regardless of the license terms of these independent modules, and to
|
14
|
+
copy and distribute the resulting executable under terms of your choice,
|
15
|
+
provided that you also meet, for each linked independent module, the
|
16
|
+
terms and conditions of the license of that module. An independent
|
17
|
+
module is a module which is not derived from or based on this library.
|
18
|
+
If you modify this library, you must extend this exception to your
|
19
|
+
version of the library.
|
20
|
+
|
21
|
+
libzmq is distributed in the hope that it will be useful, but WITHOUT
|
22
|
+
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
23
|
+
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
24
|
+
License for more details.
|
25
|
+
|
26
|
+
You should have received a copy of the GNU Lesser General Public License
|
27
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
28
|
+
*/
|
29
|
+
|
30
|
+
#ifndef __ZMQ_SCATTER_HPP_INCLUDED__
|
31
|
+
#define __ZMQ_SCATTER_HPP_INCLUDED__
|
32
|
+
|
33
|
+
#include "socket_base.hpp"
|
34
|
+
#include "session_base.hpp"
|
35
|
+
#include "lb.hpp"
|
36
|
+
|
37
|
+
namespace zmq
|
38
|
+
{
|
39
|
+
|
40
|
+
class ctx_t;
|
41
|
+
class pipe_t;
|
42
|
+
class msg_t;
|
43
|
+
class io_thread_t;
|
44
|
+
|
45
|
+
class scatter_t :
|
46
|
+
public socket_base_t
|
47
|
+
{
|
48
|
+
public:
|
49
|
+
|
50
|
+
scatter_t (zmq::ctx_t *parent_, uint32_t tid_, int sid_);
|
51
|
+
~scatter_t ();
|
52
|
+
|
53
|
+
protected:
|
54
|
+
|
55
|
+
// Overrides of functions from socket_base_t.
|
56
|
+
void xattach_pipe (zmq::pipe_t *pipe_, bool subscribe_to_all_);
|
57
|
+
int xsend (zmq::msg_t *msg_);
|
58
|
+
bool xhas_out ();
|
59
|
+
void xwrite_activated (zmq::pipe_t *pipe_);
|
60
|
+
void xpipe_terminated (zmq::pipe_t *pipe_);
|
61
|
+
|
62
|
+
private:
|
63
|
+
|
64
|
+
// Load balancer managing the outbound pipes.
|
65
|
+
lb_t lb;
|
66
|
+
|
67
|
+
scatter_t (const scatter_t&);
|
68
|
+
const scatter_t &operator = (const scatter_t&);
|
69
|
+
};
|
70
|
+
|
71
|
+
}
|
72
|
+
|
73
|
+
#endif
|
@@ -0,0 +1,567 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
|
3
|
+
|
4
|
+
This file is part of libzmq, the ZeroMQ core engine in C++.
|
5
|
+
|
6
|
+
libzmq is free software; you can redistribute it and/or modify it under
|
7
|
+
the terms of the GNU Lesser General Public License (LGPL) as published
|
8
|
+
by the Free Software Foundation; either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
As a special exception, the Contributors give you permission to link
|
12
|
+
this library with independent modules to produce an executable,
|
13
|
+
regardless of the license terms of these independent modules, and to
|
14
|
+
copy and distribute the resulting executable under terms of your choice,
|
15
|
+
provided that you also meet, for each linked independent module, the
|
16
|
+
terms and conditions of the license of that module. An independent
|
17
|
+
module is a module which is not derived from or based on this library.
|
18
|
+
If you modify this library, you must extend this exception to your
|
19
|
+
version of the library.
|
20
|
+
|
21
|
+
libzmq is distributed in the hope that it will be useful, but WITHOUT
|
22
|
+
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
23
|
+
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
24
|
+
License for more details.
|
25
|
+
|
26
|
+
You should have received a copy of the GNU Lesser General Public License
|
27
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
28
|
+
*/
|
29
|
+
|
30
|
+
#include "precompiled.hpp"
|
31
|
+
#include "select.hpp"
|
32
|
+
#if defined ZMQ_USE_SELECT
|
33
|
+
|
34
|
+
#if defined ZMQ_HAVE_WINDOWS
|
35
|
+
#elif defined ZMQ_HAVE_HPUX
|
36
|
+
#include <sys/param.h>
|
37
|
+
#include <sys/types.h>
|
38
|
+
#include <sys/time.h>
|
39
|
+
#elif defined ZMQ_HAVE_OPENVMS
|
40
|
+
#include <sys/types.h>
|
41
|
+
#include <sys/time.h>
|
42
|
+
#else
|
43
|
+
#include <sys/select.h>
|
44
|
+
#endif
|
45
|
+
|
46
|
+
#include "err.hpp"
|
47
|
+
#include "config.hpp"
|
48
|
+
#include "i_poll_events.hpp"
|
49
|
+
|
50
|
+
zmq::select_t::select_t (const zmq::ctx_t &ctx_) :
|
51
|
+
ctx (ctx_),
|
52
|
+
#if defined ZMQ_HAVE_WINDOWS
|
53
|
+
// Fine as long as map is not cleared.
|
54
|
+
current_family_entry_it (family_entries.end ()),
|
55
|
+
#else
|
56
|
+
maxfd (retired_fd),
|
57
|
+
#endif
|
58
|
+
stopping (false)
|
59
|
+
{
|
60
|
+
#if defined ZMQ_HAVE_WINDOWS
|
61
|
+
for (size_t i = 0; i < fd_family_cache_size; ++i)
|
62
|
+
fd_family_cache [i] = std::make_pair (retired_fd, 0);
|
63
|
+
#endif
|
64
|
+
}
|
65
|
+
|
66
|
+
zmq::select_t::~select_t ()
|
67
|
+
{
|
68
|
+
worker.stop ();
|
69
|
+
}
|
70
|
+
|
71
|
+
zmq::select_t::handle_t zmq::select_t::add_fd (fd_t fd_, i_poll_events *events_)
|
72
|
+
{
|
73
|
+
fd_entry_t fd_entry;
|
74
|
+
fd_entry.fd = fd_;
|
75
|
+
fd_entry.events = events_;
|
76
|
+
|
77
|
+
#if defined ZMQ_HAVE_WINDOWS
|
78
|
+
u_short family = get_fd_family (fd_);
|
79
|
+
wsa_assert (family != AF_UNSPEC);
|
80
|
+
family_entry_t &family_entry = family_entries [family];
|
81
|
+
#endif
|
82
|
+
family_entry.fd_entries.push_back (fd_entry);
|
83
|
+
FD_SET (fd_, &family_entry.fds_set.error);
|
84
|
+
|
85
|
+
#if !defined ZMQ_HAVE_WINDOWS
|
86
|
+
if (fd_ > maxfd)
|
87
|
+
maxfd = fd_;
|
88
|
+
#endif
|
89
|
+
|
90
|
+
adjust_load (1);
|
91
|
+
|
92
|
+
return fd_;
|
93
|
+
}
|
94
|
+
|
95
|
+
zmq::select_t::fd_entries_t::iterator
|
96
|
+
zmq::select_t::find_fd_entry_by_handle (fd_entries_t &fd_entries,
|
97
|
+
handle_t handle_)
|
98
|
+
{
|
99
|
+
fd_entries_t::iterator fd_entry_it;
|
100
|
+
for (fd_entry_it = fd_entries.begin (); fd_entry_it != fd_entries.end ();
|
101
|
+
++fd_entry_it)
|
102
|
+
if (fd_entry_it->fd == handle_)
|
103
|
+
break;
|
104
|
+
|
105
|
+
return fd_entry_it;
|
106
|
+
}
|
107
|
+
|
108
|
+
void zmq::select_t::trigger_events (const fd_entries_t &fd_entries_,
|
109
|
+
const fds_set_t &local_fds_set_,
|
110
|
+
int event_count_)
|
111
|
+
{
|
112
|
+
// Size is cached to avoid iteration through recently added descriptors.
|
113
|
+
for (fd_entries_t::size_type i = 0, size = fd_entries_.size ();
|
114
|
+
i < size && event_count_ > 0; ++i) {
|
115
|
+
const fd_entry_t ¤t_fd_entry = fd_entries_ [i];
|
116
|
+
|
117
|
+
if (is_retired_fd (current_fd_entry))
|
118
|
+
continue;
|
119
|
+
|
120
|
+
if (FD_ISSET (current_fd_entry.fd, &local_fds_set_.read)) {
|
121
|
+
current_fd_entry.events->in_event ();
|
122
|
+
--event_count_;
|
123
|
+
}
|
124
|
+
|
125
|
+
// TODO: can the is_retired_fd be true at this point? if it
|
126
|
+
// was retired before, we would already have continued, and I
|
127
|
+
// don't see where it might have been modified
|
128
|
+
// And if rc == 0, we can break instead of continuing
|
129
|
+
if (is_retired_fd (current_fd_entry) || event_count_ == 0)
|
130
|
+
continue;
|
131
|
+
|
132
|
+
if (FD_ISSET (current_fd_entry.fd, &local_fds_set_.write)) {
|
133
|
+
current_fd_entry.events->out_event ();
|
134
|
+
--event_count_;
|
135
|
+
}
|
136
|
+
|
137
|
+
// TODO: same as above
|
138
|
+
if (is_retired_fd (current_fd_entry) || event_count_ == 0)
|
139
|
+
continue;
|
140
|
+
|
141
|
+
if (FD_ISSET (current_fd_entry.fd, &local_fds_set_.error)) {
|
142
|
+
current_fd_entry.events->in_event ();
|
143
|
+
--event_count_;
|
144
|
+
}
|
145
|
+
}
|
146
|
+
}
|
147
|
+
|
148
|
+
#if defined ZMQ_HAVE_WINDOWS
|
149
|
+
bool zmq::select_t::try_remove_fd_entry (
|
150
|
+
family_entries_t::iterator family_entry_it, zmq::fd_t &handle_)
|
151
|
+
{
|
152
|
+
family_entry_t &family_entry = family_entry_it->second;
|
153
|
+
|
154
|
+
fd_entries_t::iterator fd_entry_it =
|
155
|
+
find_fd_entry_by_handle (family_entry.fd_entries, handle_);
|
156
|
+
if (fd_entry_it == family_entry.fd_entries.end ())
|
157
|
+
return false;
|
158
|
+
if (family_entry_it != current_family_entry_it) {
|
159
|
+
// Family is not currently being iterated and can be safely
|
160
|
+
// modified in-place. So later it can be skipped without
|
161
|
+
// re-verifying its content.
|
162
|
+
family_entry.fd_entries.erase (fd_entry_it);
|
163
|
+
} else {
|
164
|
+
// Otherwise mark removed entries as retired. It will be cleaned up
|
165
|
+
// at the end of the iteration. See zmq::select_t::loop
|
166
|
+
fd_entry_it->fd = retired_fd;
|
167
|
+
family_entry.retired = true;
|
168
|
+
}
|
169
|
+
family_entry.fds_set.remove_fd (handle_);
|
170
|
+
return true;
|
171
|
+
}
|
172
|
+
#endif
|
173
|
+
|
174
|
+
void zmq::select_t::rm_fd (handle_t handle_)
|
175
|
+
{
|
176
|
+
#if defined ZMQ_HAVE_WINDOWS
|
177
|
+
u_short family = get_fd_family (handle_);
|
178
|
+
if (family != AF_UNSPEC) {
|
179
|
+
family_entries_t::iterator family_entry_it =
|
180
|
+
family_entries.find (family);
|
181
|
+
|
182
|
+
int removed = try_remove_fd_entry (family_entry_it, handle_);
|
183
|
+
assert (removed);
|
184
|
+
} else {
|
185
|
+
// get_fd_family may fail and return AF_UNSPEC if the socket was not
|
186
|
+
// successfully connected. In that case, we need to look for the
|
187
|
+
// socket in all family_entries.
|
188
|
+
family_entries_t::iterator end = family_entries.end ();
|
189
|
+
for (family_entries_t::iterator family_entry_it =
|
190
|
+
family_entries.begin ();
|
191
|
+
family_entry_it != end; ++family_entry_it) {
|
192
|
+
if (try_remove_fd_entry (family_entry_it, handle_))
|
193
|
+
break;
|
194
|
+
}
|
195
|
+
}
|
196
|
+
#else
|
197
|
+
fd_entries_t::iterator fd_entry_it =
|
198
|
+
find_fd_entry_by_handle (family_entry.fd_entries, handle_);
|
199
|
+
assert (fd_entry_it != fd_entries.end ());
|
200
|
+
|
201
|
+
fd_entry_it->fd = retired_fd;
|
202
|
+
family_entry.fds_set.remove_fd (handle_);
|
203
|
+
|
204
|
+
if (handle_ == maxfd) {
|
205
|
+
maxfd = retired_fd;
|
206
|
+
for (fd_entry_it = family_entry.fd_entries.begin ();
|
207
|
+
fd_entry_it != family_entry.fd_entries.end (); ++fd_entry_it)
|
208
|
+
if (fd_entry_it->fd > maxfd)
|
209
|
+
maxfd = fd_entry_it->fd;
|
210
|
+
}
|
211
|
+
|
212
|
+
family_entry.retired = true;
|
213
|
+
#endif
|
214
|
+
adjust_load (-1);
|
215
|
+
}
|
216
|
+
|
217
|
+
void zmq::select_t::set_pollin (handle_t handle_)
|
218
|
+
{
|
219
|
+
#if defined ZMQ_HAVE_WINDOWS
|
220
|
+
u_short family = get_fd_family (handle_);
|
221
|
+
wsa_assert (family != AF_UNSPEC);
|
222
|
+
family_entry_t &family_entry = family_entries [family];
|
223
|
+
#endif
|
224
|
+
FD_SET (handle_, &family_entry.fds_set.read);
|
225
|
+
}
|
226
|
+
|
227
|
+
void zmq::select_t::reset_pollin (handle_t handle_)
|
228
|
+
{
|
229
|
+
#if defined ZMQ_HAVE_WINDOWS
|
230
|
+
u_short family = get_fd_family (handle_);
|
231
|
+
wsa_assert (family != AF_UNSPEC);
|
232
|
+
family_entry_t &family_entry = family_entries [family];
|
233
|
+
#endif
|
234
|
+
FD_CLR (handle_, &family_entry.fds_set.read);
|
235
|
+
}
|
236
|
+
|
237
|
+
void zmq::select_t::set_pollout (handle_t handle_)
|
238
|
+
{
|
239
|
+
#if defined ZMQ_HAVE_WINDOWS
|
240
|
+
u_short family = get_fd_family (handle_);
|
241
|
+
wsa_assert (family != AF_UNSPEC);
|
242
|
+
family_entry_t &family_entry = family_entries [family];
|
243
|
+
#endif
|
244
|
+
FD_SET (handle_, &family_entry.fds_set.write);
|
245
|
+
}
|
246
|
+
|
247
|
+
void zmq::select_t::reset_pollout (handle_t handle_)
|
248
|
+
{
|
249
|
+
#if defined ZMQ_HAVE_WINDOWS
|
250
|
+
u_short family = get_fd_family (handle_);
|
251
|
+
wsa_assert (family != AF_UNSPEC);
|
252
|
+
family_entry_t &family_entry = family_entries [family];
|
253
|
+
#endif
|
254
|
+
FD_CLR (handle_, &family_entry.fds_set.write);
|
255
|
+
}
|
256
|
+
|
257
|
+
void zmq::select_t::start ()
|
258
|
+
{
|
259
|
+
ctx.start_thread (worker, worker_routine, this);
|
260
|
+
}
|
261
|
+
|
262
|
+
void zmq::select_t::stop ()
|
263
|
+
{
|
264
|
+
stopping = true;
|
265
|
+
}
|
266
|
+
|
267
|
+
int zmq::select_t::max_fds ()
|
268
|
+
{
|
269
|
+
return FD_SETSIZE;
|
270
|
+
}
|
271
|
+
|
272
|
+
void zmq::select_t::loop ()
|
273
|
+
{
|
274
|
+
while (!stopping) {
|
275
|
+
// Execute any due timers.
|
276
|
+
int timeout = (int) execute_timers ();
|
277
|
+
|
278
|
+
#if defined ZMQ_HAVE_OSX
|
279
|
+
struct timeval tv = {(long) (timeout / 1000), timeout % 1000 * 1000};
|
280
|
+
#else
|
281
|
+
struct timeval tv = {(long) (timeout / 1000),
|
282
|
+
(long) (timeout % 1000 * 1000)};
|
283
|
+
#endif
|
284
|
+
|
285
|
+
int rc = 0;
|
286
|
+
|
287
|
+
#if defined ZMQ_HAVE_WINDOWS
|
288
|
+
/*
|
289
|
+
On Windows select does not allow to mix descriptors from different
|
290
|
+
service providers. It seems to work for AF_INET and AF_INET6,
|
291
|
+
but fails for AF_INET and VMCI. The workaround is to use
|
292
|
+
WSAEventSelect and WSAWaitForMultipleEvents to wait, then use
|
293
|
+
select to find out what actually changed. WSAWaitForMultipleEvents
|
294
|
+
cannot be used alone, because it does not support more than 64 events
|
295
|
+
which is not enough.
|
296
|
+
|
297
|
+
To reduce unnecessary overhead, WSA is only used when there are more
|
298
|
+
than one family. Moreover, AF_INET and AF_INET6 are considered the same
|
299
|
+
family because Windows seems to handle them properly.
|
300
|
+
See get_fd_family for details.
|
301
|
+
*/
|
302
|
+
|
303
|
+
// If there is just one family, there is no reason to use WSA events.
|
304
|
+
const bool use_wsa_events = family_entries.size () > 1;
|
305
|
+
if (use_wsa_events) {
|
306
|
+
// TODO: I don't really understand why we are doing this. If any of
|
307
|
+
// the events was signaled, we will call select for each fd_family
|
308
|
+
// afterwards. The only benefit is if none of the events was
|
309
|
+
// signaled, then we continue early.
|
310
|
+
// IMHO, either WSAEventSelect/WSAWaitForMultipleEvents or select
|
311
|
+
// should be used, but not both
|
312
|
+
|
313
|
+
wsa_events_t wsa_events;
|
314
|
+
|
315
|
+
for (family_entries_t::iterator family_entry_it =
|
316
|
+
family_entries.begin ();
|
317
|
+
family_entry_it != family_entries.end (); ++family_entry_it) {
|
318
|
+
family_entry_t &family_entry = family_entry_it->second;
|
319
|
+
|
320
|
+
for (fd_entries_t::iterator fd_entry_it =
|
321
|
+
family_entry.fd_entries.begin ();
|
322
|
+
fd_entry_it != family_entry.fd_entries.end ();
|
323
|
+
++fd_entry_it) {
|
324
|
+
fd_t fd = fd_entry_it->fd;
|
325
|
+
|
326
|
+
// http://stackoverflow.com/q/35043420/188530
|
327
|
+
if (FD_ISSET (fd, &family_entry.fds_set.read)
|
328
|
+
&& FD_ISSET (fd, &family_entry.fds_set.write))
|
329
|
+
rc =
|
330
|
+
WSAEventSelect (fd, wsa_events.events [3],
|
331
|
+
FD_READ | FD_ACCEPT | FD_CLOSE
|
332
|
+
| FD_WRITE | FD_CONNECT | FD_OOB);
|
333
|
+
else if (FD_ISSET (fd, &family_entry.fds_set.read))
|
334
|
+
rc = WSAEventSelect (fd, wsa_events.events [0],
|
335
|
+
FD_READ | FD_ACCEPT | FD_CLOSE
|
336
|
+
| FD_OOB);
|
337
|
+
else if (FD_ISSET (fd, &family_entry.fds_set.write))
|
338
|
+
rc = WSAEventSelect (fd, wsa_events.events [1],
|
339
|
+
FD_WRITE | FD_CONNECT | FD_OOB);
|
340
|
+
else if (FD_ISSET (fd, &family_entry.fds_set.error))
|
341
|
+
rc = WSAEventSelect (fd, wsa_events.events [2], FD_OOB);
|
342
|
+
else
|
343
|
+
rc = 0;
|
344
|
+
|
345
|
+
wsa_assert (rc != SOCKET_ERROR);
|
346
|
+
}
|
347
|
+
}
|
348
|
+
|
349
|
+
rc = WSAWaitForMultipleEvents (4, wsa_events.events, FALSE,
|
350
|
+
timeout ? timeout : INFINITE, FALSE);
|
351
|
+
wsa_assert (rc != (int) WSA_WAIT_FAILED);
|
352
|
+
zmq_assert (rc != WSA_WAIT_IO_COMPLETION);
|
353
|
+
|
354
|
+
if (rc == WSA_WAIT_TIMEOUT)
|
355
|
+
continue;
|
356
|
+
}
|
357
|
+
|
358
|
+
for (current_family_entry_it = family_entries.begin ();
|
359
|
+
current_family_entry_it != family_entries.end ();
|
360
|
+
++current_family_entry_it) {
|
361
|
+
family_entry_t &family_entry = current_family_entry_it->second;
|
362
|
+
|
363
|
+
|
364
|
+
if (use_wsa_events) {
|
365
|
+
// There is no reason to wait again after WSAWaitForMultipleEvents.
|
366
|
+
// Simply collect what is ready.
|
367
|
+
struct timeval tv_nodelay = {0, 0};
|
368
|
+
select_family_entry (family_entry, 0, true, tv_nodelay);
|
369
|
+
} else {
|
370
|
+
select_family_entry (family_entry, 0, timeout > 0, tv);
|
371
|
+
}
|
372
|
+
}
|
373
|
+
#else
|
374
|
+
select_family_entry (family_entry, maxfd, timeout > 0, tv);
|
375
|
+
#endif
|
376
|
+
}
|
377
|
+
}
|
378
|
+
|
379
|
+
void zmq::select_t::select_family_entry (family_entry_t &family_entry_,
|
380
|
+
const int max_fd_,
|
381
|
+
const bool use_timeout_,
|
382
|
+
struct timeval &tv_)
|
383
|
+
{
|
384
|
+
// select will fail when run with empty sets.
|
385
|
+
fd_entries_t &fd_entries = family_entry_.fd_entries;
|
386
|
+
if (fd_entries.empty ())
|
387
|
+
return;
|
388
|
+
|
389
|
+
fds_set_t local_fds_set = family_entry_.fds_set;
|
390
|
+
int rc = select (max_fd_, &local_fds_set.read, &local_fds_set.write,
|
391
|
+
&local_fds_set.error, use_timeout_ ? &tv_ : NULL);
|
392
|
+
|
393
|
+
#if defined ZMQ_HAVE_WINDOWS
|
394
|
+
wsa_assert (rc != SOCKET_ERROR);
|
395
|
+
#else
|
396
|
+
if (rc == -1) {
|
397
|
+
errno_assert (errno == EINTR);
|
398
|
+
return;
|
399
|
+
}
|
400
|
+
#endif
|
401
|
+
|
402
|
+
trigger_events (fd_entries, local_fds_set, rc);
|
403
|
+
|
404
|
+
if (family_entry_.retired) {
|
405
|
+
family_entry_.retired = false;
|
406
|
+
family_entry_.fd_entries.erase (std::remove_if (fd_entries.begin (),
|
407
|
+
fd_entries.end (),
|
408
|
+
is_retired_fd),
|
409
|
+
family_entry_.fd_entries.end ());
|
410
|
+
}
|
411
|
+
}
|
412
|
+
|
413
|
+
void zmq::select_t::worker_routine (void *arg_)
|
414
|
+
{
|
415
|
+
((select_t *) arg_)->loop ();
|
416
|
+
}
|
417
|
+
|
418
|
+
zmq::select_t::fds_set_t::fds_set_t ()
|
419
|
+
{
|
420
|
+
FD_ZERO (&read);
|
421
|
+
FD_ZERO (&write);
|
422
|
+
FD_ZERO (&error);
|
423
|
+
}
|
424
|
+
|
425
|
+
zmq::select_t::fds_set_t::fds_set_t (const fds_set_t &other_)
|
426
|
+
{
|
427
|
+
#if defined ZMQ_HAVE_WINDOWS
|
428
|
+
// On Windows we don't need to copy the whole fd_set.
|
429
|
+
// SOCKETS are continuous from the beginning of fd_array in fd_set.
|
430
|
+
// We just need to copy fd_count elements of fd_array.
|
431
|
+
// We gain huge memcpy() improvement if number of used SOCKETs is much lower than FD_SETSIZE.
|
432
|
+
memcpy (&read, &other_.read,
|
433
|
+
(char *) (other_.read.fd_array + other_.read.fd_count)
|
434
|
+
- (char *) &other_.read);
|
435
|
+
memcpy (&write, &other_.write,
|
436
|
+
(char *) (other_.write.fd_array + other_.write.fd_count)
|
437
|
+
- (char *) &other_.write);
|
438
|
+
memcpy (&error, &other_.error,
|
439
|
+
(char *) (other_.error.fd_array + other_.error.fd_count)
|
440
|
+
- (char *) &other_.error);
|
441
|
+
#else
|
442
|
+
memcpy (&read, &other_.read, sizeof other_.read);
|
443
|
+
memcpy (&write, &other_.write, sizeof other_.write);
|
444
|
+
memcpy (&error, &other_.error, sizeof other_.error);
|
445
|
+
#endif
|
446
|
+
}
|
447
|
+
|
448
|
+
zmq::select_t::fds_set_t &zmq::select_t::fds_set_t::
|
449
|
+
operator= (const fds_set_t &other_)
|
450
|
+
{
|
451
|
+
#if defined ZMQ_HAVE_WINDOWS
|
452
|
+
// On Windows we don't need to copy the whole fd_set.
|
453
|
+
// SOCKETS are continuous from the beginning of fd_array in fd_set.
|
454
|
+
// We just need to copy fd_count elements of fd_array.
|
455
|
+
// We gain huge memcpy() improvement if number of used SOCKETs is much lower than FD_SETSIZE.
|
456
|
+
memcpy (&read, &other_.read,
|
457
|
+
(char *) (other_.read.fd_array + other_.read.fd_count)
|
458
|
+
- (char *) &other_.read);
|
459
|
+
memcpy (&write, &other_.write,
|
460
|
+
(char *) (other_.write.fd_array + other_.write.fd_count)
|
461
|
+
- (char *) &other_.write);
|
462
|
+
memcpy (&error, &other_.error,
|
463
|
+
(char *) (other_.error.fd_array + other_.error.fd_count)
|
464
|
+
- (char *) &other_.error);
|
465
|
+
#else
|
466
|
+
memcpy (&read, &other_.read, sizeof other_.read);
|
467
|
+
memcpy (&write, &other_.write, sizeof other_.write);
|
468
|
+
memcpy (&error, &other_.error, sizeof other_.error);
|
469
|
+
#endif
|
470
|
+
return *this;
|
471
|
+
}
|
472
|
+
|
473
|
+
void zmq::select_t::fds_set_t::remove_fd (const fd_t &fd_)
|
474
|
+
{
|
475
|
+
FD_CLR (fd_, &read);
|
476
|
+
FD_CLR (fd_, &write);
|
477
|
+
FD_CLR (fd_, &error);
|
478
|
+
}
|
479
|
+
|
480
|
+
bool zmq::select_t::is_retired_fd (const fd_entry_t &entry)
|
481
|
+
{
|
482
|
+
return (entry.fd == retired_fd);
|
483
|
+
}
|
484
|
+
|
485
|
+
#if defined ZMQ_HAVE_WINDOWS
|
486
|
+
u_short zmq::select_t::get_fd_family (fd_t fd_)
|
487
|
+
{
|
488
|
+
// cache the results of determine_fd_family, as this is frequently called
|
489
|
+
// for the same sockets, and determine_fd_family is expensive
|
490
|
+
size_t i;
|
491
|
+
for (i = 0; i < fd_family_cache_size; ++i) {
|
492
|
+
const std::pair<fd_t, u_short> &entry = fd_family_cache [i];
|
493
|
+
if (entry.first == fd_) {
|
494
|
+
return entry.second;
|
495
|
+
}
|
496
|
+
if (entry.first == retired_fd)
|
497
|
+
break;
|
498
|
+
}
|
499
|
+
|
500
|
+
std::pair<fd_t, u_short> res =
|
501
|
+
std::make_pair (fd_, determine_fd_family (fd_));
|
502
|
+
if (i < fd_family_cache_size) {
|
503
|
+
fd_family_cache [i] = res;
|
504
|
+
} else {
|
505
|
+
// just overwrite a random entry
|
506
|
+
// could be optimized by some LRU strategy
|
507
|
+
fd_family_cache [rand () % fd_family_cache_size] = res;
|
508
|
+
}
|
509
|
+
|
510
|
+
return res.second;
|
511
|
+
}
|
512
|
+
|
513
|
+
u_short zmq::select_t::determine_fd_family (fd_t fd_)
|
514
|
+
{
|
515
|
+
// Use sockaddr_storage instead of sockaddr to accommodate different structure sizes
|
516
|
+
sockaddr_storage addr = {0};
|
517
|
+
int addr_size = sizeof addr;
|
518
|
+
|
519
|
+
int type;
|
520
|
+
int type_length = sizeof (int);
|
521
|
+
|
522
|
+
int rc =
|
523
|
+
getsockopt (fd_, SOL_SOCKET, SO_TYPE, (char *) &type, &type_length);
|
524
|
+
|
525
|
+
if (rc == 0) {
|
526
|
+
if (type == SOCK_DGRAM)
|
527
|
+
return AF_INET;
|
528
|
+
else {
|
529
|
+
rc = getsockname (fd_, (sockaddr *) &addr, &addr_size);
|
530
|
+
|
531
|
+
// AF_INET and AF_INET6 can be mixed in select
|
532
|
+
// TODO: If proven otherwise, should simply return addr.sa_family
|
533
|
+
if (rc != SOCKET_ERROR)
|
534
|
+
return addr.ss_family == AF_INET6 ? AF_INET : addr.ss_family;
|
535
|
+
}
|
536
|
+
}
|
537
|
+
|
538
|
+
return AF_UNSPEC;
|
539
|
+
}
|
540
|
+
|
541
|
+
zmq::select_t::family_entry_t::family_entry_t () : retired (false)
|
542
|
+
{
|
543
|
+
}
|
544
|
+
|
545
|
+
|
546
|
+
zmq::select_t::wsa_events_t::wsa_events_t ()
|
547
|
+
{
|
548
|
+
events [0] = WSACreateEvent ();
|
549
|
+
wsa_assert (events [0] != WSA_INVALID_EVENT);
|
550
|
+
events [1] = WSACreateEvent ();
|
551
|
+
wsa_assert (events [1] != WSA_INVALID_EVENT);
|
552
|
+
events [2] = WSACreateEvent ();
|
553
|
+
wsa_assert (events [2] != WSA_INVALID_EVENT);
|
554
|
+
events [3] = WSACreateEvent ();
|
555
|
+
wsa_assert (events [3] != WSA_INVALID_EVENT);
|
556
|
+
}
|
557
|
+
|
558
|
+
zmq::select_t::wsa_events_t::~wsa_events_t ()
|
559
|
+
{
|
560
|
+
wsa_assert (WSACloseEvent (events [0]));
|
561
|
+
wsa_assert (WSACloseEvent (events [1]));
|
562
|
+
wsa_assert (WSACloseEvent (events [2]));
|
563
|
+
wsa_assert (WSACloseEvent (events [3]));
|
564
|
+
}
|
565
|
+
#endif
|
566
|
+
|
567
|
+
#endif
|