mt-libcouchbase 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +22 -0
- data/.gitmodules +3 -0
- data/.rspec +1 -0
- data/.travis.yml +38 -0
- data/Gemfile +4 -0
- data/LICENSE +24 -0
- data/README.md +445 -0
- data/Rakefile +76 -0
- data/ext/README.md +6 -0
- data/ext/Rakefile +19 -0
- data/ext/libcouchbase/.gitignore +132 -0
- data/ext/libcouchbase/CMakeLists.txt +455 -0
- data/ext/libcouchbase/CONTRIBUTING.md +105 -0
- data/ext/libcouchbase/LICENSE +202 -0
- data/ext/libcouchbase/README.markdown +195 -0
- data/ext/libcouchbase/RELEASE_NOTES.markdown +3523 -0
- data/ext/libcouchbase/cmake/Modules/ConfigureDtrace.cmake +52 -0
- data/ext/libcouchbase/cmake/Modules/CopyPDB.cmake +42 -0
- data/ext/libcouchbase/cmake/Modules/DistScript.cmake +17 -0
- data/ext/libcouchbase/cmake/Modules/DownloadLcbDep.cmake +18 -0
- data/ext/libcouchbase/cmake/Modules/FindCouchbaseHdrHistogram.cmake +15 -0
- data/ext/libcouchbase/cmake/Modules/FindCouchbaseLibev.cmake +73 -0
- data/ext/libcouchbase/cmake/Modules/FindCouchbaseLibevent.cmake +54 -0
- data/ext/libcouchbase/cmake/Modules/FindCouchbaseLibuv.cmake +57 -0
- data/ext/libcouchbase/cmake/Modules/FindProfiler.cmake +16 -0
- data/ext/libcouchbase/cmake/Modules/GenerateConfigDotH.cmake +49 -0
- data/ext/libcouchbase/cmake/Modules/GetLibcouchbaseFlags.cmake +142 -0
- data/ext/libcouchbase/cmake/Modules/GetPlatformCCInfo.cmake +45 -0
- data/ext/libcouchbase/cmake/Modules/GetVersionInfo.cmake +70 -0
- data/ext/libcouchbase/cmake/config-cmake.h.in +80 -0
- data/ext/libcouchbase/cmake/configure +355 -0
- data/ext/libcouchbase/cmake/defs.mk.in +6 -0
- data/ext/libcouchbase/cmake/dtrace-instr-link.pl +51 -0
- data/ext/libcouchbase/cmake/libcouchbase.stp.in +829 -0
- data/ext/libcouchbase/cmake/source_files.cmake +104 -0
- data/ext/libcouchbase/contrib/cJSON/cJSON.c +1022 -0
- data/ext/libcouchbase/contrib/cJSON/cJSON.h +158 -0
- data/ext/libcouchbase/contrib/cbsasl/CMakeLists.txt +25 -0
- data/ext/libcouchbase/contrib/cbsasl/COPYING +202 -0
- data/ext/libcouchbase/contrib/cbsasl/include/cbsasl/cbsasl.h +259 -0
- data/ext/libcouchbase/contrib/cbsasl/src/client.c +419 -0
- data/ext/libcouchbase/contrib/cbsasl/src/common.c +50 -0
- data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/hmac.c +67 -0
- data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/hmac.h +33 -0
- data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/md5.c +296 -0
- data/ext/libcouchbase/contrib/cbsasl/src/cram-md5/md5.h +45 -0
- data/ext/libcouchbase/contrib/cbsasl/src/hash.c +573 -0
- data/ext/libcouchbase/contrib/cbsasl/src/hash.h +15 -0
- data/ext/libcouchbase/contrib/cbsasl/src/scram-sha/scram_utils.c +500 -0
- data/ext/libcouchbase/contrib/cbsasl/src/scram-sha/scram_utils.h +99 -0
- data/ext/libcouchbase/contrib/cbsasl/src/util.h +31 -0
- data/ext/libcouchbase/contrib/cliopts/CMakeLists.txt +2 -0
- data/ext/libcouchbase/contrib/cliopts/cliopts.c +938 -0
- data/ext/libcouchbase/contrib/cliopts/cliopts.h +610 -0
- data/ext/libcouchbase/contrib/genhash/genhash.c +371 -0
- data/ext/libcouchbase/contrib/genhash/genhash.h +241 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/CHANGES +157 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/CMakeLists.txt +252 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/CONTRIBUTORS +37 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/LICENSE +28 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/MINIFY.sh +15 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/README +435 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/cmake/internal_utils.cmake +227 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-death-test.h +294 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-message.h +250 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-param-test.h +1421 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-param-test.h.pump +487 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-printers.h +855 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-spi.h +232 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-test-part.h +179 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest-typed-test.h +259 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest.h +2291 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest_pred_impl.h +358 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/gtest_prod.h +58 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-death-test-internal.h +319 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-filepath.h +206 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-internal.h +1158 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-linked_ptr.h +233 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-param-util-generated.h +5143 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-param-util-generated.h.pump +301 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-param-util.h +619 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-port.h +1947 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-string.h +167 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-tuple.h +1012 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-tuple.h.pump +339 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-type-util.h +3331 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/include/gtest/internal/gtest-type-util.h.pump +297 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-all.cc +48 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-death-test.cc +1344 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-filepath.cc +382 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-internal-inl.h +1218 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-port.cc +805 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-printers.cc +363 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-test-part.cc +110 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest-typed-test.cc +110 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest.cc +5015 -0
- data/ext/libcouchbase/contrib/gtest-1.7.0/src/gtest_main.cc +38 -0
- data/ext/libcouchbase/contrib/http_parser/LICENSE-MIT +23 -0
- data/ext/libcouchbase/contrib/http_parser/README.md +178 -0
- data/ext/libcouchbase/contrib/http_parser/http_parser.c +2060 -0
- data/ext/libcouchbase/contrib/http_parser/http_parser.h +321 -0
- data/ext/libcouchbase/contrib/jsonsl/LICENSE +20 -0
- data/ext/libcouchbase/contrib/jsonsl/jsonsl.c +1452 -0
- data/ext/libcouchbase/contrib/jsonsl/jsonsl.h +971 -0
- data/ext/libcouchbase/contrib/lcb-jsoncpp/CMakeLists.txt +6 -0
- data/ext/libcouchbase/contrib/lcb-jsoncpp/LICENSE +55 -0
- data/ext/libcouchbase/contrib/lcb-jsoncpp/lcb-jsoncpp-forwards.h +255 -0
- data/ext/libcouchbase/contrib/lcb-jsoncpp/lcb-jsoncpp.cpp +4893 -0
- data/ext/libcouchbase/contrib/lcb-jsoncpp/lcb-jsoncpp.h +1961 -0
- data/ext/libcouchbase/contrib/snappy/CMakeLists.txt +7 -0
- data/ext/libcouchbase/contrib/snappy/COPYING +28 -0
- data/ext/libcouchbase/contrib/snappy/snappy-c.cc +90 -0
- data/ext/libcouchbase/contrib/snappy/snappy-c.h +138 -0
- data/ext/libcouchbase/contrib/snappy/snappy-internal.h +150 -0
- data/ext/libcouchbase/contrib/snappy/snappy-lcb-msvc.h +5 -0
- data/ext/libcouchbase/contrib/snappy/snappy-sinksource.cc +75 -0
- data/ext/libcouchbase/contrib/snappy/snappy-sinksource.h +137 -0
- data/ext/libcouchbase/contrib/snappy/snappy-stubs-internal.cc +42 -0
- data/ext/libcouchbase/contrib/snappy/snappy-stubs-internal.h +491 -0
- data/ext/libcouchbase/contrib/snappy/snappy-stubs-public.h +100 -0
- data/ext/libcouchbase/contrib/snappy/snappy.cc +1312 -0
- data/ext/libcouchbase/contrib/snappy/snappy.h +184 -0
- data/ext/libcouchbase/contrib/win32-defs/iocpdefs.h +133 -0
- data/ext/libcouchbase/contrib/win32-defs/mingwdefs.h +4396 -0
- data/ext/libcouchbase/contrib/win32-defs/win_stdint.h +258 -0
- data/ext/libcouchbase/doc/Doxyfile +2495 -0
- data/ext/libcouchbase/doc/DoxygenLayout.xml +109 -0
- data/ext/libcouchbase/doc/Makefile +44 -0
- data/ext/libcouchbase/doc/apiattr.h +117 -0
- data/ext/libcouchbase/doc/cbc-n1qlback.markdown +88 -0
- data/ext/libcouchbase/doc/cbc-pillowfight.markdown +296 -0
- data/ext/libcouchbase/doc/cbc-subdoc.markdown +299 -0
- data/ext/libcouchbase/doc/cbc.markdown +763 -0
- data/ext/libcouchbase/doc/cbcrc.markdown +52 -0
- data/ext/libcouchbase/doc/common-additional-options.markdown +82 -0
- data/ext/libcouchbase/doc/common-options.markdown +71 -0
- data/ext/libcouchbase/doc/environment.h +93 -0
- data/ext/libcouchbase/doc/example/threads.c +77 -0
- data/ext/libcouchbase/doc/footer.html +22 -0
- data/ext/libcouchbase/doc/genman.sh +25 -0
- data/ext/libcouchbase/doc/header.html +52 -0
- data/ext/libcouchbase/doc/intro.h +130 -0
- data/ext/libcouchbase/doc/mainpage.h +136 -0
- data/ext/libcouchbase/doc/man/cbc-admin.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-bucket-create.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-bucket-delete.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-cat.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-connstr.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-cp.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-create.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-decr.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-flush.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-hash.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-incr.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-lock.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-mcflush.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-mcversion.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-n1ql.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-n1qlback.1 +198 -0
- data/ext/libcouchbase/doc/man/cbc-observe.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-pillowfight.1 +499 -0
- data/ext/libcouchbase/doc/man/cbc-ping.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-rm.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-role-list.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-stats.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-subdoc.1 +494 -0
- data/ext/libcouchbase/doc/man/cbc-unlock.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-user-delete.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-user-list.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-user-upsert.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-verbosity.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-version.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-view.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc-watch.1 +1 -0
- data/ext/libcouchbase/doc/man/cbc.1 +1035 -0
- data/ext/libcouchbase/doc/man/cbcrc.4 +71 -0
- data/ext/libcouchbase/doc/style.css +1162 -0
- data/ext/libcouchbase/example/CMakeLists.txt +52 -0
- data/ext/libcouchbase/example/README.markdown +47 -0
- data/ext/libcouchbase/example/analytics/.gitignore +1 -0
- data/ext/libcouchbase/example/analytics/analytics.c +158 -0
- data/ext/libcouchbase/example/analytics/build-queries.rb +34 -0
- data/ext/libcouchbase/example/analytics/cJSON.c +1 -0
- data/ext/libcouchbase/example/analytics/cJSON.h +1 -0
- data/ext/libcouchbase/example/analytics/queries/00-show-dataverse.json +5 -0
- data/ext/libcouchbase/example/analytics/queries/01-setup-dataset-breweries.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/02-setup-dataset-beers.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/03-initiate-shadow.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/04-list-datasets.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/05-count-breweries.json +5 -0
- data/ext/libcouchbase/example/analytics/queries/06-first-brewery.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/07-key-based-lookup.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/08-exact-match-lookup.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/09-exact-match-lookup-different-shape.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/10-other-query-filters.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/11-equijoin.json +9 -0
- data/ext/libcouchbase/example/analytics/queries/12-equijoin-select-star.json +10 -0
- data/ext/libcouchbase/example/analytics/queries/13-ansi-join.json +8 -0
- data/ext/libcouchbase/example/analytics/queries/14-join-select-values.json +8 -0
- data/ext/libcouchbase/example/analytics/queries/15-nested-outer-join.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/16-theta-join.json +8 -0
- data/ext/libcouchbase/example/analytics/queries/17-existential-quantification.json +9 -0
- data/ext/libcouchbase/example/analytics/queries/18-universal-quantification.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/19-simple-aggregation.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/20-simple-aggregation-unwrapped-value.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/21-simple-aggregation-explicit.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/22-grouping-and-aggregation.json +6 -0
- data/ext/libcouchbase/example/analytics/queries/23-grouping-and-aggregation-with-hint.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/24-grouping-and-limits.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/25-named-parameters.json +7 -0
- data/ext/libcouchbase/example/analytics/queries/26-positional-parameters.json +7 -0
- data/ext/libcouchbase/example/analytics/queries.h +113 -0
- data/ext/libcouchbase/example/crypto/.gitignore +2 -0
- data/ext/libcouchbase/example/crypto/Makefile +13 -0
- data/ext/libcouchbase/example/crypto/common_provider.c +26 -0
- data/ext/libcouchbase/example/crypto/common_provider.h +33 -0
- data/ext/libcouchbase/example/crypto/openssl_symmetric_decrypt.c +144 -0
- data/ext/libcouchbase/example/crypto/openssl_symmetric_encrypt.c +146 -0
- data/ext/libcouchbase/example/crypto/openssl_symmetric_provider.c +271 -0
- data/ext/libcouchbase/example/crypto/openssl_symmetric_provider.h +29 -0
- data/ext/libcouchbase/example/db/db.c +171 -0
- data/ext/libcouchbase/example/db/vb.c +227 -0
- data/ext/libcouchbase/example/fts/.gitignore +1 -0
- data/ext/libcouchbase/example/fts/build-queries.rb +33 -0
- data/ext/libcouchbase/example/fts/fts.c +142 -0
- data/ext/libcouchbase/example/fts/queries/00-simple-text-query.json +12 -0
- data/ext/libcouchbase/example/fts/queries/01-simple-text-query-on-non-default-index.json +9 -0
- data/ext/libcouchbase/example/fts/queries/02-simple-text-query-on-stored-field.json +13 -0
- data/ext/libcouchbase/example/fts/queries/03-match-query-with-facet.json +19 -0
- data/ext/libcouchbase/example/fts/queries/04-docid-query.json +11 -0
- data/ext/libcouchbase/example/fts/queries/05-unanalyzed-term-query-with-fuzziness-level-of-0.json +13 -0
- data/ext/libcouchbase/example/fts/queries/06-unanalyzed-term-query-with-fuzziness-level-of-2.json +14 -0
- data/ext/libcouchbase/example/fts/queries/07-match-phrase-query.json +13 -0
- data/ext/libcouchbase/example/fts/queries/08-phrase-query.json +16 -0
- data/ext/libcouchbase/example/fts/queries/09-query-string-query.json +9 -0
- data/ext/libcouchbase/example/fts/queries/10-conjunction-query.json +21 -0
- data/ext/libcouchbase/example/fts/queries/11-wild-card-query.json +13 -0
- data/ext/libcouchbase/example/fts/queries/12-numeric-range-query.json +11 -0
- data/ext/libcouchbase/example/fts/queries/13-regexp-query.json +13 -0
- data/ext/libcouchbase/example/fts/queries.h +61 -0
- data/ext/libcouchbase/example/instancepool/main.cc +112 -0
- data/ext/libcouchbase/example/instancepool/pool.cc +102 -0
- data/ext/libcouchbase/example/instancepool/pool.h +69 -0
- data/ext/libcouchbase/example/libeventdirect/main.c +222 -0
- data/ext/libcouchbase/example/mcc/mcc.cc +246 -0
- data/ext/libcouchbase/example/minimal/.gitignore +1 -0
- data/ext/libcouchbase/example/minimal/minimal.c +132 -0
- data/ext/libcouchbase/example/minimal/query.c +185 -0
- data/ext/libcouchbase/example/observe/durability.c +102 -0
- data/ext/libcouchbase/example/observe/observe.c +159 -0
- data/ext/libcouchbase/example/subdoc/subdoc-multi.cc +143 -0
- data/ext/libcouchbase/example/subdoc/subdoc-simple.cc +201 -0
- data/ext/libcouchbase/example/subdoc/subdoc-xattrs.c +286 -0
- data/ext/libcouchbase/example/tick/tick.c +119 -0
- data/ext/libcouchbase/example/tracing/.gitignore +2 -0
- data/ext/libcouchbase/example/tracing/Makefile +8 -0
- data/ext/libcouchbase/example/tracing/cJSON.c +1 -0
- data/ext/libcouchbase/example/tracing/cJSON.h +1 -0
- data/ext/libcouchbase/example/tracing/tracing.c +439 -0
- data/ext/libcouchbase/example/tracing/views.c +444 -0
- data/ext/libcouchbase/example/users/README +48 -0
- data/ext/libcouchbase/example/users/users.c +147 -0
- data/ext/libcouchbase/example/views/views-example.cc +83 -0
- data/ext/libcouchbase/include/libcouchbase/_cxxwrap.h +150 -0
- data/ext/libcouchbase/include/libcouchbase/api-legacy.h +1689 -0
- data/ext/libcouchbase/include/libcouchbase/api3.h +2 -0
- data/ext/libcouchbase/include/libcouchbase/assert.h +44 -0
- data/ext/libcouchbase/include/libcouchbase/auth.h +297 -0
- data/ext/libcouchbase/include/libcouchbase/cbft.h +151 -0
- data/ext/libcouchbase/include/libcouchbase/cntl-private.h +319 -0
- data/ext/libcouchbase/include/libcouchbase/cntl.h +1418 -0
- data/ext/libcouchbase/include/libcouchbase/configuration.h.in +29 -0
- data/ext/libcouchbase/include/libcouchbase/couchbase.h +4089 -0
- data/ext/libcouchbase/include/libcouchbase/crypto.h +306 -0
- data/ext/libcouchbase/include/libcouchbase/deprecated.h +312 -0
- data/ext/libcouchbase/include/libcouchbase/error.h +680 -0
- data/ext/libcouchbase/include/libcouchbase/http.h +1 -0
- data/ext/libcouchbase/include/libcouchbase/iops.h +1053 -0
- data/ext/libcouchbase/include/libcouchbase/ixmgmt.h +263 -0
- data/ext/libcouchbase/include/libcouchbase/kvbuf.h +137 -0
- data/ext/libcouchbase/include/libcouchbase/metrics.h +79 -0
- data/ext/libcouchbase/include/libcouchbase/n1ql.h +539 -0
- data/ext/libcouchbase/include/libcouchbase/pktfwd.h +270 -0
- data/ext/libcouchbase/include/libcouchbase/plugins/io/bsdio-inl.c +370 -0
- data/ext/libcouchbase/include/libcouchbase/plugins/io/wsaerr-inl.c +76 -0
- data/ext/libcouchbase/include/libcouchbase/plugins/io/wsaerr.h +199 -0
- data/ext/libcouchbase/include/libcouchbase/subdoc.h +347 -0
- data/ext/libcouchbase/include/libcouchbase/sysdefs.h +98 -0
- data/ext/libcouchbase/include/libcouchbase/tracing.h +437 -0
- data/ext/libcouchbase/include/libcouchbase/vbucket.h +680 -0
- data/ext/libcouchbase/include/libcouchbase/views.h +357 -0
- data/ext/libcouchbase/include/libcouchbase/visibility.h +66 -0
- data/ext/libcouchbase/include/memcached/COPYING +30 -0
- data/ext/libcouchbase/include/memcached/README +10 -0
- data/ext/libcouchbase/include/memcached/protocol_binary.h +885 -0
- data/ext/libcouchbase/packaging/README +7 -0
- data/ext/libcouchbase/packaging/abicheck/.gitignore +4 -0
- data/ext/libcouchbase/packaging/abicheck/Makefile +17 -0
- data/ext/libcouchbase/packaging/abicheck/README.md +27 -0
- data/ext/libcouchbase/packaging/abicheck/template.xml +3 -0
- data/ext/libcouchbase/packaging/deb/compat +1 -0
- data/ext/libcouchbase/packaging/deb/control +72 -0
- data/ext/libcouchbase/packaging/deb/copyright +10 -0
- data/ext/libcouchbase/packaging/deb/libcouchbase-dev.docs +3 -0
- data/ext/libcouchbase/packaging/deb/package.mk +31 -0
- data/ext/libcouchbase/packaging/deb/rules +46 -0
- data/ext/libcouchbase/packaging/deb/source/format +1 -0
- data/ext/libcouchbase/packaging/distinfo/README +1 -0
- data/ext/libcouchbase/packaging/distinfo/distinfo.cmake.in +4 -0
- data/ext/libcouchbase/packaging/dllversion.rc.in +39 -0
- data/ext/libcouchbase/packaging/libcouchbase.pc.in +10 -0
- data/ext/libcouchbase/packaging/nuget/libcouchbase.autopkg +76 -0
- data/ext/libcouchbase/packaging/parse-git-describe.pl +166 -0
- data/ext/libcouchbase/packaging/rpm/libcouchbase.spec.in +101 -0
- data/ext/libcouchbase/packaging/rpm/package.mk +40 -0
- data/ext/libcouchbase/plugins/io/iocp/CMakeLists.txt +9 -0
- data/ext/libcouchbase/plugins/io/iocp/iocp_iops.c +467 -0
- data/ext/libcouchbase/plugins/io/iocp/iocp_iops.h +217 -0
- data/ext/libcouchbase/plugins/io/iocp/iocp_loop.c +295 -0
- data/ext/libcouchbase/plugins/io/iocp/iocp_timer.c +79 -0
- data/ext/libcouchbase/plugins/io/iocp/iocp_util.c +229 -0
- data/ext/libcouchbase/plugins/io/libev/CMakeLists.txt +31 -0
- data/ext/libcouchbase/plugins/io/libev/libev_io_opts.h +66 -0
- data/ext/libcouchbase/plugins/io/libev/plugin-libev.c +289 -0
- data/ext/libcouchbase/plugins/io/libevent/CMakeLists.txt +31 -0
- data/ext/libcouchbase/plugins/io/libevent/libevent_io_opts.h +67 -0
- data/ext/libcouchbase/plugins/io/libevent/plugin-libevent.c +292 -0
- data/ext/libcouchbase/plugins/io/libuv/CMakeLists.txt +44 -0
- data/ext/libcouchbase/plugins/io/libuv/libuv_compat.h +218 -0
- data/ext/libcouchbase/plugins/io/libuv/libuv_io_opts.h +118 -0
- data/ext/libcouchbase/plugins/io/libuv/plugin-internal.h +155 -0
- data/ext/libcouchbase/plugins/io/libuv/plugin-libuv.c +709 -0
- data/ext/libcouchbase/plugins/io/select/CMakeLists.txt +13 -0
- data/ext/libcouchbase/plugins/io/select/plugin-select.c +451 -0
- data/ext/libcouchbase/plugins/io/select/select_io_opts.h +39 -0
- data/ext/libcouchbase/src/README.md +101 -0
- data/ext/libcouchbase/src/aspend.h +105 -0
- data/ext/libcouchbase/src/auth-priv.h +85 -0
- data/ext/libcouchbase/src/auth.cc +146 -0
- data/ext/libcouchbase/src/bootstrap.cc +263 -0
- data/ext/libcouchbase/src/bootstrap.h +149 -0
- data/ext/libcouchbase/src/bucketconfig/bc_cccp.cc +450 -0
- data/ext/libcouchbase/src/bucketconfig/bc_file.cc +281 -0
- data/ext/libcouchbase/src/bucketconfig/bc_http.cc +527 -0
- data/ext/libcouchbase/src/bucketconfig/bc_http.h +107 -0
- data/ext/libcouchbase/src/bucketconfig/bc_static.cc +150 -0
- data/ext/libcouchbase/src/bucketconfig/clconfig.h +700 -0
- data/ext/libcouchbase/src/bucketconfig/confmon.cc +403 -0
- data/ext/libcouchbase/src/callbacks.c +380 -0
- data/ext/libcouchbase/src/cbft.cc +253 -0
- data/ext/libcouchbase/src/cntl.cc +1057 -0
- data/ext/libcouchbase/src/config_static.h +176 -0
- data/ext/libcouchbase/src/connspec.cc +555 -0
- data/ext/libcouchbase/src/connspec.h +155 -0
- data/ext/libcouchbase/src/crypto.cc +399 -0
- data/ext/libcouchbase/src/ctx-log-inl.h +44 -0
- data/ext/libcouchbase/src/dns-srv.cc +146 -0
- data/ext/libcouchbase/src/dump.cc +103 -0
- data/ext/libcouchbase/src/errmap.cc +173 -0
- data/ext/libcouchbase/src/errmap.h +271 -0
- data/ext/libcouchbase/src/getconfig.cc +72 -0
- data/ext/libcouchbase/src/gethrtime.c +109 -0
- data/ext/libcouchbase/src/handler.cc +1101 -0
- data/ext/libcouchbase/src/hashtable.c +75 -0
- data/ext/libcouchbase/src/hdr_timings.c +92 -0
- data/ext/libcouchbase/src/hostlist.cc +293 -0
- data/ext/libcouchbase/src/hostlist.h +160 -0
- data/ext/libcouchbase/src/http/http-priv.h +326 -0
- data/ext/libcouchbase/src/http/http.cc +672 -0
- data/ext/libcouchbase/src/http/http.h +1 -0
- data/ext/libcouchbase/src/http/http_io.cc +316 -0
- data/ext/libcouchbase/src/instance.cc +917 -0
- data/ext/libcouchbase/src/internal.h +285 -0
- data/ext/libcouchbase/src/iofactory.c +575 -0
- data/ext/libcouchbase/src/jsparse/parser.cc +445 -0
- data/ext/libcouchbase/src/jsparse/parser.h +159 -0
- data/ext/libcouchbase/src/lcbht/lcbht.cc +177 -0
- data/ext/libcouchbase/src/lcbht/lcbht.h +210 -0
- data/ext/libcouchbase/src/lcbio/connect.cc +603 -0
- data/ext/libcouchbase/src/lcbio/connect.h +400 -0
- data/ext/libcouchbase/src/lcbio/ctx.c +658 -0
- data/ext/libcouchbase/src/lcbio/ctx.h +405 -0
- data/ext/libcouchbase/src/lcbio/iotable.c +290 -0
- data/ext/libcouchbase/src/lcbio/iotable.h +169 -0
- data/ext/libcouchbase/src/lcbio/ioutils.cc +356 -0
- data/ext/libcouchbase/src/lcbio/ioutils.h +144 -0
- data/ext/libcouchbase/src/lcbio/lcbio.h +51 -0
- data/ext/libcouchbase/src/lcbio/manager.cc +579 -0
- data/ext/libcouchbase/src/lcbio/manager.h +195 -0
- data/ext/libcouchbase/src/lcbio/protoctx.c +84 -0
- data/ext/libcouchbase/src/lcbio/rw-inl.h +137 -0
- data/ext/libcouchbase/src/lcbio/ssl.h +159 -0
- data/ext/libcouchbase/src/lcbio/timer-cxx.h +87 -0
- data/ext/libcouchbase/src/lcbio/timer-ng.h +179 -0
- data/ext/libcouchbase/src/lcbio/timer.c +132 -0
- data/ext/libcouchbase/src/legacy.c +431 -0
- data/ext/libcouchbase/src/list.c +144 -0
- data/ext/libcouchbase/src/list.h +127 -0
- data/ext/libcouchbase/src/logging.c +244 -0
- data/ext/libcouchbase/src/logging.h +88 -0
- data/ext/libcouchbase/src/mc/compress.cc +171 -0
- data/ext/libcouchbase/src/mc/compress.h +56 -0
- data/ext/libcouchbase/src/mc/forward.c +186 -0
- data/ext/libcouchbase/src/mc/forward.h +90 -0
- data/ext/libcouchbase/src/mc/iovcursor-inl.h +279 -0
- data/ext/libcouchbase/src/mc/iovcursor.h +66 -0
- data/ext/libcouchbase/src/mc/mcreq-flush-inl.h +115 -0
- data/ext/libcouchbase/src/mc/mcreq.c +983 -0
- data/ext/libcouchbase/src/mc/mcreq.h +1015 -0
- data/ext/libcouchbase/src/mcserver/mcserver.cc +1055 -0
- data/ext/libcouchbase/src/mcserver/mcserver.h +221 -0
- data/ext/libcouchbase/src/mcserver/negotiate.cc +757 -0
- data/ext/libcouchbase/src/mcserver/negotiate.h +128 -0
- data/ext/libcouchbase/src/mctx-helper.h +62 -0
- data/ext/libcouchbase/src/metrics.cc +132 -0
- data/ext/libcouchbase/src/n1ql/ixmgmt.cc +857 -0
- data/ext/libcouchbase/src/n1ql/n1ql-internal.h +22 -0
- data/ext/libcouchbase/src/n1ql/n1ql.cc +830 -0
- data/ext/libcouchbase/src/n1ql/params.cc +260 -0
- data/ext/libcouchbase/src/netbuf/netbuf-defs.h +89 -0
- data/ext/libcouchbase/src/netbuf/netbuf-mblock.h +235 -0
- data/ext/libcouchbase/src/netbuf/netbuf.c +929 -0
- data/ext/libcouchbase/src/netbuf/netbuf.h +452 -0
- data/ext/libcouchbase/src/newconfig.cc +365 -0
- data/ext/libcouchbase/src/nodeinfo.cc +184 -0
- data/ext/libcouchbase/src/operations/cbflush.cc +63 -0
- data/ext/libcouchbase/src/operations/counter.cc +117 -0
- data/ext/libcouchbase/src/operations/durability-cas.cc +251 -0
- data/ext/libcouchbase/src/operations/durability-seqno.cc +170 -0
- data/ext/libcouchbase/src/operations/durability.cc +668 -0
- data/ext/libcouchbase/src/operations/durability_internal.h +306 -0
- data/ext/libcouchbase/src/operations/get.cc +409 -0
- data/ext/libcouchbase/src/operations/observe-seqno.cc +94 -0
- data/ext/libcouchbase/src/operations/observe.cc +367 -0
- data/ext/libcouchbase/src/operations/ping.cc +496 -0
- data/ext/libcouchbase/src/operations/pktfwd.cc +86 -0
- data/ext/libcouchbase/src/operations/remove.cc +84 -0
- data/ext/libcouchbase/src/operations/stats.cc +459 -0
- data/ext/libcouchbase/src/operations/store.cc +358 -0
- data/ext/libcouchbase/src/operations/subdoc.cc +614 -0
- data/ext/libcouchbase/src/operations/touch.cc +84 -0
- data/ext/libcouchbase/src/packetutils.h +388 -0
- data/ext/libcouchbase/src/probes.d +182 -0
- data/ext/libcouchbase/src/rdb/bigalloc.c +225 -0
- data/ext/libcouchbase/src/rdb/bigalloc.h +73 -0
- data/ext/libcouchbase/src/rdb/chunkalloc.c +174 -0
- data/ext/libcouchbase/src/rdb/libcalloc.c +94 -0
- data/ext/libcouchbase/src/rdb/rope.c +419 -0
- data/ext/libcouchbase/src/rdb/rope.h +488 -0
- data/ext/libcouchbase/src/retrychk.cc +113 -0
- data/ext/libcouchbase/src/retryq.cc +458 -0
- data/ext/libcouchbase/src/retryq.h +170 -0
- data/ext/libcouchbase/src/ringbuffer.c +442 -0
- data/ext/libcouchbase/src/ringbuffer.h +100 -0
- data/ext/libcouchbase/src/rnd.cc +61 -0
- data/ext/libcouchbase/src/rnd.h +39 -0
- data/ext/libcouchbase/src/settings.c +125 -0
- data/ext/libcouchbase/src/settings.h +273 -0
- data/ext/libcouchbase/src/sllist-inl.h +197 -0
- data/ext/libcouchbase/src/sllist.h +76 -0
- data/ext/libcouchbase/src/ssl/CMakeLists.txt +11 -0
- data/ext/libcouchbase/src/ssl/ssl_c.c +442 -0
- data/ext/libcouchbase/src/ssl/ssl_common.c +478 -0
- data/ext/libcouchbase/src/ssl/ssl_e.c +421 -0
- data/ext/libcouchbase/src/ssl/ssl_iot_common.h +182 -0
- data/ext/libcouchbase/src/strcodecs/base64.c +307 -0
- data/ext/libcouchbase/src/strcodecs/strcodecs.h +302 -0
- data/ext/libcouchbase/src/timings.c +207 -0
- data/ext/libcouchbase/src/trace.h +117 -0
- data/ext/libcouchbase/src/tracing/span.cc +421 -0
- data/ext/libcouchbase/src/tracing/threshold_logging_tracer.cc +213 -0
- data/ext/libcouchbase/src/tracing/tracer.cc +53 -0
- data/ext/libcouchbase/src/tracing/tracing-internal.h +198 -0
- data/ext/libcouchbase/src/utilities.c +176 -0
- data/ext/libcouchbase/src/vbucket/CMakeLists.txt +2 -0
- data/ext/libcouchbase/src/vbucket/aliases.h +35 -0
- data/ext/libcouchbase/src/vbucket/crc32.h +83 -0
- data/ext/libcouchbase/src/vbucket/hash.h +30 -0
- data/ext/libcouchbase/src/vbucket/json-inl.h +112 -0
- data/ext/libcouchbase/src/vbucket/ketama.c +66 -0
- data/ext/libcouchbase/src/vbucket/rfc1321/global.h +32 -0
- data/ext/libcouchbase/src/vbucket/rfc1321/md5.h +35 -0
- data/ext/libcouchbase/src/vbucket/rfc1321/md5c-inl.h +335 -0
- data/ext/libcouchbase/src/vbucket/vbucket.c +1735 -0
- data/ext/libcouchbase/src/views/docreq.cc +213 -0
- data/ext/libcouchbase/src/views/docreq.h +94 -0
- data/ext/libcouchbase/src/views/viewreq.cc +381 -0
- data/ext/libcouchbase/src/views/viewreq.h +87 -0
- data/ext/libcouchbase/src/wait.cc +156 -0
- data/ext/libcouchbase/tests/CMakeLists.txt +149 -0
- data/ext/libcouchbase/tests/basic/t_base64.cc +109 -0
- data/ext/libcouchbase/tests/basic/t_ccbc103.cc +95 -0
- data/ext/libcouchbase/tests/basic/t_connstr.cc +456 -0
- data/ext/libcouchbase/tests/basic/t_creds.cc +96 -0
- data/ext/libcouchbase/tests/basic/t_ctlcodes.cc +92 -0
- data/ext/libcouchbase/tests/basic/t_host.cc +210 -0
- data/ext/libcouchbase/tests/basic/t_jsparse.cc +82 -0
- data/ext/libcouchbase/tests/basic/t_jsparse.h +589 -0
- data/ext/libcouchbase/tests/basic/t_list.cc +155 -0
- data/ext/libcouchbase/tests/basic/t_logger.cc +65 -0
- data/ext/libcouchbase/tests/basic/t_misc.cc +24 -0
- data/ext/libcouchbase/tests/basic/t_n1qlstrings.cc +17 -0
- data/ext/libcouchbase/tests/basic/t_netbuf.cc +446 -0
- data/ext/libcouchbase/tests/basic/t_packet.cc +215 -0
- data/ext/libcouchbase/tests/basic/t_ringbuffer.cc +278 -0
- data/ext/libcouchbase/tests/basic/t_scram.cc +514 -0
- data/ext/libcouchbase/tests/basic/t_slist.cc +429 -0
- data/ext/libcouchbase/tests/basic/t_strerror.cc +64 -0
- data/ext/libcouchbase/tests/basic/t_urlencode.cc +132 -0
- data/ext/libcouchbase/tests/check-all.cc +612 -0
- data/ext/libcouchbase/tests/htparse/t_basic.cc +173 -0
- data/ext/libcouchbase/tests/ioserver/connection.cc +166 -0
- data/ext/libcouchbase/tests/ioserver/future.cc +50 -0
- data/ext/libcouchbase/tests/ioserver/ioserver.cc +117 -0
- data/ext/libcouchbase/tests/ioserver/ioserver.h +478 -0
- data/ext/libcouchbase/tests/ioserver/socket.cc +88 -0
- data/ext/libcouchbase/tests/ioserver/ssl_connection.cc +145 -0
- data/ext/libcouchbase/tests/ioserver/threads-pthreads.cc +119 -0
- data/ext/libcouchbase/tests/ioserver/threads-win32.cc +117 -0
- data/ext/libcouchbase/tests/ioserver/threads.h +66 -0
- data/ext/libcouchbase/tests/iotests/iotests.h +15 -0
- data/ext/libcouchbase/tests/iotests/mock-environment.cc +632 -0
- data/ext/libcouchbase/tests/iotests/mock-environment.h +480 -0
- data/ext/libcouchbase/tests/iotests/mock-unit-test.cc +67 -0
- data/ext/libcouchbase/tests/iotests/mock-unit-test.h +61 -0
- data/ext/libcouchbase/tests/iotests/serverparams.h +76 -0
- data/ext/libcouchbase/tests/iotests/t_arithmetic.cc +143 -0
- data/ext/libcouchbase/tests/iotests/t_behavior.cc +220 -0
- data/ext/libcouchbase/tests/iotests/t_configcache.cc +117 -0
- data/ext/libcouchbase/tests/iotests/t_confmon.cc +223 -0
- data/ext/libcouchbase/tests/iotests/t_durability.cc +1108 -0
- data/ext/libcouchbase/tests/iotests/t_eerrs.cc +121 -0
- data/ext/libcouchbase/tests/iotests/t_errmap.cc +181 -0
- data/ext/libcouchbase/tests/iotests/t_forward.cc +118 -0
- data/ext/libcouchbase/tests/iotests/t_get.cc +512 -0
- data/ext/libcouchbase/tests/iotests/t_http.cc +438 -0
- data/ext/libcouchbase/tests/iotests/t_iops.cc +175 -0
- data/ext/libcouchbase/tests/iotests/t_lock.cc +274 -0
- data/ext/libcouchbase/tests/iotests/t_misc.cc +777 -0
- data/ext/libcouchbase/tests/iotests/t_mutate.cc +609 -0
- data/ext/libcouchbase/tests/iotests/t_n1ql.cc +270 -0
- data/ext/libcouchbase/tests/iotests/t_netfail.cc +778 -0
- data/ext/libcouchbase/tests/iotests/t_obseqno.cc +156 -0
- data/ext/libcouchbase/tests/iotests/t_regression.cc +321 -0
- data/ext/libcouchbase/tests/iotests/t_sched.cc +87 -0
- data/ext/libcouchbase/tests/iotests/t_serverops.cc +231 -0
- data/ext/libcouchbase/tests/iotests/t_smoke.cc +528 -0
- data/ext/libcouchbase/tests/iotests/t_snappy.cc +316 -0
- data/ext/libcouchbase/tests/iotests/t_subdoc.cc +857 -0
- data/ext/libcouchbase/tests/iotests/t_syncmode.cc +64 -0
- data/ext/libcouchbase/tests/iotests/t_views.cc +417 -0
- data/ext/libcouchbase/tests/iotests/testutil.cc +251 -0
- data/ext/libcouchbase/tests/iotests/testutil.h +163 -0
- data/ext/libcouchbase/tests/mc/mctest.h +119 -0
- data/ext/libcouchbase/tests/mc/pktmaker.h +101 -0
- data/ext/libcouchbase/tests/mc/t_alloc.cc +269 -0
- data/ext/libcouchbase/tests/mc/t_context.cc +100 -0
- data/ext/libcouchbase/tests/mc/t_flush.cc +185 -0
- data/ext/libcouchbase/tests/mc/t_forward.cc +239 -0
- data/ext/libcouchbase/tests/mc/t_ioflush.cc +102 -0
- data/ext/libcouchbase/tests/mc/t_iovcursor.cc +173 -0
- data/ext/libcouchbase/tests/mocksupport/procutil.c +305 -0
- data/ext/libcouchbase/tests/mocksupport/procutil.h +89 -0
- data/ext/libcouchbase/tests/mocksupport/server.c +391 -0
- data/ext/libcouchbase/tests/mocksupport/server.h +72 -0
- data/ext/libcouchbase/tests/mocksupport/timeout.c +69 -0
- data/ext/libcouchbase/tests/nonio_tests.cc +23 -0
- data/ext/libcouchbase/tests/rdb/rdbtest.h +133 -0
- data/ext/libcouchbase/tests/rdb/t_basic.cc +128 -0
- data/ext/libcouchbase/tests/rdb/t_bigalloc.cc +93 -0
- data/ext/libcouchbase/tests/rdb/t_refs.cc +112 -0
- data/ext/libcouchbase/tests/socktests/socktest.cc +344 -0
- data/ext/libcouchbase/tests/socktests/socktest.h +447 -0
- data/ext/libcouchbase/tests/socktests/t_basic.cc +143 -0
- data/ext/libcouchbase/tests/socktests/t_ctx.cc +73 -0
- data/ext/libcouchbase/tests/socktests/t_manager.cc +159 -0
- data/ext/libcouchbase/tests/socktests/t_putex.cc +256 -0
- data/ext/libcouchbase/tests/socktests/t_read.cc +187 -0
- data/ext/libcouchbase/tests/socktests/t_reentrant.cc +143 -0
- data/ext/libcouchbase/tests/socktests/t_ssl.cc +80 -0
- data/ext/libcouchbase/tests/socktests/t_write.cc +95 -0
- data/ext/libcouchbase/tests/start_mock.bat +15 -0
- data/ext/libcouchbase/tests/start_mock.sh +42 -0
- data/ext/libcouchbase/tests/unit_tests.cc +43 -0
- data/ext/libcouchbase/tests/vbucket/confdata/bad.json +101 -0
- data/ext/libcouchbase/tests/vbucket/confdata/full_25.json +363 -0
- data/ext/libcouchbase/tests/vbucket/confdata/ketama_expected.json +2562 -0
- data/ext/libcouchbase/tests/vbucket/confdata/map_node_present_nodesext_missing_nodes.json +94 -0
- data/ext/libcouchbase/tests/vbucket/confdata/memd_25.json +90 -0
- data/ext/libcouchbase/tests/vbucket/confdata/memd_30.json +1 -0
- data/ext/libcouchbase/tests/vbucket/confdata/memd_45.json +1 -0
- data/ext/libcouchbase/tests/vbucket/confdata/memd_ketama_config.json +31 -0
- data/ext/libcouchbase/tests/vbucket/confdata/terse_25.json +291 -0
- data/ext/libcouchbase/tests/vbucket/confdata/terse_30.json +1 -0
- data/ext/libcouchbase/tests/vbucket/t_config.cc +386 -0
- data/ext/libcouchbase/tools/CMakeLists.txt +80 -0
- data/ext/libcouchbase/tools/cbc-handlers.h +636 -0
- data/ext/libcouchbase/tools/cbc-n1qlback.cc +496 -0
- data/ext/libcouchbase/tools/cbc-pillowfight.cc +1230 -0
- data/ext/libcouchbase/tools/cbc-proxy.cc +534 -0
- data/ext/libcouchbase/tools/cbc-subdoc.cc +825 -0
- data/ext/libcouchbase/tools/cbc.cc +1928 -0
- data/ext/libcouchbase/tools/common/histogram.cc +44 -0
- data/ext/libcouchbase/tools/common/histogram.h +23 -0
- data/ext/libcouchbase/tools/common/options.cc +451 -0
- data/ext/libcouchbase/tools/common/options.h +90 -0
- data/ext/libcouchbase/tools/docgen/docgen.h +495 -0
- data/ext/libcouchbase/tools/docgen/loc.h +211 -0
- data/ext/libcouchbase/tools/docgen/placeholders.h +211 -0
- data/ext/libcouchbase/tools/docgen/seqgen.h +122 -0
- data/ext/libcouchbase/tools/extract-packets.rb +110 -0
- data/ext/libcouchbase/tools/linenoise/linenoise.c +1199 -0
- data/ext/libcouchbase/tools/linenoise/linenoise.h +73 -0
- data/lib/mt-libcouchbase/bucket.rb +825 -0
- data/lib/mt-libcouchbase/callbacks.rb +69 -0
- data/lib/mt-libcouchbase/connection.rb +896 -0
- data/lib/mt-libcouchbase/design_docs.rb +92 -0
- data/lib/mt-libcouchbase/error.rb +68 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdbase.rb +23 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdcounter.rb +36 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdendure.rb +26 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdfts.rb +24 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdget.rb +30 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdgetreplica.rb +49 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdhttp.rb +58 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdn1ql.rb +40 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdobseqno.rb +33 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdobserve.rb +30 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdstore.rb +40 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdstoredur.rb +45 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdsubdoc.rb +61 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdverbosity.rb +29 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/cmdviewquery.rb +61 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/contigbuf.rb +14 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st.rb +15 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st0.rb +23 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st1.rb +26 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st2.rb +32 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/create_st3.rb +26 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/crst_u.rb +20 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/durability_opts_st_v.rb +11 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/durability_opts_t.rb +14 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/durabilityopt_sv0.rb +63 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/enums.rb +1007 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/fragbuf.rb +18 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/ftshandle.rb +7 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/histogram.rb +34 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/http_request_t.rb +7 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/keybuf.rb +20 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/multicmd_ctx.rb +30 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/mutation_token.rb +17 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/n1qlhandle.rb +7 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/n1qlparams.rb +7 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respbase.rb +29 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respcounter.rb +32 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respendure.rb +49 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respfts.rb +40 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respget.rb +44 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/resphttp.rb +48 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respmcversion.rb +38 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respn1ql.rb +41 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respobseqno.rb +52 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respobserve.rb +41 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respserverbase.rb +32 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respstats.rb +38 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respstore.rb +32 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respstoredur.rb +38 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respsubdoc.rb +35 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/respviewquery.rb +67 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/sdentry.rb +22 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/sdspec.rb +31 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/t.rb +7 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/valbuf.rb +22 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/valbuf_u_buf.rb +14 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase/viewhandle.rb +7 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase.rb +1175 -0
- data/lib/mt-libcouchbase/ext/mt-libcouchbase_libuv.rb +22 -0
- data/lib/mt-libcouchbase/ext/tasks.rb +39 -0
- data/lib/mt-libcouchbase/n1ql.rb +80 -0
- data/lib/mt-libcouchbase/query_full_text.rb +147 -0
- data/lib/mt-libcouchbase/query_n1ql.rb +123 -0
- data/lib/mt-libcouchbase/query_view.rb +135 -0
- data/lib/mt-libcouchbase/results_fiber.rb +281 -0
- data/lib/mt-libcouchbase/results_native.rb +220 -0
- data/lib/mt-libcouchbase/subdoc_request.rb +139 -0
- data/lib/mt-libcouchbase/version.rb +5 -0
- data/lib/mt-libcouchbase.rb +40 -0
- data/mt-libcouchbase.gemspec +68 -0
- data/spec/bucket_spec.rb +290 -0
- data/spec/connection_spec.rb +257 -0
- data/spec/design_docs_spec.rb +31 -0
- data/spec/error_spec.rb +26 -0
- data/spec/fts_spec.rb +135 -0
- data/spec/n1ql_spec.rb +260 -0
- data/spec/results_libuv_spec.rb +244 -0
- data/spec/results_native_spec.rb +259 -0
- data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/design.json +1 -0
- data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/data-0000.cbb +0 -0
- data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/failover.json +1 -0
- data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/meta.json +1 -0
- data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/seqno.json +1 -0
- data/spec/seed/2016-10-25T043505Z/2016-10-25T043505Z-full/bucket-default/node-127.0.0.1%3A8091/snapshot_markers.json +1 -0
- data/spec/subdoc_spec.rb +192 -0
- data/spec/view_spec.rb +201 -0
- data/windows_build.md +36 -0
- metadata +873 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
<doxygenlayout version="1.0">
|
|
2
|
+
<!-- Navigation index tabs for HTML output -->
|
|
3
|
+
<navindex>
|
|
4
|
+
<tab type="mainpage" visible="yes" title=""/>
|
|
5
|
+
<tab type="modules" visible="yes" title="" intro=""/>
|
|
6
|
+
<tab type="namespaces" visible="yes" title="">
|
|
7
|
+
<tab type="namespacelist" visible="yes" title="" intro=""/>
|
|
8
|
+
<tab type="namespacemembers" visible="yes" title="" intro=""/>
|
|
9
|
+
</tab>
|
|
10
|
+
<tab type="classes" visible="no" title="">
|
|
11
|
+
<tab type="classlist" visible="no" title="" intro=""/>
|
|
12
|
+
<tab type="classindex" visible="no" title=""/>
|
|
13
|
+
<tab type="hierarchy" visible="yes" title="" intro=""/>
|
|
14
|
+
<tab type="classmembers" visible="no" title="" intro=""/>
|
|
15
|
+
</tab>
|
|
16
|
+
<tab type="globals" visible="yes" title="" intro=""/>
|
|
17
|
+
<tab type="files" visible="yes" title="">
|
|
18
|
+
<tab type="filelist" visible="yes" title="" intro=""/>
|
|
19
|
+
</tab>
|
|
20
|
+
<tab type="examples" visible="yes" title="" intro="Here is a list of examples. Find more at https://github.com/couchbaselabs/devguide-examples/tree/master/c"/>
|
|
21
|
+
<tab type="pages" visible="yes" title="" intro=""/>
|
|
22
|
+
</navindex>
|
|
23
|
+
|
|
24
|
+
<!-- Layout definition for a file page -->
|
|
25
|
+
<file>
|
|
26
|
+
<briefdescription visible="yes"/>
|
|
27
|
+
<includes visible="$SHOW_INCLUDE_FILES"/>
|
|
28
|
+
<includegraph visible="$INCLUDE_GRAPH"/>
|
|
29
|
+
<includedbygraph visible="$INCLUDED_BY_GRAPH"/>
|
|
30
|
+
<sourcelink visible="yes"/>
|
|
31
|
+
<memberdecl>
|
|
32
|
+
<classes visible="yes" title=""/>
|
|
33
|
+
<namespaces visible="yes" title=""/>
|
|
34
|
+
<defines title=""/>
|
|
35
|
+
<typedefs title=""/>
|
|
36
|
+
<enums title=""/>
|
|
37
|
+
<functions title=""/>
|
|
38
|
+
<variables title=""/>
|
|
39
|
+
<membergroups visible="yes"/>
|
|
40
|
+
</memberdecl>
|
|
41
|
+
<detaileddescription title=""/>
|
|
42
|
+
<memberdef>
|
|
43
|
+
<inlineclasses title=""/>
|
|
44
|
+
<defines title=""/>
|
|
45
|
+
<typedefs title=""/>
|
|
46
|
+
<enums title=""/>
|
|
47
|
+
<functions title=""/>
|
|
48
|
+
<variables title=""/>
|
|
49
|
+
</memberdef>
|
|
50
|
+
<authorsection/>
|
|
51
|
+
</file>
|
|
52
|
+
|
|
53
|
+
<!-- Layout definition for a group page -->
|
|
54
|
+
<group>
|
|
55
|
+
<detaileddescription title=""/>
|
|
56
|
+
<briefdescription visible="no"/>
|
|
57
|
+
<groupgraph visible="$GROUP_GRAPHS"/>
|
|
58
|
+
<memberdecl>
|
|
59
|
+
<nestedgroups visible="yes" title=""/>
|
|
60
|
+
<dirs visible="no" title=""/>
|
|
61
|
+
<files visible="yes" title=""/>
|
|
62
|
+
<namespaces visible="no" title=""/>
|
|
63
|
+
<functions title="" visible="no"/>
|
|
64
|
+
<classes visible="no" title=""/>
|
|
65
|
+
<defines title="" visible="no"/>
|
|
66
|
+
<typedefs title="" visible="no"/>
|
|
67
|
+
<enums title="" visible="no"/>
|
|
68
|
+
<enumvalues title="" visible="no"/>
|
|
69
|
+
<variables title=""/>
|
|
70
|
+
<signals title=""/>
|
|
71
|
+
<publicslots title=""/>
|
|
72
|
+
<protectedslots title=""/>
|
|
73
|
+
<privateslots title=""/>
|
|
74
|
+
<events title=""/>
|
|
75
|
+
<properties title=""/>
|
|
76
|
+
<friends title=""/>
|
|
77
|
+
<membergroups visible="yes"/>
|
|
78
|
+
</memberdecl>
|
|
79
|
+
<memberdef>
|
|
80
|
+
<pagedocs/>
|
|
81
|
+
<functions title=""/>
|
|
82
|
+
<inlineclasses title=""/>
|
|
83
|
+
<defines title=""/>
|
|
84
|
+
<typedefs title=""/>
|
|
85
|
+
<enums title=""/>
|
|
86
|
+
<enumvalues title=""/>
|
|
87
|
+
<variables title=""/>
|
|
88
|
+
<signals title=""/>
|
|
89
|
+
<publicslots title=""/>
|
|
90
|
+
<protectedslots title=""/>
|
|
91
|
+
<privateslots title=""/>
|
|
92
|
+
<events title=""/>
|
|
93
|
+
<properties title=""/>
|
|
94
|
+
<friends title=""/>
|
|
95
|
+
</memberdef>
|
|
96
|
+
<authorsection visible="yes"/>
|
|
97
|
+
</group>
|
|
98
|
+
|
|
99
|
+
<!-- Layout definition for a directory page -->
|
|
100
|
+
<directory>
|
|
101
|
+
<briefdescription visible="yes"/>
|
|
102
|
+
<directorygraph visible="yes"/>
|
|
103
|
+
<memberdecl>
|
|
104
|
+
<dirs visible="yes"/>
|
|
105
|
+
<files visible="yes"/>
|
|
106
|
+
</memberdecl>
|
|
107
|
+
<detaileddescription title=""/>
|
|
108
|
+
</directory>
|
|
109
|
+
</doxygenlayout>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
SRCROOT=$(shell pwd)
|
|
2
|
+
VERSINFO=$(shell $(SRCROOT)/packaging/parse-git-describe.pl --tar)
|
|
3
|
+
ifneq ($(strip $(VERSINFO)),)
|
|
4
|
+
VERLINE=PROJECT_NUMBER=$(VERSINFO)
|
|
5
|
+
endif
|
|
6
|
+
|
|
7
|
+
DOXYGEN?=doxygen
|
|
8
|
+
DOXYFILE=doc/Doxyfile
|
|
9
|
+
OUTDIR_PUB = doc/public
|
|
10
|
+
OUTDIR_PRIV = doc/internal
|
|
11
|
+
INTERNAL_SRC = \
|
|
12
|
+
src/rdb \
|
|
13
|
+
src/bootstrap.h \
|
|
14
|
+
src/lcbio \
|
|
15
|
+
src/netbuf \
|
|
16
|
+
src/mc \
|
|
17
|
+
src/retryq.h \
|
|
18
|
+
src/bucketconfig/clconfig.h \
|
|
19
|
+
src/mcserver \
|
|
20
|
+
src/list.h \
|
|
21
|
+
src/sllist.h \
|
|
22
|
+
src/sllist-inl.h \
|
|
23
|
+
src/hostlist.h \
|
|
24
|
+
include/memcached/protocol_binary.h
|
|
25
|
+
|
|
26
|
+
all: public internal
|
|
27
|
+
public:
|
|
28
|
+
(cat $(DOXYFILE);\
|
|
29
|
+
echo $(VERLINE);\
|
|
30
|
+
echo OUTPUT_DIRECTORY=$(OUTDIR_PUB)) | $(DOXYGEN) -
|
|
31
|
+
cp doc/style.css $(OUTDIR_PUB)/html/style.css
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
internal:
|
|
36
|
+
(cat $(DOXYFILE);\
|
|
37
|
+
echo $(VERLINE); \
|
|
38
|
+
echo OUTPUT_DIRECTORY=$(OUTDIR_PRIV); \
|
|
39
|
+
echo INTERNAL_DOCS=yes; \
|
|
40
|
+
echo INPUT += $(INTERNAL_SRC);) | $(DOXYGEN) -
|
|
41
|
+
cp doc/style.css $(OUTDIR_PRIV)/html/style.css
|
|
42
|
+
|
|
43
|
+
clean:
|
|
44
|
+
rm -r -f $(OUTDIR_PRIV)/html $(OUTDIR_PUB)/html
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/* -*- Mode: C; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2010-2017 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
|
+
|
|
18
|
+
/**
|
|
19
|
+
* @page lcb_attributes Interface Attributes
|
|
20
|
+
*
|
|
21
|
+
* Libcouchbase tries to follow the _release early, release often_
|
|
22
|
+
* philosophy. As part of that we want people to be able to try out new
|
|
23
|
+
* interfaces before we "stick" to them. Unfortunately this means that we
|
|
24
|
+
* discover that we need to change them in incompatible ways.
|
|
25
|
+
*
|
|
26
|
+
* To aid developers to make reasonable decisions on how likely we are to
|
|
27
|
+
* change these interfaces all functions in libcouchbase have an
|
|
28
|
+
* associated Interface Stability tag. If you find undocumented structs,
|
|
29
|
+
* functions or files you should *not* use them. They may be changed in
|
|
30
|
+
* incompatible ways without any notice. Unless explicitly noted the
|
|
31
|
+
* interface stability applies to both source code and binaries.
|
|
32
|
+
*
|
|
33
|
+
* This is a standard definition across all official Couchbase Server SDKs.
|
|
34
|
+
* @see https://developer.couchbase.com/documentation/server/current/sdk/c/compatibility-versions-features.html
|
|
35
|
+
*
|
|
36
|
+
* The following classifications exist:
|
|
37
|
+
*
|
|
38
|
+
* ### Committed
|
|
39
|
+
*
|
|
40
|
+
* A committed interface is the highest grade of stability, and is the
|
|
41
|
+
* preferred attribute level for consumers of the library. Couchbase
|
|
42
|
+
* tries at best effort to preseve committed interfaces between major
|
|
43
|
+
* versions of libcouchbase, and changes to committed interfaces within a
|
|
44
|
+
* major version is highly exceptional. Such exceptions may include
|
|
45
|
+
* situations where the interface may lead to data corruption, security
|
|
46
|
+
* holes etc.
|
|
47
|
+
*
|
|
48
|
+
* _This is the default interface level for an API, unless the API is specifically
|
|
49
|
+
* marked otherwise._
|
|
50
|
+
*
|
|
51
|
+
* ### Uncommitted
|
|
52
|
+
*
|
|
53
|
+
* No commitment is made about the interface (in binary or source
|
|
54
|
+
* form). It may be changed in incompatible ways and dropped from one
|
|
55
|
+
* release to another. The difference between an uncommitted interface
|
|
56
|
+
* and a volatile interface is its maturity and likelyhood of being
|
|
57
|
+
* changed. Uncommitted interfaces may mature into committed interfaces.
|
|
58
|
+
*
|
|
59
|
+
* ### Volatile
|
|
60
|
+
*
|
|
61
|
+
* Volatile interfaces can change at any time and for any reason.
|
|
62
|
+
*
|
|
63
|
+
* Interfaces may be volatile for reasons including:
|
|
64
|
+
*
|
|
65
|
+
* * Interface depends on specific implementation detail within the library
|
|
66
|
+
* which may change in the future.
|
|
67
|
+
*
|
|
68
|
+
* * Interface depends on specific implementation detail within the server
|
|
69
|
+
* which may change in the future.
|
|
70
|
+
*
|
|
71
|
+
* * Interface has been introduced as part of a trial phase for the specific
|
|
72
|
+
* feature.
|
|
73
|
+
*
|
|
74
|
+
* ### Deprecated
|
|
75
|
+
*
|
|
76
|
+
* The interface is subject to be removed from future versions of
|
|
77
|
+
* libcouchbase. Interfaces may be deprecated for a variety of reasons, such
|
|
78
|
+
* as specific bugs found within the API itself, or a more uniform and/or
|
|
79
|
+
* direct method of achieving the same goal.
|
|
80
|
+
*
|
|
81
|
+
* ### Internal
|
|
82
|
+
*
|
|
83
|
+
* Internal interfaces are used internally in libcouchbase and should not
|
|
84
|
+
* be used elsewhere. Doing so may cause libcouchbase to misbehave.
|
|
85
|
+
*
|
|
86
|
+
* Unless otherwise noted, any API not found in the <include/libcouchbase>
|
|
87
|
+
* directory is considered to be internal.
|
|
88
|
+
*
|
|
89
|
+
* Some earlier versions of libcouchbase may have listed APIs as private,
|
|
90
|
+
* when the intended term in the taxonomy is internal.
|
|
91
|
+
*
|
|
92
|
+
* The listing of interfaces may be found here:
|
|
93
|
+
*
|
|
94
|
+
* * @subpage lcb_apiattr_committed
|
|
95
|
+
* * @subpage lcb_apiattr_uncommitted
|
|
96
|
+
* * @subpage lcb_apiattr_volatile
|
|
97
|
+
* * @subpage deprecated
|
|
98
|
+
* * @subpage lcb_apiattr_internal
|
|
99
|
+
**/
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* @page lcb_apiattr_committed Committed Interfaces
|
|
103
|
+
* @see @ref lcb_attributes
|
|
104
|
+
*
|
|
105
|
+
* @page lcb_apiattr_uncommitted Uncomitted Interfaces
|
|
106
|
+
* @see @ref lcb_attributes
|
|
107
|
+
*
|
|
108
|
+
* @page lcb_apiattr_volatile Volatile Interfaces
|
|
109
|
+
* @see @ref lcb_attributes
|
|
110
|
+
*
|
|
111
|
+
* @page deprecated Deprecated Interfaces
|
|
112
|
+
* @see @ref lcb_attributes
|
|
113
|
+
|
|
114
|
+
* @page lcb_apiattr_internal Internal Interfaces
|
|
115
|
+
* @see @ref lcb_attributes
|
|
116
|
+
*
|
|
117
|
+
*/
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
# cbc-n1qlback(1) - Stress Test for Couchbase Query (N1QL)
|
|
2
|
+
|
|
3
|
+
## SYNOPSIS
|
|
4
|
+
|
|
5
|
+
`cbc-n1qlback` -f QUERYFILE [_OPTIONS_]
|
|
6
|
+
|
|
7
|
+
## DESCRIPTION
|
|
8
|
+
|
|
9
|
+
`cbc-n1qlback` creates a specified number of threads each executing a set
|
|
10
|
+
of user defined queries.
|
|
11
|
+
|
|
12
|
+
`cbc-n1qlback` requires that it be passed the path to a file containing
|
|
13
|
+
the queries to execute; one per line. The query should be in the format of
|
|
14
|
+
the actual HTTP POST body (in JSON format) to be sent to the server.
|
|
15
|
+
For simple queries, only the `statement` field needs to be set:
|
|
16
|
+
|
|
17
|
+
{"statement":"SELECT country FROM `travel-sample`"}
|
|
18
|
+
{"statement":"SELECT country, COUNT(country) FROM `travel-sample` GROUP BY country"}
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
For more complex queries (for example, placeholders, custom options), you may
|
|
22
|
+
refer to the N1QL REST API reference.
|
|
23
|
+
|
|
24
|
+
`n1qlback` requires that any resources (data items, indexes) are already
|
|
25
|
+
defined.
|
|
26
|
+
|
|
27
|
+
## OPTIONS
|
|
28
|
+
|
|
29
|
+
The following options control workload generation:
|
|
30
|
+
|
|
31
|
+
* `-f` `--queryfile`=_PATH_:
|
|
32
|
+
Path to a file containing the query bodies to execute in JSON format, one
|
|
33
|
+
query per line. See above for the format.
|
|
34
|
+
|
|
35
|
+
* `-t`, `--num-threads`=_NTHREADS_:
|
|
36
|
+
Set the number of threads (and thus the number of client instances) to run
|
|
37
|
+
concurrently. Each thread is assigned its own client object.
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
The following options control how `cbc-n1qlback` connects to the cluster
|
|
41
|
+
|
|
42
|
+
@@common-options.markdown@@
|
|
43
|
+
|
|
44
|
+
* `-e`, `--error-log`=_PATH_:
|
|
45
|
+
Path to a file, where the command will write failed queries along with error details.
|
|
46
|
+
Use this option to figure out why `ERRORS` metric is not zero.
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
<a name="additional-options"></a>
|
|
50
|
+
## ADDITIONAL OPTIONS
|
|
51
|
+
|
|
52
|
+
The following options may be included in the connection string (via the `-U`
|
|
53
|
+
option) as URI-style query params (e.g.
|
|
54
|
+
`couchbase://host/bucket?option1=value1&option2=value2`) or as individual
|
|
55
|
+
key=value pairs passed to the `-D` switch (e.g. `-Doption1=value1
|
|
56
|
+
-Doption2=value`). The `-D` will internally build the connection string,
|
|
57
|
+
and is provided as a convenience for options to be easily passed on the
|
|
58
|
+
command-line
|
|
59
|
+
|
|
60
|
+
@@common-additional-options.markdown@@
|
|
61
|
+
|
|
62
|
+
## EXAMPLES
|
|
63
|
+
|
|
64
|
+
The following will create a file with 3 queries and 5 threads alternating
|
|
65
|
+
between them. It also creates indexes on the `travel-sample` bucket
|
|
66
|
+
|
|
67
|
+
cbc n1ql -U couchbase://192.168.72.101/a_bucket 'CREATE INDEX ix_name ON `travel-sample`(name)'
|
|
68
|
+
cbc n1ql -U couchbase://192.168.72.101/a_bucket 'CREATE INDEX ix_country ON `travel-sample`(country)'
|
|
69
|
+
|
|
70
|
+
cat queries.txt <<EOF
|
|
71
|
+
{"statement":"SELECT country FROM `travel-sample` WHERE `travel-sample`.country = \"United States\""}
|
|
72
|
+
{"statement":"SELECT name FROM `travel-sample` LIMIT 10"}
|
|
73
|
+
{"statement":"SELECT country, COUNT(country) FROM `travel-sample` GROUP BY country"}
|
|
74
|
+
EOF
|
|
75
|
+
|
|
76
|
+
cbc-n1qlback -U couchbase://192.168.72.101/a_bucket -t 5 -f queries.txt
|
|
77
|
+
|
|
78
|
+
## BUGS
|
|
79
|
+
|
|
80
|
+
This command's options are subject to change.
|
|
81
|
+
|
|
82
|
+
## SEE ALSO
|
|
83
|
+
|
|
84
|
+
cbc(1), cbc-pillowfight(1), cbcrc(4)
|
|
85
|
+
|
|
86
|
+
## HISTORY
|
|
87
|
+
|
|
88
|
+
The `cbc-n1qlback` tool was first introduced in libcouchbase 2.4.10
|
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
# cbc-pillowfight(1) - Stress Test for Couchbase Client and Cluster
|
|
2
|
+
|
|
3
|
+
## SYNOPSIS
|
|
4
|
+
|
|
5
|
+
`cbc-pillowfight` [_OPTIONS_]
|
|
6
|
+
|
|
7
|
+
## DESCRIPTION
|
|
8
|
+
|
|
9
|
+
`cbc-pillowfight` creates a specified number of threads each looping and
|
|
10
|
+
performing get and set operations within the cluster.
|
|
11
|
+
|
|
12
|
+
The stress test operates in the following order
|
|
13
|
+
|
|
14
|
+
1. It will pre-load the items in the cluster (set by the `--num-items` option)
|
|
15
|
+
|
|
16
|
+
2. Once the items are all loaded into the cluster, it will access all the items
|
|
17
|
+
(within the `--num-items`) specification, using a combination of storage and
|
|
18
|
+
retrieval operations (the proportion of retrieval and storage operations are
|
|
19
|
+
controlled via the `--set-pct` option).
|
|
20
|
+
|
|
21
|
+
3. Operations are scheduled in _batches_. The batches represent a single pipeline
|
|
22
|
+
(or network buffer) which is filled with a certain amount of operations (see the
|
|
23
|
+
`--batch-size` option). These batch sizes are then sent over to the cluster and
|
|
24
|
+
the requests are serviced by it.
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
### Tuning
|
|
28
|
+
|
|
29
|
+
Getting the right benchmark numbers highly depends on the type of environment
|
|
30
|
+
the client is being run in. The following provides some information about
|
|
31
|
+
specific settings which may make `pillowfight` generate more operations.
|
|
32
|
+
|
|
33
|
+
* Increasing the batch size will typically speed up operations, but increasing
|
|
34
|
+
the batch size too much will actually slow it down. Additionally, very high
|
|
35
|
+
batch sizes will cause high memory usage.
|
|
36
|
+
|
|
37
|
+
* Adding additional threads will create additional client objects and connections,
|
|
38
|
+
potentially increasing performance. Adding too many threads will cause local
|
|
39
|
+
and network resource congestion.
|
|
40
|
+
|
|
41
|
+
* Decreasing the item sizes (the `--min-size` and `--max-size` options) will
|
|
42
|
+
always yield higher performance in terms of operationd-per-second.
|
|
43
|
+
|
|
44
|
+
* Limiting the working set (i.e. `--num-items`) will decrease the working set
|
|
45
|
+
within the cluster, thereby increasing the chance that a given item will be
|
|
46
|
+
inside the server's CPU cache (which is extremely fast), rather than in main
|
|
47
|
+
memory (slower), or disk (much slower)
|
|
48
|
+
|
|
49
|
+
The benchmark tool sets up SIGQUIT (CTRL-/) handler and dumps useful diagnostics
|
|
50
|
+
and metrics to STDERR on this signal.
|
|
51
|
+
|
|
52
|
+
## OPTIONS
|
|
53
|
+
|
|
54
|
+
Options may be read either from the command line, or from a configuration file
|
|
55
|
+
(see cbcrc(4)):
|
|
56
|
+
|
|
57
|
+
The following options control workload generation:
|
|
58
|
+
|
|
59
|
+
* `-B`, `--batch-size`=_BATCHSIZE_:
|
|
60
|
+
This controls how many commands are scheduled per cycles. To simulate one operation
|
|
61
|
+
at a time, set this value to 1.
|
|
62
|
+
|
|
63
|
+
* `-I`, `--num-items`=_NUMITEMS_:
|
|
64
|
+
Set the _total_ number of items the workload will access within the cluster. This
|
|
65
|
+
will also determine the working set size at the server and may affect disk latencies
|
|
66
|
+
if set to a high number.
|
|
67
|
+
|
|
68
|
+
* `-p`, `--key-prefix`=_PREFIX_:
|
|
69
|
+
Set the prefix to prepend to all keys in the cluster. Useful if you do not wish the items
|
|
70
|
+
to conflict with existing data.
|
|
71
|
+
|
|
72
|
+
* `-t`, `--num-threads`=_NTHREADS_:
|
|
73
|
+
Set the number of threads (and thus the number of client instances) to run
|
|
74
|
+
concurrently. Each thread is assigned its own client object.
|
|
75
|
+
|
|
76
|
+
* `-r`, `--set-pct`=_PERCENTAGE_:
|
|
77
|
+
The percentage of operations which should be mutations. A value of 100 means
|
|
78
|
+
only mutations while a value of 0 means only retrievals.
|
|
79
|
+
|
|
80
|
+
* `-n`, `--no-population`:
|
|
81
|
+
By default `cbc-pillowfight` will load all the items (see `--num-items`) into
|
|
82
|
+
the cluster and then begin performing the normal workload. Specifying this
|
|
83
|
+
option bypasses this stage. Useful if the items have already been loaded in a
|
|
84
|
+
previous run.
|
|
85
|
+
|
|
86
|
+
* `--populate-only`:
|
|
87
|
+
Stop after population. Useful to populate buckets with large amounts of data.
|
|
88
|
+
|
|
89
|
+
* `-m`, `--min-size`=_MINSIZE_:
|
|
90
|
+
* `-M`, `--max-size`=_MAXSIZE_:
|
|
91
|
+
Specify the minimum and maximum value sizes to be stored into the cluster.
|
|
92
|
+
This is typically a range, in which case each value generated will be between
|
|
93
|
+
`--min-size` and `--max-size` bytes.
|
|
94
|
+
|
|
95
|
+
* `-E`, `--pause-at-end`:
|
|
96
|
+
When the workload completes, do not exit immediately, but wait for user input.
|
|
97
|
+
This is helpful for analyzing open socket connections and state.
|
|
98
|
+
|
|
99
|
+
* `-c`, `--num-cycles`:
|
|
100
|
+
Specify the number of times the workload should cycle. During each cycle
|
|
101
|
+
an amount of `--batch-size` operations are executed. Setting this to `-1`
|
|
102
|
+
will cause the workload to run infinitely.
|
|
103
|
+
|
|
104
|
+
* `--sequential`:
|
|
105
|
+
Specify that the access pattern should be done in a sequential manner. This
|
|
106
|
+
is useful for bulk-loading many documents in a single server.
|
|
107
|
+
|
|
108
|
+
* `--start-at`:
|
|
109
|
+
This specifies the starting offset for the items. The items by default are
|
|
110
|
+
generated with the key prefix (`--key-prefix`) up to the number of items
|
|
111
|
+
(`--num-items`). The `--start-at` value will increase the lower limit of
|
|
112
|
+
the items. This is useful to resume a previously cancelled load operation.
|
|
113
|
+
|
|
114
|
+
* `-T`, `--timings`:
|
|
115
|
+
Enabled timing recorded. Timing histogram will be dumped to STDERR on SIGQUIT
|
|
116
|
+
(CTRL-/). When specified second time, it will dump a histogram of command
|
|
117
|
+
timings and latencies to the screen every second.
|
|
118
|
+
|
|
119
|
+
* `-e`, `--expiry`=_SECONDS_:
|
|
120
|
+
Set the expiration time on the document for _SECONDS_ when performing each
|
|
121
|
+
operation. Note that setting this too low may cause not-found errors to
|
|
122
|
+
appear on the screen.
|
|
123
|
+
|
|
124
|
+
@@common-options.markdown@@
|
|
125
|
+
|
|
126
|
+
* `p`, `--persist-to`=_NUMNODES_:
|
|
127
|
+
Wait until the item has been persisted to at least `NUMNODES` nodes' disk. If
|
|
128
|
+
`NUMNODES` is 1 then wait until only the master node has persisted the item for
|
|
129
|
+
this key. You may not specify a number greater than the number of nodes actually
|
|
130
|
+
in the cluster. `-1` is special value, which mean to use all available nodes.
|
|
131
|
+
|
|
132
|
+
* `r` `--replicate-to`=_NREPLICAS_:
|
|
133
|
+
Wait until the item has been replicated to at least `NREPLICAS` replica nodes.
|
|
134
|
+
The bucket must be configured with at least one replica, and at least `NREPLICAS`
|
|
135
|
+
replica nodes must be online. `-1` is special value, which mean to use all
|
|
136
|
+
available replicas.
|
|
137
|
+
|
|
138
|
+
* `--lock`=_TIME_:
|
|
139
|
+
This will retrieve and lock an item before update, making it inaccessible for
|
|
140
|
+
modification until the update completed, or `TIME` has passed.
|
|
141
|
+
|
|
142
|
+
* `--json`:
|
|
143
|
+
Make `pillowfight` store document as JSON rather than binary. This will
|
|
144
|
+
allow the documents to nominally be analyzed by other Couchbase services
|
|
145
|
+
such as Query and MapReduce.
|
|
146
|
+
|
|
147
|
+
JSON documents are created by creating an empty JSON object (`{}`) and then
|
|
148
|
+
repeated populating it with `Field_%d` property names (where `%d` is `1` and
|
|
149
|
+
higher), and setting its value to a repeating asterisk `*` up to 16 times:
|
|
150
|
+
|
|
151
|
+
{
|
|
152
|
+
"Field_1": "****************",
|
|
153
|
+
"Field_2": "****************",
|
|
154
|
+
"Field_3": "****************",
|
|
155
|
+
"Field_4": "****************",
|
|
156
|
+
"Field_5": "********"
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
When using document size constraints, be aware that the minimum and maximum
|
|
160
|
+
sizes (`--min-size` and `--max-size`) are not strict limits, and that the
|
|
161
|
+
resultant sizes may be bigger or smaller by a few bytes in order to satisfy
|
|
162
|
+
the requirements of proper JSON syntax.
|
|
163
|
+
|
|
164
|
+
* `--noop`:
|
|
165
|
+
Use couchbase NOOP operations when running the workload. This mode ignores
|
|
166
|
+
population, and all other document operations. Useful as the most lightweight
|
|
167
|
+
workload.
|
|
168
|
+
|
|
169
|
+
* `--subdoc`:
|
|
170
|
+
Use couchbase sub-document operations when running the workload. In this
|
|
171
|
+
mode `pillowfight` will use Couchbase
|
|
172
|
+
[sub-document operations](http://blog.couchbase.com/2016/february/subdoc-explained)
|
|
173
|
+
to perform gets and sets of data. This option must be used with `--json`
|
|
174
|
+
|
|
175
|
+
* `--pathcount`:
|
|
176
|
+
Specify the number of paths a single sub-document operation should contain.
|
|
177
|
+
By default, each subdoc operation operates on only a single path within the
|
|
178
|
+
document. You can specify multiple paths to atomically executed multiple
|
|
179
|
+
subdoc operations within a single command.
|
|
180
|
+
|
|
181
|
+
This option does not affect the `--batch-size` option as a subdoc command
|
|
182
|
+
is considered as a single command (with respect to batching) regardless of
|
|
183
|
+
how many operations it contains.
|
|
184
|
+
|
|
185
|
+
<a name="additional-options"></a>
|
|
186
|
+
## ADDITIONAL OPTIONS
|
|
187
|
+
|
|
188
|
+
The following options may be included in the connection string (via the `-U`
|
|
189
|
+
option) as URI-style query params (e.g.
|
|
190
|
+
`couchbase://host/bucket?option1=value1&option2=value2`) or as individual
|
|
191
|
+
key=value pairs passed to the `-D` switch (e.g. `-Doption1=value1
|
|
192
|
+
-Doption2=value`). The `-D` will internally build the connection string,
|
|
193
|
+
and is provided as a convenience for options to be easily passed on the
|
|
194
|
+
command-line
|
|
195
|
+
|
|
196
|
+
@@common-additional-options.markdown@@
|
|
197
|
+
|
|
198
|
+
## EXAMPLES
|
|
199
|
+
|
|
200
|
+
### CONNECTION EXAMPLES
|
|
201
|
+
|
|
202
|
+
The following examples show how to connect `pillowfight` to different types
|
|
203
|
+
of cluster configurations.
|
|
204
|
+
|
|
205
|
+
Connect to a bucket (`a_bucket`) on a cluster on a remote host (for servers version 5.x+).
|
|
206
|
+
It uses account 'myname' and asks password interactively:
|
|
207
|
+
|
|
208
|
+
cbc-pillowfight -U couchbase://192.168.33.101/a_bucket -u myname -P-
|
|
209
|
+
|
|
210
|
+
Run against a password-less bucket (`a_bucket`) on a cluster on a remote host (for servers older than 5.x):
|
|
211
|
+
|
|
212
|
+
cbc-pillowfight -U couchbase://192.168.33.101/a_bucket
|
|
213
|
+
|
|
214
|
+
Connect to an SSL cluster at `secure.net`. The certificate for the cluster is
|
|
215
|
+
stored locally at `/home/couchbase/couchbase_cert.pem`:
|
|
216
|
+
|
|
217
|
+
cbc-pillowfight -U couchbases://secure.net/topsecret_bucket?certpath=/home/couchbase/couchbase_cert.pem
|
|
218
|
+
|
|
219
|
+
Connect to an SSL cluster at `secure.net`, ignoring certificate verification.
|
|
220
|
+
This is insecure but handy for testing:
|
|
221
|
+
|
|
222
|
+
cbc-pillowfight -U couchbases://secure.net/topsecret_bucket?ssl=no_verify
|
|
223
|
+
|
|
224
|
+
Connect to a password protected bucket (`protected`) on a remote host (for servers older than 5.x):
|
|
225
|
+
|
|
226
|
+
cbc-pillowfight -U couchbase://remote.host.net/protected -P -
|
|
227
|
+
Bucket password:
|
|
228
|
+
...
|
|
229
|
+
|
|
230
|
+
Connect to a password protected bucket (for servers older than 5.x), specifying the password on the
|
|
231
|
+
command line (INSECURE, but useful for testing dummy environments)
|
|
232
|
+
|
|
233
|
+
cbc-pillowfight -U couchbase://remote.host.net/protected -P t0ps3cr3t
|
|
234
|
+
|
|
235
|
+
Connect to a bucket running on a cluster with a custom REST API port
|
|
236
|
+
|
|
237
|
+
cbc-pillowfight -U http://localhost:9000/default
|
|
238
|
+
|
|
239
|
+
Connec to bucket running on a cluster with a custom memcached port
|
|
240
|
+
|
|
241
|
+
cbc-pillowfight -U couchbase://localhost:12000/default
|
|
242
|
+
|
|
243
|
+
Connect to a *memcached* (http://memcached.org)
|
|
244
|
+
cluster using the binary protocol. A vanilla memcached cluster is not the same
|
|
245
|
+
as a memcached bucket residing within a couchbase cluster (use the normal
|
|
246
|
+
`couchbase://` scheme for that):
|
|
247
|
+
|
|
248
|
+
cbc-pillowfight -U memcached://host1,host2,host3,host4
|
|
249
|
+
|
|
250
|
+
Connect to an SSL cluster at `secure.net`:
|
|
251
|
+
|
|
252
|
+
cbc-pillowfight -U couchbases://secure.net/topsecret_bucket
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
Run against a bucket (`a_bucket`) on a cluster on a remote host:
|
|
256
|
+
|
|
257
|
+
cbc-pillowfight -U couchbase://192.168.33.101/a_bucket
|
|
258
|
+
|
|
259
|
+
### BENCHMARK EXAMPLES
|
|
260
|
+
|
|
261
|
+
The following examples show how to configure different types of workloads with
|
|
262
|
+
pillowfight.
|
|
263
|
+
|
|
264
|
+
Run with 20 threads/instances, each doing one operation at a time:
|
|
265
|
+
|
|
266
|
+
cbc-pillowfight -t 20 -B 1
|
|
267
|
+
|
|
268
|
+
Run 100 iterations of 2MB item sizes, using a dataset of 50 items
|
|
269
|
+
|
|
270
|
+
cbc-pillowfight -M $(1024*1024) -m $(1024*1024) -c 100 -I 50
|
|
271
|
+
|
|
272
|
+
Use JSON documents of 100k each
|
|
273
|
+
|
|
274
|
+
cbc-pillowfight --json -m 100000 -M 100000
|
|
275
|
+
|
|
276
|
+
Stress-test sub-document mutations
|
|
277
|
+
|
|
278
|
+
cbc-pillowfight --json --subdoc --set-pct 100
|
|
279
|
+
|
|
280
|
+
|
|
281
|
+
## TODO
|
|
282
|
+
|
|
283
|
+
Rather than spawning threads for multiple instances, offer a way to have multiple
|
|
284
|
+
instances function cooperatively inside an event loop.
|
|
285
|
+
|
|
286
|
+
## BUGS
|
|
287
|
+
|
|
288
|
+
This command's options are subject to change.
|
|
289
|
+
|
|
290
|
+
## SEE ALSO
|
|
291
|
+
|
|
292
|
+
cbc(1), cbcrc(4)
|
|
293
|
+
|
|
294
|
+
## HISTORY
|
|
295
|
+
|
|
296
|
+
The `cbc-pillowfight` tool was first introduced in libcouchbase 2.0.7
|