laag-libzmq 4.2.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (792) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +57 -0
  3. data/LICENSE.txt +181 -0
  4. data/README.org +34 -0
  5. data/ext/laag/libzmq/extconf.rb +22 -0
  6. data/laag-libzmq.gemspec +21 -0
  7. data/lib/laag/libzmq.rb +31 -0
  8. data/vendor/github.com/zeromq/libzmq/.github/PULL_REQUEST_TEMPLATE.md +28 -0
  9. data/vendor/github.com/zeromq/libzmq/.github/issue_template.md +22 -0
  10. data/vendor/github.com/zeromq/libzmq/.gitignore +180 -0
  11. data/vendor/github.com/zeromq/libzmq/.hgeol +2 -0
  12. data/vendor/github.com/zeromq/libzmq/.mailmap +81 -0
  13. data/vendor/github.com/zeromq/libzmq/.travis.yml +115 -0
  14. data/vendor/github.com/zeromq/libzmq/AUTHORS +151 -0
  15. data/vendor/github.com/zeromq/libzmq/CMakeLists.txt +1104 -0
  16. data/vendor/github.com/zeromq/libzmq/COPYING +674 -0
  17. data/vendor/github.com/zeromq/libzmq/COPYING.LESSER +181 -0
  18. data/vendor/github.com/zeromq/libzmq/Dockerfile +11 -0
  19. data/vendor/github.com/zeromq/libzmq/Doxygen.cfg +2320 -0
  20. data/vendor/github.com/zeromq/libzmq/FindSodium.cmake +40 -0
  21. data/vendor/github.com/zeromq/libzmq/INSTALL +311 -0
  22. data/vendor/github.com/zeromq/libzmq/Jenkinsfile +369 -0
  23. data/vendor/github.com/zeromq/libzmq/Makefile.am +908 -0
  24. data/vendor/github.com/zeromq/libzmq/NEWS +1582 -0
  25. data/vendor/github.com/zeromq/libzmq/README.cygwin.md +15 -0
  26. data/vendor/github.com/zeromq/libzmq/README.doxygen.md +48 -0
  27. data/vendor/github.com/zeromq/libzmq/README.md +102 -0
  28. data/vendor/github.com/zeromq/libzmq/RELICENSE/AndreLouisCaron.md +15 -0
  29. data/vendor/github.com/zeromq/libzmq/RELICENSE/Asmod4n.md +13 -0
  30. data/vendor/github.com/zeromq/libzmq/RELICENSE/BerndPrager.md +13 -0
  31. data/vendor/github.com/zeromq/libzmq/RELICENSE/Bklyn.md +15 -0
  32. data/vendor/github.com/zeromq/libzmq/RELICENSE/BrianBuchanan.md +15 -0
  33. data/vendor/github.com/zeromq/libzmq/RELICENSE/ChuckRemes.md +15 -0
  34. data/vendor/github.com/zeromq/libzmq/RELICENSE/FrancoFichtner.md +15 -0
  35. data/vendor/github.com/zeromq/libzmq/RELICENSE/GavinMcNiff.md +15 -0
  36. data/vendor/github.com/zeromq/libzmq/RELICENSE/GhislainPutois.md +15 -0
  37. data/vendor/github.com/zeromq/libzmq/RELICENSE/GiuseppeCorbelli.md +15 -0
  38. data/vendor/github.com/zeromq/libzmq/RELICENSE/HaraldAchitz.md +17 -0
  39. data/vendor/github.com/zeromq/libzmq/RELICENSE/Hugne.md +17 -0
  40. data/vendor/github.com/zeromq/libzmq/RELICENSE/JimHague.md +16 -0
  41. data/vendor/github.com/zeromq/libzmq/RELICENSE/JohanMabille.md +16 -0
  42. data/vendor/github.com/zeromq/libzmq/RELICENSE/LeonardMichelet +14 -0
  43. data/vendor/github.com/zeromq/libzmq/RELICENSE/LeonardoConsoni.md +15 -0
  44. data/vendor/github.com/zeromq/libzmq/RELICENSE/LionelOrry.md +15 -0
  45. data/vendor/github.com/zeromq/libzmq/RELICENSE/OsirisPedroso.md +15 -0
  46. data/vendor/github.com/zeromq/libzmq/RELICENSE/README.md +23 -0
  47. data/vendor/github.com/zeromq/libzmq/RELICENSE/RobGagnon.md +13 -0
  48. data/vendor/github.com/zeromq/libzmq/RELICENSE/SebastienRombauts.md +15 -0
  49. data/vendor/github.com/zeromq/libzmq/RELICENSE/StoianIvanov.md +15 -0
  50. data/vendor/github.com/zeromq/libzmq/RELICENSE/SylvainCorlay.md +16 -0
  51. data/vendor/github.com/zeromq/libzmq/RELICENSE/TimotheeBesset.md +15 -0
  52. data/vendor/github.com/zeromq/libzmq/RELICENSE/VincentTellier.md +15 -0
  53. data/vendor/github.com/zeromq/libzmq/RELICENSE/VolodymyrKorniichuk.md +15 -0
  54. data/vendor/github.com/zeromq/libzmq/RELICENSE/abbradar.md +16 -0
  55. data/vendor/github.com/zeromq/libzmq/RELICENSE/agronholm.md +15 -0
  56. data/vendor/github.com/zeromq/libzmq/RELICENSE/amuraru.md +15 -0
  57. data/vendor/github.com/zeromq/libzmq/RELICENSE/arsenm.md +15 -0
  58. data/vendor/github.com/zeromq/libzmq/RELICENSE/aseering.md +15 -0
  59. data/vendor/github.com/zeromq/libzmq/RELICENSE/bjorntopel.md +16 -0
  60. data/vendor/github.com/zeromq/libzmq/RELICENSE/bjovke.md +16 -0
  61. data/vendor/github.com/zeromq/libzmq/RELICENSE/brocade_communications_systems.md +15 -0
  62. data/vendor/github.com/zeromq/libzmq/RELICENSE/brunobodin.md +13 -0
  63. data/vendor/github.com/zeromq/libzmq/RELICENSE/c-rack.md +15 -0
  64. data/vendor/github.com/zeromq/libzmq/RELICENSE/camachat.md +15 -0
  65. data/vendor/github.com/zeromq/libzmq/RELICENSE/cdolan.md +15 -0
  66. data/vendor/github.com/zeromq/libzmq/RELICENSE/chrisstaite.md +14 -0
  67. data/vendor/github.com/zeromq/libzmq/RELICENSE/chugga_fan.md +15 -0
  68. data/vendor/github.com/zeromq/libzmq/RELICENSE/cjuniet.md +15 -0
  69. data/vendor/github.com/zeromq/libzmq/RELICENSE/ckamm.md +15 -0
  70. data/vendor/github.com/zeromq/libzmq/RELICENSE/clkao.md +15 -0
  71. data/vendor/github.com/zeromq/libzmq/RELICENSE/danielhtshih.md +15 -0
  72. data/vendor/github.com/zeromq/libzmq/RELICENSE/danriegsecker.md +16 -0
  73. data/vendor/github.com/zeromq/libzmq/RELICENSE/dfons.md +16 -0
  74. data/vendor/github.com/zeromq/libzmq/RELICENSE/djelenc.md +15 -0
  75. data/vendor/github.com/zeromq/libzmq/RELICENSE/drodri.md +15 -0
  76. data/vendor/github.com/zeromq/libzmq/RELICENSE/eburkitt.md +15 -0
  77. data/vendor/github.com/zeromq/libzmq/RELICENSE/egomotion.md +16 -0
  78. data/vendor/github.com/zeromq/libzmq/RELICENSE/evoskuil.md +15 -0
  79. data/vendor/github.com/zeromq/libzmq/RELICENSE/febeling.md +16 -0
  80. data/vendor/github.com/zeromq/libzmq/RELICENSE/fidlej.md +15 -0
  81. data/vendor/github.com/zeromq/libzmq/RELICENSE/flub.md +14 -0
  82. data/vendor/github.com/zeromq/libzmq/RELICENSE/gena-moscow.md +15 -0
  83. data/vendor/github.com/zeromq/libzmq/RELICENSE/gonzus.md +15 -0
  84. data/vendor/github.com/zeromq/libzmq/RELICENSE/goodfella_ltd.md +13 -0
  85. data/vendor/github.com/zeromq/libzmq/RELICENSE/google.md +13 -0
  86. data/vendor/github.com/zeromq/libzmq/RELICENSE/ianbarber.md +15 -0
  87. data/vendor/github.com/zeromq/libzmq/RELICENSE/imatix.md +23 -0
  88. data/vendor/github.com/zeromq/libzmq/RELICENSE/jakecobb.md +13 -0
  89. data/vendor/github.com/zeromq/libzmq/RELICENSE/jemc.md +15 -0
  90. data/vendor/github.com/zeromq/libzmq/RELICENSE/jimklimov.md +17 -0
  91. data/vendor/github.com/zeromq/libzmq/RELICENSE/jkryl.md +15 -0
  92. data/vendor/github.com/zeromq/libzmq/RELICENSE/johntconklin.md +15 -0
  93. data/vendor/github.com/zeromq/libzmq/RELICENSE/jruffin.md +14 -0
  94. data/vendor/github.com/zeromq/libzmq/RELICENSE/kentzo.md +15 -0
  95. data/vendor/github.com/zeromq/libzmq/RELICENSE/kevinsapper.md +13 -0
  96. data/vendor/github.com/zeromq/libzmq/RELICENSE/kobolog.md +12 -0
  97. data/vendor/github.com/zeromq/libzmq/RELICENSE/kurdybacha.md +15 -0
  98. data/vendor/github.com/zeromq/libzmq/RELICENSE/linville.md +15 -0
  99. data/vendor/github.com/zeromq/libzmq/RELICENSE/loachfish.md +15 -0
  100. data/vendor/github.com/zeromq/libzmq/RELICENSE/lodagro.md +15 -0
  101. data/vendor/github.com/zeromq/libzmq/RELICENSE/madebr.md +15 -0
  102. data/vendor/github.com/zeromq/libzmq/RELICENSE/mattconnolly.md +15 -0
  103. data/vendor/github.com/zeromq/libzmq/RELICENSE/mauri-melato.md +13 -0
  104. data/vendor/github.com/zeromq/libzmq/RELICENSE/mditzel.md +15 -0
  105. data/vendor/github.com/zeromq/libzmq/RELICENSE/meox.md +15 -0
  106. data/vendor/github.com/zeromq/libzmq/RELICENSE/michael-fox.md +16 -0
  107. data/vendor/github.com/zeromq/libzmq/RELICENSE/michicc.md +15 -0
  108. data/vendor/github.com/zeromq/libzmq/RELICENSE/minrk.md +15 -0
  109. data/vendor/github.com/zeromq/libzmq/RELICENSE/mipaaa.md +15 -0
  110. data/vendor/github.com/zeromq/libzmq/RELICENSE/mkluwe.md +15 -0
  111. data/vendor/github.com/zeromq/libzmq/RELICENSE/montoyaedu.md +15 -0
  112. data/vendor/github.com/zeromq/libzmq/RELICENSE/naos_ltd.md +19 -0
  113. data/vendor/github.com/zeromq/libzmq/RELICENSE/natano.md +15 -0
  114. data/vendor/github.com/zeromq/libzmq/RELICENSE/olafmandel.md +13 -0
  115. data/vendor/github.com/zeromq/libzmq/RELICENSE/pijyoi.md +13 -0
  116. data/vendor/github.com/zeromq/libzmq/RELICENSE/ptroja.md +14 -0
  117. data/vendor/github.com/zeromq/libzmq/RELICENSE/reunanen.md +15 -0
  118. data/vendor/github.com/zeromq/libzmq/RELICENSE/reza-ebrahimi.md +15 -0
  119. data/vendor/github.com/zeromq/libzmq/RELICENSE/rikvdh.md +15 -0
  120. data/vendor/github.com/zeromq/libzmq/RELICENSE/rlenferink.md +15 -0
  121. data/vendor/github.com/zeromq/libzmq/RELICENSE/roalz.md +13 -0
  122. data/vendor/github.com/zeromq/libzmq/RELICENSE/rodgert.md +17 -0
  123. data/vendor/github.com/zeromq/libzmq/RELICENSE/rotty.md +16 -0
  124. data/vendor/github.com/zeromq/libzmq/RELICENSE/sabae.md +15 -0
  125. data/vendor/github.com/zeromq/libzmq/RELICENSE/scemama.md +15 -0
  126. data/vendor/github.com/zeromq/libzmq/RELICENSE/sheremetyev.md +13 -0
  127. data/vendor/github.com/zeromq/libzmq/RELICENSE/shripchenko.md +15 -0
  128. data/vendor/github.com/zeromq/libzmq/RELICENSE/sigiesec.md +17 -0
  129. data/vendor/github.com/zeromq/libzmq/RELICENSE/soulik.md +15 -0
  130. data/vendor/github.com/zeromq/libzmq/RELICENSE/swansontec.md +15 -0
  131. data/vendor/github.com/zeromq/libzmq/RELICENSE/t-b.md +15 -0
  132. data/vendor/github.com/zeromq/libzmq/RELICENSE/tSed.md +15 -0
  133. data/vendor/github.com/zeromq/libzmq/RELICENSE/tabe.md +15 -0
  134. data/vendor/github.com/zeromq/libzmq/RELICENSE/tailhook.md +16 -0
  135. data/vendor/github.com/zeromq/libzmq/RELICENSE/taotetek.md +13 -0
  136. data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2-any-osi.txt +15 -0
  137. data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2-share-alike-osi.txt +15 -0
  138. data/vendor/github.com/zeromq/libzmq/RELICENSE/templates/relicense-template-mplv2.txt +13 -0
  139. data/vendor/github.com/zeromq/libzmq/RELICENSE/thompsa.md +15 -0
  140. data/vendor/github.com/zeromq/libzmq/RELICENSE/torehalvorsen.md +15 -0
  141. data/vendor/github.com/zeromq/libzmq/RELICENSE/twhittock.md +15 -0
  142. data/vendor/github.com/zeromq/libzmq/RELICENSE/ulikoehler.md +16 -0
  143. data/vendor/github.com/zeromq/libzmq/RELICENSE/vyskocilm.md +7 -0
  144. data/vendor/github.com/zeromq/libzmq/RELICENSE/willstrang.md +15 -0
  145. data/vendor/github.com/zeromq/libzmq/RELICENSE/xaqq.md +13 -0
  146. data/vendor/github.com/zeromq/libzmq/RELICENSE/yuvallanger.md +15 -0
  147. data/vendor/github.com/zeromq/libzmq/ZeroMQConfig.cmake.in +25 -0
  148. data/vendor/github.com/zeromq/libzmq/acinclude.m4 +1122 -0
  149. data/vendor/github.com/zeromq/libzmq/appveyor.yml +97 -0
  150. data/vendor/github.com/zeromq/libzmq/autogen.sh +49 -0
  151. data/vendor/github.com/zeromq/libzmq/branding.bmp +0 -0
  152. data/vendor/github.com/zeromq/libzmq/builds/Makefile.am +31 -0
  153. data/vendor/github.com/zeromq/libzmq/builds/README +4 -0
  154. data/vendor/github.com/zeromq/libzmq/builds/android/Dockerfile +22 -0
  155. data/vendor/github.com/zeromq/libzmq/builds/android/README.md +78 -0
  156. data/vendor/github.com/zeromq/libzmq/builds/android/android_build_helper.sh +316 -0
  157. data/vendor/github.com/zeromq/libzmq/builds/android/build.sh +70 -0
  158. data/vendor/github.com/zeromq/libzmq/builds/android/ci_build.sh +30 -0
  159. data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/FindAsciiDoc.cmake +26 -0
  160. data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/TestZMQVersion.cmake +8 -0
  161. data/vendor/github.com/zeromq/libzmq/builds/cmake/Modules/ZMQSourceRunChecks.cmake +301 -0
  162. data/vendor/github.com/zeromq/libzmq/builds/cmake/NSIS.template32.in +952 -0
  163. data/vendor/github.com/zeromq/libzmq/builds/cmake/NSIS.template64.in +960 -0
  164. data/vendor/github.com/zeromq/libzmq/builds/cmake/ci_build.sh +34 -0
  165. data/vendor/github.com/zeromq/libzmq/builds/cmake/platform.hpp.in +104 -0
  166. data/vendor/github.com/zeromq/libzmq/builds/coverage/ci_build.sh +32 -0
  167. data/vendor/github.com/zeromq/libzmq/builds/cygwin/Makefile.cygwin +48 -0
  168. data/vendor/github.com/zeromq/libzmq/builds/gyp/.gitignore +5 -0
  169. data/vendor/github.com/zeromq/libzmq/builds/gyp/build.bat +4 -0
  170. data/vendor/github.com/zeromq/libzmq/builds/gyp/platform.hpp +80 -0
  171. data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.gsl +19 -0
  172. data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.gypi +895 -0
  173. data/vendor/github.com/zeromq/libzmq/builds/gyp/project-tests.xml +83 -0
  174. data/vendor/github.com/zeromq/libzmq/builds/gyp/project.gyp +295 -0
  175. data/vendor/github.com/zeromq/libzmq/builds/mingw32/Makefile.mingw32 +49 -0
  176. data/vendor/github.com/zeromq/libzmq/builds/mingw32/platform.hpp +43 -0
  177. data/vendor/github.com/zeromq/libzmq/builds/msvc/.gitignore +256 -0
  178. data/vendor/github.com/zeromq/libzmq/builds/msvc/Makefile.am +94 -0
  179. data/vendor/github.com/zeromq/libzmq/builds/msvc/build/build.bat +33 -0
  180. data/vendor/github.com/zeromq/libzmq/builds/msvc/build/buildall.bat +16 -0
  181. data/vendor/github.com/zeromq/libzmq/builds/msvc/build/buildbase.bat +73 -0
  182. data/vendor/github.com/zeromq/libzmq/builds/msvc/errno.cpp +32 -0
  183. data/vendor/github.com/zeromq/libzmq/builds/msvc/errno.hpp +56 -0
  184. data/vendor/github.com/zeromq/libzmq/builds/msvc/platform.hpp +14 -0
  185. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Common.props +21 -0
  186. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DLL.props +16 -0
  187. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Debug.props +29 -0
  188. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugDEXE.props +21 -0
  189. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugDLL.props +20 -0
  190. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLEXE.props +20 -0
  191. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLIB.props +21 -0
  192. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugLTCG.props +20 -0
  193. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/DebugSEXE.props +21 -0
  194. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/EXE.props +17 -0
  195. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/LIB.props +16 -0
  196. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/LTCG.props +13 -0
  197. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Link.props +21 -0
  198. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Messages.props +15 -0
  199. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Output.props +30 -0
  200. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Release.props +41 -0
  201. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseDEXE.props +20 -0
  202. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseDLL.props +19 -0
  203. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLEXE.props +20 -0
  204. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLIB.props +19 -0
  205. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseLTCG.props +19 -0
  206. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/ReleaseSEXE.props +20 -0
  207. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/Win32.props +20 -0
  208. data/vendor/github.com/zeromq/libzmq/builds/msvc/properties/x64.props +23 -0
  209. data/vendor/github.com/zeromq/libzmq/builds/msvc/readme.txt +27 -0
  210. data/vendor/github.com/zeromq/libzmq/builds/msvc/resource.h +14 -0
  211. data/vendor/github.com/zeromq/libzmq/builds/msvc/resource.rc +0 -0
  212. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/inproc_lat/inproc_lat.vcproj +52 -0
  213. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/inproc_thr/inproc_thr.vcproj +52 -0
  214. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/libzmq.sln +95 -0
  215. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/libzmq/libzmq.vcproj +338 -0
  216. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/local_lat/local_lat.vcproj +52 -0
  217. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/local_thr/local_thr.vcproj +52 -0
  218. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/remote_lat/remote_lat.vcproj +52 -0
  219. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2008/remote_thr/remote_thr.vcproj +52 -0
  220. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_lat/inproc_lat.props +49 -0
  221. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_lat/inproc_lat.vcxproj +82 -0
  222. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_thr/inproc_thr.props +49 -0
  223. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/inproc_thr/inproc_thr.vcxproj +82 -0
  224. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libsodium.import.props +52 -0
  225. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libsodium.import.xml +17 -0
  226. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.import.props +64 -0
  227. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.import.xml +49 -0
  228. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq.sln +206 -0
  229. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.props +76 -0
  230. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.vcxproj +289 -0
  231. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.vcxproj.filters +627 -0
  232. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/libzmq/libzmq.xml +40 -0
  233. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_lat/local_lat.props +49 -0
  234. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_lat/local_lat.vcxproj +82 -0
  235. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_thr/local_thr.props +49 -0
  236. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/local_thr/local_thr.vcxproj +82 -0
  237. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_lat/remote_lat.props +49 -0
  238. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_lat/remote_lat.vcxproj +82 -0
  239. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_thr/remote_thr.props +49 -0
  240. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2010/remote_thr/remote_thr.vcxproj +82 -0
  241. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_lat/inproc_lat.props +49 -0
  242. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_lat/inproc_lat.vcxproj +82 -0
  243. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_thr/inproc_thr.props +49 -0
  244. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/inproc_thr/inproc_thr.vcxproj +82 -0
  245. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libsodium.import.props +52 -0
  246. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libsodium.import.xml +17 -0
  247. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.import.props +64 -0
  248. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.import.xml +49 -0
  249. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq.sln +206 -0
  250. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.props +76 -0
  251. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.vcxproj +289 -0
  252. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.vcxproj.filters +627 -0
  253. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/libzmq/libzmq.xml +40 -0
  254. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_lat/local_lat.props +49 -0
  255. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_lat/local_lat.vcxproj +82 -0
  256. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_thr/local_thr.props +49 -0
  257. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/local_thr/local_thr.vcxproj +82 -0
  258. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_lat/remote_lat.props +49 -0
  259. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_lat/remote_lat.vcxproj +82 -0
  260. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_thr/remote_thr.props +49 -0
  261. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2012/remote_thr/remote_thr.vcxproj +82 -0
  262. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_lat/inproc_lat.props +49 -0
  263. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_lat/inproc_lat.vcxproj +82 -0
  264. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_thr/inproc_thr.props +49 -0
  265. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/inproc_thr/inproc_thr.vcxproj +82 -0
  266. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libsodium.import.props +52 -0
  267. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libsodium.import.xml +17 -0
  268. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.import.props +64 -0
  269. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.import.xml +49 -0
  270. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq.sln +208 -0
  271. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.props +76 -0
  272. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.vcxproj +289 -0
  273. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.vcxproj.filters +627 -0
  274. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/libzmq/libzmq.xml +40 -0
  275. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_lat/local_lat.props +49 -0
  276. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_lat/local_lat.vcxproj +82 -0
  277. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_thr/local_thr.props +49 -0
  278. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/local_thr/local_thr.vcxproj +82 -0
  279. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_lat/remote_lat.props +49 -0
  280. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_lat/remote_lat.vcxproj +82 -0
  281. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_thr/remote_thr.props +49 -0
  282. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2013/remote_thr/remote_thr.vcxproj +82 -0
  283. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_lat/inproc_lat.props +49 -0
  284. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_lat/inproc_lat.vcxproj +82 -0
  285. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_thr/inproc_thr.props +49 -0
  286. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/inproc_thr/inproc_thr.vcxproj +82 -0
  287. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libsodium.import.props +52 -0
  288. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libsodium.import.xml +17 -0
  289. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.import.props +64 -0
  290. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.import.xml +49 -0
  291. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq.sln +208 -0
  292. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.props +76 -0
  293. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.vcxproj +289 -0
  294. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.vcxproj.filters +627 -0
  295. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/libzmq/libzmq.xml +40 -0
  296. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_lat/local_lat.props +49 -0
  297. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_lat/local_lat.vcxproj +82 -0
  298. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_thr/local_thr.props +49 -0
  299. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/local_thr/local_thr.vcxproj +82 -0
  300. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_lat/remote_lat.props +49 -0
  301. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_lat/remote_lat.vcxproj +82 -0
  302. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_thr/remote_thr.props +49 -0
  303. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015/remote_thr/remote_thr.vcxproj +82 -0
  304. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/libzmq.vcxproj +258 -0
  305. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/platform.hpp +15 -0
  306. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/test_zmq/test_multithread.cpp +229 -0
  307. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2015_xp/test_zmq/test_zmq.vcxproj +155 -0
  308. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_lat/inproc_lat.props +49 -0
  309. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_lat/inproc_lat.vcxproj +82 -0
  310. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_thr/inproc_thr.props +49 -0
  311. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/inproc_thr/inproc_thr.vcxproj +82 -0
  312. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libsodium.import.props +52 -0
  313. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libsodium.import.xml +17 -0
  314. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.import.props +64 -0
  315. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.import.xml +49 -0
  316. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq.sln +208 -0
  317. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.props +76 -0
  318. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.vcxproj +289 -0
  319. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.vcxproj.filters +627 -0
  320. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/libzmq/libzmq.xml +40 -0
  321. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_lat/local_lat.props +49 -0
  322. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_lat/local_lat.vcxproj +82 -0
  323. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_thr/local_thr.props +49 -0
  324. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/local_thr/local_thr.vcxproj +82 -0
  325. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_lat/remote_lat.props +49 -0
  326. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_lat/remote_lat.vcxproj +82 -0
  327. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_thr/remote_thr.props +49 -0
  328. data/vendor/github.com/zeromq/libzmq/builds/msvc/vs2017/remote_thr/remote_thr.vcxproj +82 -0
  329. data/vendor/github.com/zeromq/libzmq/builds/nuget/libzmq.autopkg +52 -0
  330. data/vendor/github.com/zeromq/libzmq/builds/nuget/readme.nuget +20 -0
  331. data/vendor/github.com/zeromq/libzmq/builds/openwrt/Makefile +70 -0
  332. data/vendor/github.com/zeromq/libzmq/builds/valgrind/ci_build.sh +30 -0
  333. data/vendor/github.com/zeromq/libzmq/builds/valgrind/valgrind.supp +22 -0
  334. data/vendor/github.com/zeromq/libzmq/builds/valgrind/vg +1 -0
  335. data/vendor/github.com/zeromq/libzmq/builds/zos/README.md +463 -0
  336. data/vendor/github.com/zeromq/libzmq/builds/zos/cxxall +62 -0
  337. data/vendor/github.com/zeromq/libzmq/builds/zos/makeclean +36 -0
  338. data/vendor/github.com/zeromq/libzmq/builds/zos/makelibzmq +54 -0
  339. data/vendor/github.com/zeromq/libzmq/builds/zos/maketests +102 -0
  340. data/vendor/github.com/zeromq/libzmq/builds/zos/platform.hpp +300 -0
  341. data/vendor/github.com/zeromq/libzmq/builds/zos/runtests +188 -0
  342. data/vendor/github.com/zeromq/libzmq/builds/zos/test_fork.cpp +95 -0
  343. data/vendor/github.com/zeromq/libzmq/builds/zos/zc++ +42 -0
  344. data/vendor/github.com/zeromq/libzmq/ci_build.sh +66 -0
  345. data/vendor/github.com/zeromq/libzmq/ci_deploy.sh +34 -0
  346. data/vendor/github.com/zeromq/libzmq/configure.ac +827 -0
  347. data/vendor/github.com/zeromq/libzmq/doc/Makefile.am +64 -0
  348. data/vendor/github.com/zeromq/libzmq/doc/asciidoc.conf +56 -0
  349. data/vendor/github.com/zeromq/libzmq/doc/zmq.txt +276 -0
  350. data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_dec.txt +62 -0
  351. data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_destroy.txt +62 -0
  352. data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_inc.txt +61 -0
  353. data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_new.txt +62 -0
  354. data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_set.txt +61 -0
  355. data/vendor/github.com/zeromq/libzmq/doc/zmq_atomic_counter_value.txt +62 -0
  356. data/vendor/github.com/zeromq/libzmq/doc/zmq_bind.txt +103 -0
  357. data/vendor/github.com/zeromq/libzmq/doc/zmq_close.txt +56 -0
  358. data/vendor/github.com/zeromq/libzmq/doc/zmq_connect.txt +101 -0
  359. data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_destroy.txt +67 -0
  360. data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_get.txt +105 -0
  361. data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_new.txt +50 -0
  362. data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_set.txt +184 -0
  363. data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_shutdown.txt +52 -0
  364. data/vendor/github.com/zeromq/libzmq/doc/zmq_ctx_term.txt +68 -0
  365. data/vendor/github.com/zeromq/libzmq/doc/zmq_curve.txt +92 -0
  366. data/vendor/github.com/zeromq/libzmq/doc/zmq_curve_keypair.txt +56 -0
  367. data/vendor/github.com/zeromq/libzmq/doc/zmq_curve_public.txt +62 -0
  368. data/vendor/github.com/zeromq/libzmq/doc/zmq_disconnect.txt +75 -0
  369. data/vendor/github.com/zeromq/libzmq/doc/zmq_errno.txt +50 -0
  370. data/vendor/github.com/zeromq/libzmq/doc/zmq_getsockopt.txt +944 -0
  371. data/vendor/github.com/zeromq/libzmq/doc/zmq_gssapi.txt +78 -0
  372. data/vendor/github.com/zeromq/libzmq/doc/zmq_has.txt +44 -0
  373. data/vendor/github.com/zeromq/libzmq/doc/zmq_init.txt +52 -0
  374. data/vendor/github.com/zeromq/libzmq/doc/zmq_inproc.txt +88 -0
  375. data/vendor/github.com/zeromq/libzmq/doc/zmq_ipc.txt +106 -0
  376. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_close.txt +56 -0
  377. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_copy.txt +72 -0
  378. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_data.txt +48 -0
  379. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_get.txt +83 -0
  380. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_gets.txt +81 -0
  381. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init.txt +64 -0
  382. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init_data.txt +89 -0
  383. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_init_size.txt +58 -0
  384. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_more.txt +65 -0
  385. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_move.txt +52 -0
  386. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_recv.txt +124 -0
  387. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_routing_id.txt +61 -0
  388. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_send.txt +127 -0
  389. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_set.txt +46 -0
  390. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_set_routing_id.txt +46 -0
  391. data/vendor/github.com/zeromq/libzmq/doc/zmq_msg_size.txt +48 -0
  392. data/vendor/github.com/zeromq/libzmq/doc/zmq_null.txt +27 -0
  393. data/vendor/github.com/zeromq/libzmq/doc/zmq_pgm.txt +164 -0
  394. data/vendor/github.com/zeromq/libzmq/doc/zmq_plain.txt +37 -0
  395. data/vendor/github.com/zeromq/libzmq/doc/zmq_poll.txt +135 -0
  396. data/vendor/github.com/zeromq/libzmq/doc/zmq_proxy.txt +99 -0
  397. data/vendor/github.com/zeromq/libzmq/doc/zmq_proxy_steerable.txt +111 -0
  398. data/vendor/github.com/zeromq/libzmq/doc/zmq_recv.txt +91 -0
  399. data/vendor/github.com/zeromq/libzmq/doc/zmq_recvmsg.txt +121 -0
  400. data/vendor/github.com/zeromq/libzmq/doc/zmq_send.txt +104 -0
  401. data/vendor/github.com/zeromq/libzmq/doc/zmq_send_const.txt +103 -0
  402. data/vendor/github.com/zeromq/libzmq/doc/zmq_sendmsg.txt +121 -0
  403. data/vendor/github.com/zeromq/libzmq/doc/zmq_setsockopt.txt +1318 -0
  404. data/vendor/github.com/zeromq/libzmq/doc/zmq_socket.txt +609 -0
  405. data/vendor/github.com/zeromq/libzmq/doc/zmq_socket_monitor.txt +294 -0
  406. data/vendor/github.com/zeromq/libzmq/doc/zmq_strerror.txt +56 -0
  407. data/vendor/github.com/zeromq/libzmq/doc/zmq_tcp.txt +118 -0
  408. data/vendor/github.com/zeromq/libzmq/doc/zmq_term.txt +66 -0
  409. data/vendor/github.com/zeromq/libzmq/doc/zmq_tipc.txt +83 -0
  410. data/vendor/github.com/zeromq/libzmq/doc/zmq_udp.txt +99 -0
  411. data/vendor/github.com/zeromq/libzmq/doc/zmq_unbind.txt +90 -0
  412. data/vendor/github.com/zeromq/libzmq/doc/zmq_version.txt +54 -0
  413. data/vendor/github.com/zeromq/libzmq/doc/zmq_vmci.txt +97 -0
  414. data/vendor/github.com/zeromq/libzmq/doc/zmq_z85_decode.txt +51 -0
  415. data/vendor/github.com/zeromq/libzmq/doc/zmq_z85_encode.txt +58 -0
  416. data/vendor/github.com/zeromq/libzmq/include/zmq.h +708 -0
  417. data/vendor/github.com/zeromq/libzmq/include/zmq_utils.h +48 -0
  418. data/vendor/github.com/zeromq/libzmq/installer.ico +0 -0
  419. data/vendor/github.com/zeromq/libzmq/m4/ax_check_compile_flag.m4 +74 -0
  420. data/vendor/github.com/zeromq/libzmq/m4/ax_code_coverage.m4 +264 -0
  421. data/vendor/github.com/zeromq/libzmq/m4/ax_cxx_compile_stdcxx.m4 +562 -0
  422. data/vendor/github.com/zeromq/libzmq/m4/ax_cxx_compile_stdcxx_11.m4 +40 -0
  423. data/vendor/github.com/zeromq/libzmq/m4/ax_valgrind_check.m4 +233 -0
  424. data/vendor/github.com/zeromq/libzmq/packaging/README +4 -0
  425. data/vendor/github.com/zeromq/libzmq/packaging/debian/changelog +5 -0
  426. data/vendor/github.com/zeromq/libzmq/packaging/debian/compat +1 -0
  427. data/vendor/github.com/zeromq/libzmq/packaging/debian/control +64 -0
  428. data/vendor/github.com/zeromq/libzmq/packaging/debian/copyright +93 -0
  429. data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq3-dev.install +4 -0
  430. data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq3-dev.manpages +2 -0
  431. data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq5.docs +2 -0
  432. data/vendor/github.com/zeromq/libzmq/packaging/debian/libzmq5.install +1 -0
  433. data/vendor/github.com/zeromq/libzmq/packaging/debian/rules +67 -0
  434. data/vendor/github.com/zeromq/libzmq/packaging/debian/source/format +1 -0
  435. data/vendor/github.com/zeromq/libzmq/packaging/debian/zeromq.dsc.obs +15 -0
  436. data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.bat +14 -0
  437. data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.config +6 -0
  438. data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.gsl +264 -0
  439. data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.nuspec +98 -0
  440. data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.targets +129 -0
  441. data/vendor/github.com/zeromq/libzmq/packaging/nuget/package.xml +22 -0
  442. data/vendor/github.com/zeromq/libzmq/packaging/obs/_service +98 -0
  443. data/vendor/github.com/zeromq/libzmq/packaging/redhat/zeromq.spec +234 -0
  444. data/vendor/github.com/zeromq/libzmq/perf/inproc_lat.cpp +240 -0
  445. data/vendor/github.com/zeromq/libzmq/perf/inproc_thr.cpp +250 -0
  446. data/vendor/github.com/zeromq/libzmq/perf/local_lat.cpp +116 -0
  447. data/vendor/github.com/zeromq/libzmq/perf/local_thr.cpp +160 -0
  448. data/vendor/github.com/zeromq/libzmq/perf/remote_lat.cpp +129 -0
  449. data/vendor/github.com/zeromq/libzmq/perf/remote_thr.cpp +135 -0
  450. data/vendor/github.com/zeromq/libzmq/src/address.cpp +134 -0
  451. data/vendor/github.com/zeromq/libzmq/src/address.hpp +77 -0
  452. data/vendor/github.com/zeromq/libzmq/src/array.hpp +167 -0
  453. data/vendor/github.com/zeromq/libzmq/src/atomic_counter.hpp +249 -0
  454. data/vendor/github.com/zeromq/libzmq/src/atomic_ptr.hpp +227 -0
  455. data/vendor/github.com/zeromq/libzmq/src/blob.hpp +186 -0
  456. data/vendor/github.com/zeromq/libzmq/src/client.cpp +116 -0
  457. data/vendor/github.com/zeromq/libzmq/src/client.hpp +81 -0
  458. data/vendor/github.com/zeromq/libzmq/src/clock.cpp +253 -0
  459. data/vendor/github.com/zeromq/libzmq/src/clock.hpp +83 -0
  460. data/vendor/github.com/zeromq/libzmq/src/command.hpp +188 -0
  461. data/vendor/github.com/zeromq/libzmq/src/condition_variable.hpp +279 -0
  462. data/vendor/github.com/zeromq/libzmq/src/config.hpp +98 -0
  463. data/vendor/github.com/zeromq/libzmq/src/ctx.cpp +644 -0
  464. data/vendor/github.com/zeromq/libzmq/src/ctx.hpp +242 -0
  465. data/vendor/github.com/zeromq/libzmq/src/curve_client.cpp +297 -0
  466. data/vendor/github.com/zeromq/libzmq/src/curve_client.hpp +87 -0
  467. data/vendor/github.com/zeromq/libzmq/src/curve_client_tools.hpp +307 -0
  468. data/vendor/github.com/zeromq/libzmq/src/curve_mechanism_base.cpp +181 -0
  469. data/vendor/github.com/zeromq/libzmq/src/curve_mechanism_base.hpp +79 -0
  470. data/vendor/github.com/zeromq/libzmq/src/curve_server.cpp +492 -0
  471. data/vendor/github.com/zeromq/libzmq/src/curve_server.hpp +94 -0
  472. data/vendor/github.com/zeromq/libzmq/src/dbuffer.hpp +144 -0
  473. data/vendor/github.com/zeromq/libzmq/src/dealer.cpp +143 -0
  474. data/vendor/github.com/zeromq/libzmq/src/dealer.hpp +89 -0
  475. data/vendor/github.com/zeromq/libzmq/src/decoder.hpp +198 -0
  476. data/vendor/github.com/zeromq/libzmq/src/decoder_allocators.cpp +144 -0
  477. data/vendor/github.com/zeromq/libzmq/src/decoder_allocators.hpp +155 -0
  478. data/vendor/github.com/zeromq/libzmq/src/devpoll.cpp +205 -0
  479. data/vendor/github.com/zeromq/libzmq/src/devpoll.hpp +119 -0
  480. data/vendor/github.com/zeromq/libzmq/src/dgram.cpp +177 -0
  481. data/vendor/github.com/zeromq/libzmq/src/dgram.hpp +81 -0
  482. data/vendor/github.com/zeromq/libzmq/src/dish.cpp +360 -0
  483. data/vendor/github.com/zeromq/libzmq/src/dish.hpp +125 -0
  484. data/vendor/github.com/zeromq/libzmq/src/dist.cpp +235 -0
  485. data/vendor/github.com/zeromq/libzmq/src/dist.hpp +120 -0
  486. data/vendor/github.com/zeromq/libzmq/src/encoder.hpp +189 -0
  487. data/vendor/github.com/zeromq/libzmq/src/epoll.cpp +206 -0
  488. data/vendor/github.com/zeromq/libzmq/src/epoll.hpp +119 -0
  489. data/vendor/github.com/zeromq/libzmq/src/err.cpp +447 -0
  490. data/vendor/github.com/zeromq/libzmq/src/err.hpp +173 -0
  491. data/vendor/github.com/zeromq/libzmq/src/fd.hpp +52 -0
  492. data/vendor/github.com/zeromq/libzmq/src/fq.cpp +163 -0
  493. data/vendor/github.com/zeromq/libzmq/src/fq.hpp +92 -0
  494. data/vendor/github.com/zeromq/libzmq/src/gather.cpp +94 -0
  495. data/vendor/github.com/zeromq/libzmq/src/gather.hpp +75 -0
  496. data/vendor/github.com/zeromq/libzmq/src/gssapi_client.cpp +237 -0
  497. data/vendor/github.com/zeromq/libzmq/src/gssapi_client.hpp +94 -0
  498. data/vendor/github.com/zeromq/libzmq/src/gssapi_mechanism_base.cpp +402 -0
  499. data/vendor/github.com/zeromq/libzmq/src/gssapi_mechanism_base.hpp +134 -0
  500. data/vendor/github.com/zeromq/libzmq/src/gssapi_server.cpp +249 -0
  501. data/vendor/github.com/zeromq/libzmq/src/gssapi_server.hpp +95 -0
  502. data/vendor/github.com/zeromq/libzmq/src/i_decoder.hpp +64 -0
  503. data/vendor/github.com/zeromq/libzmq/src/i_encoder.hpp +60 -0
  504. data/vendor/github.com/zeromq/libzmq/src/i_engine.hpp +68 -0
  505. data/vendor/github.com/zeromq/libzmq/src/i_mailbox.hpp +60 -0
  506. data/vendor/github.com/zeromq/libzmq/src/i_poll_events.hpp +55 -0
  507. data/vendor/github.com/zeromq/libzmq/src/io_object.cpp +117 -0
  508. data/vendor/github.com/zeromq/libzmq/src/io_object.hpp +89 -0
  509. data/vendor/github.com/zeromq/libzmq/src/io_thread.cpp +114 -0
  510. data/vendor/github.com/zeromq/libzmq/src/io_thread.hpp +99 -0
  511. data/vendor/github.com/zeromq/libzmq/src/ip.cpp +235 -0
  512. data/vendor/github.com/zeromq/libzmq/src/ip.hpp +64 -0
  513. data/vendor/github.com/zeromq/libzmq/src/ipc_address.cpp +106 -0
  514. data/vendor/github.com/zeromq/libzmq/src/ipc_address.hpp +74 -0
  515. data/vendor/github.com/zeromq/libzmq/src/ipc_connecter.cpp +278 -0
  516. data/vendor/github.com/zeromq/libzmq/src/ipc_connecter.hpp +135 -0
  517. data/vendor/github.com/zeromq/libzmq/src/ipc_listener.cpp +427 -0
  518. data/vendor/github.com/zeromq/libzmq/src/ipc_listener.hpp +123 -0
  519. data/vendor/github.com/zeromq/libzmq/src/kqueue.cpp +227 -0
  520. data/vendor/github.com/zeromq/libzmq/src/kqueue.hpp +127 -0
  521. data/vendor/github.com/zeromq/libzmq/src/lb.cpp +173 -0
  522. data/vendor/github.com/zeromq/libzmq/src/lb.hpp +88 -0
  523. data/vendor/github.com/zeromq/libzmq/src/libzmq.pc.cmake.in +11 -0
  524. data/vendor/github.com/zeromq/libzmq/src/libzmq.pc.in +11 -0
  525. data/vendor/github.com/zeromq/libzmq/src/libzmq.vers +4 -0
  526. data/vendor/github.com/zeromq/libzmq/src/likely.hpp +42 -0
  527. data/vendor/github.com/zeromq/libzmq/src/macros.hpp +12 -0
  528. data/vendor/github.com/zeromq/libzmq/src/mailbox.cpp +101 -0
  529. data/vendor/github.com/zeromq/libzmq/src/mailbox.hpp +90 -0
  530. data/vendor/github.com/zeromq/libzmq/src/mailbox_safe.cpp +117 -0
  531. data/vendor/github.com/zeromq/libzmq/src/mailbox_safe.hpp +94 -0
  532. data/vendor/github.com/zeromq/libzmq/src/mechanism.cpp +285 -0
  533. data/vendor/github.com/zeromq/libzmq/src/mechanism.hpp +152 -0
  534. data/vendor/github.com/zeromq/libzmq/src/mechanism_base.cpp +70 -0
  535. data/vendor/github.com/zeromq/libzmq/src/mechanism_base.hpp +53 -0
  536. data/vendor/github.com/zeromq/libzmq/src/metadata.cpp +62 -0
  537. data/vendor/github.com/zeromq/libzmq/src/metadata.hpp +70 -0
  538. data/vendor/github.com/zeromq/libzmq/src/msg.cpp +578 -0
  539. data/vendor/github.com/zeromq/libzmq/src/msg.hpp +268 -0
  540. data/vendor/github.com/zeromq/libzmq/src/mtrie.cpp +434 -0
  541. data/vendor/github.com/zeromq/libzmq/src/mtrie.hpp +102 -0
  542. data/vendor/github.com/zeromq/libzmq/src/mutex.hpp +213 -0
  543. data/vendor/github.com/zeromq/libzmq/src/norm_engine.cpp +736 -0
  544. data/vendor/github.com/zeromq/libzmq/src/norm_engine.hpp +190 -0
  545. data/vendor/github.com/zeromq/libzmq/src/null_mechanism.cpp +220 -0
  546. data/vendor/github.com/zeromq/libzmq/src/null_mechanism.hpp +77 -0
  547. data/vendor/github.com/zeromq/libzmq/src/object.cpp +476 -0
  548. data/vendor/github.com/zeromq/libzmq/src/object.hpp +156 -0
  549. data/vendor/github.com/zeromq/libzmq/src/options.cpp +1089 -0
  550. data/vendor/github.com/zeromq/libzmq/src/options.hpp +251 -0
  551. data/vendor/github.com/zeromq/libzmq/src/own.cpp +216 -0
  552. data/vendor/github.com/zeromq/libzmq/src/own.hpp +154 -0
  553. data/vendor/github.com/zeromq/libzmq/src/pair.cpp +142 -0
  554. data/vendor/github.com/zeromq/libzmq/src/pair.hpp +78 -0
  555. data/vendor/github.com/zeromq/libzmq/src/pgm_receiver.cpp +307 -0
  556. data/vendor/github.com/zeromq/libzmq/src/pgm_receiver.hpp +147 -0
  557. data/vendor/github.com/zeromq/libzmq/src/pgm_sender.cpp +257 -0
  558. data/vendor/github.com/zeromq/libzmq/src/pgm_sender.hpp +124 -0
  559. data/vendor/github.com/zeromq/libzmq/src/pgm_socket.cpp +712 -0
  560. data/vendor/github.com/zeromq/libzmq/src/pgm_socket.hpp +128 -0
  561. data/vendor/github.com/zeromq/libzmq/src/pipe.cpp +547 -0
  562. data/vendor/github.com/zeromq/libzmq/src/pipe.hpp +253 -0
  563. data/vendor/github.com/zeromq/libzmq/src/plain_client.cpp +220 -0
  564. data/vendor/github.com/zeromq/libzmq/src/plain_client.hpp +79 -0
  565. data/vendor/github.com/zeromq/libzmq/src/plain_server.cpp +253 -0
  566. data/vendor/github.com/zeromq/libzmq/src/plain_server.hpp +71 -0
  567. data/vendor/github.com/zeromq/libzmq/src/poll.cpp +193 -0
  568. data/vendor/github.com/zeromq/libzmq/src/poll.hpp +121 -0
  569. data/vendor/github.com/zeromq/libzmq/src/poller.hpp +64 -0
  570. data/vendor/github.com/zeromq/libzmq/src/poller_base.cpp +110 -0
  571. data/vendor/github.com/zeromq/libzmq/src/poller_base.hpp +95 -0
  572. data/vendor/github.com/zeromq/libzmq/src/pollset.cpp +254 -0
  573. data/vendor/github.com/zeromq/libzmq/src/pollset.hpp +121 -0
  574. data/vendor/github.com/zeromq/libzmq/src/precompiled.cpp +30 -0
  575. data/vendor/github.com/zeromq/libzmq/src/precompiled.hpp +120 -0
  576. data/vendor/github.com/zeromq/libzmq/src/proxy.cpp +622 -0
  577. data/vendor/github.com/zeromq/libzmq/src/proxy.hpp +42 -0
  578. data/vendor/github.com/zeromq/libzmq/src/pub.cpp +67 -0
  579. data/vendor/github.com/zeromq/libzmq/src/pub.hpp +63 -0
  580. data/vendor/github.com/zeromq/libzmq/src/pull.cpp +78 -0
  581. data/vendor/github.com/zeromq/libzmq/src/pull.hpp +75 -0
  582. data/vendor/github.com/zeromq/libzmq/src/push.cpp +77 -0
  583. data/vendor/github.com/zeromq/libzmq/src/push.hpp +73 -0
  584. data/vendor/github.com/zeromq/libzmq/src/radio.cpp +252 -0
  585. data/vendor/github.com/zeromq/libzmq/src/radio.hpp +112 -0
  586. data/vendor/github.com/zeromq/libzmq/src/random.cpp +118 -0
  587. data/vendor/github.com/zeromq/libzmq/src/random.hpp +52 -0
  588. data/vendor/github.com/zeromq/libzmq/src/raw_decoder.cpp +74 -0
  589. data/vendor/github.com/zeromq/libzmq/src/raw_decoder.hpp +74 -0
  590. data/vendor/github.com/zeromq/libzmq/src/raw_encoder.cpp +51 -0
  591. data/vendor/github.com/zeromq/libzmq/src/raw_encoder.hpp +64 -0
  592. data/vendor/github.com/zeromq/libzmq/src/reaper.cpp +142 -0
  593. data/vendor/github.com/zeromq/libzmq/src/reaper.hpp +94 -0
  594. data/vendor/github.com/zeromq/libzmq/src/rep.cpp +134 -0
  595. data/vendor/github.com/zeromq/libzmq/src/rep.hpp +73 -0
  596. data/vendor/github.com/zeromq/libzmq/src/req.cpp +323 -0
  597. data/vendor/github.com/zeromq/libzmq/src/req.hpp +121 -0
  598. data/vendor/github.com/zeromq/libzmq/src/router.cpp +551 -0
  599. data/vendor/github.com/zeromq/libzmq/src/router.hpp +147 -0
  600. data/vendor/github.com/zeromq/libzmq/src/scatter.cpp +83 -0
  601. data/vendor/github.com/zeromq/libzmq/src/scatter.hpp +73 -0
  602. data/vendor/github.com/zeromq/libzmq/src/select.cpp +567 -0
  603. data/vendor/github.com/zeromq/libzmq/src/select.hpp +184 -0
  604. data/vendor/github.com/zeromq/libzmq/src/server.cpp +184 -0
  605. data/vendor/github.com/zeromq/libzmq/src/server.hpp +96 -0
  606. data/vendor/github.com/zeromq/libzmq/src/session_base.cpp +716 -0
  607. data/vendor/github.com/zeromq/libzmq/src/session_base.hpp +173 -0
  608. data/vendor/github.com/zeromq/libzmq/src/signaler.cpp +682 -0
  609. data/vendor/github.com/zeromq/libzmq/src/signaler.hpp +91 -0
  610. data/vendor/github.com/zeromq/libzmq/src/socket_base.cpp +1778 -0
  611. data/vendor/github.com/zeromq/libzmq/src/socket_base.hpp +307 -0
  612. data/vendor/github.com/zeromq/libzmq/src/socket_poller.cpp +697 -0
  613. data/vendor/github.com/zeromq/libzmq/src/socket_poller.hpp +145 -0
  614. data/vendor/github.com/zeromq/libzmq/src/socks.cpp +286 -0
  615. data/vendor/github.com/zeromq/libzmq/src/socks.hpp +135 -0
  616. data/vendor/github.com/zeromq/libzmq/src/socks_connecter.cpp +482 -0
  617. data/vendor/github.com/zeromq/libzmq/src/socks_connecter.hpp +163 -0
  618. data/vendor/github.com/zeromq/libzmq/src/stdint.hpp +77 -0
  619. data/vendor/github.com/zeromq/libzmq/src/stream.cpp +321 -0
  620. data/vendor/github.com/zeromq/libzmq/src/stream.hpp +107 -0
  621. data/vendor/github.com/zeromq/libzmq/src/stream_engine.cpp +1110 -0
  622. data/vendor/github.com/zeromq/libzmq/src/stream_engine.hpp +233 -0
  623. data/vendor/github.com/zeromq/libzmq/src/sub.cpp +87 -0
  624. data/vendor/github.com/zeromq/libzmq/src/sub.hpp +64 -0
  625. data/vendor/github.com/zeromq/libzmq/src/tcp.cpp +356 -0
  626. data/vendor/github.com/zeromq/libzmq/src/tcp.hpp +69 -0
  627. data/vendor/github.com/zeromq/libzmq/src/tcp_address.cpp +897 -0
  628. data/vendor/github.com/zeromq/libzmq/src/tcp_address.hpp +117 -0
  629. data/vendor/github.com/zeromq/libzmq/src/tcp_connecter.cpp +426 -0
  630. data/vendor/github.com/zeromq/libzmq/src/tcp_connecter.hpp +134 -0
  631. data/vendor/github.com/zeromq/libzmq/src/tcp_listener.cpp +357 -0
  632. data/vendor/github.com/zeromq/libzmq/src/tcp_listener.hpp +98 -0
  633. data/vendor/github.com/zeromq/libzmq/src/thread.cpp +238 -0
  634. data/vendor/github.com/zeromq/libzmq/src/thread.hpp +102 -0
  635. data/vendor/github.com/zeromq/libzmq/src/timers.cpp +199 -0
  636. data/vendor/github.com/zeromq/libzmq/src/timers.hpp +110 -0
  637. data/vendor/github.com/zeromq/libzmq/src/tipc_address.cpp +124 -0
  638. data/vendor/github.com/zeromq/libzmq/src/tipc_address.hpp +75 -0
  639. data/vendor/github.com/zeromq/libzmq/src/tipc_connecter.cpp +268 -0
  640. data/vendor/github.com/zeromq/libzmq/src/tipc_connecter.hpp +137 -0
  641. data/vendor/github.com/zeromq/libzmq/src/tipc_listener.cpp +190 -0
  642. data/vendor/github.com/zeromq/libzmq/src/tipc_listener.hpp +107 -0
  643. data/vendor/github.com/zeromq/libzmq/src/trie.cpp +340 -0
  644. data/vendor/github.com/zeromq/libzmq/src/trie.hpp +86 -0
  645. data/vendor/github.com/zeromq/libzmq/src/tweetnacl.c +988 -0
  646. data/vendor/github.com/zeromq/libzmq/src/tweetnacl.h +75 -0
  647. data/vendor/github.com/zeromq/libzmq/src/udp_address.cpp +172 -0
  648. data/vendor/github.com/zeromq/libzmq/src/udp_address.hpp +78 -0
  649. data/vendor/github.com/zeromq/libzmq/src/udp_engine.cpp +394 -0
  650. data/vendor/github.com/zeromq/libzmq/src/udp_engine.hpp +73 -0
  651. data/vendor/github.com/zeromq/libzmq/src/v1_decoder.cpp +153 -0
  652. data/vendor/github.com/zeromq/libzmq/src/v1_decoder.hpp +69 -0
  653. data/vendor/github.com/zeromq/libzmq/src/v1_encoder.cpp +76 -0
  654. data/vendor/github.com/zeromq/libzmq/src/v1_encoder.hpp +59 -0
  655. data/vendor/github.com/zeromq/libzmq/src/v2_decoder.cpp +161 -0
  656. data/vendor/github.com/zeromq/libzmq/src/v2_decoder.hpp +74 -0
  657. data/vendor/github.com/zeromq/libzmq/src/v2_encoder.cpp +78 -0
  658. data/vendor/github.com/zeromq/libzmq/src/v2_encoder.hpp +59 -0
  659. data/vendor/github.com/zeromq/libzmq/src/v2_protocol.hpp +49 -0
  660. data/vendor/github.com/zeromq/libzmq/src/version.rc.in +93 -0
  661. data/vendor/github.com/zeromq/libzmq/src/vmci.cpp +88 -0
  662. data/vendor/github.com/zeromq/libzmq/src/vmci.hpp +60 -0
  663. data/vendor/github.com/zeromq/libzmq/src/vmci_address.cpp +170 -0
  664. data/vendor/github.com/zeromq/libzmq/src/vmci_address.hpp +71 -0
  665. data/vendor/github.com/zeromq/libzmq/src/vmci_connecter.cpp +307 -0
  666. data/vendor/github.com/zeromq/libzmq/src/vmci_connecter.hpp +136 -0
  667. data/vendor/github.com/zeromq/libzmq/src/vmci_listener.cpp +262 -0
  668. data/vendor/github.com/zeromq/libzmq/src/vmci_listener.hpp +102 -0
  669. data/vendor/github.com/zeromq/libzmq/src/windows.hpp +93 -0
  670. data/vendor/github.com/zeromq/libzmq/src/wire.hpp +108 -0
  671. data/vendor/github.com/zeromq/libzmq/src/xpub.cpp +340 -0
  672. data/vendor/github.com/zeromq/libzmq/src/xpub.hpp +126 -0
  673. data/vendor/github.com/zeromq/libzmq/src/xsub.cpp +251 -0
  674. data/vendor/github.com/zeromq/libzmq/src/xsub.hpp +103 -0
  675. data/vendor/github.com/zeromq/libzmq/src/ypipe.hpp +218 -0
  676. data/vendor/github.com/zeromq/libzmq/src/ypipe_base.hpp +54 -0
  677. data/vendor/github.com/zeromq/libzmq/src/ypipe_conflate.hpp +137 -0
  678. data/vendor/github.com/zeromq/libzmq/src/yqueue.hpp +225 -0
  679. data/vendor/github.com/zeromq/libzmq/src/zap_client.cpp +305 -0
  680. data/vendor/github.com/zeromq/libzmq/src/zap_client.hpp +100 -0
  681. data/vendor/github.com/zeromq/libzmq/src/zmq.cpp +1527 -0
  682. data/vendor/github.com/zeromq/libzmq/src/zmq_draft.h +178 -0
  683. data/vendor/github.com/zeromq/libzmq/src/zmq_utils.cpp +318 -0
  684. data/vendor/github.com/zeromq/libzmq/tests/CMakeLists.txt +218 -0
  685. data/vendor/github.com/zeromq/libzmq/tests/README.md +28 -0
  686. data/vendor/github.com/zeromq/libzmq/tests/test_abstract_ipc.cpp +67 -0
  687. data/vendor/github.com/zeromq/libzmq/tests/test_ancillaries.cpp +51 -0
  688. data/vendor/github.com/zeromq/libzmq/tests/test_atomics.cpp +48 -0
  689. data/vendor/github.com/zeromq/libzmq/tests/test_base85.cpp +162 -0
  690. data/vendor/github.com/zeromq/libzmq/tests/test_bind_after_connect_tcp.cpp +97 -0
  691. data/vendor/github.com/zeromq/libzmq/tests/test_bind_src_address.cpp +57 -0
  692. data/vendor/github.com/zeromq/libzmq/tests/test_capabilities.cpp +82 -0
  693. data/vendor/github.com/zeromq/libzmq/tests/test_client_server.cpp +106 -0
  694. data/vendor/github.com/zeromq/libzmq/tests/test_conflate.cpp +86 -0
  695. data/vendor/github.com/zeromq/libzmq/tests/test_connect_delay_tipc.cpp +238 -0
  696. data/vendor/github.com/zeromq/libzmq/tests/test_connect_resolve.cpp +70 -0
  697. data/vendor/github.com/zeromq/libzmq/tests/test_connect_rid.cpp +199 -0
  698. data/vendor/github.com/zeromq/libzmq/tests/test_ctx_destroy.cpp +110 -0
  699. data/vendor/github.com/zeromq/libzmq/tests/test_ctx_options.cpp +204 -0
  700. data/vendor/github.com/zeromq/libzmq/tests/test_dgram.cpp +99 -0
  701. data/vendor/github.com/zeromq/libzmq/tests/test_diffserv.cpp +85 -0
  702. data/vendor/github.com/zeromq/libzmq/tests/test_disconnect_inproc.cpp +136 -0
  703. data/vendor/github.com/zeromq/libzmq/tests/test_filter_ipc.cpp +166 -0
  704. data/vendor/github.com/zeromq/libzmq/tests/test_fork.cpp +99 -0
  705. data/vendor/github.com/zeromq/libzmq/tests/test_getsockopt_memset.cpp +64 -0
  706. data/vendor/github.com/zeromq/libzmq/tests/test_heartbeats.cpp +341 -0
  707. data/vendor/github.com/zeromq/libzmq/tests/test_hwm.cpp +312 -0
  708. data/vendor/github.com/zeromq/libzmq/tests/test_hwm_pubsub.cpp +253 -0
  709. data/vendor/github.com/zeromq/libzmq/tests/test_immediate.cpp +250 -0
  710. data/vendor/github.com/zeromq/libzmq/tests/test_inproc_connect.cpp +536 -0
  711. data/vendor/github.com/zeromq/libzmq/tests/test_invalid_rep.cpp +98 -0
  712. data/vendor/github.com/zeromq/libzmq/tests/test_iov.cpp +157 -0
  713. data/vendor/github.com/zeromq/libzmq/tests/test_ipc_wildcard.cpp +65 -0
  714. data/vendor/github.com/zeromq/libzmq/tests/test_issue_566.cpp +99 -0
  715. data/vendor/github.com/zeromq/libzmq/tests/test_last_endpoint.cpp +66 -0
  716. data/vendor/github.com/zeromq/libzmq/tests/test_many_sockets.cpp +100 -0
  717. data/vendor/github.com/zeromq/libzmq/tests/test_metadata.cpp +134 -0
  718. data/vendor/github.com/zeromq/libzmq/tests/test_monitor.cpp +116 -0
  719. data/vendor/github.com/zeromq/libzmq/tests/test_msg_ffn.cpp +145 -0
  720. data/vendor/github.com/zeromq/libzmq/tests/test_msg_flags.cpp +127 -0
  721. data/vendor/github.com/zeromq/libzmq/tests/test_pair_inproc.cpp +81 -0
  722. data/vendor/github.com/zeromq/libzmq/tests/test_pair_ipc.cpp +60 -0
  723. data/vendor/github.com/zeromq/libzmq/tests/test_pair_tcp.cpp +64 -0
  724. data/vendor/github.com/zeromq/libzmq/tests/test_pair_tipc.cpp +62 -0
  725. data/vendor/github.com/zeromq/libzmq/tests/test_pair_vmci.cpp +68 -0
  726. data/vendor/github.com/zeromq/libzmq/tests/test_poller.cpp +404 -0
  727. data/vendor/github.com/zeromq/libzmq/tests/test_probe_router.cpp +86 -0
  728. data/vendor/github.com/zeromq/libzmq/tests/test_proxy.cpp +486 -0
  729. data/vendor/github.com/zeromq/libzmq/tests/test_proxy_single_socket.cpp +121 -0
  730. data/vendor/github.com/zeromq/libzmq/tests/test_proxy_terminate.cpp +132 -0
  731. data/vendor/github.com/zeromq/libzmq/tests/test_pub_invert_matching.cpp +136 -0
  732. data/vendor/github.com/zeromq/libzmq/tests/test_radio_dish.cpp +191 -0
  733. data/vendor/github.com/zeromq/libzmq/tests/test_rebind_ipc.cpp +84 -0
  734. data/vendor/github.com/zeromq/libzmq/tests/test_reconnect_ivl.cpp +149 -0
  735. data/vendor/github.com/zeromq/libzmq/tests/test_req_correlate.cpp +140 -0
  736. data/vendor/github.com/zeromq/libzmq/tests/test_req_relaxed.cpp +220 -0
  737. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_device.cpp +153 -0
  738. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_device_tipc.cpp +146 -0
  739. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_inproc.cpp +60 -0
  740. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_ipc.cpp +112 -0
  741. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_tcp.cpp +336 -0
  742. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_tipc.cpp +61 -0
  743. data/vendor/github.com/zeromq/libzmq/tests/test_reqrep_vmci.cpp +68 -0
  744. data/vendor/github.com/zeromq/libzmq/tests/test_router_handover.cpp +116 -0
  745. data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory.cpp +292 -0
  746. data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory_hwm.cpp +129 -0
  747. data/vendor/github.com/zeromq/libzmq/tests/test_router_mandatory_tipc.cpp +70 -0
  748. data/vendor/github.com/zeromq/libzmq/tests/test_scatter_gather.cpp +84 -0
  749. data/vendor/github.com/zeromq/libzmq/tests/test_security_curve.cpp +792 -0
  750. data/vendor/github.com/zeromq/libzmq/tests/test_security_gssapi.cpp +362 -0
  751. data/vendor/github.com/zeromq/libzmq/tests/test_security_null.cpp +209 -0
  752. data/vendor/github.com/zeromq/libzmq/tests/test_security_plain.cpp +212 -0
  753. data/vendor/github.com/zeromq/libzmq/tests/test_security_zap.cpp +417 -0
  754. data/vendor/github.com/zeromq/libzmq/tests/test_setsockopt.cpp +153 -0
  755. data/vendor/github.com/zeromq/libzmq/tests/test_shutdown_stress.cpp +101 -0
  756. data/vendor/github.com/zeromq/libzmq/tests/test_shutdown_stress_tipc.cpp +95 -0
  757. data/vendor/github.com/zeromq/libzmq/tests/test_socket_null.cpp +82 -0
  758. data/vendor/github.com/zeromq/libzmq/tests/test_sockopt_hwm.cpp +190 -0
  759. data/vendor/github.com/zeromq/libzmq/tests/test_sodium.cpp +98 -0
  760. data/vendor/github.com/zeromq/libzmq/tests/test_spec_dealer.cpp +266 -0
  761. data/vendor/github.com/zeromq/libzmq/tests/test_spec_pushpull.cpp +304 -0
  762. data/vendor/github.com/zeromq/libzmq/tests/test_spec_rep.cpp +169 -0
  763. data/vendor/github.com/zeromq/libzmq/tests/test_spec_req.cpp +266 -0
  764. data/vendor/github.com/zeromq/libzmq/tests/test_spec_router.cpp +217 -0
  765. data/vendor/github.com/zeromq/libzmq/tests/test_srcfd.cpp +127 -0
  766. data/vendor/github.com/zeromq/libzmq/tests/test_stream.cpp +342 -0
  767. data/vendor/github.com/zeromq/libzmq/tests/test_stream_disconnect.cpp +295 -0
  768. data/vendor/github.com/zeromq/libzmq/tests/test_stream_empty.cpp +74 -0
  769. data/vendor/github.com/zeromq/libzmq/tests/test_stream_exceeds_buffer.cpp +124 -0
  770. data/vendor/github.com/zeromq/libzmq/tests/test_stream_timeout.cpp +235 -0
  771. data/vendor/github.com/zeromq/libzmq/tests/test_sub_forward.cpp +109 -0
  772. data/vendor/github.com/zeromq/libzmq/tests/test_sub_forward_tipc.cpp +102 -0
  773. data/vendor/github.com/zeromq/libzmq/tests/test_system.cpp +98 -0
  774. data/vendor/github.com/zeromq/libzmq/tests/test_term_endpoint.cpp +226 -0
  775. data/vendor/github.com/zeromq/libzmq/tests/test_term_endpoint_tipc.cpp +120 -0
  776. data/vendor/github.com/zeromq/libzmq/tests/test_thread_safe.cpp +90 -0
  777. data/vendor/github.com/zeromq/libzmq/tests/test_timeo.cpp +85 -0
  778. data/vendor/github.com/zeromq/libzmq/tests/test_timers.cpp +226 -0
  779. data/vendor/github.com/zeromq/libzmq/tests/test_udp.cpp +133 -0
  780. data/vendor/github.com/zeromq/libzmq/tests/test_unbind_inproc.cpp +43 -0
  781. data/vendor/github.com/zeromq/libzmq/tests/test_unbind_wildcard.cpp +216 -0
  782. data/vendor/github.com/zeromq/libzmq/tests/test_use_fd_ipc.cpp +223 -0
  783. data/vendor/github.com/zeromq/libzmq/tests/test_use_fd_tcp.cpp +238 -0
  784. data/vendor/github.com/zeromq/libzmq/tests/test_xpub_manual.cpp +597 -0
  785. data/vendor/github.com/zeromq/libzmq/tests/test_xpub_nodrop.cpp +118 -0
  786. data/vendor/github.com/zeromq/libzmq/tests/test_xpub_welcome_msg.cpp +81 -0
  787. data/vendor/github.com/zeromq/libzmq/tests/test_zmq_poll_fd.cpp +98 -0
  788. data/vendor/github.com/zeromq/libzmq/tests/testutil.hpp +408 -0
  789. data/vendor/github.com/zeromq/libzmq/tests/testutil_security.hpp +684 -0
  790. data/vendor/github.com/zeromq/libzmq/tools/curve_keygen.cpp +58 -0
  791. data/vendor/github.com/zeromq/libzmq/version.sh +21 -0
  792. metadata +875 -0
