mt-libcouchbase 1.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (707) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +22 -0
  3. data/.gitmodules +3 -0
  4. data/.rspec +1 -0
  5. data/.travis.yml +38 -0
  6. data/Gemfile +4 -0
  7. data/LICENSE +24 -0
  8. data/README.md +445 -0
  9. data/Rakefile +76 -0
  10. data/ext/README.md +6 -0
  11. data/ext/Rakefile +19 -0
  12. data/ext/libcouchbase/.gitignore +132 -0
  13. data/ext/libcouchbase/CMakeLists.txt +455 -0
  14. data/ext/libcouchbase/CONTRIBUTING.md +105 -0
  15. data/ext/libcouchbase/LICENSE +202 -0
  16. data/ext/libcouchbase/README.markdown +195 -0
  17. data/ext/libcouchbase/RELEASE_NOTES.markdown +3523 -0
  18. data/ext/libcouchbase/cmake/Modules/ConfigureDtrace.cmake +52 -0
  19. data/ext/libcouchbase/cmake/Modules/CopyPDB.cmake +42 -0
  20. data/ext/libcouchbase/cmake/Modules/DistScript.cmake +17 -0
  21. data/ext/libcouchbase/cmake/Modules/DownloadLcbDep.cmake +18 -0
  22. data/ext/libcouchbase/cmake/Modules/FindCouchbaseHdrHistogram.cmake +15 -0
  23. data/ext/libcouchbase/cmake/Modules/FindCouchbaseLibev.cmake +73 -0
  24. data/ext/libcouchbase/cmake/Modules/FindCouchbaseLibevent.cmake +54 -0
  25. data/ext/libcouchbase/cmake/Modules/FindCouchbaseLibuv.cmake +57 -0
  26. data/ext/libcouchbase/cmake/Modules/FindProfiler.cmake +16 -0
  27. data/ext/libcouchbase/cmake/Modules/GenerateConfigDotH.cmake +49 -0
  28. data/ext/libcouchbase/cmake/Modules/GetLibcouchbaseFlags.cmake +142 -0
  29. data/ext/libcouchbase/cmake/Modules/GetPlatformCCInfo.cmake +45 -0
  30. data/ext/libcouchbase/cmake/Modules/GetVersionInfo.cmake +70 -0
  31. data/ext/libcouchbase/cmake/config-cmake.h.in +80 -0
  32. data/ext/libcouchbase/cmake/configure +355 -0
  33. data/ext/libcouchbase/cmake/defs.mk.in +6 -0
  34. data/ext/libcouchbase/cmake/dtrace-instr-link.pl +51 -0
  35. data/ext/libcouchbase/cmake/libcouchbase.stp.in +829 -0
  36. data/ext/libcouchbase/cmake/source_files.cmake +104 -0
  37. data/ext/libcouchbase/contrib/cJSON/cJSON.c +1022 -0
  38. data/ext/libcouchbase/contrib/cJSON/cJSON.h +158 -0
  39. data/ext/libcouchbase/contrib/cbsasl/CMakeLists.txt +25 -0
  40. data/ext/libcouchbase/contrib/cbsasl/COPYING +202 -0
  41. data/ext/libcouchbase/contrib/cbsasl/include/cbsasl/cbsasl.h +259 -0
  42. data/ext/libcouchbase/contrib/cbsasl/src/client.c +419 -0
  43. data/ext/libcouchbase/contrib/cbsasl/src/common.c +50 -0
  44. data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/hmac.c +67 -0
  45. data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/hmac.h +33 -0
  46. data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/md5.c +296 -0
  47. data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/md5.h +45 -0
  48. data/ext/libcouchbase/contrib/cbsasl/src/hash.c +573 -0
  49. data/ext/libcouchbase/contrib/cbsasl/src/hash.h +15 -0
  50. data/ext/libcouchbase/contrib/cbsasl/src/scram-sha/scram_utils.c +500 -0
  51. data/ext/libcouchbase/contrib/cbsasl/src/scram-sha/scram_utils.h +99 -0
  52. data/ext/libcouchbase/contrib/cbsasl/src/util.h +31 -0
  53. data/ext/libcouchbase/contrib/cliopts/CMakeLists.txt +2 -0
  54. data/ext/libcouchbase/contrib/cliopts/cliopts.c +938 -0
  55. data/ext/libcouchbase/contrib/cliopts/cliopts.h +610 -0
  56. data/ext/libcouchbase/contrib/genhash/genhash.c +371 -0
  57. data/ext/libcouchbase/contrib/genhash/genhash.h +241 -0
  58. data/ext/libcouchbase/contrib/gtest-1.7.0/CHANGES +157 -0
  59. data/ext/libcouchbase/contrib/gtest-1.7.0/CMakeLists.txt +252 -0
  60. data/ext/libcouchbase/contrib/gtest-1.7.0/CONTRIBUTORS +37 -0
  61. data/ext/libcouchbase/contrib/gtest-1.7.0/LICENSE +28 -0
  62. data/ext/libcouchbase/contrib/gtest-1.7.0/MINIFY.sh +15 -0
  63. data/ext/libcouchbase/contrib/gtest-1.7.0/README +435 -0
  64. data/ext/libcouchbase/contrib/gtest-1.7.0/cmake/internal_utils.cmake +227 -0
  65. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-death-test.h +294 -0
  66. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-message.h +250 -0
  67. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-param-test.h +1421 -0
  68. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-param-test.h.pump +487 -0
  69. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-printers.h +855 -0
  70. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-spi.h +232 -0
  71. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-test-part.h +179 -0
  72. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-typed-test.h +259 -0
  73. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest.h +2291 -0
  74. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest_pred_impl.h +358 -0
  75. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest_prod.h +58 -0
  76. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-death-test-internal.h +319 -0
  77. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-filepath.h +206 -0
  78. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-internal.h +1158 -0
  79. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-linked_ptr.h +233 -0
  80. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-param-util-generated.h +5143 -0
  81. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-param-util-generated.h.pump +301 -0
  82. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-param-util.h +619 -0
  83. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-port.h +1947 -0
  84. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-string.h +167 -0
  85. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-tuple.h +1012 -0
  86. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-tuple.h.pump +339 -0
  87. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-type-util.h +3331 -0
  88. data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-type-util.h.pump +297 -0
  89. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-all.cc +48 -0
  90. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-death-test.cc +1344 -0
  91. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-filepath.cc +382 -0
  92. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-internal-inl.h +1218 -0
  93. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-port.cc +805 -0
  94. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-printers.cc +363 -0
  95. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-test-part.cc +110 -0
  96. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-typed-test.cc +110 -0
  97. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest.cc +5015 -0
  98. data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest_main.cc +38 -0
  99. data/ext/libcouchbase/contrib/http_parser/LICENSE-MIT +23 -0
  100. data/ext/libcouchbase/contrib/http_parser/README.md +178 -0
  101. data/ext/libcouchbase/contrib/http_parser/http_parser.c +2060 -0
  102. data/ext/libcouchbase/contrib/http_parser/http_parser.h +321 -0
  103. data/ext/libcouchbase/contrib/jsonsl/LICENSE +20 -0
  104. data/ext/libcouchbase/contrib/jsonsl/jsonsl.c +1452 -0
  105. data/ext/libcouchbase/contrib/jsonsl/jsonsl.h +971 -0
  106. data/ext/libcouchbase/contrib/lcb-jsoncpp/CMakeLists.txt +6 -0
  107. data/ext/libcouchbase/contrib/lcb-jsoncpp/LICENSE +55 -0
  108. data/ext/libcouchbase/contrib/lcb-jsoncpp/lcb-jsoncpp-forwards.h +255 -0
  109. data/ext/libcouchbase/contrib/lcb-jsoncpp/lcb-jsoncpp.cpp +4893 -0
  110. data/ext/libcouchbase/contrib/lcb-jsoncpp/lcb-jsoncpp.h +1961 -0
  111. data/ext/libcouchbase/contrib/snappy/CMakeLists.txt +7 -0
  112. data/ext/libcouchbase/contrib/snappy/COPYING +28 -0
  113. data/ext/libcouchbase/contrib/snappy/snappy-c.cc +90 -0
  114. data/ext/libcouchbase/contrib/snappy/snappy-c.h +138 -0
  115. data/ext/libcouchbase/contrib/snappy/snappy-internal.h +150 -0
  116. data/ext/libcouchbase/contrib/snappy/snappy-lcb-msvc.h +5 -0
  117. data/ext/libcouchbase/contrib/snappy/snappy-sinksource.cc +75 -0
  118. data/ext/libcouchbase/contrib/snappy/snappy-sinksource.h +137 -0
  119. data/ext/libcouchbase/contrib/snappy/snappy-stubs-internal.cc +42 -0
  120. data/ext/libcouchbase/contrib/snappy/snappy-stubs-internal.h +491 -0
  121. data/ext/libcouchbase/contrib/snappy/snappy-stubs-public.h +100 -0
  122. data/ext/libcouchbase/contrib/snappy/snappy.cc +1312 -0
  123. data/ext/libcouchbase/contrib/snappy/snappy.h +184 -0
  124. data/ext/libcouchbase/contrib/win32-defs/iocpdefs.h +133 -0
  125. data/ext/libcouchbase/contrib/win32-defs/mingwdefs.h +4396 -0
  126. data/ext/libcouchbase/contrib/win32-defs/win_stdint.h +258 -0
  127. data/ext/libcouchbase/doc/Doxyfile +2495 -0
  128. data/ext/libcouchbase/doc/DoxygenLayout.xml +109 -0
  129. data/ext/libcouchbase/doc/Makefile +44 -0
  130. data/ext/libcouchbase/doc/apiattr.h +117 -0
  131. data/ext/libcouchbase/doc/cbc-n1qlback.markdown +88 -0
  132. data/ext/libcouchbase/doc/cbc-pillowfight.markdown +296 -0
  133. data/ext/libcouchbase/doc/cbc-subdoc.markdown +299 -0
  134. data/ext/libcouchbase/doc/cbc.markdown +763 -0
  135. data/ext/libcouchbase/doc/cbcrc.markdown +52 -0
  136. data/ext/libcouchbase/doc/common-additional-options.markdown +82 -0
  137. data/ext/libcouchbase/doc/common-options.markdown +71 -0
  138. data/ext/libcouchbase/doc/environment.h +93 -0
  139. data/ext/libcouchbase/doc/example/threads.c +77 -0
  140. data/ext/libcouchbase/doc/footer.html +22 -0
  141. data/ext/libcouchbase/doc/genman.sh +25 -0
  142. data/ext/libcouchbase/doc/header.html +52 -0
  143. data/ext/libcouchbase/doc/intro.h +130 -0
  144. data/ext/libcouchbase/doc/mainpage.h +136 -0
  145. data/ext/libcouchbase/doc/man/cbc-admin.1 +1 -0
  146. data/ext/libcouchbase/doc/man/cbc-bucket-create.1 +1 -0
  147. data/ext/libcouchbase/doc/man/cbc-bucket-delete.1 +1 -0
  148. data/ext/libcouchbase/doc/man/cbc-cat.1 +1 -0
  149. data/ext/libcouchbase/doc/man/cbc-connstr.1 +1 -0
  150. data/ext/libcouchbase/doc/man/cbc-cp.1 +1 -0
  151. data/ext/libcouchbase/doc/man/cbc-create.1 +1 -0
  152. data/ext/libcouchbase/doc/man/cbc-decr.1 +1 -0
  153. data/ext/libcouchbase/doc/man/cbc-flush.1 +1 -0
  154. data/ext/libcouchbase/doc/man/cbc-hash.1 +1 -0
  155. data/ext/libcouchbase/doc/man/cbc-incr.1 +1 -0
  156. data/ext/libcouchbase/doc/man/cbc-lock.1 +1 -0
  157. data/ext/libcouchbase/doc/man/cbc-mcflush.1 +1 -0
  158. data/ext/libcouchbase/doc/man/cbc-mcversion.1 +1 -0
  159. data/ext/libcouchbase/doc/man/cbc-n1ql.1 +1 -0
  160. data/ext/libcouchbase/doc/man/cbc-n1qlback.1 +198 -0
  161. data/ext/libcouchbase/doc/man/cbc-observe.1 +1 -0
  162. data/ext/libcouchbase/doc/man/cbc-pillowfight.1 +499 -0
  163. data/ext/libcouchbase/doc/man/cbc-ping.1 +1 -0
  164. data/ext/libcouchbase/doc/man/cbc-rm.1 +1 -0
  165. data/ext/libcouchbase/doc/man/cbc-role-list.1 +1 -0
  166. data/ext/libcouchbase/doc/man/cbc-stats.1 +1 -0
  167. data/ext/libcouchbase/doc/man/cbc-subdoc.1 +494 -0
  168. data/ext/libcouchbase/doc/man/cbc-unlock.1 +1 -0
  169. data/ext/libcouchbase/doc/man/cbc-user-delete.1 +1 -0
  170. data/ext/libcouchbase/doc/man/cbc-user-list.1 +1 -0
  171. data/ext/libcouchbase/doc/man/cbc-user-upsert.1 +1 -0
  172. data/ext/libcouchbase/doc/man/cbc-verbosity.1 +1 -0
  173. data/ext/libcouchbase/doc/man/cbc-version.1 +1 -0
  174. data/ext/libcouchbase/doc/man/cbc-view.1 +1 -0
  175. data/ext/libcouchbase/doc/man/cbc-watch.1 +1 -0
  176. data/ext/libcouchbase/doc/man/cbc.1 +1035 -0
  177. data/ext/libcouchbase/doc/man/cbcrc.4 +71 -0
  178. data/ext/libcouchbase/doc/style.css +1162 -0
  179. data/ext/libcouchbase/example/CMakeLists.txt +52 -0
  180. data/ext/libcouchbase/example/README.markdown +47 -0
  181. data/ext/libcouchbase/example/analytics/.gitignore +1 -0
  182. data/ext/libcouchbase/example/analytics/analytics.c +158 -0
  183. data/ext/libcouchbase/example/analytics/build-queries.rb +34 -0
  184. data/ext/libcouchbase/example/analytics/cJSON.c +1 -0
  185. data/ext/libcouchbase/example/analytics/cJSON.h +1 -0
  186. data/ext/libcouchbase/example/analytics/queries/00-show-dataverse.json +5 -0
  187. data/ext/libcouchbase/example/analytics/queries/01-setup-dataset-breweries.json +6 -0
  188. data/ext/libcouchbase/example/analytics/queries/02-setup-dataset-beers.json +6 -0
  189. data/ext/libcouchbase/example/analytics/queries/03-initiate-shadow.json +6 -0
  190. data/ext/libcouchbase/example/analytics/queries/04-list-datasets.json +7 -0
  191. data/ext/libcouchbase/example/analytics/queries/05-count-breweries.json +5 -0
  192. data/ext/libcouchbase/example/analytics/queries/06-first-brewery.json +6 -0
  193. data/ext/libcouchbase/example/analytics/queries/07-key-based-lookup.json +6 -0
  194. data/ext/libcouchbase/example/analytics/queries/08-exact-match-lookup.json +7 -0
  195. data/ext/libcouchbase/example/analytics/queries/09-exact-match-lookup-different-shape.json +6 -0
  196. data/ext/libcouchbase/example/analytics/queries/10-other-query-filters.json +6 -0
  197. data/ext/libcouchbase/example/analytics/queries/11-equijoin.json +9 -0
  198. data/ext/libcouchbase/example/analytics/queries/12-equijoin-select-star.json +10 -0
  199. data/ext/libcouchbase/example/analytics/queries/13-ansi-join.json +8 -0
  200. data/ext/libcouchbase/example/analytics/queries/14-join-select-values.json +8 -0
  201. data/ext/libcouchbase/example/analytics/queries/15-nested-outer-join.json +7 -0
  202. data/ext/libcouchbase/example/analytics/queries/16-theta-join.json +8 -0
  203. data/ext/libcouchbase/example/analytics/queries/17-existential-quantification.json +9 -0
  204. data/ext/libcouchbase/example/analytics/queries/18-universal-quantification.json +7 -0
  205. data/ext/libcouchbase/example/analytics/queries/19-simple-aggregation.json +6 -0
  206. data/ext/libcouchbase/example/analytics/queries/20-simple-aggregation-unwrapped-value.json +6 -0
  207. data/ext/libcouchbase/example/analytics/queries/21-simple-aggregation-explicit.json +6 -0
  208. data/ext/libcouchbase/example/analytics/queries/22-grouping-and-aggregation.json +6 -0
  209. data/ext/libcouchbase/example/analytics/queries/23-grouping-and-aggregation-with-hint.json +7 -0
  210. data/ext/libcouchbase/example/analytics/queries/24-grouping-and-limits.json +7 -0
  211. data/ext/libcouchbase/example/analytics/queries/25-named-parameters.json +7 -0
  212. data/ext/libcouchbase/example/analytics/queries/26-positional-parameters.json +7 -0
  213. data/ext/libcouchbase/example/analytics/queries.h +113 -0
  214. data/ext/libcouchbase/example/crypto/.gitignore +2 -0
  215. data/ext/libcouchbase/example/crypto/Makefile +13 -0
  216. data/ext/libcouchbase/example/crypto/common_provider.c +26 -0
  217. data/ext/libcouchbase/example/crypto/common_provider.h +33 -0
  218. data/ext/libcouchbase/example/crypto/openssl_symmetric_decrypt.c +144 -0
  219. data/ext/libcouchbase/example/crypto/openssl_symmetric_encrypt.c +146 -0
  220. data/ext/libcouchbase/example/crypto/openssl_symmetric_provider.c +271 -0
  221. data/ext/libcouchbase/example/crypto/openssl_symmetric_provider.h +29 -0
  222. data/ext/libcouchbase/example/db/db.c +171 -0
  223. data/ext/libcouchbase/example/db/vb.c +227 -0
  224. data/ext/libcouchbase/example/fts/.gitignore +1 -0
  225. data/ext/libcouchbase/example/fts/build-queries.rb +33 -0
  226. data/ext/libcouchbase/example/fts/fts.c +142 -0
  227. data/ext/libcouchbase/example/fts/queries/00-simple-text-query.json +12 -0
  228. data/ext/libcouchbase/example/fts/queries/01-simple-text-query-on-non-default-index.json +9 -0
  229. data/ext/libcouchbase/example/fts/queries/02-simple-text-query-on-stored-field.json +13 -0
  230. data/ext/libcouchbase/example/fts/queries/03-match-query-with-facet.json +19 -0
  231. data/ext/libcouchbase/example/fts/queries/04-docid-query.json +11 -0
  232. data/ext/libcouchbase/example/fts/queries/05-unanalyzed-term-query-with-fuzziness-level-of-0.json +13 -0
  233. data/ext/libcouchbase/example/fts/queries/06-unanalyzed-term-query-with-fuzziness-level-of-2.json +14 -0
  234. data/ext/libcouchbase/example/fts/queries/07-match-phrase-query.json +13 -0
  235. data/ext/libcouchbase/example/fts/queries/08-phrase-query.json +16 -0
  236. data/ext/libcouchbase/example/fts/queries/09-query-string-query.json +9 -0
  237. data/ext/libcouchbase/example/fts/queries/10-conjunction-query.json +21 -0
  238. data/ext/libcouchbase/example/fts/queries/11-wild-card-query.json +13 -0
  239. data/ext/libcouchbase/example/fts/queries/12-numeric-range-query.json +11 -0
  240. data/ext/libcouchbase/example/fts/queries/13-regexp-query.json +13 -0
  241. data/ext/libcouchbase/example/fts/queries.h +61 -0
  242. data/ext/libcouchbase/example/instancepool/main.cc +112 -0
  243. data/ext/libcouchbase/example/instancepool/pool.cc +102 -0
  244. data/ext/libcouchbase/example/instancepool/pool.h +69 -0
  245. data/ext/libcouchbase/example/libeventdirect/main.c +222 -0
  246. data/ext/libcouchbase/example/mcc/mcc.cc +246 -0
  247. data/ext/libcouchbase/example/minimal/.gitignore +1 -0
  248. data/ext/libcouchbase/example/minimal/minimal.c +132 -0
  249. data/ext/libcouchbase/example/minimal/query.c +185 -0
  250. data/ext/libcouchbase/example/observe/durability.c +102 -0
  251. data/ext/libcouchbase/example/observe/observe.c +159 -0
  252. data/ext/libcouchbase/example/subdoc/subdoc-multi.cc +143 -0
  253. data/ext/libcouchbase/example/subdoc/subdoc-simple.cc +201 -0
  254. data/ext/libcouchbase/example/subdoc/subdoc-xattrs.c +286 -0
  255. data/ext/libcouchbase/example/tick/tick.c +119 -0
  256. data/ext/libcouchbase/example/tracing/.gitignore +2 -0
  257. data/ext/libcouchbase/example/tracing/Makefile +8 -0
  258. data/ext/libcouchbase/example/tracing/cJSON.c +1 -0
  259. data/ext/libcouchbase/example/tracing/cJSON.h +1 -0
  260. data/ext/libcouchbase/example/tracing/tracing.c +439 -0
  261. data/ext/libcouchbase/example/tracing/views.c +444 -0
  262. data/ext/libcouchbase/example/users/README +48 -0
  263. data/ext/libcouchbase/example/users/users.c +147 -0
  264. data/ext/libcouchbase/example/views/views-example.cc +83 -0
  265. data/ext/libcouchbase/include/libcouchbase/_cxxwrap.h +150 -0
  266. data/ext/libcouchbase/include/libcouchbase/api-legacy.h +1689 -0
  267. data/ext/libcouchbase/include/libcouchbase/api3.h +2 -0
  268. data/ext/libcouchbase/include/libcouchbase/assert.h +44 -0
  269. data/ext/libcouchbase/include/libcouchbase/auth.h +297 -0
  270. data/ext/libcouchbase/include/libcouchbase/cbft.h +151 -0
  271. data/ext/libcouchbase/include/libcouchbase/cntl-private.h +319 -0
  272. data/ext/libcouchbase/include/libcouchbase/cntl.h +1418 -0
  273. data/ext/libcouchbase/include/libcouchbase/configuration.h.in +29 -0
  274. data/ext/libcouchbase/include/libcouchbase/couchbase.h +4089 -0
  275. data/ext/libcouchbase/include/libcouchbase/crypto.h +306 -0
  276. data/ext/libcouchbase/include/libcouchbase/deprecated.h +312 -0
  277. data/ext/libcouchbase/include/libcouchbase/error.h +680 -0
  278. data/ext/libcouchbase/include/libcouchbase/http.h +1 -0
  279. data/ext/libcouchbase/include/libcouchbase/iops.h +1053 -0
  280. data/ext/libcouchbase/include/libcouchbase/ixmgmt.h +263 -0
  281. data/ext/libcouchbase/include/libcouchbase/kvbuf.h +137 -0
  282. data/ext/libcouchbase/include/libcouchbase/metrics.h +79 -0
  283. data/ext/libcouchbase/include/libcouchbase/n1ql.h +539 -0
  284. data/ext/libcouchbase/include/libcouchbase/pktfwd.h +270 -0
  285. data/ext/libcouchbase/include/libcouchbase/plugins/io/bsdio-inl.c +370 -0
  286. data/ext/libcouchbase/include/libcouchbase/plugins/io/wsaerr-inl.c +76 -0
  287. data/ext/libcouchbase/include/libcouchbase/plugins/io/wsaerr.h +199 -0
  288. data/ext/libcouchbase/include/libcouchbase/subdoc.h +347 -0
  289. data/ext/libcouchbase/include/libcouchbase/sysdefs.h +98 -0
  290. data/ext/libcouchbase/include/libcouchbase/tracing.h +437 -0
  291. data/ext/libcouchbase/include/libcouchbase/vbucket.h +680 -0
  292. data/ext/libcouchbase/include/libcouchbase/views.h +357 -0
  293. data/ext/libcouchbase/include/libcouchbase/visibility.h +66 -0
  294. data/ext/libcouchbase/include/memcached/COPYING +30 -0
  295. data/ext/libcouchbase/include/memcached/README +10 -0
  296. data/ext/libcouchbase/include/memcached/protocol_binary.h +885 -0
  297. data/ext/libcouchbase/packaging/README +7 -0
  298. data/ext/libcouchbase/packaging/abicheck/.gitignore +4 -0
  299. data/ext/libcouchbase/packaging/abicheck/Makefile +17 -0
  300. data/ext/libcouchbase/packaging/abicheck/README.md +27 -0
  301. data/ext/libcouchbase/packaging/abicheck/template.xml +3 -0
  302. data/ext/libcouchbase/packaging/deb/compat +1 -0
  303. data/ext/libcouchbase/packaging/deb/control +72 -0
  304. data/ext/libcouchbase/packaging/deb/copyright +10 -0
  305. data/ext/libcouchbase/packaging/deb/libcouchbase-dev.docs +3 -0
  306. data/ext/libcouchbase/packaging/deb/package.mk +31 -0
  307. data/ext/libcouchbase/packaging/deb/rules +46 -0
  308. data/ext/libcouchbase/packaging/deb/source/format +1 -0
  309. data/ext/libcouchbase/packaging/distinfo/README +1 -0
  310. data/ext/libcouchbase/packaging/distinfo/distinfo.cmake.in +4 -0
  311. data/ext/libcouchbase/packaging/dllversion.rc.in +39 -0
  312. data/ext/libcouchbase/packaging/libcouchbase.pc.in +10 -0
  313. data/ext/libcouchbase/packaging/nuget/libcouchbase.autopkg +76 -0
  314. data/ext/libcouchbase/packaging/parse-git-describe.pl +166 -0
  315. data/ext/libcouchbase/packaging/rpm/libcouchbase.spec.in +101 -0
  316. data/ext/libcouchbase/packaging/rpm/package.mk +40 -0
  317. data/ext/libcouchbase/plugins/io/iocp/CMakeLists.txt +9 -0
  318. data/ext/libcouchbase/plugins/io/iocp/iocp_iops.c +467 -0
  319. data/ext/libcouchbase/plugins/io/iocp/iocp_iops.h +217 -0
  320. data/ext/libcouchbase/plugins/io/iocp/iocp_loop.c +295 -0
  321. data/ext/libcouchbase/plugins/io/iocp/iocp_timer.c +79 -0
  322. data/ext/libcouchbase/plugins/io/iocp/iocp_util.c +229 -0
  323. data/ext/libcouchbase/plugins/io/libev/CMakeLists.txt +31 -0
  324. data/ext/libcouchbase/plugins/io/libev/libev_io_opts.h +66 -0
  325. data/ext/libcouchbase/plugins/io/libev/plugin-libev.c +289 -0
  326. data/ext/libcouchbase/plugins/io/libevent/CMakeLists.txt +31 -0
  327. data/ext/libcouchbase/plugins/io/libevent/libevent_io_opts.h +67 -0
  328. data/ext/libcouchbase/plugins/io/libevent/plugin-libevent.c +292 -0
  329. data/ext/libcouchbase/plugins/io/libuv/CMakeLists.txt +44 -0
  330. data/ext/libcouchbase/plugins/io/libuv/libuv_compat.h +218 -0
  331. data/ext/libcouchbase/plugins/io/libuv/libuv_io_opts.h +118 -0
  332. data/ext/libcouchbase/plugins/io/libuv/plugin-internal.h +155 -0
  333. data/ext/libcouchbase/plugins/io/libuv/plugin-libuv.c +709 -0
  334. data/ext/libcouchbase/plugins/io/select/CMakeLists.txt +13 -0
  335. data/ext/libcouchbase/plugins/io/select/plugin-select.c +451 -0
  336. data/ext/libcouchbase/plugins/io/select/select_io_opts.h +39 -0
  337. data/ext/libcouchbase/src/README.md +101 -0
  338. data/ext/libcouchbase/src/aspend.h +105 -0
  339. data/ext/libcouchbase/src/auth-priv.h +85 -0
  340. data/ext/libcouchbase/src/auth.cc +146 -0
  341. data/ext/libcouchbase/src/bootstrap.cc +263 -0
  342. data/ext/libcouchbase/src/bootstrap.h +149 -0
  343. data/ext/libcouchbase/src/bucketconfig/bc_cccp.cc +450 -0
  344. data/ext/libcouchbase/src/bucketconfig/bc_file.cc +281 -0
  345. data/ext/libcouchbase/src/bucketconfig/bc_http.cc +527 -0
  346. data/ext/libcouchbase/src/bucketconfig/bc_http.h +107 -0
  347. data/ext/libcouchbase/src/bucketconfig/bc_static.cc +150 -0
  348. data/ext/libcouchbase/src/bucketconfig/clconfig.h +700 -0
  349. data/ext/libcouchbase/src/bucketconfig/confmon.cc +403 -0
  350. data/ext/libcouchbase/src/callbacks.c +380 -0
  351. data/ext/libcouchbase/src/cbft.cc +253 -0
  352. data/ext/libcouchbase/src/cntl.cc +1057 -0
  353. data/ext/libcouchbase/src/config_static.h +176 -0
  354. data/ext/libcouchbase/src/connspec.cc +555 -0
  355. data/ext/libcouchbase/src/connspec.h +155 -0
  356. data/ext/libcouchbase/src/crypto.cc +399 -0
  357. data/ext/libcouchbase/src/ctx-log-inl.h +44 -0
  358. data/ext/libcouchbase/src/dns-srv.cc +146 -0
  359. data/ext/libcouchbase/src/dump.cc +103 -0
  360. data/ext/libcouchbase/src/errmap.cc +173 -0
  361. data/ext/libcouchbase/src/errmap.h +271 -0
  362. data/ext/libcouchbase/src/getconfig.cc +72 -0
  363. data/ext/libcouchbase/src/gethrtime.c +109 -0
  364. data/ext/libcouchbase/src/handler.cc +1101 -0
  365. data/ext/libcouchbase/src/hashtable.c +75 -0
  366. data/ext/libcouchbase/src/hdr_timings.c +92 -0
  367. data/ext/libcouchbase/src/hostlist.cc +293 -0
  368. data/ext/libcouchbase/src/hostlist.h +160 -0
  369. data/ext/libcouchbase/src/http/http-priv.h +326 -0
  370. data/ext/libcouchbase/src/http/http.cc +672 -0
  371. data/ext/libcouchbase/src/http/http.h +1 -0
  372. data/ext/libcouchbase/src/http/http_io.cc +316 -0
  373. data/ext/libcouchbase/src/instance.cc +917 -0
  374. data/ext/libcouchbase/src/internal.h +285 -0
  375. data/ext/libcouchbase/src/iofactory.c +575 -0
  376. data/ext/libcouchbase/src/jsparse/parser.cc +445 -0
  377. data/ext/libcouchbase/src/jsparse/parser.h +159 -0
  378. data/ext/libcouchbase/src/lcbht/lcbht.cc +177 -0
  379. data/ext/libcouchbase/src/lcbht/lcbht.h +210 -0
  380. data/ext/libcouchbase/src/lcbio/connect.cc +603 -0
  381. data/ext/libcouchbase/src/lcbio/connect.h +400 -0
  382. data/ext/libcouchbase/src/lcbio/ctx.c +658 -0
  383. data/ext/libcouchbase/src/lcbio/ctx.h +405 -0
  384. data/ext/libcouchbase/src/lcbio/iotable.c +290 -0
  385. data/ext/libcouchbase/src/lcbio/iotable.h +169 -0
  386. data/ext/libcouchbase/src/lcbio/ioutils.cc +356 -0
  387. data/ext/libcouchbase/src/lcbio/ioutils.h +144 -0
  388. data/ext/libcouchbase/src/lcbio/lcbio.h +51 -0
  389. data/ext/libcouchbase/src/lcbio/manager.cc +579 -0
  390. data/ext/libcouchbase/src/lcbio/manager.h +195 -0
  391. data/ext/libcouchbase/src/lcbio/protoctx.c +84 -0
  392. data/ext/libcouchbase/src/lcbio/rw-inl.h +137 -0
  393. data/ext/libcouchbase/src/lcbio/ssl.h +159 -0
  394. data/ext/libcouchbase/src/lcbio/timer-cxx.h +87 -0
  395. data/ext/libcouchbase/src/lcbio/timer-ng.h +179 -0
  396. data/ext/libcouchbase/src/lcbio/timer.c +132 -0
  397. data/ext/libcouchbase/src/legacy.c +431 -0
  398. data/ext/libcouchbase/src/list.c +144 -0
  399. data/ext/libcouchbase/src/list.h +127 -0
  400. data/ext/libcouchbase/src/logging.c +244 -0
  401. data/ext/libcouchbase/src/logging.h +88 -0
  402. data/ext/libcouchbase/src/mc/compress.cc +171 -0
  403. data/ext/libcouchbase/src/mc/compress.h +56 -0
  404. data/ext/libcouchbase/src/mc/forward.c +186 -0
  405. data/ext/libcouchbase/src/mc/forward.h +90 -0
  406. data/ext/libcouchbase/src/mc/iovcursor-inl.h +279 -0
  407. data/ext/libcouchbase/src/mc/iovcursor.h +66 -0
  408. data/ext/libcouchbase/src/mc/mcreq-flush-inl.h +115 -0
  409. data/ext/libcouchbase/src/mc/mcreq.c +983 -0
  410. data/ext/libcouchbase/src/mc/mcreq.h +1015 -0
  411. data/ext/libcouchbase/src/mcserver/mcserver.cc +1055 -0
  412. data/ext/libcouchbase/src/mcserver/mcserver.h +221 -0
  413. data/ext/libcouchbase/src/mcserver/negotiate.cc +757 -0
  414. data/ext/libcouchbase/src/mcserver/negotiate.h +128 -0
  415. data/ext/libcouchbase/src/mctx-helper.h +62 -0
  416. data/ext/libcouchbase/src/metrics.cc +132 -0
  417. data/ext/libcouchbase/src/n1ql/ixmgmt.cc +857 -0
  418. data/ext/libcouchbase/src/n1ql/n1ql-internal.h +22 -0
  419. data/ext/libcouchbase/src/n1ql/n1ql.cc +830 -0
  420. data/ext/libcouchbase/src/n1ql/params.cc +260 -0
  421. data/ext/libcouchbase/src/netbuf/netbuf-defs.h +89 -0
  422. data/ext/libcouchbase/src/netbuf/netbuf-mblock.h +235 -0
  423. data/ext/libcouchbase/src/netbuf/netbuf.c +929 -0
  424. data/ext/libcouchbase/src/netbuf/netbuf.h +452 -0
  425. data/ext/libcouchbase/src/newconfig.cc +365 -0
  426. data/ext/libcouchbase/src/nodeinfo.cc +184 -0
  427. data/ext/libcouchbase/src/operations/cbflush.cc +63 -0
  428. data/ext/libcouchbase/src/operations/counter.cc +117 -0
  429. data/ext/libcouchbase/src/operations/durability-cas.cc +251 -0
  430. data/ext/libcouchbase/src/operations/durability-seqno.cc +170 -0
  431. data/ext/libcouchbase/src/operations/durability.cc +668 -0
  432. data/ext/libcouchbase/src/operations/durability_internal.h +306 -0
  433. data/ext/libcouchbase/src/operations/get.cc +409 -0
  434. data/ext/libcouchbase/src/operations/observe-seqno.cc +94 -0
  435. data/ext/libcouchbase/src/operations/observe.cc +367 -0
  436. data/ext/libcouchbase/src/operations/ping.cc +496 -0
  437. data/ext/libcouchbase/src/operations/pktfwd.cc +86 -0
  438. data/ext/libcouchbase/src/operations/remove.cc +84 -0
  439. data/ext/libcouchbase/src/operations/stats.cc +459 -0
  440. data/ext/libcouchbase/src/operations/store.cc +358 -0
  441. data/ext/libcouchbase/src/operations/subdoc.cc +614 -0
  442. data/ext/libcouchbase/src/operations/touch.cc +84 -0
  443. data/ext/libcouchbase/src/packetutils.h +388 -0
  444. data/ext/libcouchbase/src/probes.d +182 -0
  445. data/ext/libcouchbase/src/rdb/bigalloc.c +225 -0
  446. data/ext/libcouchbase/src/rdb/bigalloc.h +73 -0
  447. data/ext/libcouchbase/src/rdb/chunkalloc.c +174 -0
  448. data/ext/libcouchbase/src/rdb/libcalloc.c +94 -0
  449. data/ext/libcouchbase/src/rdb/rope.c +419 -0
  450. data/ext/libcouchbase/src/rdb/rope.h +488 -0
  451. data/ext/libcouchbase/src/retrychk.cc +113 -0
  452. data/ext/libcouchbase/src/retryq.cc +458 -0
  453. data/ext/libcouchbase/src/retryq.h +170 -0
  454. data/ext/libcouchbase/src/ringbuffer.c +442 -0
  455. data/ext/libcouchbase/src/ringbuffer.h +100 -0
  456. data/ext/libcouchbase/src/rnd.cc +61 -0
  457. data/ext/libcouchbase/src/rnd.h +39 -0
  458. data/ext/libcouchbase/src/settings.c +125 -0
  459. data/ext/libcouchbase/src/settings.h +273 -0
  460. data/ext/libcouchbase/src/sllist-inl.h +197 -0
  461. data/ext/libcouchbase/src/sllist.h +76 -0
  462. data/ext/libcouchbase/src/ssl/CMakeLists.txt +11 -0
  463. data/ext/libcouchbase/src/ssl/ssl_c.c +442 -0
  464. data/ext/libcouchbase/src/ssl/ssl_common.c +478 -0
  465. data/ext/libcouchbase/src/ssl/ssl_e.c +421 -0
  466. data/ext/libcouchbase/src/ssl/ssl_iot_common.h +182 -0
  467. data/ext/libcouchbase/src/strcodecs/base64.c +307 -0
  468. data/ext/libcouchbase/src/strcodecs/strcodecs.h +302 -0
  469. data/ext/libcouchbase/src/timings.c +207 -0
  470. data/ext/libcouchbase/src/trace.h +117 -0
  471. data/ext/libcouchbase/src/tracing/span.cc +421 -0
  472. data/ext/libcouchbase/src/tracing/threshold_logging_tracer.cc +213 -0
  473. data/ext/libcouchbase/src/tracing/tracer.cc +53 -0
  474. data/ext/libcouchbase/src/tracing/tracing-internal.h +198 -0
  475. data/ext/libcouchbase/src/utilities.c +176 -0
  476. data/ext/libcouchbase/src/vbucket/CMakeLists.txt +2 -0
  477. data/ext/libcouchbase/src/vbucket/aliases.h +35 -0
  478. data/ext/libcouchbase/src/vbucket/crc32.h +83 -0
  479. data/ext/libcouchbase/src/vbucket/hash.h +30 -0
  480. data/ext/libcouchbase/src/vbucket/json-inl.h +112 -0
  481. data/ext/libcouchbase/src/vbucket/ketama.c +66 -0
  482. data/ext/libcouchbase/src/vbucket/rfc1321/global.h +32 -0
  483. data/ext/libcouchbase/src/vbucket/rfc1321/md5.h +35 -0
  484. data/ext/libcouchbase/src/vbucket/rfc1321/md5c-inl.h +335 -0
  485. data/ext/libcouchbase/src/vbucket/vbucket.c +1735 -0
  486. data/ext/libcouchbase/src/views/docreq.cc +213 -0
  487. data/ext/libcouchbase/src/views/docreq.h +94 -0
  488. data/ext/libcouchbase/src/views/viewreq.cc +381 -0
  489. data/ext/libcouchbase/src/views/viewreq.h +87 -0
  490. data/ext/libcouchbase/src/wait.cc +156 -0
  491. data/ext/libcouchbase/tests/CMakeLists.txt +149 -0
  492. data/ext/libcouchbase/tests/basic/t_base64.cc +109 -0
  493. data/ext/libcouchbase/tests/basic/t_ccbc103.cc +95 -0
  494. data/ext/libcouchbase/tests/basic/t_connstr.cc +456 -0
  495. data/ext/libcouchbase/tests/basic/t_creds.cc +96 -0
  496. data/ext/libcouchbase/tests/basic/t_ctlcodes.cc +92 -0
  497. data/ext/libcouchbase/tests/basic/t_host.cc +210 -0
  498. data/ext/libcouchbase/tests/basic/t_jsparse.cc +82 -0
  499. data/ext/libcouchbase/tests/basic/t_jsparse.h +589 -0
  500. data/ext/libcouchbase/tests/basic/t_list.cc +155 -0
  501. data/ext/libcouchbase/tests/basic/t_logger.cc +65 -0
  502. data/ext/libcouchbase/tests/basic/t_misc.cc +24 -0
  503. data/ext/libcouchbase/tests/basic/t_n1qlstrings.cc +17 -0
  504. data/ext/libcouchbase/tests/basic/t_netbuf.cc +446 -0
  505. data/ext/libcouchbase/tests/basic/t_packet.cc +215 -0
  506. data/ext/libcouchbase/tests/basic/t_ringbuffer.cc +278 -0
  507. data/ext/libcouchbase/tests/basic/t_scram.cc +514 -0
  508. data/ext/libcouchbase/tests/basic/t_slist.cc +429 -0
  509. data/ext/libcouchbase/tests/basic/t_strerror.cc +64 -0
  510. data/ext/libcouchbase/tests/basic/t_urlencode.cc +132 -0
  511. data/ext/libcouchbase/tests/check-all.cc +612 -0
  512. data/ext/libcouchbase/tests/htparse/t_basic.cc +173 -0
  513. data/ext/libcouchbase/tests/ioserver/connection.cc +166 -0
  514. data/ext/libcouchbase/tests/ioserver/future.cc +50 -0
  515. data/ext/libcouchbase/tests/ioserver/ioserver.cc +117 -0
  516. data/ext/libcouchbase/tests/ioserver/ioserver.h +478 -0
  517. data/ext/libcouchbase/tests/ioserver/socket.cc +88 -0
  518. data/ext/libcouchbase/tests/ioserver/ssl_connection.cc +145 -0
  519. data/ext/libcouchbase/tests/ioserver/threads-pthreads.cc +119 -0
  520. data/ext/libcouchbase/tests/ioserver/threads-win32.cc +117 -0
  521. data/ext/libcouchbase/tests/ioserver/threads.h +66 -0
  522. data/ext/libcouchbase/tests/iotests/iotests.h +15 -0
  523. data/ext/libcouchbase/tests/iotests/mock-environment.cc +632 -0
  524. data/ext/libcouchbase/tests/iotests/mock-environment.h +480 -0
  525. data/ext/libcouchbase/tests/iotests/mock-unit-test.cc +67 -0
  526. data/ext/libcouchbase/tests/iotests/mock-unit-test.h +61 -0
  527. data/ext/libcouchbase/tests/iotests/serverparams.h +76 -0
  528. data/ext/libcouchbase/tests/iotests/t_arithmetic.cc +143 -0
  529. data/ext/libcouchbase/tests/iotests/t_behavior.cc +220 -0
  530. data/ext/libcouchbase/tests/iotests/t_configcache.cc +117 -0
  531. data/ext/libcouchbase/tests/iotests/t_confmon.cc +223 -0
  532. data/ext/libcouchbase/tests/iotests/t_durability.cc +1108 -0
  533. data/ext/libcouchbase/tests/iotests/t_eerrs.cc +121 -0
  534. data/ext/libcouchbase/tests/iotests/t_errmap.cc +181 -0
  535. data/ext/libcouchbase/tests/iotests/t_forward.cc +118 -0
  536. data/ext/libcouchbase/tests/iotests/t_get.cc +512 -0
  537. data/ext/libcouchbase/tests/iotests/t_http.cc +438 -0
  538. data/ext/libcouchbase/tests/iotests/t_iops.cc +175 -0
  539. data/ext/libcouchbase/tests/iotests/t_lock.cc +274 -0
  540. data/ext/libcouchbase/tests/iotests/t_misc.cc +777 -0
  541. data/ext/libcouchbase/tests/iotests/t_mutate.cc +609 -0
  542. data/ext/libcouchbase/tests/iotests/t_n1ql.cc +270 -0
  543. data/ext/libcouchbase/tests/iotests/t_netfail.cc +778 -0
  544. data/ext/libcouchbase/tests/iotests/t_obseqno.cc +156 -0
  545. data/ext/libcouchbase/tests/iotests/t_regression.cc +321 -0
  546. data/ext/libcouchbase/tests/iotests/t_sched.cc +87 -0
  547. data/ext/libcouchbase/tests/iotests/t_serverops.cc +231 -0
  548. data/ext/libcouchbase/tests/iotests/t_smoke.cc +528 -0
  549. data/ext/libcouchbase/tests/iotests/t_snappy.cc +316 -0
  550. data/ext/libcouchbase/tests/iotests/t_subdoc.cc +857 -0
  551. data/ext/libcouchbase/tests/iotests/t_syncmode.cc +64 -0
  552. data/ext/libcouchbase/tests/iotests/t_views.cc +417 -0
  553. data/ext/libcouchbase/tests/iotests/testutil.cc +251 -0
  554. data/ext/libcouchbase/tests/iotests/testutil.h +163 -0
  555. data/ext/libcouchbase/tests/mc/mctest.h +119 -0
  556. data/ext/libcouchbase/tests/mc/pktmaker.h +101 -0
  557. data/ext/libcouchbase/tests/mc/t_alloc.cc +269 -0
  558. data/ext/libcouchbase/tests/mc/t_context.cc +100 -0
  559. data/ext/libcouchbase/tests/mc/t_flush.cc +185 -0
  560. data/ext/libcouchbase/tests/mc/t_forward.cc +239 -0
  561. data/ext/libcouchbase/tests/mc/t_ioflush.cc +102 -0
  562. data/ext/libcouchbase/tests/mc/t_iovcursor.cc +173 -0
  563. data/ext/libcouchbase/tests/mocksupport/procutil.c +305 -0
  564. data/ext/libcouchbase/tests/mocksupport/procutil.h +89 -0
  565. data/ext/libcouchbase/tests/mocksupport/server.c +391 -0
  566. data/ext/libcouchbase/tests/mocksupport/server.h +72 -0
  567. data/ext/libcouchbase/tests/mocksupport/timeout.c +69 -0
  568. data/ext/libcouchbase/tests/nonio_tests.cc +23 -0
  569. data/ext/libcouchbase/tests/rdb/rdbtest.h +133 -0
  570. data/ext/libcouchbase/tests/rdb/t_basic.cc +128 -0
  571. data/ext/libcouchbase/tests/rdb/t_bigalloc.cc +93 -0
  572. data/ext/libcouchbase/tests/rdb/t_refs.cc +112 -0
  573. data/ext/libcouchbase/tests/socktests/socktest.cc +344 -0
  574. data/ext/libcouchbase/tests/socktests/socktest.h +447 -0
  575. data/ext/libcouchbase/tests/socktests/t_basic.cc +143 -0
  576. data/ext/libcouchbase/tests/socktests/t_ctx.cc +73 -0
  577. data/ext/libcouchbase/tests/socktests/t_manager.cc +159 -0
  578. data/ext/libcouchbase/tests/socktests/t_putex.cc +256 -0
  579. data/ext/libcouchbase/tests/socktests/t_read.cc +187 -0
  580. data/ext/libcouchbase/tests/socktests/t_reentrant.cc +143 -0
  581. data/ext/libcouchbase/tests/socktests/t_ssl.cc +80 -0
  582. data/ext/libcouchbase/tests/socktests/t_write.cc +95 -0
  583. data/ext/libcouchbase/tests/start_mock.bat +15 -0
  584. data/ext/libcouchbase/tests/start_mock.sh +42 -0
  585. data/ext/libcouchbase/tests/unit_tests.cc +43 -0
  586. data/ext/libcouchbase/tests/vbucket/confdata/bad.json +101 -0
  587. data/ext/libcouchbase/tests/vbucket/confdata/full_25.json +363 -0
  588. data/ext/libcouchbase/tests/vbucket/confdata/ketama_expected.json +2562 -0
  589. data/ext/libcouchbase/tests/vbucket/confdata/map_node_present_nodesext_missing_nodes.json +94 -0
  590. data/ext/libcouchbase/tests/vbucket/confdata/memd_25.json +90 -0
  591. data/ext/libcouchbase/tests/vbucket/confdata/memd_30.json +1 -0
  592. data/ext/libcouchbase/tests/vbucket/confdata/memd_45.json +1 -0
  593. data/ext/libcouchbase/tests/vbucket/confdata/memd_ketama_config.json +31 -0
  594. data/ext/libcouchbase/tests/vbucket/confdata/terse_25.json +291 -0
  595. data/ext/libcouchbase/tests/vbucket/confdata/terse_30.json +1 -0
  596. data/ext/libcouchbase/tests/vbucket/t_config.cc +386 -0
  597. data/ext/libcouchbase/tools/CMakeLists.txt +80 -0
  598. data/ext/libcouchbase/tools/cbc-handlers.h +636 -0
  599. data/ext/libcouchbase/tools/cbc-n1qlback.cc +496 -0
  600. data/ext/libcouchbase/tools/cbc-pillowfight.cc +1230 -0
  601. data/ext/libcouchbase/tools/cbc-proxy.cc +534 -0
  602. data/ext/libcouchbase/tools/cbc-subdoc.cc +825 -0
  603. data/ext/libcouchbase/tools/cbc.cc +1928 -0
  604. data/ext/libcouchbase/tools/common/histogram.cc +44 -0
  605. data/ext/libcouchbase/tools/common/histogram.h +23 -0
  606. data/ext/libcouchbase/tools/common/options.cc +451 -0
  607. data/ext/libcouchbase/tools/common/options.h +90 -0
  608. data/ext/libcouchbase/tools/docgen/docgen.h +495 -0
  609. data/ext/libcouchbase/tools/docgen/loc.h +211 -0
  610. data/ext/libcouchbase/tools/docgen/placeholders.h +211 -0
  611. data/ext/libcouchbase/tools/docgen/seqgen.h +122 -0
  612. data/ext/libcouchbase/tools/extract-packets.rb +110 -0
  613. data/ext/libcouchbase/tools/linenoise/linenoise.c +1199 -0
  614. data/ext/libcouchbase/tools/linenoise/linenoise.h +73 -0
  615. data/lib/mt-libcouchbase/bucket.rb +825 -0
  616. data/lib/mt-libcouchbase/callbacks.rb +69 -0
  617. data/lib/mt-libcouchbase/connection.rb +896 -0
  618. data/lib/mt-libcouchbase/design_docs.rb +92 -0
  619. data/lib/mt-libcouchbase/error.rb +68 -0
  620. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdbase.rb +23 -0
  621. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdcounter.rb +36 -0
  622. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdendure.rb +26 -0
  623. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdfts.rb +24 -0
  624. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdget.rb +30 -0
  625. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdgetreplica.rb +49 -0
  626. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdhttp.rb +58 -0
  627. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdn1ql.rb +40 -0
  628. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdobseqno.rb +33 -0
  629. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdobserve.rb +30 -0
  630. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdstore.rb +40 -0
  631. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdstoredur.rb +45 -0
  632. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdsubdoc.rb +61 -0
  633. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdverbosity.rb +29 -0
  634. data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdviewquery.rb +61 -0
  635. data/lib/mt-libcouchbase/ext/mt-libcouchbase/contigbuf.rb +14 -0
  636. data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st.rb +15 -0
  637. data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st0.rb +23 -0
  638. data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st1.rb +26 -0
  639. data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st2.rb +32 -0
  640. data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st3.rb +26 -0
  641. data/lib/mt-libcouchbase/ext/mt-libcouchbase/crst_u.rb +20 -0
  642. data/lib/mt-libcouchbase/ext/mt-libcouchbase/durability_opts_st_v.rb +11 -0
  643. data/lib/mt-libcouchbase/ext/mt-libcouchbase/durability_opts_t.rb +14 -0
  644. data/lib/mt-libcouchbase/ext/mt-libcouchbase/durabilityopt_sv0.rb +63 -0
  645. data/lib/mt-libcouchbase/ext/mt-libcouchbase/enums.rb +1007 -0
  646. data/lib/mt-libcouchbase/ext/mt-libcouchbase/fragbuf.rb +18 -0
  647. data/lib/mt-libcouchbase/ext/mt-libcouchbase/ftshandle.rb +7 -0
  648. data/lib/mt-libcouchbase/ext/mt-libcouchbase/histogram.rb +34 -0
  649. data/lib/mt-libcouchbase/ext/mt-libcouchbase/http_request_t.rb +7 -0
  650. data/lib/mt-libcouchbase/ext/mt-libcouchbase/keybuf.rb +20 -0
  651. data/lib/mt-libcouchbase/ext/mt-libcouchbase/multicmd_ctx.rb +30 -0
  652. data/lib/mt-libcouchbase/ext/mt-libcouchbase/mutation_token.rb +17 -0
  653. data/lib/mt-libcouchbase/ext/mt-libcouchbase/n1qlhandle.rb +7 -0
  654. data/lib/mt-libcouchbase/ext/mt-libcouchbase/n1qlparams.rb +7 -0
  655. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respbase.rb +29 -0
  656. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respcounter.rb +32 -0
  657. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respendure.rb +49 -0
  658. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respfts.rb +40 -0
  659. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respget.rb +44 -0
  660. data/lib/mt-libcouchbase/ext/mt-libcouchbase/resphttp.rb +48 -0
  661. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respmcversion.rb +38 -0
  662. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respn1ql.rb +41 -0
  663. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respobseqno.rb +52 -0
  664. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respobserve.rb +41 -0
  665. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respserverbase.rb +32 -0
  666. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respstats.rb +38 -0
  667. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respstore.rb +32 -0
  668. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respstoredur.rb +38 -0
  669. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respsubdoc.rb +35 -0
  670. data/lib/mt-libcouchbase/ext/mt-libcouchbase/respviewquery.rb +67 -0
  671. data/lib/mt-libcouchbase/ext/mt-libcouchbase/sdentry.rb +22 -0
  672. data/lib/mt-libcouchbase/ext/mt-libcouchbase/sdspec.rb +31 -0
  673. data/lib/mt-libcouchbase/ext/mt-libcouchbase/t.rb +7 -0
  674. data/lib/mt-libcouchbase/ext/mt-libcouchbase/valbuf.rb +22 -0
  675. data/lib/mt-libcouchbase/ext/mt-libcouchbase/valbuf_u_buf.rb +14 -0
  676. data/lib/mt-libcouchbase/ext/mt-libcouchbase/viewhandle.rb +7 -0
  677. data/lib/mt-libcouchbase/ext/mt-libcouchbase.rb +1175 -0
  678. data/lib/mt-libcouchbase/ext/mt-libcouchbase_libuv.rb +22 -0
  679. data/lib/mt-libcouchbase/ext/tasks.rb +39 -0
  680. data/lib/mt-libcouchbase/n1ql.rb +80 -0
  681. data/lib/mt-libcouchbase/query_full_text.rb +147 -0
  682. data/lib/mt-libcouchbase/query_n1ql.rb +123 -0
  683. data/lib/mt-libcouchbase/query_view.rb +135 -0
  684. data/lib/mt-libcouchbase/results_fiber.rb +281 -0
  685. data/lib/mt-libcouchbase/results_native.rb +220 -0
  686. data/lib/mt-libcouchbase/subdoc_request.rb +139 -0
  687. data/lib/mt-libcouchbase/version.rb +5 -0
  688. data/lib/mt-libcouchbase.rb +40 -0
  689. data/mt-libcouchbase.gemspec +68 -0
  690. data/spec/bucket_spec.rb +290 -0
  691. data/spec/connection_spec.rb +257 -0
  692. data/spec/design_docs_spec.rb +31 -0
  693. data/spec/error_spec.rb +26 -0
  694. data/spec/fts_spec.rb +135 -0
  695. data/spec/n1ql_spec.rb +260 -0
  696. data/spec/results_libuv_spec.rb +244 -0
  697. data/spec/results_native_spec.rb +259 -0
  698. data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/design.json +1 -0
  699. data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/data-0000.cbb +0 -0
  700. data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/failover.json +1 -0
  701. data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/meta.json +1 -0
  702. data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/seqno.json +1 -0
  703. data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/snapshot_markers.json +1 -0
  704. data/spec/subdoc_spec.rb +192 -0
  705. data/spec/view_spec.rb +201 -0
  706. data/windows_build.md +36 -0
  707. metadata +873 -0
