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,279 @@
|
|
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_CONDITON_VARIABLE_HPP_INCLUDED__
|
31
|
+
#define __ZMQ_CONDITON_VARIABLE_HPP_INCLUDED__
|
32
|
+
|
33
|
+
#include "clock.hpp"
|
34
|
+
#include "err.hpp"
|
35
|
+
#include "mutex.hpp"
|
36
|
+
|
37
|
+
// Condition variable class encapsulates OS mutex in a platform-independent way.
|
38
|
+
|
39
|
+
#ifdef ZMQ_HAVE_WINDOWS
|
40
|
+
|
41
|
+
#include "windows.hpp"
|
42
|
+
#if defined(_MSC_VER)
|
43
|
+
#if _MSC_VER >= 1800
|
44
|
+
#define _SUPPORT_CONDITION_VARIABLE 1
|
45
|
+
#else
|
46
|
+
#define _SUPPORT_CONDITION_VARIABLE 0
|
47
|
+
#endif
|
48
|
+
#else
|
49
|
+
#if _cplusplus >= 201103L
|
50
|
+
#define _SUPPORT_CONDITION_VARIABLE 1
|
51
|
+
#else
|
52
|
+
#define _SUPPORT_CONDITION_VARIABLE 0
|
53
|
+
#endif
|
54
|
+
#endif
|
55
|
+
|
56
|
+
// Condition variable is supported from Windows Vista only, to use condition variable define _WIN32_WINNT to 0x0600
|
57
|
+
#if _WIN32_WINNT < 0x0600 && !_SUPPORT_CONDITION_VARIABLE
|
58
|
+
|
59
|
+
namespace zmq
|
60
|
+
{
|
61
|
+
|
62
|
+
class condition_variable_t
|
63
|
+
{
|
64
|
+
public:
|
65
|
+
inline condition_variable_t ()
|
66
|
+
{
|
67
|
+
zmq_assert(false);
|
68
|
+
}
|
69
|
+
|
70
|
+
inline ~condition_variable_t ()
|
71
|
+
{
|
72
|
+
|
73
|
+
}
|
74
|
+
|
75
|
+
inline int wait (mutex_t* mutex_, int timeout_ )
|
76
|
+
{
|
77
|
+
zmq_assert(false);
|
78
|
+
return -1;
|
79
|
+
}
|
80
|
+
|
81
|
+
inline void broadcast ()
|
82
|
+
{
|
83
|
+
zmq_assert(false);
|
84
|
+
}
|
85
|
+
|
86
|
+
private:
|
87
|
+
|
88
|
+
// Disable copy construction and assignment.
|
89
|
+
condition_variable_t (const condition_variable_t&);
|
90
|
+
void operator = (const condition_variable_t&);
|
91
|
+
};
|
92
|
+
|
93
|
+
}
|
94
|
+
|
95
|
+
#else
|
96
|
+
|
97
|
+
#if _SUPPORT_CONDITION_VARIABLE || defined(ZMQ_HAVE_WINDOWS_TARGET_XP)
|
98
|
+
#include <condition_variable>
|
99
|
+
#include <mutex>
|
100
|
+
#endif
|
101
|
+
|
102
|
+
namespace zmq
|
103
|
+
{
|
104
|
+
|
105
|
+
#if !defined(ZMQ_HAVE_WINDOWS_TARGET_XP) && _WIN32_WINNT >= 0x0600
|
106
|
+
class condition_variable_t
|
107
|
+
{
|
108
|
+
public:
|
109
|
+
inline condition_variable_t ()
|
110
|
+
{
|
111
|
+
InitializeConditionVariable (&cv);
|
112
|
+
}
|
113
|
+
|
114
|
+
inline ~condition_variable_t ()
|
115
|
+
{
|
116
|
+
|
117
|
+
}
|
118
|
+
|
119
|
+
inline int wait (mutex_t* mutex_, int timeout_ )
|
120
|
+
{
|
121
|
+
int rc = SleepConditionVariableCS(&cv, mutex_->get_cs (), timeout_);
|
122
|
+
|
123
|
+
if (rc != 0)
|
124
|
+
return 0;
|
125
|
+
|
126
|
+
rc = GetLastError();
|
127
|
+
|
128
|
+
if (rc != ERROR_TIMEOUT)
|
129
|
+
win_assert(rc);
|
130
|
+
|
131
|
+
errno = EAGAIN;
|
132
|
+
return -1;
|
133
|
+
}
|
134
|
+
|
135
|
+
inline void broadcast ()
|
136
|
+
{
|
137
|
+
WakeAllConditionVariable(&cv);
|
138
|
+
}
|
139
|
+
|
140
|
+
private:
|
141
|
+
|
142
|
+
CONDITION_VARIABLE cv;
|
143
|
+
|
144
|
+
// Disable copy construction and assignment.
|
145
|
+
condition_variable_t (const condition_variable_t&);
|
146
|
+
void operator = (const condition_variable_t&);
|
147
|
+
};
|
148
|
+
#else
|
149
|
+
class condition_variable_t
|
150
|
+
{
|
151
|
+
public:
|
152
|
+
inline condition_variable_t()
|
153
|
+
{
|
154
|
+
|
155
|
+
}
|
156
|
+
|
157
|
+
inline ~condition_variable_t()
|
158
|
+
{
|
159
|
+
|
160
|
+
}
|
161
|
+
|
162
|
+
inline int wait(mutex_t* mutex_, int timeout_)
|
163
|
+
{
|
164
|
+
std::unique_lock<std::mutex> lck(mtx); // lock mtx
|
165
|
+
mutex_->unlock(); // unlock mutex_
|
166
|
+
int res = 0;
|
167
|
+
if(timeout_ == -1) {
|
168
|
+
cv.wait(lck); // unlock mtx and wait cv.notify_all(), lock mtx after cv.notify_all()
|
169
|
+
} else if (cv.wait_for(lck, std::chrono::milliseconds(timeout_)) == std::cv_status::timeout) {
|
170
|
+
// time expired
|
171
|
+
errno = EAGAIN;
|
172
|
+
res = -1;
|
173
|
+
}
|
174
|
+
lck.unlock(); // unlock mtx
|
175
|
+
mutex_->lock(); // lock mutex_
|
176
|
+
return res;
|
177
|
+
}
|
178
|
+
|
179
|
+
inline void broadcast()
|
180
|
+
{
|
181
|
+
std::unique_lock<std::mutex> lck(mtx); // lock mtx
|
182
|
+
cv.notify_all();
|
183
|
+
}
|
184
|
+
|
185
|
+
private:
|
186
|
+
|
187
|
+
std::condition_variable cv;
|
188
|
+
std::mutex mtx;
|
189
|
+
|
190
|
+
// Disable copy construction and assignment.
|
191
|
+
condition_variable_t(const condition_variable_t&);
|
192
|
+
void operator = (const condition_variable_t&);
|
193
|
+
};
|
194
|
+
|
195
|
+
#endif
|
196
|
+
}
|
197
|
+
|
198
|
+
#endif
|
199
|
+
|
200
|
+
#else
|
201
|
+
|
202
|
+
#include <pthread.h>
|
203
|
+
|
204
|
+
namespace zmq
|
205
|
+
{
|
206
|
+
|
207
|
+
class condition_variable_t
|
208
|
+
{
|
209
|
+
public:
|
210
|
+
inline condition_variable_t ()
|
211
|
+
{
|
212
|
+
int rc = pthread_cond_init (&cond, NULL);
|
213
|
+
posix_assert (rc);
|
214
|
+
}
|
215
|
+
|
216
|
+
inline ~condition_variable_t ()
|
217
|
+
{
|
218
|
+
int rc = pthread_cond_destroy (&cond);
|
219
|
+
posix_assert (rc);
|
220
|
+
}
|
221
|
+
|
222
|
+
inline int wait (mutex_t* mutex_, int timeout_)
|
223
|
+
{
|
224
|
+
int rc;
|
225
|
+
|
226
|
+
if (timeout_ != -1) {
|
227
|
+
struct timespec timeout;
|
228
|
+
|
229
|
+
#if defined ZMQ_HAVE_OSX && __MAC_OS_X_VERSION_MIN_REQUIRED < 101200 // less than macOS 10.12
|
230
|
+
alt_clock_gettime(SYSTEM_CLOCK, &timeout);
|
231
|
+
#else
|
232
|
+
clock_gettime(CLOCK_MONOTONIC, &timeout);
|
233
|
+
#endif
|
234
|
+
|
235
|
+
timeout.tv_sec += timeout_ / 1000;
|
236
|
+
timeout.tv_nsec += (timeout_ % 1000) * 1000000;
|
237
|
+
|
238
|
+
if (timeout.tv_nsec > 1000000000) {
|
239
|
+
timeout.tv_sec++;
|
240
|
+
timeout.tv_nsec -= 1000000000;
|
241
|
+
}
|
242
|
+
|
243
|
+
rc = pthread_cond_timedwait (&cond, mutex_->get_mutex (), &timeout);
|
244
|
+
}
|
245
|
+
else
|
246
|
+
rc = pthread_cond_wait(&cond, mutex_->get_mutex());
|
247
|
+
|
248
|
+
if (rc == 0)
|
249
|
+
return 0;
|
250
|
+
|
251
|
+
if (rc == ETIMEDOUT){
|
252
|
+
errno= EAGAIN;
|
253
|
+
return -1;
|
254
|
+
}
|
255
|
+
|
256
|
+
posix_assert (rc);
|
257
|
+
return -1;
|
258
|
+
}
|
259
|
+
|
260
|
+
inline void broadcast ()
|
261
|
+
{
|
262
|
+
int rc = pthread_cond_broadcast (&cond);
|
263
|
+
posix_assert (rc);
|
264
|
+
}
|
265
|
+
|
266
|
+
private:
|
267
|
+
|
268
|
+
pthread_cond_t cond;
|
269
|
+
|
270
|
+
// Disable copy construction and assignment.
|
271
|
+
condition_variable_t (const condition_variable_t&);
|
272
|
+
const condition_variable_t &operator = (const condition_variable_t&);
|
273
|
+
};
|
274
|
+
}
|
275
|
+
|
276
|
+
#endif
|
277
|
+
|
278
|
+
|
279
|
+
#endif
|
@@ -0,0 +1,98 @@
|
|
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_CONFIG_HPP_INCLUDED__
|
31
|
+
#define __ZMQ_CONFIG_HPP_INCLUDED__
|
32
|
+
|
33
|
+
namespace zmq
|
34
|
+
{
|
35
|
+
|
36
|
+
// Compile-time settings.
|
37
|
+
|
38
|
+
enum
|
39
|
+
{
|
40
|
+
// Number of new messages in message pipe needed to trigger new memory
|
41
|
+
// allocation. Setting this parameter to 256 decreases the impact of
|
42
|
+
// memory allocation by approximately 99.6%
|
43
|
+
message_pipe_granularity = 256,
|
44
|
+
|
45
|
+
// Commands in pipe per allocation event.
|
46
|
+
command_pipe_granularity = 16,
|
47
|
+
|
48
|
+
// Determines how often does socket poll for new commands when it
|
49
|
+
// still has unprocessed messages to handle. Thus, if it is set to 100,
|
50
|
+
// socket will process 100 inbound messages before doing the poll.
|
51
|
+
// If there are no unprocessed messages available, poll is done
|
52
|
+
// immediately. Decreasing the value trades overall latency for more
|
53
|
+
// real-time behaviour (less latency peaks).
|
54
|
+
inbound_poll_rate = 100,
|
55
|
+
|
56
|
+
// Maximal batching size for engines with receiving functionality.
|
57
|
+
// So, if there are 10 messages that fit into the batch size, all of
|
58
|
+
// them may be read by a single 'recv' system call, thus avoiding
|
59
|
+
// unnecessary network stack traversals.
|
60
|
+
in_batch_size = 8192,
|
61
|
+
|
62
|
+
// Maximal batching size for engines with sending functionality.
|
63
|
+
// So, if there are 10 messages that fit into the batch size, all of
|
64
|
+
// them may be written by a single 'send' system call, thus avoiding
|
65
|
+
// unnecessary network stack traversals.
|
66
|
+
out_batch_size = 8192,
|
67
|
+
|
68
|
+
// Maximal delta between high and low watermark.
|
69
|
+
max_wm_delta = 1024,
|
70
|
+
|
71
|
+
// Maximum number of events the I/O thread can process in one go.
|
72
|
+
max_io_events = 256,
|
73
|
+
|
74
|
+
// Maximal delay to process command in API thread (in CPU ticks).
|
75
|
+
// 3,000,000 ticks equals to 1 - 2 milliseconds on current CPUs.
|
76
|
+
// Note that delay is only applied when there is continuous stream of
|
77
|
+
// messages to process. If not so, commands are processed immediately.
|
78
|
+
max_command_delay = 3000000,
|
79
|
+
|
80
|
+
// Low-precision clock precision in CPU ticks. 1ms. Value of 1000000
|
81
|
+
// should be OK for CPU frequencies above 1GHz. If should work
|
82
|
+
// reasonably well for CPU frequencies above 500MHz. For lower CPU
|
83
|
+
// frequencies you may consider lowering this value to get best
|
84
|
+
// possible latencies.
|
85
|
+
clock_precision = 1000000,
|
86
|
+
|
87
|
+
// On some OSes the signaler has to be emulated using a TCP
|
88
|
+
// connection. In such cases following port is used.
|
89
|
+
// If 0, it lets the OS choose a free port without requiring use of a
|
90
|
+
// global mutex. The original implementation of a Windows signaler
|
91
|
+
// socket used port 5905 instead of letting the OS choose a free port.
|
92
|
+
// https://github.com/zeromq/libzmq/issues/1542
|
93
|
+
signaler_port = 0
|
94
|
+
};
|
95
|
+
|
96
|
+
}
|
97
|
+
|
98
|
+
#endif
|
@@ -0,0 +1,644 @@
|
|
1
|
+
/*
|
2
|
+
Copyright (c) 2007-2017 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
|
+
#ifndef ZMQ_HAVE_WINDOWS
|
33
|
+
#include <unistd.h>
|
34
|
+
#endif
|
35
|
+
|
36
|
+
#include <limits>
|
37
|
+
#include <climits>
|
38
|
+
#include <new>
|
39
|
+
#include <sstream>
|
40
|
+
#include <string.h>
|
41
|
+
|
42
|
+
#include "ctx.hpp"
|
43
|
+
#include "socket_base.hpp"
|
44
|
+
#include "io_thread.hpp"
|
45
|
+
#include "reaper.hpp"
|
46
|
+
#include "pipe.hpp"
|
47
|
+
#include "err.hpp"
|
48
|
+
#include "msg.hpp"
|
49
|
+
#include "random.hpp"
|
50
|
+
|
51
|
+
#ifdef ZMQ_HAVE_VMCI
|
52
|
+
#include <vmci_sockets.h>
|
53
|
+
#endif
|
54
|
+
|
55
|
+
#define ZMQ_CTX_TAG_VALUE_GOOD 0xabadcafe
|
56
|
+
#define ZMQ_CTX_TAG_VALUE_BAD 0xdeadbeef
|
57
|
+
|
58
|
+
int clipped_maxsocket (int max_requested)
|
59
|
+
{
|
60
|
+
if (max_requested >= zmq::poller_t::max_fds () && zmq::poller_t::max_fds () != -1)
|
61
|
+
// -1 because we need room for the reaper mailbox.
|
62
|
+
max_requested = zmq::poller_t::max_fds () - 1;
|
63
|
+
|
64
|
+
return max_requested;
|
65
|
+
}
|
66
|
+
|
67
|
+
zmq::ctx_t::ctx_t () :
|
68
|
+
tag (ZMQ_CTX_TAG_VALUE_GOOD),
|
69
|
+
starting (true),
|
70
|
+
terminating (false),
|
71
|
+
reaper (NULL),
|
72
|
+
slot_count (0),
|
73
|
+
slots (NULL),
|
74
|
+
max_sockets (clipped_maxsocket (ZMQ_MAX_SOCKETS_DFLT)),
|
75
|
+
max_msgsz (INT_MAX),
|
76
|
+
io_thread_count (ZMQ_IO_THREADS_DFLT),
|
77
|
+
blocky (true),
|
78
|
+
ipv6 (false),
|
79
|
+
thread_priority (ZMQ_THREAD_PRIORITY_DFLT),
|
80
|
+
thread_sched_policy (ZMQ_THREAD_SCHED_POLICY_DFLT)
|
81
|
+
{
|
82
|
+
#ifdef HAVE_FORK
|
83
|
+
pid = getpid();
|
84
|
+
#endif
|
85
|
+
#ifdef ZMQ_HAVE_VMCI
|
86
|
+
vmci_fd = -1;
|
87
|
+
vmci_family = -1;
|
88
|
+
#endif
|
89
|
+
|
90
|
+
// Initialise crypto library, if needed.
|
91
|
+
zmq::random_open ();
|
92
|
+
}
|
93
|
+
|
94
|
+
bool zmq::ctx_t::check_tag ()
|
95
|
+
{
|
96
|
+
return tag == ZMQ_CTX_TAG_VALUE_GOOD;
|
97
|
+
}
|
98
|
+
|
99
|
+
zmq::ctx_t::~ctx_t ()
|
100
|
+
{
|
101
|
+
// Check that there are no remaining sockets.
|
102
|
+
zmq_assert (sockets.empty ());
|
103
|
+
|
104
|
+
// Ask I/O threads to terminate. If stop signal wasn't sent to I/O
|
105
|
+
// thread subsequent invocation of destructor would hang-up.
|
106
|
+
for (io_threads_t::size_type i = 0; i != io_threads.size (); i++) {
|
107
|
+
io_threads [i]->stop ();
|
108
|
+
}
|
109
|
+
|
110
|
+
// Wait till I/O threads actually terminate.
|
111
|
+
for (io_threads_t::size_type i = 0; i != io_threads.size (); i++) {
|
112
|
+
LIBZMQ_DELETE(io_threads [i]);
|
113
|
+
}
|
114
|
+
|
115
|
+
// Deallocate the reaper thread object.
|
116
|
+
LIBZMQ_DELETE(reaper);
|
117
|
+
|
118
|
+
// Deallocate the array of mailboxes. No special work is
|
119
|
+
// needed as mailboxes themselves were deallocated with their
|
120
|
+
// corresponding io_thread/socket objects.
|
121
|
+
free (slots);
|
122
|
+
|
123
|
+
// De-initialise crypto library, if needed.
|
124
|
+
zmq::random_close ();
|
125
|
+
|
126
|
+
// Remove the tag, so that the object is considered dead.
|
127
|
+
tag = ZMQ_CTX_TAG_VALUE_BAD;
|
128
|
+
}
|
129
|
+
|
130
|
+
int zmq::ctx_t::terminate ()
|
131
|
+
{
|
132
|
+
slot_sync.lock();
|
133
|
+
|
134
|
+
bool saveTerminating = terminating;
|
135
|
+
terminating = false;
|
136
|
+
|
137
|
+
// Connect up any pending inproc connections, otherwise we will hang
|
138
|
+
pending_connections_t copy = pending_connections;
|
139
|
+
for (pending_connections_t::iterator p = copy.begin (); p != copy.end (); ++p) {
|
140
|
+
zmq::socket_base_t *s = create_socket (ZMQ_PAIR);
|
141
|
+
// create_socket might fail eg: out of memory/sockets limit reached
|
142
|
+
zmq_assert (s);
|
143
|
+
s->bind (p->first.c_str ());
|
144
|
+
s->close ();
|
145
|
+
}
|
146
|
+
terminating = saveTerminating;
|
147
|
+
|
148
|
+
if (!starting) {
|
149
|
+
|
150
|
+
#ifdef HAVE_FORK
|
151
|
+
if (pid != getpid ()) {
|
152
|
+
// we are a forked child process. Close all file descriptors
|
153
|
+
// inherited from the parent.
|
154
|
+
for (sockets_t::size_type i = 0; i != sockets.size (); i++)
|
155
|
+
sockets [i]->get_mailbox ()->forked ();
|
156
|
+
|
157
|
+
term_mailbox.forked ();
|
158
|
+
}
|
159
|
+
#endif
|
160
|
+
|
161
|
+
// Check whether termination was already underway, but interrupted and now
|
162
|
+
// restarted.
|
163
|
+
bool restarted = terminating;
|
164
|
+
terminating = true;
|
165
|
+
|
166
|
+
// First attempt to terminate the context.
|
167
|
+
if (!restarted) {
|
168
|
+
// First send stop command to sockets so that any blocking calls
|
169
|
+
// can be interrupted. If there are no sockets we can ask reaper
|
170
|
+
// thread to stop.
|
171
|
+
for (sockets_t::size_type i = 0; i != sockets.size (); i++)
|
172
|
+
sockets [i]->stop ();
|
173
|
+
if (sockets.empty ())
|
174
|
+
reaper->stop ();
|
175
|
+
}
|
176
|
+
slot_sync.unlock();
|
177
|
+
|
178
|
+
// Wait till reaper thread closes all the sockets.
|
179
|
+
command_t cmd;
|
180
|
+
int rc = term_mailbox.recv (&cmd, -1);
|
181
|
+
if (rc == -1 && errno == EINTR)
|
182
|
+
return -1;
|
183
|
+
errno_assert (rc == 0);
|
184
|
+
zmq_assert (cmd.type == command_t::done);
|
185
|
+
slot_sync.lock ();
|
186
|
+
zmq_assert (sockets.empty ());
|
187
|
+
}
|
188
|
+
slot_sync.unlock ();
|
189
|
+
|
190
|
+
#ifdef ZMQ_HAVE_VMCI
|
191
|
+
vmci_sync.lock ();
|
192
|
+
|
193
|
+
VMCISock_ReleaseAFValueFd (vmci_fd);
|
194
|
+
vmci_family = -1;
|
195
|
+
vmci_fd = -1;
|
196
|
+
|
197
|
+
vmci_sync.unlock ();
|
198
|
+
#endif
|
199
|
+
|
200
|
+
// Deallocate the resources.
|
201
|
+
delete this;
|
202
|
+
|
203
|
+
return 0;
|
204
|
+
}
|
205
|
+
|
206
|
+
int zmq::ctx_t::shutdown ()
|
207
|
+
{
|
208
|
+
scoped_lock_t locker(slot_sync);
|
209
|
+
|
210
|
+
if (!starting && !terminating) {
|
211
|
+
terminating = true;
|
212
|
+
|
213
|
+
// Send stop command to sockets so that any blocking calls
|
214
|
+
// can be interrupted. If there are no sockets we can ask reaper
|
215
|
+
// thread to stop.
|
216
|
+
for (sockets_t::size_type i = 0; i != sockets.size (); i++)
|
217
|
+
sockets [i]->stop ();
|
218
|
+
if (sockets.empty ())
|
219
|
+
reaper->stop ();
|
220
|
+
}
|
221
|
+
|
222
|
+
return 0;
|
223
|
+
}
|
224
|
+
|
225
|
+
int zmq::ctx_t::set (int option_, int optval_)
|
226
|
+
{
|
227
|
+
int rc = 0;
|
228
|
+
if (option_ == ZMQ_MAX_SOCKETS
|
229
|
+
&& optval_ >= 1 && optval_ == clipped_maxsocket (optval_)) {
|
230
|
+
scoped_lock_t locker(opt_sync);
|
231
|
+
max_sockets = optval_;
|
232
|
+
}
|
233
|
+
else
|
234
|
+
if (option_ == ZMQ_IO_THREADS && optval_ >= 0) {
|
235
|
+
scoped_lock_t locker(opt_sync);
|
236
|
+
io_thread_count = optval_;
|
237
|
+
}
|
238
|
+
else
|
239
|
+
if (option_ == ZMQ_IPV6 && optval_ >= 0) {
|
240
|
+
scoped_lock_t locker(opt_sync);
|
241
|
+
ipv6 = (optval_ != 0);
|
242
|
+
}
|
243
|
+
else
|
244
|
+
if (option_ == ZMQ_THREAD_PRIORITY && optval_ >= 0) {
|
245
|
+
scoped_lock_t locker(opt_sync);
|
246
|
+
thread_priority = optval_;
|
247
|
+
}
|
248
|
+
else
|
249
|
+
if (option_ == ZMQ_THREAD_SCHED_POLICY && optval_ >= 0) {
|
250
|
+
scoped_lock_t locker(opt_sync);
|
251
|
+
thread_sched_policy = optval_;
|
252
|
+
}
|
253
|
+
else
|
254
|
+
if (option_ == ZMQ_THREAD_AFFINITY_CPU_ADD && optval_ >= 0) {
|
255
|
+
scoped_lock_t locker(opt_sync);
|
256
|
+
thread_affinity_cpus.insert( optval_ );
|
257
|
+
}
|
258
|
+
else
|
259
|
+
if (option_ == ZMQ_THREAD_AFFINITY_CPU_REMOVE && optval_ >= 0) {
|
260
|
+
scoped_lock_t locker(opt_sync);
|
261
|
+
std::set<int>::iterator it = thread_affinity_cpus.find( optval_ );
|
262
|
+
if (it != thread_affinity_cpus.end()) {
|
263
|
+
thread_affinity_cpus.erase( it );
|
264
|
+
} else {
|
265
|
+
errno = EINVAL;
|
266
|
+
rc = -1;
|
267
|
+
}
|
268
|
+
}
|
269
|
+
else
|
270
|
+
if (option_ == ZMQ_THREAD_NAME_PREFIX && optval_ >= 0) {
|
271
|
+
std::ostringstream s;
|
272
|
+
s << optval_;
|
273
|
+
scoped_lock_t locker(opt_sync);
|
274
|
+
thread_name_prefix = s.str();
|
275
|
+
}
|
276
|
+
else
|
277
|
+
if (option_ == ZMQ_BLOCKY && optval_ >= 0) {
|
278
|
+
scoped_lock_t locker(opt_sync);
|
279
|
+
blocky = (optval_ != 0);
|
280
|
+
}
|
281
|
+
else
|
282
|
+
if (option_ == ZMQ_MAX_MSGSZ && optval_ >= 0) {
|
283
|
+
scoped_lock_t locker(opt_sync);
|
284
|
+
max_msgsz = optval_ < INT_MAX? optval_: INT_MAX;
|
285
|
+
}
|
286
|
+
else {
|
287
|
+
errno = EINVAL;
|
288
|
+
rc = -1;
|
289
|
+
}
|
290
|
+
return rc;
|
291
|
+
}
|
292
|
+
|
293
|
+
int zmq::ctx_t::get (int option_)
|
294
|
+
{
|
295
|
+
int rc = 0;
|
296
|
+
if (option_ == ZMQ_MAX_SOCKETS)
|
297
|
+
rc = max_sockets;
|
298
|
+
else
|
299
|
+
if (option_ == ZMQ_SOCKET_LIMIT)
|
300
|
+
rc = clipped_maxsocket (65535);
|
301
|
+
else
|
302
|
+
if (option_ == ZMQ_IO_THREADS)
|
303
|
+
rc = io_thread_count;
|
304
|
+
else
|
305
|
+
if (option_ == ZMQ_IPV6)
|
306
|
+
rc = ipv6;
|
307
|
+
else
|
308
|
+
if (option_ == ZMQ_BLOCKY)
|
309
|
+
rc = blocky;
|
310
|
+
else
|
311
|
+
if (option_ == ZMQ_MAX_MSGSZ)
|
312
|
+
rc = max_msgsz;
|
313
|
+
else
|
314
|
+
if (option_ == ZMQ_MSG_T_SIZE)
|
315
|
+
rc = sizeof (zmq_msg_t);
|
316
|
+
else {
|
317
|
+
errno = EINVAL;
|
318
|
+
rc = -1;
|
319
|
+
}
|
320
|
+
return rc;
|
321
|
+
}
|
322
|
+
|
323
|
+
zmq::socket_base_t *zmq::ctx_t::create_socket (int type_)
|
324
|
+
{
|
325
|
+
scoped_lock_t locker(slot_sync);
|
326
|
+
|
327
|
+
if (unlikely (starting)) {
|
328
|
+
|
329
|
+
starting = false;
|
330
|
+
// Initialise the array of mailboxes. Additional three slots are for
|
331
|
+
// zmq_ctx_term thread and reaper thread.
|
332
|
+
opt_sync.lock ();
|
333
|
+
int mazmq = max_sockets;
|
334
|
+
int ios = io_thread_count;
|
335
|
+
opt_sync.unlock ();
|
336
|
+
slot_count = mazmq + ios + 2;
|
337
|
+
slots = (i_mailbox **) malloc (sizeof (i_mailbox*) * slot_count);
|
338
|
+
alloc_assert (slots);
|
339
|
+
|
340
|
+
// Initialise the infrastructure for zmq_ctx_term thread.
|
341
|
+
slots [term_tid] = &term_mailbox;
|
342
|
+
|
343
|
+
// Create the reaper thread.
|
344
|
+
reaper = new (std::nothrow) reaper_t (this, reaper_tid);
|
345
|
+
alloc_assert (reaper);
|
346
|
+
slots [reaper_tid] = reaper->get_mailbox ();
|
347
|
+
reaper->start ();
|
348
|
+
|
349
|
+
// Create I/O thread objects and launch them.
|
350
|
+
for (int i = 2; i != ios + 2; i++) {
|
351
|
+
io_thread_t *io_thread = new (std::nothrow) io_thread_t (this, i);
|
352
|
+
alloc_assert (io_thread);
|
353
|
+
io_threads.push_back (io_thread);
|
354
|
+
slots [i] = io_thread->get_mailbox ();
|
355
|
+
io_thread->start ();
|
356
|
+
}
|
357
|
+
|
358
|
+
// In the unused part of the slot array, create a list of empty slots.
|
359
|
+
for (int32_t i = (int32_t) slot_count - 1;
|
360
|
+
i >= (int32_t) ios + 2; i--) {
|
361
|
+
empty_slots.push_back (i);
|
362
|
+
slots [i] = NULL;
|
363
|
+
}
|
364
|
+
}
|
365
|
+
|
366
|
+
// Once zmq_ctx_term() was called, we can't create new sockets.
|
367
|
+
if (terminating) {
|
368
|
+
errno = ETERM;
|
369
|
+
return NULL;
|
370
|
+
}
|
371
|
+
|
372
|
+
// If max_sockets limit was reached, return error.
|
373
|
+
if (empty_slots.empty ()) {
|
374
|
+
errno = EMFILE;
|
375
|
+
return NULL;
|
376
|
+
}
|
377
|
+
|
378
|
+
// Choose a slot for the socket.
|
379
|
+
uint32_t slot = empty_slots.back ();
|
380
|
+
empty_slots.pop_back ();
|
381
|
+
|
382
|
+
// Generate new unique socket ID.
|
383
|
+
int sid = ((int) max_socket_id.add (1)) + 1;
|
384
|
+
|
385
|
+
// Create the socket and register its mailbox.
|
386
|
+
socket_base_t *s = socket_base_t::create (type_, this, slot, sid);
|
387
|
+
if (!s) {
|
388
|
+
empty_slots.push_back (slot);
|
389
|
+
return NULL;
|
390
|
+
}
|
391
|
+
sockets.push_back (s);
|
392
|
+
slots [slot] = s->get_mailbox ();
|
393
|
+
|
394
|
+
return s;
|
395
|
+
}
|
396
|
+
|
397
|
+
void zmq::ctx_t::destroy_socket (class socket_base_t *socket_)
|
398
|
+
{
|
399
|
+
scoped_lock_t locker(slot_sync);
|
400
|
+
|
401
|
+
// Free the associated thread slot.
|
402
|
+
uint32_t tid = socket_->get_tid ();
|
403
|
+
empty_slots.push_back (tid);
|
404
|
+
slots [tid] = NULL;
|
405
|
+
|
406
|
+
// Remove the socket from the list of sockets.
|
407
|
+
sockets.erase (socket_);
|
408
|
+
|
409
|
+
// If zmq_ctx_term() was already called and there are no more socket
|
410
|
+
// we can ask reaper thread to terminate.
|
411
|
+
if (terminating && sockets.empty ())
|
412
|
+
reaper->stop ();
|
413
|
+
}
|
414
|
+
|
415
|
+
zmq::object_t *zmq::ctx_t::get_reaper ()
|
416
|
+
{
|
417
|
+
return reaper;
|
418
|
+
}
|
419
|
+
|
420
|
+
void zmq::ctx_t::start_thread (thread_t &thread_, thread_fn *tfn_, void *arg_) const
|
421
|
+
{
|
422
|
+
static unsigned int nthreads_started = 0;
|
423
|
+
|
424
|
+
thread_.setSchedulingParameters(thread_priority, thread_sched_policy, thread_affinity_cpus);
|
425
|
+
thread_.start(tfn_, arg_);
|
426
|
+
#ifndef ZMQ_HAVE_ANDROID
|
427
|
+
std::ostringstream s;
|
428
|
+
if (!thread_name_prefix.empty())
|
429
|
+
s << thread_name_prefix << "/";
|
430
|
+
s << "ZMQbg/" << nthreads_started;
|
431
|
+
thread_.setThreadName (s.str().c_str());
|
432
|
+
#endif
|
433
|
+
nthreads_started++;
|
434
|
+
}
|
435
|
+
|
436
|
+
void zmq::ctx_t::send_command (uint32_t tid_, const command_t &command_)
|
437
|
+
{
|
438
|
+
slots [tid_]->send (command_);
|
439
|
+
}
|
440
|
+
|
441
|
+
zmq::io_thread_t *zmq::ctx_t::choose_io_thread (uint64_t affinity_)
|
442
|
+
{
|
443
|
+
if (io_threads.empty ())
|
444
|
+
return NULL;
|
445
|
+
|
446
|
+
// Find the I/O thread with minimum load.
|
447
|
+
int min_load = -1;
|
448
|
+
io_thread_t *selected_io_thread = NULL;
|
449
|
+
for (io_threads_t::size_type i = 0; i != io_threads.size (); i++) {
|
450
|
+
if (!affinity_ || (affinity_ & (uint64_t (1) << i))) {
|
451
|
+
int load = io_threads [i]->get_load ();
|
452
|
+
if (selected_io_thread == NULL || load < min_load) {
|
453
|
+
min_load = load;
|
454
|
+
selected_io_thread = io_threads [i];
|
455
|
+
}
|
456
|
+
}
|
457
|
+
}
|
458
|
+
return selected_io_thread;
|
459
|
+
}
|
460
|
+
|
461
|
+
int zmq::ctx_t::register_endpoint (const char *addr_,
|
462
|
+
const endpoint_t &endpoint_)
|
463
|
+
{
|
464
|
+
scoped_lock_t locker(endpoints_sync);
|
465
|
+
|
466
|
+
const bool inserted = endpoints.ZMQ_MAP_INSERT_OR_EMPLACE (addr_,
|
467
|
+
endpoint_).second;
|
468
|
+
if (!inserted) {
|
469
|
+
errno = EADDRINUSE;
|
470
|
+
return -1;
|
471
|
+
}
|
472
|
+
return 0;
|
473
|
+
}
|
474
|
+
|
475
|
+
int zmq::ctx_t::unregister_endpoint (
|
476
|
+
const std::string &addr_, socket_base_t *socket_)
|
477
|
+
{
|
478
|
+
scoped_lock_t locker(endpoints_sync);
|
479
|
+
|
480
|
+
const endpoints_t::iterator it = endpoints.find (addr_);
|
481
|
+
if (it == endpoints.end () || it->second.socket != socket_) {
|
482
|
+
errno = ENOENT;
|
483
|
+
return -1;
|
484
|
+
}
|
485
|
+
|
486
|
+
// Remove endpoint.
|
487
|
+
endpoints.erase (it);
|
488
|
+
|
489
|
+
return 0;
|
490
|
+
}
|
491
|
+
|
492
|
+
void zmq::ctx_t::unregister_endpoints (socket_base_t *socket_)
|
493
|
+
{
|
494
|
+
scoped_lock_t locker(endpoints_sync);
|
495
|
+
|
496
|
+
endpoints_t::iterator it = endpoints.begin ();
|
497
|
+
while (it != endpoints.end ()) {
|
498
|
+
if (it->second.socket == socket_) {
|
499
|
+
endpoints_t::iterator to_erase = it;
|
500
|
+
++it;
|
501
|
+
endpoints.erase (to_erase);
|
502
|
+
continue;
|
503
|
+
}
|
504
|
+
++it;
|
505
|
+
}
|
506
|
+
}
|
507
|
+
|
508
|
+
zmq::endpoint_t zmq::ctx_t::find_endpoint (const char *addr_)
|
509
|
+
{
|
510
|
+
scoped_lock_t locker(endpoints_sync);
|
511
|
+
|
512
|
+
endpoints_t::iterator it = endpoints.find (addr_);
|
513
|
+
if (it == endpoints.end ()) {
|
514
|
+
errno = ECONNREFUSED;
|
515
|
+
endpoint_t empty = {NULL, options_t()};
|
516
|
+
return empty;
|
517
|
+
}
|
518
|
+
endpoint_t endpoint = it->second;
|
519
|
+
|
520
|
+
// Increment the command sequence number of the peer so that it won't
|
521
|
+
// get deallocated until "bind" command is issued by the caller.
|
522
|
+
// The subsequent 'bind' has to be called with inc_seqnum parameter
|
523
|
+
// set to false, so that the seqnum isn't incremented twice.
|
524
|
+
endpoint.socket->inc_seqnum ();
|
525
|
+
|
526
|
+
return endpoint;
|
527
|
+
}
|
528
|
+
|
529
|
+
void zmq::ctx_t::pend_connection (const std::string &addr_,
|
530
|
+
const endpoint_t &endpoint_, pipe_t **pipes_)
|
531
|
+
{
|
532
|
+
scoped_lock_t locker(endpoints_sync);
|
533
|
+
|
534
|
+
const pending_connection_t pending_connection = {endpoint_, pipes_ [0], pipes_ [1]};
|
535
|
+
|
536
|
+
endpoints_t::iterator it = endpoints.find (addr_);
|
537
|
+
if (it == endpoints.end ()) {
|
538
|
+
// Still no bind.
|
539
|
+
endpoint_.socket->inc_seqnum ();
|
540
|
+
pending_connections.ZMQ_MAP_INSERT_OR_EMPLACE (addr_, pending_connection);
|
541
|
+
} else {
|
542
|
+
// Bind has happened in the mean time, connect directly
|
543
|
+
connect_inproc_sockets(it->second.socket, it->second.options, pending_connection, connect_side);
|
544
|
+
}
|
545
|
+
}
|
546
|
+
|
547
|
+
void zmq::ctx_t::connect_pending (const char *addr_, zmq::socket_base_t *bind_socket_)
|
548
|
+
{
|
549
|
+
scoped_lock_t locker(endpoints_sync);
|
550
|
+
|
551
|
+
std::pair<pending_connections_t::iterator, pending_connections_t::iterator> pending = pending_connections.equal_range(addr_);
|
552
|
+
for (pending_connections_t::iterator p = pending.first; p != pending.second; ++p)
|
553
|
+
connect_inproc_sockets(bind_socket_, endpoints[addr_].options, p->second, bind_side);
|
554
|
+
|
555
|
+
pending_connections.erase(pending.first, pending.second);
|
556
|
+
}
|
557
|
+
|
558
|
+
void zmq::ctx_t::connect_inproc_sockets (zmq::socket_base_t *bind_socket_,
|
559
|
+
options_t& bind_options, const pending_connection_t &pending_connection_, side side_)
|
560
|
+
{
|
561
|
+
bind_socket_->inc_seqnum();
|
562
|
+
pending_connection_.bind_pipe->set_tid (bind_socket_->get_tid ());
|
563
|
+
|
564
|
+
if (!bind_options.recv_routing_id) {
|
565
|
+
msg_t msg;
|
566
|
+
const bool ok = pending_connection_.bind_pipe->read (&msg);
|
567
|
+
zmq_assert (ok);
|
568
|
+
const int rc = msg.close ();
|
569
|
+
errno_assert (rc == 0);
|
570
|
+
}
|
571
|
+
|
572
|
+
bool conflate = pending_connection_.endpoint.options.conflate &&
|
573
|
+
(pending_connection_.endpoint.options.type == ZMQ_DEALER ||
|
574
|
+
pending_connection_.endpoint.options.type == ZMQ_PULL ||
|
575
|
+
pending_connection_.endpoint.options.type == ZMQ_PUSH ||
|
576
|
+
pending_connection_.endpoint.options.type == ZMQ_PUB ||
|
577
|
+
pending_connection_.endpoint.options.type == ZMQ_SUB);
|
578
|
+
|
579
|
+
if (!conflate) {
|
580
|
+
pending_connection_.connect_pipe->set_hwms_boost(bind_options.sndhwm, bind_options.rcvhwm);
|
581
|
+
pending_connection_.bind_pipe->set_hwms_boost(pending_connection_.endpoint.options.sndhwm, pending_connection_.endpoint.options.rcvhwm);
|
582
|
+
|
583
|
+
pending_connection_.connect_pipe->set_hwms(pending_connection_.endpoint.options.rcvhwm, pending_connection_.endpoint.options.sndhwm);
|
584
|
+
pending_connection_.bind_pipe->set_hwms(bind_options.rcvhwm, bind_options.sndhwm);
|
585
|
+
}
|
586
|
+
else {
|
587
|
+
pending_connection_.connect_pipe->set_hwms(-1, -1);
|
588
|
+
pending_connection_.bind_pipe->set_hwms(-1, -1);
|
589
|
+
}
|
590
|
+
|
591
|
+
if (side_ == bind_side) {
|
592
|
+
command_t cmd;
|
593
|
+
cmd.type = command_t::bind;
|
594
|
+
cmd.args.bind.pipe = pending_connection_.bind_pipe;
|
595
|
+
bind_socket_->process_command (cmd);
|
596
|
+
bind_socket_->send_inproc_connected (pending_connection_.endpoint.socket);
|
597
|
+
}
|
598
|
+
else
|
599
|
+
pending_connection_.connect_pipe->send_bind (bind_socket_, pending_connection_.bind_pipe, false);
|
600
|
+
|
601
|
+
// When a ctx is terminated all pending inproc connection will be
|
602
|
+
// connected, but the socket will already be closed and the pipe will be
|
603
|
+
// in waiting_for_delimiter state, which means no more writes can be done
|
604
|
+
// and the routing id write fails and causes an assert. Check if the socket
|
605
|
+
// is open before sending.
|
606
|
+
if (pending_connection_.endpoint.options.recv_routing_id &&
|
607
|
+
pending_connection_.endpoint.socket->check_tag ()) {
|
608
|
+
msg_t routing_id;
|
609
|
+
const int rc = routing_id.init_size (bind_options.routing_id_size);
|
610
|
+
errno_assert (rc == 0);
|
611
|
+
memcpy (routing_id.data (), bind_options.routing_id, bind_options.routing_id_size);
|
612
|
+
routing_id.set_flags (msg_t::routing_id);
|
613
|
+
const bool written = pending_connection_.bind_pipe->write (&routing_id);
|
614
|
+
zmq_assert (written);
|
615
|
+
pending_connection_.bind_pipe->flush ();
|
616
|
+
}
|
617
|
+
}
|
618
|
+
|
619
|
+
#ifdef ZMQ_HAVE_VMCI
|
620
|
+
|
621
|
+
int zmq::ctx_t::get_vmci_socket_family ()
|
622
|
+
{
|
623
|
+
zmq::scoped_lock_t locker(vmci_sync);
|
624
|
+
|
625
|
+
if (vmci_fd == -1) {
|
626
|
+
vmci_family = VMCISock_GetAFValueFd (&vmci_fd);
|
627
|
+
|
628
|
+
if (vmci_fd != -1) {
|
629
|
+
#ifdef FD_CLOEXEC
|
630
|
+
int rc = fcntl (vmci_fd, F_SETFD, FD_CLOEXEC);
|
631
|
+
errno_assert (rc != -1);
|
632
|
+
#endif
|
633
|
+
}
|
634
|
+
}
|
635
|
+
|
636
|
+
return vmci_family;
|
637
|
+
}
|
638
|
+
|
639
|
+
#endif
|
640
|
+
|
641
|
+
// The last used socket ID, or 0 if no socket was used so far. Note that this
|
642
|
+
// is a global variable. Thus, even sockets created in different contexts have
|
643
|
+
// unique IDs.
|
644
|
+
zmq::atomic_counter_t zmq::ctx_t::max_socket_id;
|