@@ -0,0 +1,107 @@
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_STREAM_HPP_INCLUDED__
31
+ #define __ZMQ_STREAM_HPP_INCLUDED__
32
+
33
+ #include <map>
34
+
35
+ #include "router.hpp"
36
+
37
+ namespace zmq
38
+ {
39
+
40
+ class ctx_t;
41
+ class pipe_t;
42
+
43
+ class stream_t :
44
+ public socket_base_t
45
+ {
46
+ public:
47
+
48
+ stream_t (zmq::ctx_t *parent_, uint32_t tid_, int sid);
49
+ ~stream_t ();
50
+
51
+ // Overrides of functions from socket_base_t.
52
+ void xattach_pipe (zmq::pipe_t *pipe_, bool subscribe_to_all_);
53
+ int xsend (zmq::msg_t *msg_);
54
+ int xrecv (zmq::msg_t *msg_);
55
+ bool xhas_in ();
56
+ bool xhas_out ();
57
+ void xread_activated (zmq::pipe_t *pipe_);
58
+ void xwrite_activated (zmq::pipe_t *pipe_);
59
+ void xpipe_terminated (zmq::pipe_t *pipe_);
60
+ int xsetsockopt (int option_, const void *optval_, size_t optvallen_);
61
+ private:
62
+ // Generate peer's id and update lookup map
63
+ void identify_peer (pipe_t *pipe_);
64
+
65
+ // Fair queueing object for inbound pipes.
66
+ fq_t fq;
67
+
68
+ // True iff there is a message held in the pre-fetch buffer.
69
+ bool prefetched;
70
+
71
+ // If true, the receiver got the message part with
72
+ // the peer's identity.
73
+ bool routing_id_sent;
74
+
75
+ // Holds the prefetched identity.
76
+ msg_t prefetched_routing_id;
77
+
78
+ // Holds the prefetched message.
79
+ msg_t prefetched_msg;
80
+
81
+ struct outpipe_t
82
+ {
83
+ zmq::pipe_t *pipe;
84
+ bool active;
85
+ };
86
+
87
+ // Outbound pipes indexed by the peer IDs.
88
+ typedef std::map <blob_t, outpipe_t> outpipes_t;
89
+ outpipes_t outpipes;
90
+
91
+ // The pipe we are currently writing to.
92
+ zmq::pipe_t *current_out;
93
+
94
+ // If true, more outgoing message parts are expected.
95
+ bool more_out;
96
+
97
+ // Routing IDs are generated. It's a simple increment and wrap-over
98
+ // algorithm. This value is the next ID to use (if not used already).
99
+ uint32_t next_integral_routing_id;
100
+
101
+ stream_t (const stream_t&);
102
+ const stream_t &operator = (const stream_t&);
103
+ };
104
+
105
+ }
106
+
107
+ #endif
@@ -0,0 +1,1110 @@
1
+ /*
2
+ Copyright (c) 2007-2016 Contributors as noted in the AUTHORS file
3
+
4
+ This file is part of libzmq, the ZeroMQ core engine in C++.
5
+
6
+ libzmq is free software; you can redistribute it and/or modify it under
7
+ the terms of the GNU Lesser General Public License (LGPL) as published
8
+ by the Free Software Foundation; either version 3 of the License, or
9
+ (at your option) any later version.
10
+
11
+ As a special exception, the Contributors give you permission to link
12
+ this library with independent modules to produce an executable,
13
+ regardless of the license terms of these independent modules, and to
14
+ copy and distribute the resulting executable under terms of your choice,
15
+ provided that you also meet, for each linked independent module, the
16
+ terms and conditions of the license of that module. An independent
17
+ module is a module which is not derived from or based on this library.
18
+ If you modify this library, you must extend this exception to your
19
+ version of the library.
20
+
21
+ libzmq is distributed in the hope that it will be useful, but WITHOUT
22
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
23
+ FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
24
+ License for more details.
25
+
26
+ You should have received a copy of the GNU Lesser General Public License
27
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
28
+ */
29
+
30
+ #include "precompiled.hpp"
31
+ #include "macros.hpp"
32
+
33
+ #include <string.h>
34
+
35
+ #ifndef ZMQ_HAVE_WINDOWS
36
+ #include <unistd.h>
37
+ #endif
38
+
39
+ #include <new>
40
+ #include <sstream>
41
+
42
+ #include "stream_engine.hpp"
43
+ #include "io_thread.hpp"
44
+ #include "session_base.hpp"
45
+ #include "v1_encoder.hpp"
46
+ #include "v1_decoder.hpp"
47
+ #include "v2_encoder.hpp"
48
+ #include "v2_decoder.hpp"
49
+ #include "null_mechanism.hpp"
50
+ #include "plain_client.hpp"
51
+ #include "plain_server.hpp"
52
+ #include "gssapi_client.hpp"
53
+ #include "gssapi_server.hpp"
54
+ #include "curve_client.hpp"
55
+ #include "curve_server.hpp"
56
+ #include "raw_decoder.hpp"
57
+ #include "raw_encoder.hpp"
58
+ #include "config.hpp"
59
+ #include "err.hpp"
60
+ #include "ip.hpp"
61
+ #include "tcp.hpp"
62
+ #include "likely.hpp"
63
+ #include "wire.hpp"
64
+
65
+ zmq::stream_engine_t::stream_engine_t (fd_t fd_, const options_t &options_,
66
+ const std::string &endpoint_) :
67
+ s (fd_),
68
+ as_server(false),
69
+ handle((handle_t)NULL),
70
+ inpos (NULL),
71
+ insize (0),
72
+ decoder (NULL),
73
+ outpos (NULL),
74
+ outsize (0),
75
+ encoder (NULL),
76
+ metadata (NULL),
77
+ handshaking (true),
78
+ greeting_size (v2_greeting_size),
79
+ greeting_bytes_read (0),
80
+ session (NULL),
81
+ options (options_),
82
+ endpoint (endpoint_),
83
+ plugged (false),
84
+ next_msg (&stream_engine_t::routing_id_msg),
85
+ process_msg (&stream_engine_t::process_routing_id_msg),
86
+ io_error (false),
87
+ subscription_required (false),
88
+ mechanism (NULL),
89
+ input_stopped (false),
90
+ output_stopped (false),
91
+ has_handshake_timer (false),
92
+ has_ttl_timer (false),
93
+ has_timeout_timer (false),
94
+ has_heartbeat_timer (false),
95
+ heartbeat_timeout (0),
96
+ socket (NULL)
97
+ {
98
+ int rc = tx_msg.init ();
99
+ errno_assert (rc == 0);
100
+
101
+ // Put the socket into non-blocking mode.
102
+ unblock_socket (s);
103
+
104
+ int family = get_peer_ip_address (s, peer_address);
105
+ if (family == 0)
106
+ peer_address.clear();
107
+ #if defined ZMQ_HAVE_SO_PEERCRED
108
+ else
109
+ if (family == PF_UNIX) {
110
+ struct ucred cred;
111
+ socklen_t size = sizeof (cred);
112
+ if (!getsockopt (s, SOL_SOCKET, SO_PEERCRED, &cred, &size)) {
113
+ std::ostringstream buf;
114
+ buf << ":" << cred.uid << ":" << cred.gid << ":" << cred.pid;
115
+ peer_address += buf.str ();
116
+ }
117
+ }
118
+ #elif defined ZMQ_HAVE_LOCAL_PEERCRED
119
+ else
120
+ if (family == PF_UNIX) {
121
+ struct xucred cred;
122
+ socklen_t size = sizeof (cred);
123
+ if (!getsockopt (s, 0, LOCAL_PEERCRED, &cred, &size)
124
+ && cred.cr_version == XUCRED_VERSION) {
125
+ std::ostringstream buf;
126
+ buf << ":" << cred.cr_uid << ":";
127
+ if (cred.cr_ngroups > 0)
128
+ buf << cred.cr_groups[0];
129
+ buf << ":";
130
+ peer_address += buf.str ();
131
+ }
132
+ }
133
+ #endif
134
+
135
+ if(options.heartbeat_interval > 0) {
136
+ heartbeat_timeout = options.heartbeat_timeout;
137
+ if(heartbeat_timeout == -1)
138
+ heartbeat_timeout = options.heartbeat_interval;
139
+ }
140
+ }
141
+
142
+ zmq::stream_engine_t::~stream_engine_t ()
143
+ {
144
+ zmq_assert (!plugged);
145
+
146
+ if (s != retired_fd) {
147
+ #ifdef ZMQ_HAVE_WINDOWS
148
+ int rc = closesocket (s);
149
+ wsa_assert (rc != SOCKET_ERROR);
150
+ #else
151
+ int rc = close (s);
152
+ #if defined(__FreeBSD_kernel__) || defined (__FreeBSD__)
153
+ // FreeBSD may return ECONNRESET on close() under load but this is not
154
+ // an error.
155
+ if (rc == -1 && errno == ECONNRESET)
156
+ rc = 0;
157
+ #endif
158
+ errno_assert (rc == 0);
159
+ #endif
160
+ s = retired_fd;
161
+ }
162
+
163
+ int rc = tx_msg.close ();
164
+ errno_assert (rc == 0);
165
+
166
+ // Drop reference to metadata and destroy it if we are
167
+ // the only user.
168
+ if (metadata != NULL) {
169
+ if (metadata->drop_ref ()) {
170
+ LIBZMQ_DELETE(metadata);
171
+ }
172
+ }
173
+
174
+ LIBZMQ_DELETE(encoder);
175
+ LIBZMQ_DELETE(decoder);
176
+ LIBZMQ_DELETE(mechanism);
177
+ }
178
+
179
+ void zmq::stream_engine_t::plug (io_thread_t *io_thread_,
180
+ session_base_t *session_)
181
+ {
182
+ zmq_assert (!plugged);
183
+ plugged = true;
184
+
185
+ // Connect to session object.
186
+ zmq_assert (!session);
187
+ zmq_assert (session_);
188
+ session = session_;
189
+ socket = session-> get_socket ();
190
+
191
+ // Connect to I/O threads poller object.
192
+ io_object_t::plug (io_thread_);
193
+ handle = add_fd (s);
194
+ io_error = false;
195
+
196
+ if (options.raw_socket) {
197
+ // no handshaking for raw sock, instantiate raw encoder and decoders
198
+ encoder = new (std::nothrow) raw_encoder_t (out_batch_size);
199
+ alloc_assert (encoder);
200
+
201
+ decoder = new (std::nothrow) raw_decoder_t (in_batch_size);
202
+ alloc_assert (decoder);
203
+
204
+ // disable handshaking for raw socket
205
+ handshaking = false;
206
+
207
+ next_msg = &stream_engine_t::pull_msg_from_session;
208
+ process_msg = &stream_engine_t::push_raw_msg_to_session;
209
+
210
+ properties_t properties;
211
+ if (init_properties(properties)) {
212
+ // Compile metadata.
213
+ zmq_assert (metadata == NULL);
214
+ metadata = new (std::nothrow) metadata_t (properties);
215
+ alloc_assert (metadata);
216
+ }
217
+
218
+ if (options.raw_notify) {
219
+ // For raw sockets, send an initial 0-length message to the
220
+ // application so that it knows a peer has connected.
221
+ msg_t connector;
222
+ connector.init();
223
+ push_raw_msg_to_session (&connector);
224
+ connector.close();
225
+ session->flush ();
226
+ }
227
+ }
228
+ else {
229
+ // start optional timer, to prevent handshake hanging on no input
230
+ set_handshake_timer ();
231
+
232
+ // Send the 'length' and 'flags' fields of the routing id message.
233
+ // The 'length' field is encoded in the long format.
234
+ outpos = greeting_send;
235
+ outpos [outsize++] = 0xff;
236
+ put_uint64 (&outpos [outsize], options.routing_id_size + 1);
237
+ outsize += 8;
238
+ outpos [outsize++] = 0x7f;
239
+ }
240
+
241
+ set_pollin (handle);
242
+ set_pollout (handle);
243
+ // Flush all the data that may have been already received downstream.
244
+ in_event ();
245
+ }
246
+
247
+ void zmq::stream_engine_t::unplug ()
248
+ {
249
+ zmq_assert (plugged);
250
+ plugged = false;
251
+
252
+ // Cancel all timers.
253
+ if (has_handshake_timer) {
254
+ cancel_timer (handshake_timer_id);
255
+ has_handshake_timer = false;
256
+ }
257
+
258
+ if (has_ttl_timer) {
259
+ cancel_timer (heartbeat_ttl_timer_id);
260
+ has_ttl_timer = false;
261
+ }
262
+
263
+ if (has_timeout_timer) {
264
+ cancel_timer (heartbeat_timeout_timer_id);
265
+ has_timeout_timer = false;
266
+ }
267
+
268
+ if (has_heartbeat_timer) {
269
+ cancel_timer (heartbeat_ivl_timer_id);
270
+ has_heartbeat_timer = false;
271
+ }
272
+ // Cancel all fd subscriptions.
273
+ if (!io_error)
274
+ rm_fd (handle);
275
+
276
+ // Disconnect from I/O threads poller object.
277
+ io_object_t::unplug ();
278
+
279
+ session = NULL;
280
+ }
281
+
282
+ void zmq::stream_engine_t::terminate ()
283
+ {
284
+ unplug ();
285
+ delete this;
286
+ }
287
+
288
+ void zmq::stream_engine_t::in_event ()
289
+ {
290
+ zmq_assert (!io_error);
291
+
292
+ // If still handshaking, receive and process the greeting message.
293
+ if (unlikely (handshaking))
294
+ if (!handshake ())
295
+ return;
296
+
297
+ zmq_assert (decoder);
298
+
299
+ // If there has been an I/O error, stop polling.
300
+ if (input_stopped) {
301
+ rm_fd (handle);
302
+ io_error = true;
303
+ return;
304
+ }
305
+
306
+ // If there's no data to process in the buffer...
307
+ if (!insize) {
308
+
309
+ // Retrieve the buffer and read as much data as possible.
310
+ // Note that buffer can be arbitrarily large. However, we assume
311
+ // the underlying TCP layer has fixed buffer size and thus the
312
+ // number of bytes read will be always limited.
313
+ size_t bufsize = 0;
314
+ decoder->get_buffer (&inpos, &bufsize);
315
+
316
+ const int rc = tcp_read (s, inpos, bufsize);
317
+
318
+ if (rc == 0) {
319
+ // connection closed by peer
320
+ errno = EPIPE;
321
+ error (connection_error);
322
+ return;
323
+ }
324
+ if (rc == -1) {
325
+ if (errno != EAGAIN)
326
+ error (connection_error);
327
+ return;
328
+ }
329
+
330
+ // Adjust input size
331
+ insize = static_cast <size_t> (rc);
332
+ // Adjust buffer size to received bytes
333
+ decoder->resize_buffer(insize);
334
+ }
335
+
336
+ int rc = 0;
337
+ size_t processed = 0;
338
+
339
+ while (insize > 0) {
340
+ rc = decoder->decode (inpos, insize, processed);
341
+ zmq_assert (processed <= insize);
342
+ inpos += processed;
343
+ insize -= processed;
344
+ if (rc == 0 || rc == -1)
345
+ break;
346
+ rc = (this->*process_msg) (decoder->msg ());
347
+ if (rc == -1)
348
+ break;
349
+ }
350
+
351
+ // Tear down the connection if we have failed to decode input data
352
+ // or the session has rejected the message.
353
+ if (rc == -1) {
354
+ if (errno != EAGAIN) {
355
+ error(protocol_error);
356
+ return;
357
+ }
358
+ input_stopped = true;
359
+ reset_pollin (handle);
360
+ }
361
+
362
+ session->flush ();
363
+ }
364
+
365
+ void zmq::stream_engine_t::out_event ()
366
+ {
367
+ zmq_assert (!io_error);
368
+
369
+ // If write buffer is empty, try to read new data from the encoder.
370
+ if (!outsize) {
371
+
372
+ // Even when we stop polling as soon as there is no
373
+ // data to send, the poller may invoke out_event one
374
+ // more time due to 'speculative write' optimisation.
375
+ if (unlikely (encoder == NULL)) {
376
+ zmq_assert (handshaking);
377
+ return;
378
+ }
379
+
380
+ outpos = NULL;
381
+ outsize = encoder->encode (&outpos, 0);
382
+
383
+ while (outsize < (size_t) out_batch_size) {
384
+ if ((this->*next_msg) (&tx_msg) == -1)
385
+ break;
386
+ encoder->load_msg (&tx_msg);
387
+ unsigned char *bufptr = outpos + outsize;
388
+ size_t n = encoder->encode (&bufptr, out_batch_size - outsize);
389
+ zmq_assert (n > 0);
390
+ if (outpos == NULL)
391
+ outpos = bufptr;
392
+ outsize += n;
393
+ }
394
+
395
+ // If there is no data to send, stop polling for output.
396
+ if (outsize == 0) {
397
+ output_stopped = true;
398
+ reset_pollout (handle);
399
+ return;
400
+ }
401
+ }
402
+
403
+ // If there are any data to write in write buffer, write as much as
404
+ // possible to the socket. Note that amount of data to write can be
405
+ // arbitrarily large. However, we assume that underlying TCP layer has
406
+ // limited transmission buffer and thus the actual number of bytes
407
+ // written should be reasonably modest.
408
+ const int nbytes = tcp_write (s, outpos, outsize);
409
+
410
+ // IO error has occurred. We stop waiting for output events.
411
+ // The engine is not terminated until we detect input error;
412
+ // this is necessary to prevent losing incoming messages.
413
+ if (nbytes == -1) {
414
+ reset_pollout (handle);
415
+ return;
416
+ }
417
+
418
+ outpos += nbytes;
419
+ outsize -= nbytes;
420
+
421
+ // If we are still handshaking and there are no data
422
+ // to send, stop polling for output.
423
+ if (unlikely (handshaking))
424
+ if (outsize == 0)
425
+ reset_pollout (handle);
426
+ }
427
+
428
+ void zmq::stream_engine_t::restart_output ()
429
+ {
430
+ if (unlikely (io_error))
431
+ return;
432
+
433
+ if (likely (output_stopped)) {
434
+ set_pollout (handle);
435
+ output_stopped = false;
436
+ }
437
+
438
+ // Speculative write: The assumption is that at the moment new message
439
+ // was sent by the user the socket is probably available for writing.
440
+ // Thus we try to write the data to socket avoiding polling for POLLOUT.
441
+ // Consequently, the latency should be better in request/reply scenarios.
442
+ out_event ();
443
+ }
444
+
445
+ void zmq::stream_engine_t::restart_input ()
446
+ {
447
+ zmq_assert (input_stopped);
448
+ zmq_assert (session != NULL);
449
+ zmq_assert (decoder != NULL);
450
+
451
+ int rc = (this->*process_msg) (decoder->msg ());
452
+ if (rc == -1) {
453
+ if (errno == EAGAIN)
454
+ session->flush ();
455
+ else
456
+ error (protocol_error);
457
+ return;
458
+ }
459
+
460
+ while (insize > 0) {
461
+ size_t processed = 0;
462
+ rc = decoder->decode (inpos, insize, processed);
463
+ zmq_assert (processed <= insize);
464
+ inpos += processed;
465
+ insize -= processed;
466
+ if (rc == 0 || rc == -1)
467
+ break;
468
+ rc = (this->*process_msg) (decoder->msg ());
469
+ if (rc == -1)
470
+ break;
471
+ }
472
+
473
+ if (rc == -1 && errno == EAGAIN)
474
+ session->flush ();
475
+ else
476
+ if (io_error)
477
+ error (connection_error);
478
+ else
479
+ if (rc == -1)
480
+ error (protocol_error);
481
+ else {
482
+ input_stopped = false;
483
+ set_pollin (handle);
484
+ session->flush ();
485
+
486
+ // Speculative read.
487
+ in_event ();
488
+ }
489
+ }
490
+
491
+ bool zmq::stream_engine_t::handshake ()
492
+ {
493
+ zmq_assert (handshaking);
494
+ zmq_assert (greeting_bytes_read < greeting_size);
495
+ // Receive the greeting.
496
+ while (greeting_bytes_read < greeting_size) {
497
+ const int n = tcp_read (s, greeting_recv + greeting_bytes_read,
498
+ greeting_size - greeting_bytes_read);
499
+ if (n == 0) {
500
+ errno = EPIPE;
501
+ error (connection_error);
502
+ return false;
503
+ }
504
+ if (n == -1) {
505
+ if (errno != EAGAIN)
506
+ error (connection_error);
507
+ return false;
508
+ }
509
+
510
+ greeting_bytes_read += n;
511
+
512
+ // We have received at least one byte from the peer.
513
+ // If the first byte is not 0xff, we know that the
514
+ // peer is using unversioned protocol.
515
+ if (greeting_recv [0] != 0xff)
516
+ break;
517
+
518
+ if (greeting_bytes_read < signature_size)
519
+ continue;
520
+
521
+ // Inspect the right-most bit of the 10th byte (which coincides
522
+ // with the 'flags' field if a regular message was sent).
523
+ // Zero indicates this is a header of a routing id message
524
+ // (i.e. the peer is using the unversioned protocol).
525
+ if (!(greeting_recv [9] & 0x01))
526
+ break;
527
+
528
+ // The peer is using versioned protocol.
529
+ // Send the major version number.
530
+ if (outpos + outsize == greeting_send + signature_size) {
531
+ if (outsize == 0)
532
+ set_pollout (handle);
533
+ outpos [outsize++] = 3; // Major version number
534
+ }
535
+
536
+ if (greeting_bytes_read > signature_size) {
537
+ if (outpos + outsize == greeting_send + signature_size + 1) {
538
+ if (outsize == 0)
539
+ set_pollout (handle);
540
+
541
+ // Use ZMTP/2.0 to talk to older peers.
542
+ if (greeting_recv [10] == ZMTP_1_0
543
+ || greeting_recv [10] == ZMTP_2_0)
544
+ outpos [outsize++] = options.type;
545
+ else {
546
+ outpos [outsize++] = 0; // Minor version number
547
+ memset (outpos + outsize, 0, 20);
548
+
549
+ zmq_assert (options.mechanism == ZMQ_NULL
550
+ || options.mechanism == ZMQ_PLAIN
551
+ || options.mechanism == ZMQ_CURVE
552
+ || options.mechanism == ZMQ_GSSAPI);
553
+
554
+ if (options.mechanism == ZMQ_NULL)
555
+ memcpy (outpos + outsize, "NULL", 4);
556
+ else
557
+ if (options.mechanism == ZMQ_PLAIN)
558
+ memcpy (outpos + outsize, "PLAIN", 5);
559
+ else
560
+ if (options.mechanism == ZMQ_GSSAPI)
561
+ memcpy (outpos + outsize, "GSSAPI", 6);
562
+ else
563
+ if (options.mechanism == ZMQ_CURVE)
564
+ memcpy (outpos + outsize, "CURVE", 5);
565
+ outsize += 20;
566
+ memset (outpos + outsize, 0, 32);
567
+ outsize += 32;
568
+ greeting_size = v3_greeting_size;
569
+ }
570
+ }
571
+ }
572
+ }
573
+
574
+ // Position of the revision field in the greeting.
575
+ const size_t revision_pos = 10;
576
+
577
+ // Is the peer using ZMTP/1.0 with no revision number?
578
+ // If so, we send and receive rest of routing id message
579
+ if (greeting_recv [0] != 0xff || !(greeting_recv [9] & 0x01)) {
580
+ if (session->zap_enabled ()) {
581
+ // reject ZMTP 1.0 connections if ZAP is enabled
582
+ error (protocol_error);
583
+ return false;
584
+ }
585
+
586
+ encoder = new (std::nothrow) v1_encoder_t (out_batch_size);
587
+ alloc_assert (encoder);
588
+
589
+ decoder = new (std::nothrow) v1_decoder_t (in_batch_size, options.maxmsgsize);
590
+ alloc_assert (decoder);
591
+
592
+ // We have already sent the message header.
593
+ // Since there is no way to tell the encoder to
594
+ // skip the message header, we simply throw that
595
+ // header data away.
596
+ const size_t header_size = options.routing_id_size + 1 >= 255 ? 10 : 2;
597
+ unsigned char tmp [10], *bufferp = tmp;
598
+
599
+ // Prepare the routing id message and load it into encoder.
600
+ // Then consume bytes we have already sent to the peer.
601
+ const int rc = tx_msg.init_size (options.routing_id_size);
602
+ zmq_assert (rc == 0);
603
+ memcpy (tx_msg.data (), options.routing_id, options.routing_id_size);
604
+ encoder->load_msg (&tx_msg);
605
+ size_t buffer_size = encoder->encode (&bufferp, header_size);
606
+ zmq_assert (buffer_size == header_size);
607
+
608
+ // Make sure the decoder sees the data we have already received.
609
+ inpos = greeting_recv;
610
+ insize = greeting_bytes_read;
611
+
612
+ // To allow for interoperability with peers that do not forward
613
+ // their subscriptions, we inject a phantom subscription message
614
+ // message into the incoming message stream.
615
+ if (options.type == ZMQ_PUB || options.type == ZMQ_XPUB)
616
+ subscription_required = true;
617
+
618
+ // We are sending our routing id now and the next message
619
+ // will come from the socket.
620
+ next_msg = &stream_engine_t::pull_msg_from_session;
621
+
622
+ // We are expecting routing id message.
623
+ process_msg = &stream_engine_t::process_routing_id_msg;
624
+ }
625
+ else
626
+ if (greeting_recv [revision_pos] == ZMTP_1_0) {
627
+ if (session->zap_enabled ()) {
628
+ // reject ZMTP 1.0 connections if ZAP is enabled
629
+ error (protocol_error);
630
+ return false;
631
+ }
632
+
633
+ encoder = new (std::nothrow) v1_encoder_t (out_batch_size);
634
+ alloc_assert (encoder);
635
+
636
+ decoder = new (std::nothrow) v1_decoder_t (
637
+ in_batch_size, options.maxmsgsize);
638
+ alloc_assert (decoder);
639
+ }
640
+ else
641
+ if (greeting_recv [revision_pos] == ZMTP_2_0) {
642
+ if (session->zap_enabled ()) {
643
+ // reject ZMTP 2.0 connections if ZAP is enabled
644
+ error (protocol_error);
645
+ return false;
646
+ }
647
+
648
+ encoder = new (std::nothrow) v2_encoder_t (out_batch_size);
649
+ alloc_assert (encoder);
650
+
651
+ decoder = new (std::nothrow) v2_decoder_t (
652
+ in_batch_size, options.maxmsgsize);
653
+ alloc_assert (decoder);
654
+ }
655
+ else {
656
+ encoder = new (std::nothrow) v2_encoder_t (out_batch_size);
657
+ alloc_assert (encoder);
658
+
659
+ decoder = new (std::nothrow) v2_decoder_t (
660
+ in_batch_size, options.maxmsgsize);
661
+ alloc_assert (decoder);
662
+
663
+ if (options.mechanism == ZMQ_NULL
664
+ && memcmp (greeting_recv + 12, "NULL\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20) == 0) {
665
+ mechanism = new (std::nothrow)
666
+ null_mechanism_t (session, peer_address, options);
667
+ alloc_assert (mechanism);
668
+ }
669
+ else
670
+ if (options.mechanism == ZMQ_PLAIN
671
+ && memcmp (greeting_recv + 12, "PLAIN\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20) == 0) {
672
+ if (options.as_server)
673
+ mechanism = new (std::nothrow)
674
+ plain_server_t (session, peer_address, options);
675
+ else
676
+ mechanism = new (std::nothrow)
677
+ plain_client_t (session, options);
678
+ alloc_assert (mechanism);
679
+ }
680
+ #ifdef ZMQ_HAVE_CURVE
681
+ else
682
+ if (options.mechanism == ZMQ_CURVE
683
+ && memcmp (greeting_recv + 12, "CURVE\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20) == 0) {
684
+ if (options.as_server)
685
+ mechanism = new (std::nothrow)
686
+ curve_server_t (session, peer_address, options);
687
+ else
688
+ mechanism =
689
+ new (std::nothrow) curve_client_t (session, options);
690
+ alloc_assert (mechanism);
691
+ }
692
+ #endif
693
+ #ifdef HAVE_LIBGSSAPI_KRB5
694
+ else
695
+ if (options.mechanism == ZMQ_GSSAPI
696
+ && memcmp (greeting_recv + 12, "GSSAPI\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20) == 0) {
697
+ if (options.as_server)
698
+ mechanism = new (std::nothrow)
699
+ gssapi_server_t (session, peer_address, options);
700
+ else
701
+ mechanism =
702
+ new (std::nothrow) gssapi_client_t (session, options);
703
+ alloc_assert (mechanism);
704
+ }
705
+ #endif
706
+ else {
707
+ session->get_socket ()->event_handshake_failed_protocol (
708
+ session->get_endpoint (), ZMQ_PROTOCOL_ERROR_ZMTP_MECHANISM_MISMATCH);
709
+ error (protocol_error);
710
+ return false;
711
+ }
712
+ next_msg = &stream_engine_t::next_handshake_command;
713
+ process_msg = &stream_engine_t::process_handshake_command;
714
+ }
715
+
716
+ // Start polling for output if necessary.
717
+ if (outsize == 0)
718
+ set_pollout (handle);
719
+
720
+ // Handshaking was successful.
721
+ // Switch into the normal message flow.
722
+ handshaking = false;
723
+
724
+ if (has_handshake_timer) {
725
+ cancel_timer (handshake_timer_id);
726
+ has_handshake_timer = false;
727
+ }
728
+
729
+ return true;
730
+ }
731
+
732
+ int zmq::stream_engine_t::routing_id_msg (msg_t *msg_)
733
+ {
734
+ int rc = msg_->init_size (options.routing_id_size);
735
+ errno_assert (rc == 0);
736
+ if (options.routing_id_size > 0)
737
+ memcpy (msg_->data (), options.routing_id, options.routing_id_size);
738
+ next_msg = &stream_engine_t::pull_msg_from_session;
739
+ return 0;
740
+ }
741
+
742
+ int zmq::stream_engine_t::process_routing_id_msg (msg_t *msg_)
743
+ {
744
+ if (options.recv_routing_id) {
745
+ msg_->set_flags (msg_t::routing_id);
746
+ int rc = session->push_msg (msg_);
747
+ errno_assert (rc == 0);
748
+ }
749
+ else {
750
+ int rc = msg_->close ();
751
+ errno_assert (rc == 0);
752
+ rc = msg_->init ();
753
+ errno_assert (rc == 0);
754
+ }
755
+
756
+ if (subscription_required) {
757
+ msg_t subscription;
758
+
759
+ // Inject the subscription message, so that also
760
+ // ZMQ 2.x peers receive published messages.
761
+ int rc = subscription.init_size (1);
762
+ errno_assert (rc == 0);
763
+ *(unsigned char*) subscription.data () = 1;
764
+ rc = session->push_msg (&subscription);
765
+ errno_assert (rc == 0);
766
+ }
767
+
768
+ process_msg = &stream_engine_t::push_msg_to_session;
769
+
770
+ return 0;
771
+ }
772
+
773
+ int zmq::stream_engine_t::next_handshake_command (msg_t *msg_)
774
+ {
775
+ zmq_assert (mechanism != NULL);
776
+
777
+ if (mechanism->status () == mechanism_t::ready) {
778
+ mechanism_ready ();
779
+ return pull_and_encode (msg_);
780
+ }
781
+ else
782
+ if (mechanism->status () == mechanism_t::error) {
783
+ errno = EPROTO;
784
+ return -1;
785
+ }
786
+ else {
787
+ const int rc = mechanism->next_handshake_command (msg_);
788
+
789
+ if (rc == 0)
790
+ msg_->set_flags (msg_t::command);
791
+
792
+ return rc;
793
+ }
794
+ }
795
+
796
+ int zmq::stream_engine_t::process_handshake_command (msg_t *msg_)
797
+ {
798
+ zmq_assert (mechanism != NULL);
799
+ const int rc = mechanism->process_handshake_command (msg_);
800
+ if (rc == 0) {
801
+ if (mechanism->status () == mechanism_t::ready)
802
+ mechanism_ready ();
803
+ else
804
+ if (mechanism->status () == mechanism_t::error) {
805
+ errno = EPROTO;
806
+ return -1;
807
+ }
808
+ if (output_stopped)
809
+ restart_output ();
810
+ }
811
+
812
+ return rc;
813
+ }
814
+
815
+ void zmq::stream_engine_t::zap_msg_available ()
816
+ {
817
+ zmq_assert (mechanism != NULL);
818
+
819
+ const int rc = mechanism->zap_msg_available ();
820
+ if (rc == -1) {
821
+ error (protocol_error);
822
+ return;
823
+ }
824
+ if (input_stopped)
825
+ restart_input ();
826
+ if (output_stopped)
827
+ restart_output ();
828
+ }
829
+
830
+ const char *zmq::stream_engine_t::get_endpoint () const
831
+ {
832
+ return endpoint.c_str ();
833
+ }
834
+
835
+ void zmq::stream_engine_t::mechanism_ready ()
836
+ {
837
+ if (options.heartbeat_interval > 0) {
838
+ add_timer(options.heartbeat_interval, heartbeat_ivl_timer_id);
839
+ has_heartbeat_timer = true;
840
+ }
841
+
842
+ if (options.recv_routing_id) {
843
+ msg_t routing_id;
844
+ mechanism->peer_routing_id (&routing_id);
845
+ const int rc = session->push_msg (&routing_id);
846
+ if (rc == -1 && errno == EAGAIN) {
847
+ // If the write is failing at this stage with
848
+ // an EAGAIN the pipe must be being shut down,
849
+ // so we can just bail out of the routing id set.
850
+ return;
851
+ }
852
+ errno_assert (rc == 0);
853
+ session->flush ();
854
+ }
855
+
856
+ next_msg = &stream_engine_t::pull_and_encode;
857
+ process_msg = &stream_engine_t::write_credential;
858
+
859
+ // Compile metadata.
860
+ properties_t properties;
861
+ init_properties(properties);
862
+
863
+ // Add ZAP properties.
864
+ const properties_t& zap_properties = mechanism->get_zap_properties ();
865
+ properties.insert(zap_properties.begin (), zap_properties.end ());
866
+
867
+ // Add ZMTP properties.
868
+ const properties_t& zmtp_properties = mechanism->get_zmtp_properties ();
869
+ properties.insert(zmtp_properties.begin (), zmtp_properties.end ());
870
+
871
+ zmq_assert (metadata == NULL);
872
+ if (!properties.empty ())
873
+ {
874
+ metadata = new (std::nothrow) metadata_t (properties);
875
+ alloc_assert (metadata);
876
+ }
877
+
878
+ #ifdef ZMQ_BUILD_DRAFT_API
879
+ socket->event_handshake_succeeded (endpoint, 0);
880
+ #endif
881
+ }
882
+
883
+ int zmq::stream_engine_t::pull_msg_from_session (msg_t *msg_)
884
+ {
885
+ return session->pull_msg (msg_);
886
+ }
887
+
888
+ int zmq::stream_engine_t::push_msg_to_session (msg_t *msg_)
889
+ {
890
+ return session->push_msg (msg_);
891
+ }
892
+
893
+ int zmq::stream_engine_t::push_raw_msg_to_session (msg_t *msg_) {
894
+ if (metadata && metadata != msg_->metadata())
895
+ msg_->set_metadata(metadata);
896
+ return push_msg_to_session(msg_);
897
+ }
898
+
899
+ int zmq::stream_engine_t::write_credential (msg_t *msg_)
900
+ {
901
+ zmq_assert (mechanism != NULL);
902
+ zmq_assert (session != NULL);
903
+
904
+ const blob_t &credential = mechanism->get_user_id ();
905
+ if (credential.size () > 0) {
906
+ msg_t msg;
907
+ int rc = msg.init_size (credential.size ());
908
+ zmq_assert (rc == 0);
909
+ memcpy (msg.data (), credential.data (), credential.size ());
910
+ msg.set_flags (msg_t::credential);
911
+ rc = session->push_msg (&msg);
912
+ if (rc == -1) {
913
+ rc = msg.close ();
914
+ errno_assert (rc == 0);
915
+ return -1;
916
+ }
917
+ }
918
+ process_msg = &stream_engine_t::decode_and_push;
919
+ return decode_and_push (msg_);
920
+ }
921
+
922
+ int zmq::stream_engine_t::pull_and_encode (msg_t *msg_)
923
+ {
924
+ zmq_assert (mechanism != NULL);
925
+
926
+ if (session->pull_msg (msg_) == -1)
927
+ return -1;
928
+ if (mechanism->encode (msg_) == -1)
929
+ return -1;
930
+ return 0;
931
+ }
932
+
933
+ int zmq::stream_engine_t::decode_and_push (msg_t *msg_)
934
+ {
935
+ zmq_assert (mechanism != NULL);
936
+
937
+ if (mechanism->decode (msg_) == -1)
938
+ return -1;
939
+
940
+ if(has_timeout_timer) {
941
+ has_timeout_timer = false;
942
+ cancel_timer(heartbeat_timeout_timer_id);
943
+ }
944
+
945
+ if(has_ttl_timer) {
946
+ has_ttl_timer = false;
947
+ cancel_timer(heartbeat_ttl_timer_id);
948
+ }
949
+
950
+ if(msg_->flags() & msg_t::command) {
951
+ uint8_t cmd_id = *((uint8_t*)msg_->data());
952
+ if(cmd_id == 4)
953
+ process_heartbeat_message(msg_);
954
+ }
955
+
956
+ if (metadata)
957
+ msg_->set_metadata (metadata);
958
+ if (session->push_msg (msg_) == -1) {
959
+ if (errno == EAGAIN)
960
+ process_msg = &stream_engine_t::push_one_then_decode_and_push;
961
+ return -1;
962
+ }
963
+ return 0;
964
+ }
965
+
966
+ int zmq::stream_engine_t::push_one_then_decode_and_push (msg_t *msg_)
967
+ {
968
+ const int rc = session->push_msg (msg_);
969
+ if (rc == 0)
970
+ process_msg = &stream_engine_t::decode_and_push;
971
+ return rc;
972
+ }
973
+
974
+ void zmq::stream_engine_t::error (error_reason_t reason)
975
+ {
976
+ if (options.raw_socket && options.raw_notify) {
977
+ // For raw sockets, send a final 0-length message to the application
978
+ // so that it knows the peer has been disconnected.
979
+ msg_t terminator;
980
+ terminator.init();
981
+ (this->*process_msg) (&terminator);
982
+ terminator.close();
983
+ }
984
+ zmq_assert (session);
985
+ #ifdef ZMQ_BUILD_DRAFT_API
986
+ // protocol errors have been signaled already at the point where they occurred
987
+ if (reason != protocol_error
988
+ && (mechanism == NULL
989
+ || mechanism->status () == mechanism_t::handshaking)) {
990
+ int err = errno;
991
+ socket->event_handshake_failed_no_detail (endpoint, err);
992
+ }
993
+ #endif
994
+ socket->event_disconnected (endpoint, (int) s);
995
+ session->flush ();
996
+ session->engine_error (reason);
997
+ unplug ();
998
+ delete this;
999
+ }
1000
+
1001
+ void zmq::stream_engine_t::set_handshake_timer ()
1002
+ {
1003
+ zmq_assert (!has_handshake_timer);
1004
+
1005
+ if (!options.raw_socket && options.handshake_ivl > 0) {
1006
+ add_timer (options.handshake_ivl, handshake_timer_id);
1007
+ has_handshake_timer = true;
1008
+ }
1009
+ }
1010
+
1011
+ bool zmq::stream_engine_t::init_properties (properties_t & properties) {
1012
+ if (peer_address.empty()) return false;
1013
+ properties.ZMQ_MAP_INSERT_OR_EMPLACE (
1014
+ ZMQ_MSG_PROPERTY_PEER_ADDRESS, peer_address);
1015
+
1016
+ // Private property to support deprecated SRCFD
1017
+ std::ostringstream stream;
1018
+ stream << (int)s;
1019
+ std::string fd_string = stream.str();
1020
+ properties.ZMQ_MAP_INSERT_OR_EMPLACE ("__fd", ZMQ_MOVE(fd_string));
1021
+ return true;
1022
+ }
1023
+
1024
+ void zmq::stream_engine_t::timer_event (int id_)
1025
+ {
1026
+ if(id_ == handshake_timer_id) {
1027
+ has_handshake_timer = false;
1028
+ // handshake timer expired before handshake completed, so engine fail
1029
+ error (timeout_error);
1030
+ }
1031
+ else if(id_ == heartbeat_ivl_timer_id) {
1032
+ next_msg = &stream_engine_t::produce_ping_message;
1033
+ out_event();
1034
+ add_timer(options.heartbeat_interval, heartbeat_ivl_timer_id);
1035
+ }
1036
+ else if(id_ == heartbeat_ttl_timer_id) {
1037
+ has_ttl_timer = false;
1038
+ error(timeout_error);
1039
+ }
1040
+ else if(id_ == heartbeat_timeout_timer_id) {
1041
+ has_timeout_timer = false;
1042
+ error(timeout_error);
1043
+ }
1044
+ else
1045
+ // There are no other valid timer ids!
1046
+ assert(false);
1047
+ }
1048
+
1049
+ int zmq::stream_engine_t::produce_ping_message(msg_t * msg_)
1050
+ {
1051
+ int rc = 0;
1052
+ zmq_assert (mechanism != NULL);
1053
+
1054
+ // 16-bit TTL + \4PING == 7
1055
+ rc = msg_->init_size(7);
1056
+ errno_assert(rc == 0);
1057
+ msg_->set_flags(msg_t::command);
1058
+ // Copy in the command message
1059
+ memcpy(msg_->data(), "\4PING", 5);
1060
+
1061
+ uint16_t ttl_val = htons(options.heartbeat_ttl);
1062
+ memcpy(((uint8_t*)msg_->data()) + 5, &ttl_val, sizeof(ttl_val));
1063
+
1064
+ rc = mechanism->encode (msg_);
1065
+ next_msg = &stream_engine_t::pull_and_encode;
1066
+ if(!has_timeout_timer && heartbeat_timeout > 0) {
1067
+ add_timer(heartbeat_timeout, heartbeat_timeout_timer_id);
1068
+ has_timeout_timer = true;
1069
+ }
1070
+ return rc;
1071
+ }
1072
+
1073
+ int zmq::stream_engine_t::produce_pong_message(msg_t * msg_)
1074
+ {
1075
+ int rc = 0;
1076
+ zmq_assert (mechanism != NULL);
1077
+
1078
+ rc = msg_->init_size(5);
1079
+ errno_assert(rc == 0);
1080
+ msg_->set_flags(msg_t::command);
1081
+
1082
+ memcpy(msg_->data(), "\4PONG", 5);
1083
+
1084
+ rc = mechanism->encode (msg_);
1085
+ next_msg = &stream_engine_t::pull_and_encode;
1086
+ return rc;
1087
+ }
1088
+
1089
+ int zmq::stream_engine_t::process_heartbeat_message(msg_t * msg_)
1090
+ {
1091
+ if(memcmp(msg_->data(), "\4PING", 5) == 0) {
1092
+ uint16_t remote_heartbeat_ttl;
1093
+ // Get the remote heartbeat TTL to setup the timer
1094
+ memcpy(&remote_heartbeat_ttl, (uint8_t*)msg_->data() + 5, 2);
1095
+ remote_heartbeat_ttl = ntohs(remote_heartbeat_ttl);
1096
+ // The remote heartbeat is in 10ths of a second
1097
+ // so we multiply it by 100 to get the timer interval in ms.
1098
+ remote_heartbeat_ttl *= 100;
1099
+
1100
+ if(!has_ttl_timer && remote_heartbeat_ttl > 0) {
1101
+ add_timer(remote_heartbeat_ttl, heartbeat_ttl_timer_id);
1102
+ has_ttl_timer = true;
1103
+ }
1104
+
1105
+ next_msg = &stream_engine_t::produce_pong_message;
1106
+ out_event();
1107
+ }
1108
+
1109
+ return 0;
1110
+ }