@@ -0,0 +1,1230 @@
1
+ /* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
2
+ /*
3
+ * Copyright 2011-2012 Couchbase, Inc.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ #define NOMINMAX // Because MS' CRT headers #define min and max :(
18
+ #include "config.h"
19
+ #include <sys/types.h>
20
+ #include <libcouchbase/couchbase.h>
21
+ #include <errno.h>
22
+ #include <iostream>
23
+ #include <map>
24
+ #include <sstream>
25
+ #include <queue>
26
+ #include <list>
27
+ #include <cstring>
28
+ #include <cassert>
29
+ #include <cstdio>
30
+ #include <cstdlib>
31
+ #include <fstream>
32
+ #include <signal.h>
33
+ #ifndef WIN32
34
+ #include <pthread.h>
35
+ #include <libcouchbase/metrics.h>
36
+ #else
37
+ #define usleep(n) Sleep(n/1000)
38
+ #endif
39
+ #include <cstdarg>
40
+ #include <exception>
41
+ #include <stdexcept>
42
+ #include "common/options.h"
43
+ #include "common/histogram.h"
44
+ #include "contrib/lcb-jsoncpp/lcb-jsoncpp.h"
45
+
46
+ #include "docgen/seqgen.h"
47
+ #include "docgen/docgen.h"
48
+
49
+ using namespace std;
50
+ using namespace cbc;
51
+ using namespace cliopts;
52
+ using namespace Pillowfight;
53
+ using std::vector;
54
+ using std::string;
55
+
56
+ // Deprecated options which still exist from previous versions.
57
+ struct DeprecatedOptions {
58
+ UIntOption iterations;
59
+ UIntOption instances;
60
+ BoolOption loop;
61
+
62
+ DeprecatedOptions() :
63
+ iterations("iterations"), instances("num-instances"), loop("loop")
64
+ {
65
+ iterations.abbrev('i').hide().setDefault(1000);
66
+ instances.abbrev('Q').hide().setDefault(1);
67
+ loop.abbrev('l').hide().setDefault(false);
68
+ }
69
+
70
+ void addOptions(Parser &p) {
71
+ p.addOption(instances);
72
+ p.addOption(loop);
73
+ p.addOption(iterations);
74
+ }
75
+ };
76
+
77
+ static TemplateSpec
78
+ parseTemplateSpec(const string& input)
79
+ {
80
+ TemplateSpec spec;
81
+ // Just need to find the path
82
+ size_t endpos = input.find(',');
83
+ if (endpos == string::npos) {
84
+ throw std::runtime_error("invalid template spec: need field,min,max");
85
+ }
86
+ spec.term = input.substr(0, endpos);
87
+ unsigned is_sequential = 0;
88
+ int rv = sscanf(input.c_str() + endpos + 1, "%u,%u,%u",
89
+ &spec.minval, &spec.maxval, &is_sequential);
90
+ if (rv < 2) {
91
+ throw std::runtime_error("invalid template spec: need field,min,max");
92
+ }
93
+ spec.sequential = is_sequential;
94
+ if (spec.minval > spec.maxval) {
95
+ throw std::runtime_error("min cannot be higher than max");
96
+ }
97
+ return spec;
98
+ }
99
+
100
+ class Configuration
101
+ {
102
+ public:
103
+ Configuration() :
104
+ o_multiSize("batch-size"),
105
+ o_numItems("num-items"),
106
+ o_keyPrefix("key-prefix"),
107
+ o_numThreads("num-threads"),
108
+ o_randSeed("random-seed"),
109
+ o_randomBody("random-body"),
110
+ o_setPercent("set-pct"),
111
+ o_minSize("min-size"),
112
+ o_maxSize("max-size"),
113
+ o_noPopulate("no-population"),
114
+ o_pauseAtEnd("pause-at-end"),
115
+ o_numCycles("num-cycles"),
116
+ o_sequential("sequential"),
117
+ o_startAt("start-at"),
118
+ o_rateLimit("rate-limit"),
119
+ o_userdocs("docs"),
120
+ o_writeJson("json"),
121
+ o_templatePairs("template"),
122
+ o_subdoc("subdoc"),
123
+ o_noop("noop"),
124
+ o_sdPathCount("pathcount"),
125
+ o_populateOnly("populate-only"),
126
+ o_exptime("expiry"),
127
+ o_collection("collection"),
128
+ o_separator("separator"),
129
+ o_persist("persist-to"),
130
+ o_replicate("replicate-to"),
131
+ o_lock("lock")
132
+ {
133
+ o_multiSize.setDefault(100).abbrev('B').description("Number of operations to batch");
134
+ o_numItems.setDefault(1000).abbrev('I').description("Number of items to operate on");
135
+ o_keyPrefix.abbrev('p').description("key prefix to use");
136
+ o_numThreads.setDefault(1).abbrev('t').description("The number of threads to use");
137
+ o_randSeed.setDefault(0).abbrev('s').description("Specify random seed").hide();
138
+ o_randomBody.setDefault(false).abbrev('R').description("Randomize document body (otherwise use 'x' and '*' to fill)");
139
+ o_setPercent.setDefault(33).abbrev('r').description("The percentage of operations which should be mutations");
140
+ o_minSize.setDefault(50).abbrev('m').description("Set minimum payload size");
141
+ o_maxSize.setDefault(5120).abbrev('M').description("Set maximum payload size");
142
+ o_noPopulate.setDefault(false).abbrev('n').description("Skip population");
143
+ o_pauseAtEnd.setDefault(false).abbrev('E').description("Pause at end of run (holding connections open) until user input");
144
+ o_numCycles.setDefault(-1).abbrev('c').description("Number of cycles to be run until exiting. Set to -1 to loop infinitely");
145
+ o_sequential.setDefault(false).description("Use sequential access (instead of random)");
146
+ o_startAt.setDefault(0).description("For sequential access, set the first item");
147
+ o_rateLimit.setDefault(0).description("Set operations per second limit (per thread)");
148
+ o_userdocs.description("User documents to load (overrides --min-size and --max-size");
149
+ o_writeJson.abbrev('J').description("Enable writing JSON values (rather than bytes)");
150
+ o_templatePairs.description("Values for templates to be inserted into user documents");
151
+ o_templatePairs.argdesc("FIELD,MIN,MAX[,SEQUENTIAL]").hide();
152
+ o_subdoc.description("Use subdoc instead of fulldoc operations");
153
+ o_noop.description("Use NOOP instead of document operations").setDefault(0);
154
+ o_sdPathCount.description("Number of subdoc paths per command").setDefault(1);
155
+ o_populateOnly.description("Exit after documents have been populated");
156
+ o_exptime.description("Set TTL for items").abbrev('e');
157
+ o_collection.description("Allowed collection name (could be specified multiple times)").hide();
158
+ o_separator.setDefault(":").description("Separator for collection prefix in keys").hide();
159
+ o_persist.description("Wait until item is persisted to this number of nodes (-1 for master+replicas)").setDefault(0);
160
+ o_replicate.description("Wait until item is replicated to this number of nodes (-1 for all replicas)").setDefault(0);
161
+ o_lock.description("Lock keys for updates for given time (will not lock when set to zero)").setDefault(0);
162
+ params.getTimings().description("Enable command timings (second time to dump timings automatically)");
163
+ }
164
+
165
+ void processOptions() {
166
+ opsPerCycle = o_multiSize.result();
167
+ prefix = o_keyPrefix.result();
168
+ setprc = o_setPercent.result();
169
+ shouldPopulate = !o_noPopulate.result();
170
+ persistTo = o_persist.result();
171
+ replicateTo = o_replicate.result();
172
+ lockTime = o_lock.result();
173
+ if (lockTime && o_numItems < opsPerCycle * o_numThreads) {
174
+ fprintf(stderr, "The --num-items=%d cannot be smaller than --batch-size=%d multiplied to --num-thread=%d when used with --lock=%d\n",
175
+ (int)o_numItems, (int)opsPerCycle, (int)o_numThreads, (int)lockTime);
176
+ exit(EXIT_FAILURE);
177
+ }
178
+
179
+ if (o_keyPrefix.passed() && o_collection.passed()) {
180
+ throw std::runtime_error("The --collection is not compatible with --key-prefix");
181
+ }
182
+ if (depr.loop.passed()) {
183
+ fprintf(stderr, "The --loop/-l option is deprecated. Use --num-cycles\n");
184
+ maxCycles = -1;
185
+ } else {
186
+ maxCycles = o_numCycles.result();
187
+ }
188
+
189
+ if (o_populateOnly.passed()) {
190
+ // Determine how many iterations are required.
191
+ if (o_numCycles.passed()) {
192
+ throw std::runtime_error("--num-cycles incompatible with --populate-only");
193
+ }
194
+ size_t est = (o_numItems / o_numThreads) / o_multiSize;
195
+ while (est * o_numThreads * o_multiSize < o_numItems) {
196
+ est++;
197
+ }
198
+ maxCycles = est;
199
+ o_sequential.setDefault(true);
200
+ fprintf(stderr, "Populating using %d cycles\n", maxCycles);
201
+ }
202
+
203
+ if (depr.iterations.passed()) {
204
+ fprintf(stderr, "The --num-iterations/-I option is deprecated. Use --batch-size\n");
205
+ opsPerCycle = depr.iterations.result();
206
+ }
207
+
208
+ vector<TemplateSpec> specs;
209
+ vector<string> userdocs;
210
+
211
+ if (o_templatePairs.passed()) {
212
+ vector<string> specs_str = o_templatePairs.result();
213
+ for (size_t ii = 0; ii < specs_str.size(); ii++) {
214
+ specs.push_back(parseTemplateSpec(specs_str[ii]));
215
+ }
216
+ }
217
+
218
+ // Set the document sizes..
219
+ if (o_userdocs.passed()) {
220
+ if (o_minSize.passed() || o_maxSize.passed()) {
221
+ fprintf(stderr, "--min-size/--max-size invalid with userdocs\n");
222
+ }
223
+
224
+ vector<string> filenames = o_userdocs.result();
225
+ for (size_t ii = 0; ii < filenames.size(); ii++) {
226
+ std::stringstream ss;
227
+ std::ifstream ifs(filenames[ii].c_str());
228
+ if (!ifs.is_open()) {
229
+ perror(filenames[ii].c_str());
230
+ exit(EXIT_FAILURE);
231
+ }
232
+ ss << ifs.rdbuf();
233
+ userdocs.push_back(ss.str());
234
+ }
235
+ }
236
+
237
+ if (specs.empty()) {
238
+ if (o_writeJson.result()) {
239
+ docgen = new JsonDocGenerator(o_minSize.result(), o_maxSize.result(), o_randomBody.numSpecified());
240
+ } else if (!userdocs.empty()) {
241
+ docgen = new PresetDocGenerator(userdocs);
242
+ } else {
243
+ docgen = new RawDocGenerator(o_minSize.result(), o_maxSize.result(), o_randomBody.numSpecified());
244
+ }
245
+ } else {
246
+ if (o_writeJson.result()) {
247
+ if (userdocs.empty()) {
248
+ docgen = new PlaceholderJsonGenerator(
249
+ o_minSize.result(), o_maxSize.result(), specs, o_randomBody.numSpecified());
250
+ } else {
251
+ docgen = new PlaceholderJsonGenerator(userdocs, specs);
252
+ }
253
+ } else {
254
+ if (userdocs.empty()) {
255
+ throw std::runtime_error("Must provide documents with placeholders!");
256
+ }
257
+ docgen = new PlaceholderDocGenerator(userdocs, specs);
258
+ }
259
+ }
260
+
261
+ sdOpsPerCmd = o_sdPathCount.result();
262
+ if (o_sdPathCount.passed()) {
263
+ o_subdoc.setDefault(true);
264
+ }
265
+
266
+ if (o_collection.passed()) {
267
+ string separator = o_separator.result();
268
+ if (separator.empty()) {
269
+ throw std::runtime_error("Collection name separator must not be empty");
270
+ }
271
+ vector<string> names = o_collection.result();
272
+ for (size_t ii = 0; ii < names.size(); ii++) {
273
+ collections.push_back(names[ii] + separator);
274
+ }
275
+ }
276
+ }
277
+
278
+ void addOptions(Parser& parser) {
279
+ parser.addOption(o_multiSize);
280
+ parser.addOption(o_numItems);
281
+ parser.addOption(o_keyPrefix);
282
+ parser.addOption(o_numThreads);
283
+ parser.addOption(o_randSeed);
284
+ parser.addOption(o_randomBody);
285
+ parser.addOption(o_setPercent);
286
+ parser.addOption(o_noPopulate);
287
+ parser.addOption(o_minSize);
288
+ parser.addOption(o_maxSize);
289
+ parser.addOption(o_pauseAtEnd);
290
+ parser.addOption(o_numCycles);
291
+ parser.addOption(o_sequential);
292
+ parser.addOption(o_startAt);
293
+ parser.addOption(o_rateLimit);
294
+ parser.addOption(o_userdocs);
295
+ parser.addOption(o_writeJson);
296
+ parser.addOption(o_templatePairs);
297
+ parser.addOption(o_subdoc);
298
+ parser.addOption(o_noop);
299
+ parser.addOption(o_sdPathCount);
300
+ parser.addOption(o_populateOnly);
301
+ parser.addOption(o_exptime);
302
+ parser.addOption(o_collection);
303
+ parser.addOption(o_separator);
304
+ parser.addOption(o_persist);
305
+ parser.addOption(o_replicate);
306
+ parser.addOption(o_lock);
307
+ params.addToParser(parser);
308
+ depr.addOptions(parser);
309
+ }
310
+
311
+ int numTimings(void) { return params.numTimings(); }
312
+
313
+ bool isLoopDone(size_t niter) {
314
+ if (maxCycles == -1) {
315
+ return false;
316
+ }
317
+ return niter >= (size_t)maxCycles;
318
+ }
319
+
320
+ uint32_t getRandomSeed() { return o_randSeed; }
321
+ uint32_t getNumThreads() { return o_numThreads; }
322
+ string& getKeyPrefix() { return prefix; }
323
+ bool shouldPauseAtEnd() { return o_pauseAtEnd; }
324
+ bool sequentialAccess() { return o_sequential; }
325
+ bool isSubdoc() { return o_subdoc; }
326
+ bool isNoop() { return o_noop.result(); }
327
+ bool useCollections() { return o_collection.passed(); }
328
+ bool writeJson() { return o_writeJson.result(); }
329
+ unsigned firstKeyOffset() { return o_startAt; }
330
+ uint32_t getNumItems() { return o_numItems; }
331
+ uint32_t getRateLimit() { return o_rateLimit; }
332
+ unsigned getExptime() { return o_exptime; }
333
+
334
+ uint32_t opsPerCycle;
335
+ uint32_t sdOpsPerCmd;
336
+ unsigned setprc;
337
+ string prefix;
338
+ volatile int maxCycles;
339
+ bool shouldPopulate;
340
+ bool hasTemplates;
341
+ ConnParams params;
342
+ const DocGeneratorBase *docgen;
343
+ vector<string> collections;
344
+ int replicateTo;
345
+ int persistTo;
346
+ int lockTime;
347
+
348
+ private:
349
+ UIntOption o_multiSize;
350
+ UIntOption o_numItems;
351
+ StringOption o_keyPrefix;
352
+ UIntOption o_numThreads;
353
+ UIntOption o_randSeed;
354
+ BoolOption o_randomBody;
355
+ UIntOption o_setPercent;
356
+ UIntOption o_minSize;
357
+ UIntOption o_maxSize;
358
+ BoolOption o_noPopulate;
359
+ BoolOption o_pauseAtEnd; // Should pillowfight pause execution (with
360
+ // connections open) before exiting?
361
+ IntOption o_numCycles;
362
+ BoolOption o_sequential;
363
+ UIntOption o_startAt;
364
+ UIntOption o_rateLimit;
365
+
366
+ // List of paths to user documents to load.. They should all be valid JSON
367
+ ListOption o_userdocs;
368
+
369
+ // Whether generated values should be JSON
370
+ BoolOption o_writeJson;
371
+
372
+ // List of template ranges for value generation
373
+ ListOption o_templatePairs;
374
+ BoolOption o_subdoc;
375
+ BoolOption o_noop;
376
+ UIntOption o_sdPathCount;
377
+
378
+ // Compound option
379
+ BoolOption o_populateOnly;
380
+
381
+ UIntOption o_exptime;
382
+
383
+ ListOption o_collection;
384
+ StringOption o_separator;
385
+ IntOption o_persist;
386
+ IntOption o_replicate;
387
+
388
+ IntOption o_lock;
389
+ DeprecatedOptions depr;
390
+ } config;
391
+
392
+ void log(const char *format, ...)
393
+ {
394
+ char buffer[512];
395
+ va_list args;
396
+
397
+ va_start(args, format);
398
+ vsprintf(buffer, format, args);
399
+ if (config.numTimings() > 0) {
400
+ std::cerr << "[" << std::fixed << lcb_nstime() / 1000000000.0 << "] ";
401
+ }
402
+ std::cerr << buffer << std::endl;
403
+ va_end(args);
404
+ }
405
+
406
+
407
+
408
+ extern "C" {
409
+ static void operationCallback(lcb_t, int, const lcb_RESPBASE*);
410
+ static void storeCallback(lcb_t, int, const lcb_RESPBASE *);
411
+ }
412
+
413
+ class ThreadContext;
414
+
415
+ class InstanceCookie {
416
+ public:
417
+ InstanceCookie(lcb_t instance) {
418
+ lcb_set_cookie(instance, this);
419
+ lastPrint = 0;
420
+ if (config.numTimings() > 0) {
421
+ hg.install(instance, stdout);
422
+ }
423
+ stats.total = 0;
424
+ stats.retried = 0;
425
+ stats.etmpfail = 0;
426
+ stats.eexist = 0;
427
+ stats.etimeout = 0;
428
+ }
429
+
430
+ static InstanceCookie* get(lcb_t instance) {
431
+ return (InstanceCookie *)lcb_get_cookie(instance);
432
+ }
433
+
434
+
435
+ static void dumpTimings(lcb_t instance, const char *header = NULL, bool force=false) {
436
+ time_t now = time(NULL);
437
+ InstanceCookie *ic = get(instance);
438
+
439
+ if (now - ic->lastPrint > 0) {
440
+ ic->lastPrint = now;
441
+ } else if (!force) {
442
+ return;
443
+ }
444
+
445
+ Histogram &h = ic->hg;
446
+ if (header) {
447
+ printf("[%f %s]\n", lcb_nstime() / 1000000000.0, header);
448
+ }
449
+ printf(" +---------+---------+---------+---------+\n");
450
+ h.write();
451
+ printf(" +----------------------------------------\n");
452
+ }
453
+
454
+ void setContext(ThreadContext *context) {
455
+ m_context = context;
456
+ }
457
+
458
+ ThreadContext * getContext() {
459
+ return m_context;
460
+ }
461
+
462
+ struct {
463
+ size_t total;
464
+ size_t retried;
465
+ size_t etmpfail;
466
+ size_t eexist;
467
+ size_t etimeout;
468
+ } stats;
469
+ private:
470
+ time_t lastPrint;
471
+ Histogram hg;
472
+ ThreadContext *m_context;
473
+ };
474
+
475
+ struct NextOp {
476
+ NextOp() : m_seqno(0), m_mode(GET), m_cas(0) {}
477
+
478
+ string m_key;
479
+ uint32_t m_seqno;
480
+ vector<lcb_IOV> m_valuefrags;
481
+ vector<lcb_SDSPEC> m_specs;
482
+ // The mode here is for future use with subdoc
483
+ enum Mode { STORE, GET, SDSTORE, SDGET, NOOP };
484
+ Mode m_mode;
485
+ uint64_t m_cas;
486
+ };
487
+
488
+ class OpGenerator {
489
+ public:
490
+ OpGenerator(int id): m_id(id) {}
491
+
492
+ virtual ~OpGenerator() {};
493
+ virtual void setNextOp(NextOp& op) = 0;
494
+ virtual void setValue(NextOp& op) = 0;
495
+ virtual void populateIov(uint32_t, vector<lcb_IOV>&) = 0;
496
+ virtual bool inPopulation() const = 0;
497
+ virtual void checkin(uint32_t) = 0;
498
+ virtual const char *getStageString() const = 0;
499
+
500
+ protected:
501
+ int m_id;
502
+ };
503
+
504
+ class NoopGenerator : public OpGenerator {
505
+ public:
506
+ NoopGenerator(int ix) : OpGenerator(ix) {}
507
+
508
+
509
+ void setNextOp(NextOp& op) {
510
+ op.m_mode = NextOp::NOOP;
511
+ }
512
+
513
+ void setValue(NextOp&) {}
514
+ void populateIov(uint32_t, vector<lcb_IOV>&) {}
515
+
516
+ bool inPopulation() const {
517
+ return false;
518
+ }
519
+
520
+ void checkin(uint32_t) {}
521
+
522
+ const char *getStageString() const {
523
+ return "Run";
524
+ }
525
+ };
526
+
527
+ /** Stateful, per-thread generator */
528
+ class KeyGenerator : public OpGenerator {
529
+ public:
530
+ KeyGenerator(int ix)
531
+ : OpGenerator(ix), m_gencount(0), m_force_sequential(false),
532
+ m_in_population(config.shouldPopulate)
533
+ {
534
+ srand(config.getRandomSeed());
535
+
536
+ m_genrandom = new SeqGenerator(
537
+ config.firstKeyOffset(),
538
+ config.getNumItems() + config.firstKeyOffset());
539
+
540
+ m_gensequence = new SeqGenerator(
541
+ config.firstKeyOffset(),
542
+ config.getNumItems() + config.firstKeyOffset(),
543
+ config.getNumThreads(),
544
+ ix);
545
+
546
+ if (m_in_population) {
547
+ m_force_sequential = true;
548
+ } else {
549
+ m_force_sequential = config.sequentialAccess();
550
+ }
551
+
552
+ m_local_genstate = config.docgen->createState(config.getNumThreads(), ix);
553
+ if (config.isSubdoc()) {
554
+ m_mode_read = NextOp::SDGET;
555
+ m_mode_write = NextOp::SDSTORE;
556
+ m_sdgenstate = config.docgen->createSubdocState(config.getNumThreads(), ix);
557
+ if (!m_sdgenstate) {
558
+ std::cerr << "Current generator does not support subdoc. Did you try --json?" << std::endl;
559
+ exit(EXIT_FAILURE);
560
+ }
561
+ } else {
562
+ m_mode_read = NextOp::GET;
563
+ m_mode_write = NextOp::STORE;
564
+ }
565
+ }
566
+
567
+ void setValue(NextOp& op) {
568
+ m_local_genstate->populateIov(op.m_seqno, op.m_valuefrags);
569
+ }
570
+
571
+ void populateIov(uint32_t seq, vector<lcb_IOV>& iov_out) {
572
+ m_local_genstate->populateIov(seq, iov_out);
573
+ }
574
+
575
+ void setNextOp(NextOp& op) {
576
+ bool store_override = false;
577
+
578
+ if (m_in_population) {
579
+ if (m_gencount++ < m_gensequence->maxItems()) {
580
+ store_override = true;
581
+ } else {
582
+ printf("Thread %d has finished populating.\n", m_id);
583
+ m_in_population = false;
584
+ m_force_sequential = config.sequentialAccess();
585
+ }
586
+ }
587
+
588
+ if (m_in_population || !config.lockTime) {
589
+ op.m_seqno = (m_force_sequential ? m_gensequence : m_genrandom)->next();
590
+ } else {
591
+ op.m_seqno = (m_force_sequential ? m_gensequence : m_genrandom)->checkout();
592
+ }
593
+
594
+ if (store_override) {
595
+ // Populate
596
+ op.m_mode = NextOp::STORE;
597
+ setValue(op);
598
+
599
+ } else if (shouldStore(op.m_seqno)) {
600
+ op.m_mode = m_mode_write;
601
+ if (op.m_mode == NextOp::STORE) {
602
+ setValue(op);
603
+ } else if (op.m_mode == NextOp::SDSTORE) {
604
+ op.m_specs.resize(config.sdOpsPerCmd);
605
+ m_sdgenstate->populateMutate(op.m_seqno, op.m_specs);
606
+ } else {
607
+ fprintf(stderr, "Invalid mode for op: %d\n", op.m_mode);
608
+ abort();
609
+ }
610
+ } else {
611
+ op.m_mode = m_mode_read;
612
+ if (op.m_mode == NextOp::SDGET) {
613
+ op.m_specs.resize(config.sdOpsPerCmd);
614
+ m_sdgenstate->populateLookup(op.m_seqno, op.m_specs);
615
+ }
616
+ }
617
+
618
+ generateKey(op);
619
+ }
620
+
621
+ bool inPopulation() const {
622
+ return m_in_population;
623
+ }
624
+
625
+ void checkin(uint32_t seqno) {
626
+ (m_force_sequential ? m_gensequence : m_genrandom)->checkin(seqno);
627
+ }
628
+
629
+ const char *getStageString() const {
630
+ if (m_in_population) {
631
+ return "Populate";
632
+ } else {
633
+ return "Run";
634
+ }
635
+ }
636
+
637
+ private:
638
+ bool shouldStore(uint32_t seqno) {
639
+ if (config.setprc == 0) {
640
+ return false;
641
+ }
642
+
643
+ float seqno_f = seqno % 100;
644
+ float pct_f = seqno_f / config.setprc;
645
+ return pct_f < 1;
646
+ }
647
+
648
+ void generateKey(NextOp& op) {
649
+ uint32_t seqno = op.m_seqno;
650
+ char buffer[21];
651
+ snprintf(buffer, sizeof(buffer), "%020d", seqno);
652
+ string &prefix = config.useCollections()
653
+ ? config.collections[seqno % config.collections.size()]
654
+ : config.getKeyPrefix();
655
+ op.m_key.assign(prefix + buffer);
656
+ }
657
+
658
+
659
+ SeqGenerator *m_genrandom;
660
+ SeqGenerator *m_gensequence;
661
+ size_t m_gencount;
662
+
663
+ bool m_force_sequential;
664
+ bool m_in_population;
665
+ NextOp::Mode m_mode_read;
666
+ NextOp::Mode m_mode_write;
667
+ GeneratorState *m_local_genstate;
668
+ SubdocGeneratorState *m_sdgenstate;
669
+ };
670
+
671
+ #define OPFLAGS_LOCKED 0x01
672
+
673
+ class ThreadContext
674
+ {
675
+ public:
676
+ ThreadContext(lcb_t handle, int ix) : niter(0), instance(handle) {
677
+ if (config.isNoop()) {
678
+ gen = new NoopGenerator(ix);
679
+ } else {
680
+ gen = new KeyGenerator(ix);
681
+ }
682
+ }
683
+
684
+ ~ThreadContext() {
685
+ delete gen;
686
+ gen = NULL;
687
+ }
688
+
689
+ bool inPopulation() {
690
+ return gen && (gen->inPopulation() || !retryq.empty());
691
+ }
692
+
693
+ void checkin(uint32_t seqno) {
694
+ if (gen) {
695
+ gen->checkin(seqno);
696
+ }
697
+ }
698
+
699
+ void singleLoop() {
700
+ bool hasItems = false;
701
+
702
+ lcb_sched_enter(instance);
703
+ for (size_t ii = 0; ii < config.opsPerCycle; ++ii) {
704
+ hasItems = scheduleNextOperation();
705
+ }
706
+ if (hasItems) {
707
+ error = LCB_SUCCESS;
708
+ lcb_sched_leave(instance);
709
+ lcb_wait(instance);
710
+ } else {
711
+ lcb_sched_fail(instance);
712
+ }
713
+ purgeRetryQueue();
714
+ }
715
+
716
+ void purgeRetryQueue() {
717
+ NextOp opinfo;
718
+ InstanceCookie *cookie = InstanceCookie::get(instance);
719
+
720
+ while (!retryq.empty()) {
721
+ unsigned exptime = config.getExptime();
722
+ lcb_sched_enter(instance);
723
+ while (!retryq.empty()) {
724
+ opinfo = retryq.front();
725
+ retryq.pop();
726
+ lcb_CMDSTOREDUR scmd = { 0 };
727
+ scmd.operation = LCB_SET;
728
+ scmd.exptime = exptime;
729
+ LCB_CMD_SET_KEY(&scmd, opinfo.m_key.c_str(), opinfo.m_key.size());
730
+ LCB_CMD_SET_VALUEIOV(&scmd, &opinfo.m_valuefrags[0], opinfo.m_valuefrags.size());
731
+ if (config.persistTo > 0 || config.replicateTo > 0) {
732
+ scmd.persist_to = config.persistTo;
733
+ scmd.replicate_to = config.replicateTo;
734
+ error = lcb_storedur3(instance, NULL, &scmd);
735
+ } else {
736
+ error = lcb_store3(instance, NULL, reinterpret_cast<lcb_CMDSTORE*>(&scmd));
737
+ }
738
+ cookie->stats.retried++;
739
+ }
740
+ lcb_sched_leave(instance);
741
+ lcb_wait(instance);
742
+ if (error != LCB_SUCCESS) {
743
+ log("Operation(s) failed: [0x%x] %s", error, lcb_strerror(instance, error));
744
+ }
745
+ }
746
+ }
747
+
748
+ bool scheduleNextOperation()
749
+ {
750
+ NextOp opinfo;
751
+ unsigned exptime = config.getExptime();
752
+ gen->setNextOp(opinfo);
753
+
754
+ switch (opinfo.m_mode) {
755
+ case NextOp::STORE: {
756
+ if (!gen->inPopulation() && config.lockTime > 0) {
757
+ lcb_CMDGET gcmd = { 0 };
758
+ LCB_CMD_SET_KEY(&gcmd, opinfo.m_key.c_str(), opinfo.m_key.size());
759
+ gcmd.lock = config.lockTime;
760
+ error = lcb_get3(instance, (void *)OPFLAGS_LOCKED, &gcmd);
761
+ } else {
762
+ lcb_CMDSTOREDUR scmd = { 0 };
763
+ scmd.operation = LCB_SET;
764
+ scmd.exptime = exptime;
765
+ if (config.writeJson()) {
766
+ scmd.datatype = LCB_VALUE_F_JSON;
767
+ }
768
+ LCB_CMD_SET_KEY(&scmd, opinfo.m_key.c_str(), opinfo.m_key.size());
769
+ LCB_CMD_SET_VALUEIOV(&scmd, &opinfo.m_valuefrags[0], opinfo.m_valuefrags.size());
770
+ if (config.persistTo > 0 || config.replicateTo > 0) {
771
+ scmd.persist_to = config.persistTo;
772
+ scmd.replicate_to = config.replicateTo;
773
+ error = lcb_storedur3(instance, NULL, &scmd);
774
+ } else {
775
+ error = lcb_store3(instance, NULL, reinterpret_cast<lcb_CMDSTORE*>(&scmd));
776
+ }
777
+ }
778
+ break;
779
+ }
780
+ case NextOp::GET: {
781
+ lcb_CMDGET gcmd = { 0 };
782
+ LCB_CMD_SET_KEY(&gcmd, opinfo.m_key.c_str(), opinfo.m_key.size());
783
+ gcmd.exptime = exptime;
784
+ error = lcb_get3(instance, this, &gcmd);
785
+ break;
786
+ }
787
+ case NextOp::SDSTORE:
788
+ case NextOp::SDGET: {
789
+ lcb_CMDSUBDOC sdcmd = { 0 };
790
+ if (opinfo.m_mode == NextOp::SDSTORE) {
791
+ sdcmd.exptime = exptime;
792
+ }
793
+ LCB_CMD_SET_KEY(&sdcmd, opinfo.m_key.c_str(), opinfo.m_key.size());
794
+ sdcmd.specs = &opinfo.m_specs[0];
795
+ sdcmd.nspecs = opinfo.m_specs.size();
796
+ error = lcb_subdoc3(instance, NULL, &sdcmd);
797
+ break;
798
+ }
799
+ case NextOp::NOOP: {
800
+ lcb_CMDNOOP ncmd = { 0 };
801
+ error = lcb_noop3(instance, NULL, &ncmd);
802
+ break;
803
+ }
804
+ }
805
+
806
+ if (error != LCB_SUCCESS) {
807
+ log("Failed to schedule operation: [0x%x] %s", error, lcb_strerror(instance, error));
808
+ return false;
809
+ } else {
810
+ return true;
811
+ }
812
+ }
813
+
814
+ bool run() {
815
+ do {
816
+ singleLoop();
817
+
818
+ if (config.numTimings() > 1) {
819
+ InstanceCookie::dumpTimings(instance, gen->getStageString());
820
+ }
821
+ if (config.params.shouldDump()) {
822
+ lcb_dump(instance, stderr, LCB_DUMP_ALL);
823
+ }
824
+ if (config.getRateLimit() > 0) {
825
+ rateLimitThrottle();
826
+ }
827
+
828
+ } while (!config.isLoopDone(++niter));
829
+
830
+ if (config.numTimings() > 1) {
831
+ InstanceCookie::dumpTimings(instance, gen->getStageString(), true);
832
+ }
833
+ return true;
834
+ }
835
+
836
+ void retry(NextOp &op) {
837
+ if (op.m_mode == NextOp::STORE) {
838
+ gen->setValue(op);
839
+ }
840
+ retryq.push(op);
841
+ }
842
+
843
+ void populateIov(uint32_t seq, vector<lcb_IOV>& iov_out)
844
+ {
845
+ gen->populateIov(seq, iov_out);
846
+ }
847
+
848
+
849
+ #ifndef WIN32
850
+ pthread_t thr;
851
+ #endif
852
+
853
+ lcb_t getInstance() {
854
+ return instance;
855
+ }
856
+
857
+ protected:
858
+ // the callback methods needs to be able to set the error handler..
859
+ friend void operationCallback(lcb_t, int, const lcb_RESPBASE*);
860
+ friend void storeCallback(lcb_t, int, const lcb_RESPBASE *);
861
+
862
+ Histogram histogram;
863
+
864
+ void setError(lcb_error_t e) { error = e; }
865
+
866
+ private:
867
+
868
+ void rateLimitThrottle() {
869
+ lcb_U64 now = lcb_nstime();
870
+ static lcb_U64 previous_time = now;
871
+
872
+ const lcb_U64 elapsed_ns = now - previous_time;
873
+ const lcb_U64 wanted_duration_ns =
874
+ (config.getNumThreads() * config.opsPerCycle * 1e9) / config.getRateLimit();
875
+ // On first invocation no previous_time, so skip attempting to sleep.
876
+ if (elapsed_ns > 0 && elapsed_ns < wanted_duration_ns) {
877
+ // Dampen the sleep time by averaging with the previous
878
+ // sleep time.
879
+ static lcb_U64 last_sleep_ns = 0;
880
+ const lcb_U64 sleep_ns =
881
+ (last_sleep_ns + wanted_duration_ns - elapsed_ns) / 2;
882
+ usleep(sleep_ns / 1000);
883
+ now += sleep_ns;
884
+ last_sleep_ns = sleep_ns;
885
+ }
886
+ previous_time = now;
887
+ }
888
+
889
+ OpGenerator *gen;
890
+ size_t niter;
891
+ lcb_error_t error;
892
+ lcb_t instance;
893
+ std::queue<NextOp> retryq;
894
+ };
895
+
896
+ static void updateOpsPerSecDisplay()
897
+ {
898
+
899
+ static time_t start_time = time(NULL);
900
+ static int is_tty =
901
+ #ifdef WIN32
902
+ 0;
903
+ #else
904
+ isatty(STDERR_FILENO);
905
+ #endif
906
+ static volatile unsigned long nops = 0;
907
+ time_t now = time(NULL);
908
+ time_t nsecs = now - start_time;
909
+ if (!nsecs) { nsecs = 1; }
910
+ unsigned long ops_sec = nops / nsecs;
911
+ if (++nops % 10000 == 0) {
912
+ fprintf(stderr, "OPS/SEC: %10lu%c", ops_sec, is_tty ? '\r' : '\n');
913
+ }
914
+ }
915
+
916
+ static void updateStats(InstanceCookie *cookie, lcb_error_t rc)
917
+ {
918
+ cookie->stats.total++;
919
+ switch (rc) {
920
+ case LCB_ETMPFAIL:
921
+ cookie->stats.etmpfail++;
922
+ break;
923
+ case LCB_KEY_EEXISTS:
924
+ cookie->stats.eexist++;
925
+ break;
926
+ case LCB_ETIMEDOUT:
927
+ cookie->stats.etimeout++;
928
+ break;
929
+ default:
930
+ break;
931
+ }
932
+ }
933
+
934
+ static void operationCallback(lcb_t instance, int cbtype, const lcb_RESPBASE *resp)
935
+ {
936
+ InstanceCookie *cookie = InstanceCookie::get(instance);
937
+ ThreadContext *tc = cookie->getContext();
938
+ tc->setError(resp->rc);
939
+ updateStats(cookie, resp->rc);
940
+
941
+ uintptr_t flags = 0;
942
+ if (resp->cookie) {
943
+ flags = (uintptr_t)resp->cookie;
944
+ }
945
+ bool done = true;
946
+ string key((const char*)resp->key, resp->nkey);
947
+ uint32_t seqno = atoi(key.c_str());
948
+ if (cbtype == LCB_CALLBACK_GET && (flags & OPFLAGS_LOCKED)) {
949
+ if (resp->rc == LCB_SUCCESS) {
950
+ lcb_CMDSTOREDUR scmd = { 0 };
951
+ vector<lcb_IOV> valuefrags;
952
+ scmd.operation = LCB_SET;
953
+ scmd.exptime = config.getExptime();
954
+ scmd.cas = resp->cas;
955
+ tc->populateIov(seqno, valuefrags);
956
+ LCB_CMD_SET_KEY(&scmd, resp->key, resp->nkey);
957
+ LCB_CMD_SET_VALUEIOV(&scmd, &valuefrags[0], valuefrags.size());
958
+ if (config.persistTo > 0 || config.replicateTo > 0) {
959
+ scmd.persist_to = config.persistTo;
960
+ scmd.replicate_to = config.replicateTo;
961
+ lcb_storedur3(instance, NULL, &scmd);
962
+ } else {
963
+ lcb_store3(instance, NULL, reinterpret_cast<lcb_CMDSTORE*>(&scmd));
964
+ }
965
+ done = false;
966
+ } else if (resp->rc == LCB_ETMPFAIL) {
967
+ NextOp op;
968
+ op.m_mode = NextOp::STORE;
969
+ op.m_key = key;
970
+ op.m_seqno = seqno;
971
+ tc->retry(op);
972
+ done = false;
973
+ }
974
+ }
975
+
976
+ if (done) {
977
+ tc->checkin(seqno);
978
+ }
979
+ updateOpsPerSecDisplay();
980
+ }
981
+
982
+ static void storeCallback(lcb_t instance, int, const lcb_RESPBASE *resp)
983
+ {
984
+ InstanceCookie *cookie = InstanceCookie::get(instance);
985
+ ThreadContext *tc = cookie->getContext();
986
+ tc->setError(resp->rc);
987
+ updateStats(cookie, resp->rc);
988
+
989
+ string key((const char*)resp->key, resp->nkey);
990
+ uint32_t seqno = atoi(key.c_str());
991
+ if (resp->rc != LCB_SUCCESS && tc->inPopulation()) {
992
+ NextOp op;
993
+ op.m_mode = NextOp::STORE;
994
+ op.m_key = key;
995
+ op.m_seqno = seqno;
996
+ tc->retry(op);
997
+ } else {
998
+ tc->checkin(seqno);
999
+ }
1000
+
1001
+ updateOpsPerSecDisplay();
1002
+ }
1003
+
1004
+ std::list<ThreadContext *> contexts;
1005
+
1006
+ extern "C" {
1007
+ typedef void (*handler_t)(int);
1008
+
1009
+ static void dump_metrics(void)
1010
+ {
1011
+ std::list<ThreadContext *>::iterator it;
1012
+ for (it = contexts.begin(); it != contexts.end(); ++it) {
1013
+ lcb_t instance = (*it)->getInstance();
1014
+ lcb_CMDDIAG req = {};
1015
+ req.options = LCB_PINGOPT_F_JSONPRETTY;
1016
+ lcb_diag(instance, NULL, &req);
1017
+ if (config.numTimings() > 0) {
1018
+ InstanceCookie::dumpTimings(instance);
1019
+ }
1020
+ }
1021
+ }
1022
+
1023
+ #ifndef WIN32
1024
+ static void diag_callback(lcb_t instance, int, const lcb_RESPBASE *rb)
1025
+ {
1026
+ const lcb_RESPDIAG *resp = (const lcb_RESPDIAG *)rb;
1027
+ if (resp->rc != LCB_SUCCESS) {
1028
+ fprintf(stderr, "%p, diag failed: %s\n", (void *)instance, lcb_strerror(NULL, resp->rc));
1029
+ } else {
1030
+ if (resp->njson) {
1031
+ fprintf(stderr, "\n%.*s", (int)resp->njson, resp->json);
1032
+ }
1033
+
1034
+ {
1035
+ InstanceCookie *cookie = InstanceCookie::get(instance);
1036
+ lcb_METRICS* metrics;
1037
+ size_t ii;
1038
+ lcb_cntl(instance, LCB_CNTL_GET, LCB_CNTL_METRICS, &metrics);
1039
+
1040
+ fprintf(stderr, "%p: total: %lu, etmpfail: %lu, eexist: %lu, etimeout: %lu, retried: %lu, rq: %lu\n",
1041
+ (void *)instance,
1042
+ (unsigned long)cookie->stats.total,
1043
+ (unsigned long)cookie->stats.etmpfail,
1044
+ (unsigned long)cookie->stats.eexist,
1045
+ (unsigned long)cookie->stats.etimeout,
1046
+ (unsigned long)cookie->stats.retried,
1047
+ (unsigned long)metrics->packets_retried);
1048
+ for (ii = 0; ii < metrics->nservers; ii++) {
1049
+ fprintf(stderr, " [srv-%d] snt: %lu, rcv: %lu, q: %lu, err: %lu, tmo: %lu, nmv: %lu, orph: %lu\n",
1050
+ (int)ii,
1051
+ (unsigned long)metrics->servers[ii]->packets_sent,
1052
+ (unsigned long)metrics->servers[ii]->packets_read,
1053
+ (unsigned long)metrics->servers[ii]->packets_queued,
1054
+ (unsigned long)metrics->servers[ii]->packets_errored,
1055
+ (unsigned long)metrics->servers[ii]->packets_timeout,
1056
+ (unsigned long)metrics->servers[ii]->packets_nmv,
1057
+ (unsigned long)metrics->servers[ii]->packets_ownerless);
1058
+ }
1059
+ }
1060
+ }
1061
+ }
1062
+
1063
+ static void sigquit_handler(int)
1064
+ {
1065
+ dump_metrics();
1066
+ signal(SIGQUIT, sigquit_handler); // Reinstall
1067
+ }
1068
+
1069
+ static void setup_sigquit_handler()
1070
+ {
1071
+ struct sigaction action;
1072
+ sigemptyset(&action.sa_mask);
1073
+ action.sa_handler = sigquit_handler;
1074
+ action.sa_flags = 0;
1075
+ sigaction(SIGQUIT, &action, NULL);
1076
+ }
1077
+
1078
+ static void sigint_handler(int)
1079
+ {
1080
+ static int ncalled = 0;
1081
+ ncalled++;
1082
+
1083
+ if (ncalled < 2) {
1084
+ log("\nTermination requested. Waiting threads to finish. Ctrl-C to force termination.");
1085
+ signal(SIGINT, sigint_handler); // Reinstall
1086
+ config.maxCycles = 0;
1087
+ return;
1088
+ }
1089
+
1090
+ std::list<ThreadContext *>::iterator it;
1091
+ for (it = contexts.begin(); it != contexts.end(); ++it) {
1092
+ delete *it;
1093
+ }
1094
+ contexts.clear();
1095
+ exit(EXIT_FAILURE);
1096
+ }
1097
+
1098
+ static void setup_sigint_handler()
1099
+ {
1100
+ struct sigaction action;
1101
+ sigemptyset(&action.sa_mask);
1102
+ action.sa_handler = sigint_handler;
1103
+ action.sa_flags = 0;
1104
+ sigaction(SIGINT, &action, NULL);
1105
+ }
1106
+
1107
+ static void* thread_worker(void*);
1108
+
1109
+ static void start_worker(ThreadContext *ctx)
1110
+ {
1111
+ pthread_attr_t attr;
1112
+ pthread_attr_init(&attr);
1113
+ pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
1114
+ int rc = pthread_create(&ctx->thr, &attr, thread_worker, ctx);
1115
+ if (rc != 0) {
1116
+ log("Couldn't create thread: (%d)", errno);
1117
+ exit(EXIT_FAILURE);
1118
+ }
1119
+ }
1120
+ static void join_worker(ThreadContext *ctx)
1121
+ {
1122
+ void *arg = NULL;
1123
+ int rc = pthread_join(ctx->thr, &arg);
1124
+ if (rc != 0) {
1125
+ log("Couldn't join thread (%d)", errno);
1126
+ exit(EXIT_FAILURE);
1127
+ }
1128
+ }
1129
+
1130
+ #else
1131
+ static void setup_sigquit_handler() {}
1132
+ static void setup_sigint_handler() {}
1133
+ static void start_worker(ThreadContext *ctx) { ctx->run(); }
1134
+ static void join_worker(ThreadContext *ctx) { (void)ctx; }
1135
+ #endif
1136
+
1137
+ static void *thread_worker(void *arg)
1138
+ {
1139
+ ThreadContext *ctx = static_cast<ThreadContext *>(arg);
1140
+ ctx->run();
1141
+ return NULL;
1142
+ }
1143
+ }
1144
+
1145
+ int main(int argc, char **argv)
1146
+ {
1147
+ int exit_code = EXIT_SUCCESS;
1148
+ setup_sigint_handler();
1149
+ setup_sigquit_handler();
1150
+
1151
+ Parser parser("cbc-pillowfight");
1152
+ try {
1153
+ config.addOptions(parser);
1154
+ parser.parse(argc, argv, false);
1155
+ config.processOptions();
1156
+ } catch (std::string& e) {
1157
+ std::cerr << e << std::endl;
1158
+ exit(EXIT_FAILURE);
1159
+ } catch (std::exception& e) {
1160
+ std::cerr << e.what() << std::endl;
1161
+ exit(EXIT_FAILURE);
1162
+ }
1163
+ size_t nthreads = config.getNumThreads();
1164
+ log("Running. Press Ctrl-C to terminate...");
1165
+
1166
+ #ifdef WIN32
1167
+ if (nthreads > 1) {
1168
+ log("WARNING: More than a single thread on Windows not supported. Forcing 1");
1169
+ nthreads = 1;
1170
+ }
1171
+ #endif
1172
+
1173
+ struct lcb_create_st options;
1174
+ ConnParams& cp = config.params;
1175
+ lcb_error_t error;
1176
+
1177
+ for (uint32_t ii = 0; ii < nthreads; ++ii) {
1178
+ cp.fillCropts(options);
1179
+ lcb_t instance = NULL;
1180
+ error = lcb_create(&instance, &options);
1181
+ if (error != LCB_SUCCESS) {
1182
+ log("Failed to create instance: %s", lcb_strerror(NULL, error));
1183
+ exit(EXIT_FAILURE);
1184
+ }
1185
+ lcb_install_callback3(instance, LCB_CALLBACK_STOREDUR, storeCallback);
1186
+ lcb_install_callback3(instance, LCB_CALLBACK_STORE, storeCallback);
1187
+ lcb_install_callback3(instance, LCB_CALLBACK_GET, operationCallback);
1188
+ lcb_install_callback3(instance, LCB_CALLBACK_SDMUTATE, operationCallback);
1189
+ lcb_install_callback3(instance, LCB_CALLBACK_SDLOOKUP, operationCallback);
1190
+ lcb_install_callback3(instance, LCB_CALLBACK_NOOP, operationCallback);
1191
+ #ifndef WIN32
1192
+ lcb_install_callback3(instance, LCB_CALLBACK_DIAG, diag_callback);
1193
+ {
1194
+ int activate = 1;
1195
+ lcb_cntl(instance, LCB_CNTL_SET, LCB_CNTL_METRICS, &activate);
1196
+ }
1197
+ #endif
1198
+ cp.doCtls(instance);
1199
+ if (config.useCollections()) {
1200
+ int use = 1;
1201
+ lcb_cntl(instance, LCB_CNTL_SET, LCB_CNTL_USE_COLLECTIONS, &use);
1202
+ }
1203
+
1204
+ InstanceCookie *cookie = new InstanceCookie(instance);
1205
+
1206
+ lcb_connect(instance);
1207
+ lcb_wait(instance);
1208
+ error = lcb_get_bootstrap_status(instance);
1209
+
1210
+ if (error != LCB_SUCCESS) {
1211
+ std::cout << std::endl;
1212
+ log("Failed to connect: %s", lcb_strerror(instance, error));
1213
+ exit(EXIT_FAILURE);
1214
+ }
1215
+
1216
+ ThreadContext *ctx = new ThreadContext(instance, ii);
1217
+ cookie->setContext(ctx);
1218
+ contexts.push_back(ctx);
1219
+ start_worker(ctx);
1220
+ }
1221
+
1222
+ for (std::list<ThreadContext *>::iterator it = contexts.begin();
1223
+ it != contexts.end(); ++it) {
1224
+ join_worker(*it);
1225
+ }
1226
+ if (config.numTimings() > 0) {
1227
+ dump_metrics();
1228
+ }
1229
+ return exit_code;
1230
+ }