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,173 @@
|
|
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_SESSION_BASE_HPP_INCLUDED__
|
31
|
+
#define __ZMQ_SESSION_BASE_HPP_INCLUDED__
|
32
|
+
|
33
|
+
#include <string>
|
34
|
+
#include <stdarg.h>
|
35
|
+
|
36
|
+
#include "own.hpp"
|
37
|
+
#include "io_object.hpp"
|
38
|
+
#include "pipe.hpp"
|
39
|
+
#include "socket_base.hpp"
|
40
|
+
#include "stream_engine.hpp"
|
41
|
+
|
42
|
+
namespace zmq
|
43
|
+
{
|
44
|
+
|
45
|
+
class pipe_t;
|
46
|
+
class io_thread_t;
|
47
|
+
class socket_base_t;
|
48
|
+
struct i_engine;
|
49
|
+
struct address_t;
|
50
|
+
|
51
|
+
class session_base_t :
|
52
|
+
public own_t,
|
53
|
+
public io_object_t,
|
54
|
+
public i_pipe_events
|
55
|
+
{
|
56
|
+
public:
|
57
|
+
|
58
|
+
// Create a session of the particular type.
|
59
|
+
static session_base_t *create (zmq::io_thread_t *io_thread_,
|
60
|
+
bool active_, zmq::socket_base_t *socket_,
|
61
|
+
const options_t &options_, address_t *addr_);
|
62
|
+
|
63
|
+
// To be used once only, when creating the session.
|
64
|
+
void attach_pipe (zmq::pipe_t *pipe_);
|
65
|
+
|
66
|
+
// Following functions are the interface exposed towards the engine.
|
67
|
+
virtual void reset ();
|
68
|
+
void flush ();
|
69
|
+
void engine_error (zmq::stream_engine_t::error_reason_t reason);
|
70
|
+
|
71
|
+
// i_pipe_events interface implementation.
|
72
|
+
void read_activated (zmq::pipe_t *pipe_);
|
73
|
+
void write_activated (zmq::pipe_t *pipe_);
|
74
|
+
void hiccuped (zmq::pipe_t *pipe_);
|
75
|
+
void pipe_terminated (zmq::pipe_t *pipe_);
|
76
|
+
|
77
|
+
// Delivers a message. Returns 0 if successful; -1 otherwise.
|
78
|
+
// The function takes ownership of the message.
|
79
|
+
virtual int push_msg (msg_t *msg_);
|
80
|
+
|
81
|
+
int zap_connect ();
|
82
|
+
bool zap_enabled ();
|
83
|
+
|
84
|
+
// Fetches a message. Returns 0 if successful; -1 otherwise.
|
85
|
+
// The caller is responsible for freeing the message when no
|
86
|
+
// longer used.
|
87
|
+
virtual int pull_msg (msg_t *msg_);
|
88
|
+
|
89
|
+
// Receives message from ZAP socket.
|
90
|
+
// Returns 0 on success; -1 otherwise.
|
91
|
+
// The caller is responsible for freeing the message.
|
92
|
+
int read_zap_msg (msg_t *msg_);
|
93
|
+
|
94
|
+
// Sends message to ZAP socket.
|
95
|
+
// Returns 0 on success; -1 otherwise.
|
96
|
+
// The function takes ownership of the message.
|
97
|
+
int write_zap_msg (msg_t *msg_);
|
98
|
+
|
99
|
+
socket_base_t *get_socket ();
|
100
|
+
const char *get_endpoint () const;
|
101
|
+
|
102
|
+
protected:
|
103
|
+
|
104
|
+
session_base_t (zmq::io_thread_t *io_thread_, bool active_,
|
105
|
+
zmq::socket_base_t *socket_, const options_t &options_,
|
106
|
+
address_t *addr_);
|
107
|
+
virtual ~session_base_t ();
|
108
|
+
|
109
|
+
private:
|
110
|
+
|
111
|
+
void start_connecting (bool wait_);
|
112
|
+
|
113
|
+
void reconnect ();
|
114
|
+
|
115
|
+
// Handlers for incoming commands.
|
116
|
+
void process_plug ();
|
117
|
+
void process_attach (zmq::i_engine *engine_);
|
118
|
+
void process_term (int linger_);
|
119
|
+
|
120
|
+
// i_poll_events handlers.
|
121
|
+
void timer_event (int id_);
|
122
|
+
|
123
|
+
// Remove any half processed messages. Flush unflushed messages.
|
124
|
+
// Call this function when engine disconnect to get rid of leftovers.
|
125
|
+
void clean_pipes ();
|
126
|
+
|
127
|
+
// If true, this session (re)connects to the peer. Otherwise, it's
|
128
|
+
// a transient session created by the listener.
|
129
|
+
const bool active;
|
130
|
+
|
131
|
+
// Pipe connecting the session to its socket.
|
132
|
+
zmq::pipe_t *pipe;
|
133
|
+
|
134
|
+
// Pipe used to exchange messages with ZAP socket.
|
135
|
+
zmq::pipe_t *zap_pipe;
|
136
|
+
|
137
|
+
// This set is added to with pipes we are disconnecting, but haven't yet completed
|
138
|
+
std::set <pipe_t *> terminating_pipes;
|
139
|
+
|
140
|
+
// This flag is true if the remainder of the message being processed
|
141
|
+
// is still in the in pipe.
|
142
|
+
bool incomplete_in;
|
143
|
+
|
144
|
+
// True if termination have been suspended to push the pending
|
145
|
+
// messages to the network.
|
146
|
+
bool pending;
|
147
|
+
|
148
|
+
// The protocol I/O engine connected to the session.
|
149
|
+
zmq::i_engine *engine;
|
150
|
+
|
151
|
+
// The socket the session belongs to.
|
152
|
+
zmq::socket_base_t *socket;
|
153
|
+
|
154
|
+
// I/O thread the session is living in. It will be used to plug in
|
155
|
+
// the engines into the same thread.
|
156
|
+
zmq::io_thread_t *io_thread;
|
157
|
+
|
158
|
+
// ID of the linger timer
|
159
|
+
enum {linger_timer_id = 0x20};
|
160
|
+
|
161
|
+
// True is linger timer is running.
|
162
|
+
bool has_linger_timer;
|
163
|
+
|
164
|
+
// Protocol and address to use when connecting.
|
165
|
+
address_t *addr;
|
166
|
+
|
167
|
+
session_base_t (const session_base_t&);
|
168
|
+
const session_base_t &operator = (const session_base_t&);
|
169
|
+
};
|
170
|
+
|
171
|
+
}
|
172
|
+
|
173
|
+
#endif
|
@@ -0,0 +1,682 @@
|
|
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
|
+
// On AIX, poll.h has to be included before zmq.h to get consistent
|
31
|
+
// definition of pollfd structure (AIX uses 'reqevents' and 'retnevents'
|
32
|
+
// instead of 'events' and 'revents' and defines macros to map from POSIX-y
|
33
|
+
// names to AIX-specific names).
|
34
|
+
// zmq.h must be included *after* poll.h for AIX to build properly.
|
35
|
+
// precompiled.hpp includes include/zmq.h
|
36
|
+
#if defined ZMQ_POLL_BASED_ON_POLL && defined ZMQ_HAVE_AIX
|
37
|
+
#include <poll.h>
|
38
|
+
#endif
|
39
|
+
|
40
|
+
#include "precompiled.hpp"
|
41
|
+
#include "poller.hpp"
|
42
|
+
|
43
|
+
#if defined ZMQ_POLL_BASED_ON_POLL
|
44
|
+
#if !defined ZMQ_HAVE_WINDOWS && !defined ZMQ_HAVE_AIX
|
45
|
+
#include <poll.h>
|
46
|
+
#endif
|
47
|
+
#elif defined ZMQ_POLL_BASED_ON_SELECT
|
48
|
+
#if defined ZMQ_HAVE_WINDOWS
|
49
|
+
#elif defined ZMQ_HAVE_HPUX
|
50
|
+
#include <sys/param.h>
|
51
|
+
#include <sys/types.h>
|
52
|
+
#include <sys/time.h>
|
53
|
+
#elif defined ZMQ_HAVE_OPENVMS
|
54
|
+
#include <sys/types.h>
|
55
|
+
#include <sys/time.h>
|
56
|
+
#else
|
57
|
+
#include <sys/select.h>
|
58
|
+
#endif
|
59
|
+
#endif
|
60
|
+
|
61
|
+
#include "signaler.hpp"
|
62
|
+
#include "likely.hpp"
|
63
|
+
#include "stdint.hpp"
|
64
|
+
#include "config.hpp"
|
65
|
+
#include "err.hpp"
|
66
|
+
#include "fd.hpp"
|
67
|
+
#include "ip.hpp"
|
68
|
+
|
69
|
+
#if defined ZMQ_HAVE_EVENTFD
|
70
|
+
#include <sys/eventfd.h>
|
71
|
+
#endif
|
72
|
+
|
73
|
+
#if !defined ZMQ_HAVE_WINDOWS
|
74
|
+
#include <unistd.h>
|
75
|
+
#include <netinet/tcp.h>
|
76
|
+
#include <sys/types.h>
|
77
|
+
#include <sys/socket.h>
|
78
|
+
#endif
|
79
|
+
|
80
|
+
#if !defined (ZMQ_HAVE_WINDOWS)
|
81
|
+
// Helper to sleep for specific number of milliseconds (or until signal)
|
82
|
+
//
|
83
|
+
static int sleep_ms (unsigned int ms_)
|
84
|
+
{
|
85
|
+
if (ms_ == 0)
|
86
|
+
return 0;
|
87
|
+
#if defined ZMQ_HAVE_WINDOWS
|
88
|
+
Sleep (ms_ > 0 ? ms_ : INFINITE);
|
89
|
+
return 0;
|
90
|
+
#elif defined ZMQ_HAVE_ANDROID
|
91
|
+
usleep (ms_ * 1000);
|
92
|
+
return 0;
|
93
|
+
#else
|
94
|
+
return usleep (ms_ * 1000);
|
95
|
+
#endif
|
96
|
+
}
|
97
|
+
|
98
|
+
// Helper to wait on close(), for non-blocking sockets, until it completes
|
99
|
+
// If EAGAIN is received, will sleep briefly (1-100ms) then try again, until
|
100
|
+
// the overall timeout is reached.
|
101
|
+
//
|
102
|
+
static int close_wait_ms (int fd_, unsigned int max_ms_ = 2000)
|
103
|
+
{
|
104
|
+
unsigned int ms_so_far = 0;
|
105
|
+
unsigned int step_ms = max_ms_ / 10;
|
106
|
+
if (step_ms < 1)
|
107
|
+
step_ms = 1;
|
108
|
+
if (step_ms > 100)
|
109
|
+
step_ms = 100;
|
110
|
+
|
111
|
+
int rc = 0; // do not sleep on first attempt
|
112
|
+
do {
|
113
|
+
if (rc == -1 && errno == EAGAIN) {
|
114
|
+
sleep_ms (step_ms);
|
115
|
+
ms_so_far += step_ms;
|
116
|
+
}
|
117
|
+
rc = close (fd_);
|
118
|
+
} while (ms_so_far < max_ms_ && rc == -1 && errno == EAGAIN);
|
119
|
+
|
120
|
+
return rc;
|
121
|
+
}
|
122
|
+
#endif
|
123
|
+
|
124
|
+
zmq::signaler_t::signaler_t ()
|
125
|
+
{
|
126
|
+
// Create the socketpair for signaling.
|
127
|
+
if (make_fdpair (&r, &w) == 0) {
|
128
|
+
unblock_socket (w);
|
129
|
+
unblock_socket (r);
|
130
|
+
}
|
131
|
+
#ifdef HAVE_FORK
|
132
|
+
pid = getpid ();
|
133
|
+
#endif
|
134
|
+
}
|
135
|
+
|
136
|
+
// This might get run after some part of construction failed, leaving one or
|
137
|
+
// both of r and w retired_fd.
|
138
|
+
zmq::signaler_t::~signaler_t ()
|
139
|
+
{
|
140
|
+
#if defined ZMQ_HAVE_EVENTFD
|
141
|
+
if (r == retired_fd) return;
|
142
|
+
int rc = close_wait_ms (r);
|
143
|
+
errno_assert (rc == 0);
|
144
|
+
#elif defined ZMQ_HAVE_WINDOWS
|
145
|
+
if (w != retired_fd) {
|
146
|
+
const struct linger so_linger = { 1, 0 };
|
147
|
+
int rc = setsockopt (w, SOL_SOCKET, SO_LINGER,
|
148
|
+
(const char *) &so_linger, sizeof so_linger);
|
149
|
+
// Only check shutdown if WSASTARTUP was previously done
|
150
|
+
if (rc == 0 || WSAGetLastError () != WSANOTINITIALISED) {
|
151
|
+
wsa_assert (rc != SOCKET_ERROR);
|
152
|
+
rc = closesocket (w);
|
153
|
+
wsa_assert (rc != SOCKET_ERROR);
|
154
|
+
if (r == retired_fd) return;
|
155
|
+
rc = closesocket (r);
|
156
|
+
wsa_assert (rc != SOCKET_ERROR);
|
157
|
+
}
|
158
|
+
}
|
159
|
+
#else
|
160
|
+
if (w != retired_fd) {
|
161
|
+
int rc = close_wait_ms (w);
|
162
|
+
errno_assert (rc == 0);
|
163
|
+
}
|
164
|
+
if (r != retired_fd) {
|
165
|
+
int rc = close_wait_ms (r);
|
166
|
+
errno_assert (rc == 0);
|
167
|
+
}
|
168
|
+
#endif
|
169
|
+
}
|
170
|
+
|
171
|
+
zmq::fd_t zmq::signaler_t::get_fd () const
|
172
|
+
{
|
173
|
+
return r;
|
174
|
+
}
|
175
|
+
|
176
|
+
void zmq::signaler_t::send ()
|
177
|
+
{
|
178
|
+
#if defined HAVE_FORK
|
179
|
+
if (unlikely (pid != getpid ())) {
|
180
|
+
//printf("Child process %d signaler_t::send returning without sending #1\n", getpid());
|
181
|
+
return; // do not send anything in forked child context
|
182
|
+
}
|
183
|
+
#endif
|
184
|
+
#if defined ZMQ_HAVE_EVENTFD
|
185
|
+
const uint64_t inc = 1;
|
186
|
+
ssize_t sz = write (w, &inc, sizeof (inc));
|
187
|
+
errno_assert (sz == sizeof (inc));
|
188
|
+
#elif defined ZMQ_HAVE_WINDOWS
|
189
|
+
unsigned char dummy = 0;
|
190
|
+
while (true) {
|
191
|
+
int nbytes = ::send (w, (char*) &dummy, sizeof (dummy), 0);
|
192
|
+
wsa_assert (nbytes != SOCKET_ERROR);
|
193
|
+
if (unlikely (nbytes == SOCKET_ERROR))
|
194
|
+
continue;
|
195
|
+
zmq_assert (nbytes == sizeof (dummy));
|
196
|
+
break;
|
197
|
+
}
|
198
|
+
#else
|
199
|
+
unsigned char dummy = 0;
|
200
|
+
while (true) {
|
201
|
+
ssize_t nbytes = ::send (w, &dummy, sizeof (dummy), 0);
|
202
|
+
if (unlikely (nbytes == -1 && errno == EINTR))
|
203
|
+
continue;
|
204
|
+
#if defined(HAVE_FORK)
|
205
|
+
if (unlikely (pid != getpid ())) {
|
206
|
+
//printf("Child process %d signaler_t::send returning without sending #2\n", getpid());
|
207
|
+
errno = EINTR;
|
208
|
+
break;
|
209
|
+
}
|
210
|
+
#endif
|
211
|
+
zmq_assert (nbytes == sizeof dummy);
|
212
|
+
break;
|
213
|
+
}
|
214
|
+
#endif
|
215
|
+
}
|
216
|
+
|
217
|
+
int zmq::signaler_t::wait (int timeout_)
|
218
|
+
{
|
219
|
+
#ifdef HAVE_FORK
|
220
|
+
if (unlikely (pid != getpid ())) {
|
221
|
+
// we have forked and the file descriptor is closed. Emulate an interrupt
|
222
|
+
// response.
|
223
|
+
//printf("Child process %d signaler_t::wait returning simulating interrupt #1\n", getpid());
|
224
|
+
errno = EINTR;
|
225
|
+
return -1;
|
226
|
+
}
|
227
|
+
#endif
|
228
|
+
|
229
|
+
#ifdef ZMQ_POLL_BASED_ON_POLL
|
230
|
+
struct pollfd pfd;
|
231
|
+
pfd.fd = r;
|
232
|
+
pfd.events = POLLIN;
|
233
|
+
int rc = poll (&pfd, 1, timeout_);
|
234
|
+
if (unlikely (rc < 0)) {
|
235
|
+
errno_assert (errno == EINTR);
|
236
|
+
return -1;
|
237
|
+
}
|
238
|
+
else
|
239
|
+
if (unlikely (rc == 0)) {
|
240
|
+
errno = EAGAIN;
|
241
|
+
return -1;
|
242
|
+
}
|
243
|
+
#ifdef HAVE_FORK
|
244
|
+
else
|
245
|
+
if (unlikely (pid != getpid ())) {
|
246
|
+
// we have forked and the file descriptor is closed. Emulate an interrupt
|
247
|
+
// response.
|
248
|
+
//printf("Child process %d signaler_t::wait returning simulating interrupt #2\n", getpid());
|
249
|
+
errno = EINTR;
|
250
|
+
return -1;
|
251
|
+
}
|
252
|
+
#endif
|
253
|
+
zmq_assert (rc == 1);
|
254
|
+
zmq_assert (pfd.revents & POLLIN);
|
255
|
+
return 0;
|
256
|
+
|
257
|
+
#elif defined ZMQ_POLL_BASED_ON_SELECT
|
258
|
+
|
259
|
+
fd_set fds;
|
260
|
+
FD_ZERO (&fds);
|
261
|
+
FD_SET (r, &fds);
|
262
|
+
struct timeval timeout;
|
263
|
+
if (timeout_ >= 0) {
|
264
|
+
timeout.tv_sec = timeout_ / 1000;
|
265
|
+
timeout.tv_usec = timeout_ % 1000 * 1000;
|
266
|
+
}
|
267
|
+
#ifdef ZMQ_HAVE_WINDOWS
|
268
|
+
int rc = select (0, &fds, NULL, NULL,
|
269
|
+
timeout_ >= 0 ? &timeout : NULL);
|
270
|
+
wsa_assert (rc != SOCKET_ERROR);
|
271
|
+
#else
|
272
|
+
int rc = select (r + 1, &fds, NULL, NULL,
|
273
|
+
timeout_ >= 0 ? &timeout : NULL);
|
274
|
+
if (unlikely (rc < 0)) {
|
275
|
+
errno_assert (errno == EINTR);
|
276
|
+
return -1;
|
277
|
+
}
|
278
|
+
#endif
|
279
|
+
if (unlikely (rc == 0)) {
|
280
|
+
errno = EAGAIN;
|
281
|
+
return -1;
|
282
|
+
}
|
283
|
+
zmq_assert (rc == 1);
|
284
|
+
return 0;
|
285
|
+
|
286
|
+
#else
|
287
|
+
#error
|
288
|
+
#endif
|
289
|
+
}
|
290
|
+
|
291
|
+
void zmq::signaler_t::recv ()
|
292
|
+
{
|
293
|
+
// Attempt to read a signal.
|
294
|
+
#if defined ZMQ_HAVE_EVENTFD
|
295
|
+
uint64_t dummy;
|
296
|
+
ssize_t sz = read (r, &dummy, sizeof (dummy));
|
297
|
+
errno_assert (sz == sizeof (dummy));
|
298
|
+
|
299
|
+
// If we accidentally grabbed the next signal(s) along with the current
|
300
|
+
// one, return it back to the eventfd object.
|
301
|
+
if (unlikely (dummy > 1)) {
|
302
|
+
const uint64_t inc = dummy - 1;
|
303
|
+
ssize_t sz2 = write (w, &inc, sizeof (inc));
|
304
|
+
errno_assert (sz2 == sizeof (inc));
|
305
|
+
return;
|
306
|
+
}
|
307
|
+
|
308
|
+
zmq_assert (dummy == 1);
|
309
|
+
#else
|
310
|
+
unsigned char dummy;
|
311
|
+
#if defined ZMQ_HAVE_WINDOWS
|
312
|
+
int nbytes = ::recv (r, (char *) &dummy, sizeof (dummy), 0);
|
313
|
+
wsa_assert (nbytes != SOCKET_ERROR);
|
314
|
+
#else
|
315
|
+
ssize_t nbytes = ::recv (r, &dummy, sizeof (dummy), 0);
|
316
|
+
errno_assert (nbytes >= 0);
|
317
|
+
#endif
|
318
|
+
zmq_assert (nbytes == sizeof (dummy));
|
319
|
+
zmq_assert (dummy == 0);
|
320
|
+
#endif
|
321
|
+
}
|
322
|
+
|
323
|
+
int zmq::signaler_t::recv_failable ()
|
324
|
+
{
|
325
|
+
// Attempt to read a signal.
|
326
|
+
#if defined ZMQ_HAVE_EVENTFD
|
327
|
+
uint64_t dummy;
|
328
|
+
ssize_t sz = read (r, &dummy, sizeof (dummy));
|
329
|
+
if (sz == -1) {
|
330
|
+
errno_assert (errno == EAGAIN);
|
331
|
+
return -1;
|
332
|
+
}
|
333
|
+
else {
|
334
|
+
errno_assert (sz == sizeof (dummy));
|
335
|
+
|
336
|
+
// If we accidentally grabbed the next signal(s) along with the current
|
337
|
+
// one, return it back to the eventfd object.
|
338
|
+
if (unlikely (dummy > 1)) {
|
339
|
+
const uint64_t inc = dummy - 1;
|
340
|
+
ssize_t sz2 = write (w, &inc, sizeof (inc));
|
341
|
+
errno_assert (sz2 == sizeof (inc));
|
342
|
+
return 0;
|
343
|
+
}
|
344
|
+
|
345
|
+
zmq_assert (dummy == 1);
|
346
|
+
}
|
347
|
+
#else
|
348
|
+
unsigned char dummy;
|
349
|
+
#if defined ZMQ_HAVE_WINDOWS
|
350
|
+
int nbytes = ::recv (r, (char *) &dummy, sizeof (dummy), 0);
|
351
|
+
if (nbytes == SOCKET_ERROR) {
|
352
|
+
const int last_error = WSAGetLastError();
|
353
|
+
if (last_error == WSAEWOULDBLOCK) {
|
354
|
+
errno = EAGAIN;
|
355
|
+
return -1;
|
356
|
+
}
|
357
|
+
wsa_assert (last_error == WSAEWOULDBLOCK);
|
358
|
+
}
|
359
|
+
#else
|
360
|
+
ssize_t nbytes = ::recv (r, &dummy, sizeof (dummy), 0);
|
361
|
+
if (nbytes == -1) {
|
362
|
+
if (errno == EAGAIN || errno == EWOULDBLOCK || errno == EINTR) {
|
363
|
+
errno = EAGAIN;
|
364
|
+
return -1;
|
365
|
+
}
|
366
|
+
errno_assert (errno == EAGAIN || errno == EWOULDBLOCK || errno == EINTR);
|
367
|
+
}
|
368
|
+
#endif
|
369
|
+
zmq_assert (nbytes == sizeof (dummy));
|
370
|
+
zmq_assert (dummy == 0);
|
371
|
+
#endif
|
372
|
+
return 0;
|
373
|
+
}
|
374
|
+
|
375
|
+
#ifdef HAVE_FORK
|
376
|
+
void zmq::signaler_t::forked ()
|
377
|
+
{
|
378
|
+
// Close file descriptors created in the parent and create new pair
|
379
|
+
close (r);
|
380
|
+
close (w);
|
381
|
+
make_fdpair (&r, &w);
|
382
|
+
}
|
383
|
+
#endif
|
384
|
+
|
385
|
+
// Returns -1 if we could not make the socket pair successfully
|
386
|
+
int zmq::signaler_t::make_fdpair (fd_t *r_, fd_t *w_)
|
387
|
+
{
|
388
|
+
#if defined ZMQ_HAVE_EVENTFD
|
389
|
+
int flags = 0;
|
390
|
+
#if defined ZMQ_HAVE_EVENTFD_CLOEXEC
|
391
|
+
// Setting this option result in sane behaviour when exec() functions
|
392
|
+
// are used. Old sockets are closed and don't block TCP ports, avoid
|
393
|
+
// leaks, etc.
|
394
|
+
flags |= EFD_CLOEXEC;
|
395
|
+
#endif
|
396
|
+
fd_t fd = eventfd (0, flags);
|
397
|
+
if (fd == -1) {
|
398
|
+
errno_assert (errno == ENFILE || errno == EMFILE);
|
399
|
+
*w_ = *r_ = -1;
|
400
|
+
return -1;
|
401
|
+
}
|
402
|
+
else {
|
403
|
+
*w_ = *r_ = fd;
|
404
|
+
return 0;
|
405
|
+
}
|
406
|
+
|
407
|
+
#elif defined ZMQ_HAVE_WINDOWS
|
408
|
+
# if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
|
409
|
+
// Windows CE does not manage security attributes
|
410
|
+
SECURITY_DESCRIPTOR sd;
|
411
|
+
SECURITY_ATTRIBUTES sa;
|
412
|
+
memset (&sd, 0, sizeof sd);
|
413
|
+
memset (&sa, 0, sizeof sa);
|
414
|
+
|
415
|
+
InitializeSecurityDescriptor (&sd, SECURITY_DESCRIPTOR_REVISION);
|
416
|
+
SetSecurityDescriptorDacl (&sd, TRUE, 0, FALSE);
|
417
|
+
|
418
|
+
sa.nLength = sizeof (SECURITY_ATTRIBUTES);
|
419
|
+
sa.lpSecurityDescriptor = &sd;
|
420
|
+
# endif
|
421
|
+
|
422
|
+
// This function has to be in a system-wide critical section so that
|
423
|
+
// two instances of the library don't accidentally create signaler
|
424
|
+
// crossing the process boundary.
|
425
|
+
// We'll use named event object to implement the critical section.
|
426
|
+
// Note that if the event object already exists, the CreateEvent requests
|
427
|
+
// EVENT_ALL_ACCESS access right. If this fails, we try to open
|
428
|
+
// the event object asking for SYNCHRONIZE access only.
|
429
|
+
HANDLE sync = NULL;
|
430
|
+
|
431
|
+
// Create critical section only if using fixed signaler port
|
432
|
+
// Use problematic Event implementation for compatibility if using old port 5905.
|
433
|
+
// Otherwise use Mutex implementation.
|
434
|
+
int event_signaler_port = 5905;
|
435
|
+
|
436
|
+
if (signaler_port == event_signaler_port) {
|
437
|
+
# if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
|
438
|
+
sync = CreateEventW (&sa, FALSE, TRUE, L"Global\\zmq-signaler-port-sync");
|
439
|
+
# else
|
440
|
+
sync = CreateEventW (NULL, FALSE, TRUE, L"Global\\zmq-signaler-port-sync");
|
441
|
+
# endif
|
442
|
+
if (sync == NULL && GetLastError () == ERROR_ACCESS_DENIED)
|
443
|
+
sync = OpenEventW (SYNCHRONIZE | EVENT_MODIFY_STATE,
|
444
|
+
FALSE, L"Global\\zmq-signaler-port-sync");
|
445
|
+
|
446
|
+
win_assert (sync != NULL);
|
447
|
+
}
|
448
|
+
else
|
449
|
+
if (signaler_port != 0) {
|
450
|
+
wchar_t mutex_name [MAX_PATH];
|
451
|
+
# ifdef __MINGW32__
|
452
|
+
_snwprintf (mutex_name, MAX_PATH, L"Global\\zmq-signaler-port-%d", signaler_port);
|
453
|
+
# else
|
454
|
+
swprintf (mutex_name, MAX_PATH, L"Global\\zmq-signaler-port-%d", signaler_port);
|
455
|
+
# endif
|
456
|
+
|
457
|
+
# if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
|
458
|
+
sync = CreateMutexW (&sa, FALSE, mutex_name);
|
459
|
+
# else
|
460
|
+
sync = CreateMutexW (NULL, FALSE, mutex_name);
|
461
|
+
# endif
|
462
|
+
if (sync == NULL && GetLastError () == ERROR_ACCESS_DENIED)
|
463
|
+
sync = OpenMutexW (SYNCHRONIZE, FALSE, mutex_name);
|
464
|
+
|
465
|
+
win_assert (sync != NULL);
|
466
|
+
}
|
467
|
+
|
468
|
+
// Windows has no 'socketpair' function. CreatePipe is no good as pipe
|
469
|
+
// handles cannot be polled on. Here we create the socketpair by hand.
|
470
|
+
*w_ = INVALID_SOCKET;
|
471
|
+
*r_ = INVALID_SOCKET;
|
472
|
+
|
473
|
+
// Create listening socket.
|
474
|
+
SOCKET listener;
|
475
|
+
listener = open_socket (AF_INET, SOCK_STREAM, 0);
|
476
|
+
wsa_assert (listener != INVALID_SOCKET);
|
477
|
+
|
478
|
+
// Set SO_REUSEADDR and TCP_NODELAY on listening socket.
|
479
|
+
BOOL so_reuseaddr = 1;
|
480
|
+
int rc = setsockopt (listener, SOL_SOCKET, SO_REUSEADDR,
|
481
|
+
(char *) &so_reuseaddr, sizeof so_reuseaddr);
|
482
|
+
wsa_assert (rc != SOCKET_ERROR);
|
483
|
+
BOOL tcp_nodelay = 1;
|
484
|
+
rc = setsockopt (listener, IPPROTO_TCP, TCP_NODELAY,
|
485
|
+
(char *) &tcp_nodelay, sizeof tcp_nodelay);
|
486
|
+
wsa_assert (rc != SOCKET_ERROR);
|
487
|
+
|
488
|
+
// Init sockaddr to signaler port.
|
489
|
+
struct sockaddr_in addr;
|
490
|
+
memset (&addr, 0, sizeof addr);
|
491
|
+
addr.sin_family = AF_INET;
|
492
|
+
addr.sin_addr.s_addr = htonl (INADDR_LOOPBACK);
|
493
|
+
addr.sin_port = htons (signaler_port);
|
494
|
+
|
495
|
+
// Create the writer socket.
|
496
|
+
*w_ = open_socket (AF_INET, SOCK_STREAM, 0);
|
497
|
+
wsa_assert (*w_ != INVALID_SOCKET);
|
498
|
+
|
499
|
+
// Set TCP_NODELAY on writer socket.
|
500
|
+
rc = setsockopt (*w_, IPPROTO_TCP, TCP_NODELAY,
|
501
|
+
(char *) &tcp_nodelay, sizeof tcp_nodelay);
|
502
|
+
wsa_assert (rc != SOCKET_ERROR);
|
503
|
+
|
504
|
+
if (sync != NULL) {
|
505
|
+
// Enter the critical section.
|
506
|
+
DWORD dwrc = WaitForSingleObject (sync, INFINITE);
|
507
|
+
zmq_assert (dwrc == WAIT_OBJECT_0 || dwrc == WAIT_ABANDONED);
|
508
|
+
}
|
509
|
+
|
510
|
+
// Bind listening socket to signaler port.
|
511
|
+
rc = bind (listener, (const struct sockaddr *) &addr, sizeof addr);
|
512
|
+
|
513
|
+
if (rc != SOCKET_ERROR && signaler_port == 0) {
|
514
|
+
// Retrieve ephemeral port number
|
515
|
+
int addrlen = sizeof addr;
|
516
|
+
rc = getsockname (listener, (struct sockaddr *) &addr, &addrlen);
|
517
|
+
}
|
518
|
+
|
519
|
+
// Listen for incoming connections.
|
520
|
+
if (rc != SOCKET_ERROR)
|
521
|
+
rc = listen (listener, 1);
|
522
|
+
|
523
|
+
// Connect writer to the listener.
|
524
|
+
if (rc != SOCKET_ERROR)
|
525
|
+
rc = connect (*w_, (struct sockaddr *) &addr, sizeof addr);
|
526
|
+
|
527
|
+
// Accept connection from writer.
|
528
|
+
if (rc != SOCKET_ERROR)
|
529
|
+
*r_ = accept (listener, NULL, NULL);
|
530
|
+
|
531
|
+
// Send/receive large chunk to work around TCP slow start
|
532
|
+
// This code is a workaround for #1608
|
533
|
+
if (*r_ != INVALID_SOCKET) {
|
534
|
+
size_t dummy_size = 1024 * 1024; // 1M to overload default receive buffer
|
535
|
+
unsigned char *dummy = (unsigned char *) malloc (dummy_size);
|
536
|
+
wsa_assert (dummy);
|
537
|
+
|
538
|
+
int still_to_send = (int) dummy_size;
|
539
|
+
int still_to_recv = (int) dummy_size;
|
540
|
+
while (still_to_send || still_to_recv) {
|
541
|
+
int nbytes;
|
542
|
+
if (still_to_send > 0) {
|
543
|
+
nbytes = ::send (*w_, (char *) (dummy + dummy_size - still_to_send), still_to_send, 0);
|
544
|
+
wsa_assert (nbytes != SOCKET_ERROR);
|
545
|
+
still_to_send -= nbytes;
|
546
|
+
}
|
547
|
+
nbytes = ::recv (*r_, (char *) (dummy + dummy_size - still_to_recv), still_to_recv, 0);
|
548
|
+
wsa_assert (nbytes != SOCKET_ERROR);
|
549
|
+
still_to_recv -= nbytes;
|
550
|
+
}
|
551
|
+
free (dummy);
|
552
|
+
}
|
553
|
+
|
554
|
+
// Save errno if error occurred in bind/listen/connect/accept.
|
555
|
+
int saved_errno = 0;
|
556
|
+
if (*r_ == INVALID_SOCKET)
|
557
|
+
saved_errno = WSAGetLastError ();
|
558
|
+
|
559
|
+
// We don't need the listening socket anymore. Close it.
|
560
|
+
rc = closesocket (listener);
|
561
|
+
wsa_assert(rc != SOCKET_ERROR);
|
562
|
+
|
563
|
+
if (sync != NULL) {
|
564
|
+
// Exit the critical section.
|
565
|
+
BOOL brc;
|
566
|
+
if (signaler_port == event_signaler_port)
|
567
|
+
brc = SetEvent (sync);
|
568
|
+
else
|
569
|
+
brc = ReleaseMutex (sync);
|
570
|
+
win_assert (brc != 0);
|
571
|
+
|
572
|
+
// Release the kernel object
|
573
|
+
brc = CloseHandle (sync);
|
574
|
+
win_assert (brc != 0);
|
575
|
+
}
|
576
|
+
|
577
|
+
if (*r_ != INVALID_SOCKET) {
|
578
|
+
# if !defined _WIN32_WCE && !defined ZMQ_HAVE_WINDOWS_UWP
|
579
|
+
// On Windows, preventing sockets to be inherited by child processes.
|
580
|
+
BOOL brc = SetHandleInformation ((HANDLE) *r_, HANDLE_FLAG_INHERIT, 0);
|
581
|
+
win_assert (brc);
|
582
|
+
# endif
|
583
|
+
return 0;
|
584
|
+
}
|
585
|
+
else {
|
586
|
+
// Cleanup writer if connection failed
|
587
|
+
if (*w_ != INVALID_SOCKET) {
|
588
|
+
rc = closesocket (*w_);
|
589
|
+
wsa_assert (rc != SOCKET_ERROR);
|
590
|
+
*w_ = INVALID_SOCKET;
|
591
|
+
}
|
592
|
+
// Set errno from saved value
|
593
|
+
errno = wsa_error_to_errno (saved_errno);
|
594
|
+
return -1;
|
595
|
+
}
|
596
|
+
|
597
|
+
#elif defined ZMQ_HAVE_OPENVMS
|
598
|
+
|
599
|
+
// Whilst OpenVMS supports socketpair - it maps to AF_INET only. Further,
|
600
|
+
// it does not set the socket options TCP_NODELAY and TCP_NODELACK which
|
601
|
+
// can lead to performance problems.
|
602
|
+
//
|
603
|
+
// The bug will be fixed in V5.6 ECO4 and beyond. In the meantime, we'll
|
604
|
+
// create the socket pair manually.
|
605
|
+
struct sockaddr_in lcladdr;
|
606
|
+
memset (&lcladdr, 0, sizeof lcladdr);
|
607
|
+
lcladdr.sin_family = AF_INET;
|
608
|
+
lcladdr.sin_addr.s_addr = htonl (INADDR_LOOPBACK);
|
609
|
+
lcladdr.sin_port = 0;
|
610
|
+
|
611
|
+
int listener = open_socket (AF_INET, SOCK_STREAM, 0);
|
612
|
+
errno_assert (listener != -1);
|
613
|
+
|
614
|
+
int on = 1;
|
615
|
+
int rc = setsockopt (listener, IPPROTO_TCP, TCP_NODELAY, &on, sizeof on);
|
616
|
+
errno_assert (rc != -1);
|
617
|
+
|
618
|
+
rc = setsockopt (listener, IPPROTO_TCP, TCP_NODELACK, &on, sizeof on);
|
619
|
+
errno_assert (rc != -1);
|
620
|
+
|
621
|
+
rc = bind (listener, (struct sockaddr *) &lcladdr, sizeof lcladdr);
|
622
|
+
errno_assert (rc != -1);
|
623
|
+
|
624
|
+
socklen_t lcladdr_len = sizeof lcladdr;
|
625
|
+
|
626
|
+
rc = getsockname (listener, (struct sockaddr *) &lcladdr, &lcladdr_len);
|
627
|
+
errno_assert (rc != -1);
|
628
|
+
|
629
|
+
rc = listen (listener, 1);
|
630
|
+
errno_assert (rc != -1);
|
631
|
+
|
632
|
+
*w_ = open_socket (AF_INET, SOCK_STREAM, 0);
|
633
|
+
errno_assert (*w_ != -1);
|
634
|
+
|
635
|
+
rc = setsockopt (*w_, IPPROTO_TCP, TCP_NODELAY, &on, sizeof on);
|
636
|
+
errno_assert (rc != -1);
|
637
|
+
|
638
|
+
rc = setsockopt (*w_, IPPROTO_TCP, TCP_NODELACK, &on, sizeof on);
|
639
|
+
errno_assert (rc != -1);
|
640
|
+
|
641
|
+
rc = connect (*w_, (struct sockaddr *) &lcladdr, sizeof lcladdr);
|
642
|
+
errno_assert (rc != -1);
|
643
|
+
|
644
|
+
*r_ = accept (listener, NULL, NULL);
|
645
|
+
errno_assert (*r_ != -1);
|
646
|
+
|
647
|
+
close (listener);
|
648
|
+
|
649
|
+
return 0;
|
650
|
+
|
651
|
+
#else
|
652
|
+
// All other implementations support socketpair()
|
653
|
+
int sv [2];
|
654
|
+
int type = SOCK_STREAM;
|
655
|
+
// Setting this option result in sane behaviour when exec() functions
|
656
|
+
// are used. Old sockets are closed and don't block TCP ports, avoid
|
657
|
+
// leaks, etc.
|
658
|
+
#if defined ZMQ_HAVE_SOCK_CLOEXEC
|
659
|
+
type |= SOCK_CLOEXEC;
|
660
|
+
#endif
|
661
|
+
int rc = socketpair (AF_UNIX, type, 0, sv);
|
662
|
+
if (rc == -1) {
|
663
|
+
errno_assert (errno == ENFILE || errno == EMFILE);
|
664
|
+
*w_ = *r_ = -1;
|
665
|
+
return -1;
|
666
|
+
}
|
667
|
+
else {
|
668
|
+
// If there's no SOCK_CLOEXEC, let's try the second best option. Note that
|
669
|
+
// race condition can cause socket not to be closed (if fork happens
|
670
|
+
// between socket creation and this point).
|
671
|
+
#if !defined ZMQ_HAVE_SOCK_CLOEXEC && defined FD_CLOEXEC
|
672
|
+
rc = fcntl (sv [0], F_SETFD, FD_CLOEXEC);
|
673
|
+
errno_assert (rc != -1);
|
674
|
+
rc = fcntl (sv [1], F_SETFD, FD_CLOEXEC);
|
675
|
+
errno_assert (rc != -1);
|
676
|
+
#endif
|
677
|
+
*w_ = sv [0];
|
678
|
+
*r_ = sv [1];
|
679
|
+
return 0;
|
680
|
+
}
|
681
|
+
#endif
|
682
|
+
}
|