rn-leveldb 3.11.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.
- package/LICENSE +21 -0
- package/README.md +92 -0
- package/android/.project +34 -0
- package/android/.settings/org.eclipse.buildship.core.prefs +13 -0
- package/android/CMakeLists.txt +69 -0
- package/android/build.gradle +125 -0
- package/android/cpp-adapter.cpp +19 -0
- package/android/gradle.properties +6 -0
- package/android/src/main/AndroidManifest.xml +4 -0
- package/android/src/main/java/com/reactnativeleveldb/LeveldbModule.java +57 -0
- package/android/src/main/java/com/reactnativeleveldb/LeveldbPackage.java +28 -0
- package/cpp/leveldb/.appveyor.yml +36 -0
- package/cpp/leveldb/.clang-format +18 -0
- package/cpp/leveldb/.travis.yml +88 -0
- package/cpp/leveldb/AUTHORS +12 -0
- package/cpp/leveldb/CMakeLists.txt +495 -0
- package/cpp/leveldb/CONTRIBUTING.md +36 -0
- package/cpp/leveldb/LICENSE +27 -0
- package/cpp/leveldb/NEWS +17 -0
- package/cpp/leveldb/README.md +231 -0
- package/cpp/leveldb/TODO +14 -0
- package/cpp/leveldb/benchmarks/db_bench.cc +990 -0
- package/cpp/leveldb/benchmarks/db_bench_sqlite3.cc +726 -0
- package/cpp/leveldb/benchmarks/db_bench_tree_db.cc +531 -0
- package/cpp/leveldb/cmake/leveldbConfig.cmake.in +9 -0
- package/cpp/leveldb/db/autocompact_test.cc +115 -0
- package/cpp/leveldb/db/builder.cc +82 -0
- package/cpp/leveldb/db/builder.h +30 -0
- package/cpp/leveldb/db/c.cc +562 -0
- package/cpp/leveldb/db/c_test.c +384 -0
- package/cpp/leveldb/db/corruption_test.cc +367 -0
- package/cpp/leveldb/db/db_impl.cc +1554 -0
- package/cpp/leveldb/db/db_impl.h +217 -0
- package/cpp/leveldb/db/db_iter.cc +318 -0
- package/cpp/leveldb/db/db_iter.h +26 -0
- package/cpp/leveldb/db/db_test.cc +2305 -0
- package/cpp/leveldb/db/dbformat.cc +136 -0
- package/cpp/leveldb/db/dbformat.h +224 -0
- package/cpp/leveldb/db/dbformat_test.cc +133 -0
- package/cpp/leveldb/db/dumpfile.cc +232 -0
- package/cpp/leveldb/db/fault_injection_test.cc +555 -0
- package/cpp/leveldb/db/filename.cc +141 -0
- package/cpp/leveldb/db/filename.h +83 -0
- package/cpp/leveldb/db/filename_test.cc +132 -0
- package/cpp/leveldb/db/leveldbutil.cc +64 -0
- package/cpp/leveldb/db/log_format.h +35 -0
- package/cpp/leveldb/db/log_reader.cc +274 -0
- package/cpp/leveldb/db/log_reader.h +112 -0
- package/cpp/leveldb/db/log_test.cc +563 -0
- package/cpp/leveldb/db/log_writer.cc +111 -0
- package/cpp/leveldb/db/log_writer.h +54 -0
- package/cpp/leveldb/db/memtable.cc +137 -0
- package/cpp/leveldb/db/memtable.h +87 -0
- package/cpp/leveldb/db/recovery_test.cc +339 -0
- package/cpp/leveldb/db/repair.cc +451 -0
- package/cpp/leveldb/db/skiplist.h +382 -0
- package/cpp/leveldb/db/skiplist_test.cc +373 -0
- package/cpp/leveldb/db/snapshot.h +95 -0
- package/cpp/leveldb/db/table_cache.cc +120 -0
- package/cpp/leveldb/db/table_cache.h +57 -0
- package/cpp/leveldb/db/version_edit.cc +257 -0
- package/cpp/leveldb/db/version_edit.h +106 -0
- package/cpp/leveldb/db/version_edit_test.cc +46 -0
- package/cpp/leveldb/db/version_set.cc +1562 -0
- package/cpp/leveldb/db/version_set.h +393 -0
- package/cpp/leveldb/db/version_set_test.cc +336 -0
- package/cpp/leveldb/db/write_batch.cc +150 -0
- package/cpp/leveldb/db/write_batch_internal.h +45 -0
- package/cpp/leveldb/db/write_batch_test.cc +137 -0
- package/cpp/leveldb/doc/benchmark.html +459 -0
- package/cpp/leveldb/doc/impl.md +172 -0
- package/cpp/leveldb/doc/index.md +523 -0
- package/cpp/leveldb/doc/log_format.md +75 -0
- package/cpp/leveldb/doc/table_format.md +107 -0
- package/cpp/leveldb/helpers/memenv/memenv.cc +390 -0
- package/cpp/leveldb/helpers/memenv/memenv.h +22 -0
- package/cpp/leveldb/helpers/memenv/memenv_test.cc +264 -0
- package/cpp/leveldb/include/leveldb/c.h +270 -0
- package/cpp/leveldb/include/leveldb/cache.h +111 -0
- package/cpp/leveldb/include/leveldb/comparator.h +64 -0
- package/cpp/leveldb/include/leveldb/db.h +167 -0
- package/cpp/leveldb/include/leveldb/dumpfile.h +28 -0
- package/cpp/leveldb/include/leveldb/env.h +417 -0
- package/cpp/leveldb/include/leveldb/export.h +33 -0
- package/cpp/leveldb/include/leveldb/filter_policy.h +72 -0
- package/cpp/leveldb/include/leveldb/iterator.h +112 -0
- package/cpp/leveldb/include/leveldb/options.h +187 -0
- package/cpp/leveldb/include/leveldb/slice.h +114 -0
- package/cpp/leveldb/include/leveldb/status.h +122 -0
- package/cpp/leveldb/include/leveldb/table.h +84 -0
- package/cpp/leveldb/include/leveldb/table_builder.h +93 -0
- package/cpp/leveldb/include/leveldb/write_batch.h +83 -0
- package/cpp/leveldb/issues/issue178_test.cc +90 -0
- package/cpp/leveldb/issues/issue200_test.cc +59 -0
- package/cpp/leveldb/issues/issue320_test.cc +131 -0
- package/cpp/leveldb/port/README.md +10 -0
- package/cpp/leveldb/port/port.h +19 -0
- package/cpp/leveldb/port/port_config.h.in +33 -0
- package/cpp/leveldb/port/port_example.h +100 -0
- package/cpp/leveldb/port/port_stdcxx.h +151 -0
- package/cpp/leveldb/port/thread_annotations.h +108 -0
- package/cpp/leveldb/table/block.cc +267 -0
- package/cpp/leveldb/table/block.h +44 -0
- package/cpp/leveldb/table/block_builder.cc +107 -0
- package/cpp/leveldb/table/block_builder.h +54 -0
- package/cpp/leveldb/table/filter_block.cc +106 -0
- package/cpp/leveldb/table/filter_block.h +68 -0
- package/cpp/leveldb/table/filter_block_test.cc +127 -0
- package/cpp/leveldb/table/format.cc +141 -0
- package/cpp/leveldb/table/format.h +99 -0
- package/cpp/leveldb/table/iterator.cc +76 -0
- package/cpp/leveldb/table/iterator_wrapper.h +92 -0
- package/cpp/leveldb/table/merger.cc +191 -0
- package/cpp/leveldb/table/merger.h +26 -0
- package/cpp/leveldb/table/table.cc +271 -0
- package/cpp/leveldb/table/table_builder.cc +265 -0
- package/cpp/leveldb/table/table_test.cc +834 -0
- package/cpp/leveldb/table/two_level_iterator.cc +171 -0
- package/cpp/leveldb/table/two_level_iterator.h +31 -0
- package/cpp/leveldb/third_party/benchmark/.clang-format +5 -0
- package/cpp/leveldb/third_party/benchmark/.github/ISSUE_TEMPLATE/bug_report.md +32 -0
- package/cpp/leveldb/third_party/benchmark/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
- package/cpp/leveldb/third_party/benchmark/.github/workflows/build-and-test.yml +38 -0
- package/cpp/leveldb/third_party/benchmark/.github/workflows/pylint.yml +26 -0
- package/cpp/leveldb/third_party/benchmark/.github/workflows/test_bindings.yml +24 -0
- package/cpp/leveldb/third_party/benchmark/.travis-libcxx-setup.sh +28 -0
- package/cpp/leveldb/third_party/benchmark/.travis.yml +231 -0
- package/cpp/leveldb/third_party/benchmark/.ycm_extra_conf.py +115 -0
- package/cpp/leveldb/third_party/benchmark/AUTHORS +58 -0
- package/cpp/leveldb/third_party/benchmark/BUILD.bazel +44 -0
- package/cpp/leveldb/third_party/benchmark/CMakeLists.txt +287 -0
- package/cpp/leveldb/third_party/benchmark/CONTRIBUTING.md +58 -0
- package/cpp/leveldb/third_party/benchmark/CONTRIBUTORS +83 -0
- package/cpp/leveldb/third_party/benchmark/LICENSE +202 -0
- package/cpp/leveldb/third_party/benchmark/README.md +1323 -0
- package/cpp/leveldb/third_party/benchmark/WORKSPACE +51 -0
- package/cpp/leveldb/third_party/benchmark/_config.yml +1 -0
- package/cpp/leveldb/third_party/benchmark/appveyor.yml +50 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/BUILD +3 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/build_defs.bzl +25 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/google_benchmark/BUILD +38 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/google_benchmark/__init__.py +156 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/google_benchmark/benchmark.cc +180 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/google_benchmark/example.py +136 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/pybind11.BUILD +20 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/python_headers.BUILD +6 -0
- package/cpp/leveldb/third_party/benchmark/bindings/python/requirements.txt +2 -0
- package/cpp/leveldb/third_party/benchmark/cmake/AddCXXCompilerFlag.cmake +74 -0
- package/cpp/leveldb/third_party/benchmark/cmake/CXXFeatureCheck.cmake +69 -0
- package/cpp/leveldb/third_party/benchmark/cmake/Config.cmake.in +1 -0
- package/cpp/leveldb/third_party/benchmark/cmake/GetGitVersion.cmake +54 -0
- package/cpp/leveldb/third_party/benchmark/cmake/GoogleTest.cmake +41 -0
- package/cpp/leveldb/third_party/benchmark/cmake/GoogleTest.cmake.in +58 -0
- package/cpp/leveldb/third_party/benchmark/cmake/benchmark.pc.in +12 -0
- package/cpp/leveldb/third_party/benchmark/cmake/gnu_posix_regex.cpp +12 -0
- package/cpp/leveldb/third_party/benchmark/cmake/llvm-toolchain.cmake +8 -0
- package/cpp/leveldb/third_party/benchmark/cmake/posix_regex.cpp +14 -0
- package/cpp/leveldb/third_party/benchmark/cmake/split_list.cmake +3 -0
- package/cpp/leveldb/third_party/benchmark/cmake/std_regex.cpp +10 -0
- package/cpp/leveldb/third_party/benchmark/cmake/steady_clock.cpp +7 -0
- package/cpp/leveldb/third_party/benchmark/cmake/thread_safety_attributes.cpp +4 -0
- package/cpp/leveldb/third_party/benchmark/conan/CMakeLists.txt +7 -0
- package/cpp/leveldb/third_party/benchmark/conan/test_package/CMakeLists.txt +10 -0
- package/cpp/leveldb/third_party/benchmark/conan/test_package/conanfile.py +19 -0
- package/cpp/leveldb/third_party/benchmark/conan/test_package/test_package.cpp +18 -0
- package/cpp/leveldb/third_party/benchmark/conanfile.py +79 -0
- package/cpp/leveldb/third_party/benchmark/dependencies.md +18 -0
- package/cpp/leveldb/third_party/benchmark/docs/AssemblyTests.md +147 -0
- package/cpp/leveldb/third_party/benchmark/docs/_config.yml +1 -0
- package/cpp/leveldb/third_party/benchmark/docs/releasing.md +16 -0
- package/cpp/leveldb/third_party/benchmark/docs/tools.md +203 -0
- package/cpp/leveldb/third_party/benchmark/include/benchmark/benchmark.h +1604 -0
- package/cpp/leveldb/third_party/benchmark/requirements.txt +2 -0
- package/cpp/leveldb/third_party/benchmark/setup.py +140 -0
- package/cpp/leveldb/third_party/benchmark/src/CMakeLists.txt +114 -0
- package/cpp/leveldb/third_party/benchmark/src/arraysize.h +33 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark.cc +499 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_api_internal.cc +15 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_api_internal.h +53 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_main.cc +17 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_name.cc +58 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_register.cc +515 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_register.h +108 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_runner.cc +362 -0
- package/cpp/leveldb/third_party/benchmark/src/benchmark_runner.h +51 -0
- package/cpp/leveldb/third_party/benchmark/src/check.h +82 -0
- package/cpp/leveldb/third_party/benchmark/src/colorprint.cc +188 -0
- package/cpp/leveldb/third_party/benchmark/src/colorprint.h +33 -0
- package/cpp/leveldb/third_party/benchmark/src/commandlineflags.cc +228 -0
- package/cpp/leveldb/third_party/benchmark/src/commandlineflags.h +103 -0
- package/cpp/leveldb/third_party/benchmark/src/complexity.cc +238 -0
- package/cpp/leveldb/third_party/benchmark/src/complexity.h +55 -0
- package/cpp/leveldb/third_party/benchmark/src/console_reporter.cc +177 -0
- package/cpp/leveldb/third_party/benchmark/src/counter.cc +80 -0
- package/cpp/leveldb/third_party/benchmark/src/counter.h +32 -0
- package/cpp/leveldb/third_party/benchmark/src/csv_reporter.cc +154 -0
- package/cpp/leveldb/third_party/benchmark/src/cycleclock.h +211 -0
- package/cpp/leveldb/third_party/benchmark/src/internal_macros.h +102 -0
- package/cpp/leveldb/third_party/benchmark/src/json_reporter.cc +255 -0
- package/cpp/leveldb/third_party/benchmark/src/log.h +74 -0
- package/cpp/leveldb/third_party/benchmark/src/mutex.h +155 -0
- package/cpp/leveldb/third_party/benchmark/src/re.h +158 -0
- package/cpp/leveldb/third_party/benchmark/src/reporter.cc +105 -0
- package/cpp/leveldb/third_party/benchmark/src/sleep.cc +67 -0
- package/cpp/leveldb/third_party/benchmark/src/sleep.h +15 -0
- package/cpp/leveldb/third_party/benchmark/src/statistics.cc +193 -0
- package/cpp/leveldb/third_party/benchmark/src/statistics.h +37 -0
- package/cpp/leveldb/third_party/benchmark/src/string_util.cc +255 -0
- package/cpp/leveldb/third_party/benchmark/src/string_util.h +59 -0
- package/cpp/leveldb/third_party/benchmark/src/sysinfo.cc +716 -0
- package/cpp/leveldb/third_party/benchmark/src/thread_manager.h +64 -0
- package/cpp/leveldb/third_party/benchmark/src/thread_timer.h +86 -0
- package/cpp/leveldb/third_party/benchmark/src/timers.cc +245 -0
- package/cpp/leveldb/third_party/benchmark/src/timers.h +48 -0
- package/cpp/leveldb/third_party/benchmark/test/AssemblyTests.cmake +46 -0
- package/cpp/leveldb/third_party/benchmark/test/BUILD +73 -0
- package/cpp/leveldb/third_party/benchmark/test/CMakeLists.txt +263 -0
- package/cpp/leveldb/third_party/benchmark/test/args_product_test.cc +77 -0
- package/cpp/leveldb/third_party/benchmark/test/basic_test.cc +136 -0
- package/cpp/leveldb/third_party/benchmark/test/benchmark_gtest.cc +134 -0
- package/cpp/leveldb/third_party/benchmark/test/benchmark_name_gtest.cc +74 -0
- package/cpp/leveldb/third_party/benchmark/test/benchmark_test.cc +245 -0
- package/cpp/leveldb/third_party/benchmark/test/clobber_memory_assembly_test.cc +64 -0
- package/cpp/leveldb/third_party/benchmark/test/commandlineflags_gtest.cc +201 -0
- package/cpp/leveldb/third_party/benchmark/test/complexity_test.cc +213 -0
- package/cpp/leveldb/third_party/benchmark/test/cxx03_test.cc +63 -0
- package/cpp/leveldb/third_party/benchmark/test/diagnostics_test.cc +80 -0
- package/cpp/leveldb/third_party/benchmark/test/display_aggregates_only_test.cc +43 -0
- package/cpp/leveldb/third_party/benchmark/test/donotoptimize_assembly_test.cc +163 -0
- package/cpp/leveldb/third_party/benchmark/test/donotoptimize_test.cc +52 -0
- package/cpp/leveldb/third_party/benchmark/test/filter_test.cc +104 -0
- package/cpp/leveldb/third_party/benchmark/test/fixture_test.cc +51 -0
- package/cpp/leveldb/third_party/benchmark/test/internal_threading_test.cc +184 -0
- package/cpp/leveldb/third_party/benchmark/test/link_main_test.cc +8 -0
- package/cpp/leveldb/third_party/benchmark/test/map_test.cc +57 -0
- package/cpp/leveldb/third_party/benchmark/test/memory_manager_test.cc +44 -0
- package/cpp/leveldb/third_party/benchmark/test/multiple_ranges_test.cc +96 -0
- package/cpp/leveldb/third_party/benchmark/test/options_test.cc +75 -0
- package/cpp/leveldb/third_party/benchmark/test/output_test.h +213 -0
- package/cpp/leveldb/third_party/benchmark/test/output_test_helper.cc +515 -0
- package/cpp/leveldb/third_party/benchmark/test/register_benchmark_test.cc +184 -0
- package/cpp/leveldb/third_party/benchmark/test/report_aggregates_only_test.cc +39 -0
- package/cpp/leveldb/third_party/benchmark/test/reporter_output_test.cc +747 -0
- package/cpp/leveldb/third_party/benchmark/test/skip_with_error_test.cc +195 -0
- package/cpp/leveldb/third_party/benchmark/test/state_assembly_test.cc +68 -0
- package/cpp/leveldb/third_party/benchmark/test/statistics_gtest.cc +28 -0
- package/cpp/leveldb/third_party/benchmark/test/string_util_gtest.cc +153 -0
- package/cpp/leveldb/third_party/benchmark/test/templated_fixture_test.cc +28 -0
- package/cpp/leveldb/third_party/benchmark/test/user_counters_tabular_test.cc +285 -0
- package/cpp/leveldb/third_party/benchmark/test/user_counters_test.cc +531 -0
- package/cpp/leveldb/third_party/benchmark/test/user_counters_thousands_test.cc +173 -0
- package/cpp/leveldb/third_party/benchmark/tools/BUILD.bazel +19 -0
- package/cpp/leveldb/third_party/benchmark/tools/compare.py +429 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/Inputs/test1_run1.json +119 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/Inputs/test1_run2.json +119 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/Inputs/test2_run.json +81 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/Inputs/test3_run0.json +65 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/Inputs/test3_run1.json +65 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/__init__.py +8 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/report.py +903 -0
- package/cpp/leveldb/third_party/benchmark/tools/gbench/util.py +163 -0
- package/cpp/leveldb/third_party/benchmark/tools/requirements.txt +1 -0
- package/cpp/leveldb/third_party/benchmark/tools/strip_asm.py +151 -0
- package/cpp/leveldb/third_party/googletest/.clang-format +4 -0
- package/cpp/leveldb/third_party/googletest/.travis.yml +73 -0
- package/cpp/leveldb/third_party/googletest/BUILD.bazel +179 -0
- package/cpp/leveldb/third_party/googletest/CMakeLists.txt +36 -0
- package/cpp/leveldb/third_party/googletest/CONTRIBUTING.md +142 -0
- package/cpp/leveldb/third_party/googletest/LICENSE +28 -0
- package/cpp/leveldb/third_party/googletest/README.md +132 -0
- package/cpp/leveldb/third_party/googletest/WORKSPACE +23 -0
- package/cpp/leveldb/third_party/googletest/appveyor.yml +154 -0
- package/cpp/leveldb/third_party/googletest/ci/build-linux-bazel.sh +37 -0
- package/cpp/leveldb/third_party/googletest/ci/build-platformio.sh +2 -0
- package/cpp/leveldb/third_party/googletest/ci/env-linux.sh +41 -0
- package/cpp/leveldb/third_party/googletest/ci/env-osx.sh +47 -0
- package/cpp/leveldb/third_party/googletest/ci/get-nprocessors.sh +48 -0
- package/cpp/leveldb/third_party/googletest/ci/install-linux.sh +49 -0
- package/cpp/leveldb/third_party/googletest/ci/install-osx.sh +40 -0
- package/cpp/leveldb/third_party/googletest/ci/install-platformio.sh +5 -0
- package/cpp/leveldb/third_party/googletest/ci/log-config.sh +51 -0
- package/cpp/leveldb/third_party/googletest/ci/travis.sh +44 -0
- package/cpp/leveldb/third_party/googletest/googlemock/CMakeLists.txt +233 -0
- package/cpp/leveldb/third_party/googletest/googlemock/CONTRIBUTORS +40 -0
- package/cpp/leveldb/third_party/googletest/googlemock/LICENSE +28 -0
- package/cpp/leveldb/third_party/googletest/googlemock/README.md +44 -0
- package/cpp/leveldb/third_party/googletest/googlemock/cmake/gmock.pc.in +10 -0
- package/cpp/leveldb/third_party/googletest/googlemock/cmake/gmock_main.pc.in +10 -0
- package/cpp/leveldb/third_party/googletest/googlemock/docs/cheat_sheet.md +770 -0
- package/cpp/leveldb/third_party/googletest/googlemock/docs/cook_book.md +4270 -0
- package/cpp/leveldb/third_party/googletest/googlemock/docs/for_dummies.md +700 -0
- package/cpp/leveldb/third_party/googletest/googlemock/docs/gmock_faq.md +396 -0
- package/cpp/leveldb/third_party/googletest/googlemock/docs/pump_manual.md +187 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-actions.h +1193 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-cardinalities.h +157 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-function-mocker.h +276 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-generated-actions.h +1884 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-generated-actions.h.pump +627 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-generated-function-mockers.h +752 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-generated-function-mockers.h.pump +227 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-generated-matchers.h +1097 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-generated-matchers.h.pump +346 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-matchers.h +4591 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-more-actions.h +162 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-more-matchers.h +92 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-nice-strict.h +215 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock-spec-builders.h +1985 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/gmock.h +101 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/custom/README.md +16 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/custom/gmock-generated-actions.h +10 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/custom/gmock-generated-actions.h.pump +12 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/custom/gmock-matchers.h +36 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/custom/gmock-port.h +39 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/gmock-internal-utils.h +472 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/gmock-port.h +87 -0
- package/cpp/leveldb/third_party/googletest/googlemock/include/gmock/internal/gmock-pp.h +271 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/README.md +5 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/fuse_gmock_files.py +240 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/LICENSE +203 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/README +34 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/README.cppclean +115 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/__init__.py +0 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/ast.py +1761 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/gmock_class.py +248 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/gmock_class_test.py +540 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/keywords.py +56 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/tokenize.py +284 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/cpp/utils.py +37 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/generator/gmock_gen.py +30 -0
- package/cpp/leveldb/third_party/googletest/googlemock/scripts/pump.py +856 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock-all.cc +46 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock-cardinalities.cc +155 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock-internal-utils.cc +200 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock-matchers.cc +462 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock-spec-builders.cc +892 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock.cc +213 -0
- package/cpp/leveldb/third_party/googletest/googlemock/src/gmock_main.cc +72 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/BUILD.bazel +110 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-actions_test.cc +1507 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-cardinalities_test.cc +429 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-function-mocker_nc.cc +16 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-function-mocker_nc_test.py +43 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-function-mocker_test.cc +696 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-generated-actions_test.cc +1064 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-generated-function-mockers_test.cc +659 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-generated-matchers_test.cc +1323 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-internal-utils_test.cc +732 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-matchers_test.cc +6913 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-more-actions_test.cc +698 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-nice-strict_test.cc +500 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-port_test.cc +42 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-pp-string_test.cc +206 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-pp_test.cc +83 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock-spec-builders_test.cc +2775 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_all_test.cc +49 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_ex_test.cc +80 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_leak_test.py +104 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_leak_test_.cc +99 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_link2_test.cc +39 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_link_test.cc +39 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_link_test.h +690 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_output_test.py +183 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_output_test_.cc +309 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_output_test_golden.txt +317 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_stress_test.cc +240 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_test.cc +181 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/gmock_test_utils.py +108 -0
- package/cpp/leveldb/third_party/googletest/googlemock/test/pump_test.py +182 -0
- package/cpp/leveldb/third_party/googletest/googletest/CMakeLists.txt +329 -0
- package/cpp/leveldb/third_party/googletest/googletest/CONTRIBUTORS +38 -0
- package/cpp/leveldb/third_party/googletest/googletest/LICENSE +28 -0
- package/cpp/leveldb/third_party/googletest/googletest/README.md +244 -0
- package/cpp/leveldb/third_party/googletest/googletest/cmake/Config.cmake.in +9 -0
- package/cpp/leveldb/third_party/googletest/googletest/cmake/gtest.pc.in +9 -0
- package/cpp/leveldb/third_party/googletest/googletest/cmake/gtest_main.pc.in +10 -0
- package/cpp/leveldb/third_party/googletest/googletest/cmake/internal_utils.cmake +358 -0
- package/cpp/leveldb/third_party/googletest/googletest/cmake/libgtest.la.in +21 -0
- package/cpp/leveldb/third_party/googletest/googletest/docs/advanced.md +2567 -0
- package/cpp/leveldb/third_party/googletest/googletest/docs/faq.md +753 -0
- package/cpp/leveldb/third_party/googletest/googletest/docs/pkgconfig.md +219 -0
- package/cpp/leveldb/third_party/googletest/googletest/docs/primer.md +579 -0
- package/cpp/leveldb/third_party/googletest/googletest/docs/samples.md +22 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-death-test.h +343 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-matchers.h +750 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-message.h +219 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-param-test.h +514 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-printers.h +928 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-spi.h +238 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-test-part.h +184 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest-typed-test.h +337 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest.h +2477 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest_pred_impl.h +359 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/gtest_prod.h +61 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/custom/README.md +56 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/custom/gtest-port.h +37 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/custom/gtest-printers.h +42 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/custom/gtest.h +37 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-death-test-internal.h +304 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-filepath.h +211 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-internal.h +1411 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-param-util.h +880 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-port-arch.h +111 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-port.h +2227 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-string.h +171 -0
- package/cpp/leveldb/third_party/googletest/googletest/include/gtest/internal/gtest-type-util.h +183 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/prime_tables.h +126 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample1.cc +66 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample1.h +41 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample10_unittest.cc +139 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample1_unittest.cc +151 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample2.cc +54 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample2.h +81 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample2_unittest.cc +107 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample3-inl.h +172 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample3_unittest.cc +149 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample4.cc +54 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample4.h +53 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample4_unittest.cc +53 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample5_unittest.cc +196 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample6_unittest.cc +224 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample7_unittest.cc +117 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample8_unittest.cc +154 -0
- package/cpp/leveldb/third_party/googletest/googletest/samples/sample9_unittest.cc +156 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/README.md +5 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/common.py +83 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/fuse_gtest_files.py +253 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/gen_gtest_pred_impl.py +734 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/gtest-config.in +274 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/release_docs.py +158 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/run_with_path.py +32 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/upload.py +1402 -0
- package/cpp/leveldb/third_party/googletest/googletest/scripts/upload_gtest.py +78 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-all.cc +48 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-death-test.cc +1653 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-filepath.cc +382 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-internal-inl.h +1211 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-matchers.cc +97 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-port.cc +1399 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-printers.cc +442 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-test-part.cc +108 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest-typed-test.cc +118 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest.cc +6180 -0
- package/cpp/leveldb/third_party/googletest/googletest/src/gtest_main.cc +54 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/BUILD.bazel +529 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-break-on-failure-unittest.py +208 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-break-on-failure-unittest_.cc +86 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-catch-exceptions-test.py +236 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-catch-exceptions-test_.cc +293 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-color-test.py +127 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-color-test_.cc +62 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-death-test-test.cc +1516 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-death-test_ex_test.cc +92 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-env-var-test.py +117 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-env-var-test_.cc +122 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-filepath-test.cc +649 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-filter-unittest.py +639 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-filter-unittest_.cc +137 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-json-outfiles-test.py +191 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-json-output-unittest.py +778 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-list-tests-unittest.py +205 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-list-tests-unittest_.cc +156 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-listener-test.cc +518 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-message-test.cc +158 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-options-test.cc +216 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-output-test-golden-lin.txt +1137 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-output-test.py +346 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-output-test_.cc +1149 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test-invalid-name1-test.py +63 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test-invalid-name1-test_.cc +50 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test-invalid-name2-test.py +62 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test-invalid-name2-test_.cc +55 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test-test.cc +1086 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test-test.h +51 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-param-test2-test.cc +61 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-port-test.cc +1272 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-printers-test.cc +1619 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-shuffle-test.py +323 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-shuffle-test_.cc +101 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-test-part-test.cc +230 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-test2_test.cc +61 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-throw-on-failure-test.py +168 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-throw-on-failure-test_.cc +71 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-uninitialized-test.py +67 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/googletest-uninitialized-test_.cc +42 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest-typed-test2_test.cc +44 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest-typed-test_test.cc +462 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest-typed-test_test.h +65 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest-unittest-api_test.cc +341 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_all_test.cc +46 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_assert_by_exception_test.cc +116 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_environment_test.cc +188 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_help_test.py +170 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_help_test_.cc +45 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_json_test_utils.py +60 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_list_output_unittest.py +141 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_list_output_unittest_.cc +51 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_main_unittest.cc +44 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_no_test_unittest.cc +54 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_pred_impl_unittest.cc +2427 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_premature_exit_test.cc +126 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_prod_test.cc +56 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_repeat_test.cc +233 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_skip_check_output_test.py +59 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_skip_environment_check_output_test.py +54 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_skip_in_environment_setup_test.cc +49 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_skip_test.cc +55 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_sole_header_test.cc +56 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_stress_test.cc +248 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_test_macro_stack_footprint_test.cc +89 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_test_utils.py +314 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_testbridge_test.py +63 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_testbridge_test_.cc +43 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_throw_on_failure_ex_test.cc +90 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_unittest.cc +7496 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_xml_outfile1_test_.cc +43 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_xml_outfile2_test_.cc +43 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_xml_outfiles_test.py +135 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_xml_output_unittest.py +389 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_xml_output_unittest_.cc +188 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/gtest_xml_test_utils.py +196 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/production.cc +35 -0
- package/cpp/leveldb/third_party/googletest/googletest/test/production.h +54 -0
- package/cpp/leveldb/third_party/googletest/library.json +66 -0
- package/cpp/leveldb/third_party/googletest/platformio.ini +47 -0
- package/cpp/leveldb/util/arena.cc +66 -0
- package/cpp/leveldb/util/arena.h +71 -0
- package/cpp/leveldb/util/arena_test.cc +66 -0
- package/cpp/leveldb/util/bloom.cc +92 -0
- package/cpp/leveldb/util/bloom_test.cc +159 -0
- package/cpp/leveldb/util/cache.cc +401 -0
- package/cpp/leveldb/util/cache_test.cc +229 -0
- package/cpp/leveldb/util/coding.cc +166 -0
- package/cpp/leveldb/util/coding.h +122 -0
- package/cpp/leveldb/util/coding_test.cc +198 -0
- package/cpp/leveldb/util/comparator.cc +75 -0
- package/cpp/leveldb/util/crc32c.cc +380 -0
- package/cpp/leveldb/util/crc32c.h +43 -0
- package/cpp/leveldb/util/crc32c_test.cc +61 -0
- package/cpp/leveldb/util/env.cc +108 -0
- package/cpp/leveldb/util/env_posix.cc +893 -0
- package/cpp/leveldb/util/env_posix_test.cc +353 -0
- package/cpp/leveldb/util/env_posix_test_helper.h +28 -0
- package/cpp/leveldb/util/env_test.cc +240 -0
- package/cpp/leveldb/util/env_windows.cc +796 -0
- package/cpp/leveldb/util/env_windows_test.cc +65 -0
- package/cpp/leveldb/util/env_windows_test_helper.h +25 -0
- package/cpp/leveldb/util/filter_policy.cc +11 -0
- package/cpp/leveldb/util/hash.cc +55 -0
- package/cpp/leveldb/util/hash.h +19 -0
- package/cpp/leveldb/util/hash_test.cc +46 -0
- package/cpp/leveldb/util/histogram.cc +272 -0
- package/cpp/leveldb/util/histogram.h +44 -0
- package/cpp/leveldb/util/logging.cc +82 -0
- package/cpp/leveldb/util/logging.h +44 -0
- package/cpp/leveldb/util/logging_test.cc +145 -0
- package/cpp/leveldb/util/mutexlock.h +39 -0
- package/cpp/leveldb/util/no_destructor.h +46 -0
- package/cpp/leveldb/util/no_destructor_test.cc +49 -0
- package/cpp/leveldb/util/options.cc +14 -0
- package/cpp/leveldb/util/posix_logger.h +130 -0
- package/cpp/leveldb/util/random.h +63 -0
- package/cpp/leveldb/util/status.cc +77 -0
- package/cpp/leveldb/util/status_test.cc +44 -0
- package/cpp/leveldb/util/testutil.cc +51 -0
- package/cpp/leveldb/util/testutil.h +82 -0
- package/cpp/leveldb/util/windows_logger.h +124 -0
- package/cpp/react-native-leveldb.cpp +694 -0
- package/cpp/react-native-leveldb.h +4 -0
- package/ios/Leveldb.h +9 -0
- package/ios/Leveldb.mm +35 -0
- package/ios/Leveldb.xcodeproj/project.pbxproj +288 -0
- package/lib/commonjs/fake.js +181 -0
- package/lib/commonjs/fake.js.map +1 -0
- package/lib/commonjs/fake.test.js +30 -0
- package/lib/commonjs/fake.test.js.map +1 -0
- package/lib/commonjs/index.js +172 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/package.json +1 -0
- package/lib/module/fake.js +171 -0
- package/lib/module/fake.js.map +1 -0
- package/lib/module/fake.test.js +30 -0
- package/lib/module/fake.test.js.map +1 -0
- package/lib/module/index.js +165 -0
- package/lib/module/index.js.map +1 -0
- package/lib/typescript/fake.d.ts +34 -0
- package/lib/typescript/fake.d.ts.map +1 -0
- package/lib/typescript/fake.test.d.ts +2 -0
- package/lib/typescript/fake.test.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +72 -0
- package/lib/typescript/index.d.ts.map +1 -0
- package/package.json +157 -0
- package/rn-leveldb.podspec +30 -0
- package/src/fake.test.ts +37 -0
- package/src/fake.ts +203 -0
- package/src/index.ts +291 -0
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
|
|
2
|
+
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
+
// found in the LICENSE file. See the AUTHORS file for names of contributors.
|
|
4
|
+
|
|
5
|
+
#include "db/dbformat.h"
|
|
6
|
+
|
|
7
|
+
#include <cstdio>
|
|
8
|
+
#include <sstream>
|
|
9
|
+
|
|
10
|
+
#include "port/port.h"
|
|
11
|
+
#include "util/coding.h"
|
|
12
|
+
|
|
13
|
+
namespace leveldb {
|
|
14
|
+
|
|
15
|
+
static uint64_t PackSequenceAndType(uint64_t seq, ValueType t) {
|
|
16
|
+
assert(seq <= kMaxSequenceNumber);
|
|
17
|
+
assert(t <= kValueTypeForSeek);
|
|
18
|
+
return (seq << 8) | t;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
void AppendInternalKey(std::string* result, const ParsedInternalKey& key) {
|
|
22
|
+
result->append(key.user_key.data(), key.user_key.size());
|
|
23
|
+
PutFixed64(result, PackSequenceAndType(key.sequence, key.type));
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
std::string ParsedInternalKey::DebugString() const {
|
|
27
|
+
std::ostringstream ss;
|
|
28
|
+
ss << '\'' << EscapeString(user_key.ToString()) << "' @ " << sequence << " : "
|
|
29
|
+
<< static_cast<int>(type);
|
|
30
|
+
return ss.str();
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
std::string InternalKey::DebugString() const {
|
|
34
|
+
ParsedInternalKey parsed;
|
|
35
|
+
if (ParseInternalKey(rep_, &parsed)) {
|
|
36
|
+
return parsed.DebugString();
|
|
37
|
+
}
|
|
38
|
+
std::ostringstream ss;
|
|
39
|
+
ss << "(bad)" << EscapeString(rep_);
|
|
40
|
+
return ss.str();
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const char* InternalKeyComparator::Name() const {
|
|
44
|
+
return "leveldb.InternalKeyComparator";
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
int InternalKeyComparator::Compare(const Slice& akey, const Slice& bkey) const {
|
|
48
|
+
// Order by:
|
|
49
|
+
// increasing user key (according to user-supplied comparator)
|
|
50
|
+
// decreasing sequence number
|
|
51
|
+
// decreasing type (though sequence# should be enough to disambiguate)
|
|
52
|
+
int r = user_comparator_->Compare(ExtractUserKey(akey), ExtractUserKey(bkey));
|
|
53
|
+
if (r == 0) {
|
|
54
|
+
const uint64_t anum = DecodeFixed64(akey.data() + akey.size() - 8);
|
|
55
|
+
const uint64_t bnum = DecodeFixed64(bkey.data() + bkey.size() - 8);
|
|
56
|
+
if (anum > bnum) {
|
|
57
|
+
r = -1;
|
|
58
|
+
} else if (anum < bnum) {
|
|
59
|
+
r = +1;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return r;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
void InternalKeyComparator::FindShortestSeparator(std::string* start,
|
|
66
|
+
const Slice& limit) const {
|
|
67
|
+
// Attempt to shorten the user portion of the key
|
|
68
|
+
Slice user_start = ExtractUserKey(*start);
|
|
69
|
+
Slice user_limit = ExtractUserKey(limit);
|
|
70
|
+
std::string tmp(user_start.data(), user_start.size());
|
|
71
|
+
user_comparator_->FindShortestSeparator(&tmp, user_limit);
|
|
72
|
+
if (tmp.size() < user_start.size() &&
|
|
73
|
+
user_comparator_->Compare(user_start, tmp) < 0) {
|
|
74
|
+
// User key has become shorter physically, but larger logically.
|
|
75
|
+
// Tack on the earliest possible number to the shortened user key.
|
|
76
|
+
PutFixed64(&tmp,
|
|
77
|
+
PackSequenceAndType(kMaxSequenceNumber, kValueTypeForSeek));
|
|
78
|
+
assert(this->Compare(*start, tmp) < 0);
|
|
79
|
+
assert(this->Compare(tmp, limit) < 0);
|
|
80
|
+
start->swap(tmp);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
void InternalKeyComparator::FindShortSuccessor(std::string* key) const {
|
|
85
|
+
Slice user_key = ExtractUserKey(*key);
|
|
86
|
+
std::string tmp(user_key.data(), user_key.size());
|
|
87
|
+
user_comparator_->FindShortSuccessor(&tmp);
|
|
88
|
+
if (tmp.size() < user_key.size() &&
|
|
89
|
+
user_comparator_->Compare(user_key, tmp) < 0) {
|
|
90
|
+
// User key has become shorter physically, but larger logically.
|
|
91
|
+
// Tack on the earliest possible number to the shortened user key.
|
|
92
|
+
PutFixed64(&tmp,
|
|
93
|
+
PackSequenceAndType(kMaxSequenceNumber, kValueTypeForSeek));
|
|
94
|
+
assert(this->Compare(*key, tmp) < 0);
|
|
95
|
+
key->swap(tmp);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
const char* InternalFilterPolicy::Name() const { return user_policy_->Name(); }
|
|
100
|
+
|
|
101
|
+
void InternalFilterPolicy::CreateFilter(const Slice* keys, int n,
|
|
102
|
+
std::string* dst) const {
|
|
103
|
+
// We rely on the fact that the code in table.cc does not mind us
|
|
104
|
+
// adjusting keys[].
|
|
105
|
+
Slice* mkey = const_cast<Slice*>(keys);
|
|
106
|
+
for (int i = 0; i < n; i++) {
|
|
107
|
+
mkey[i] = ExtractUserKey(keys[i]);
|
|
108
|
+
// TODO(sanjay): Suppress dups?
|
|
109
|
+
}
|
|
110
|
+
user_policy_->CreateFilter(keys, n, dst);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
bool InternalFilterPolicy::KeyMayMatch(const Slice& key, const Slice& f) const {
|
|
114
|
+
return user_policy_->KeyMayMatch(ExtractUserKey(key), f);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
LookupKey::LookupKey(const Slice& user_key, SequenceNumber s) {
|
|
118
|
+
size_t usize = user_key.size();
|
|
119
|
+
size_t needed = usize + 13; // A conservative estimate
|
|
120
|
+
char* dst;
|
|
121
|
+
if (needed <= sizeof(space_)) {
|
|
122
|
+
dst = space_;
|
|
123
|
+
} else {
|
|
124
|
+
dst = new char[needed];
|
|
125
|
+
}
|
|
126
|
+
start_ = dst;
|
|
127
|
+
dst = EncodeVarint32(dst, usize + 8);
|
|
128
|
+
kstart_ = dst;
|
|
129
|
+
std::memcpy(dst, user_key.data(), usize);
|
|
130
|
+
dst += usize;
|
|
131
|
+
EncodeFixed64(dst, PackSequenceAndType(s, kValueTypeForSeek));
|
|
132
|
+
dst += 8;
|
|
133
|
+
end_ = dst;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
} // namespace leveldb
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
|
|
2
|
+
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
+
// found in the LICENSE file. See the AUTHORS file for names of contributors.
|
|
4
|
+
|
|
5
|
+
#ifndef STORAGE_LEVELDB_DB_DBFORMAT_H_
|
|
6
|
+
#define STORAGE_LEVELDB_DB_DBFORMAT_H_
|
|
7
|
+
|
|
8
|
+
#include <cstddef>
|
|
9
|
+
#include <cstdint>
|
|
10
|
+
#include <string>
|
|
11
|
+
|
|
12
|
+
#include "leveldb/comparator.h"
|
|
13
|
+
#include "leveldb/db.h"
|
|
14
|
+
#include "leveldb/filter_policy.h"
|
|
15
|
+
#include "leveldb/slice.h"
|
|
16
|
+
#include "leveldb/table_builder.h"
|
|
17
|
+
#include "util/coding.h"
|
|
18
|
+
#include "util/logging.h"
|
|
19
|
+
|
|
20
|
+
namespace leveldb {
|
|
21
|
+
|
|
22
|
+
// Grouping of constants. We may want to make some of these
|
|
23
|
+
// parameters set via options.
|
|
24
|
+
namespace config {
|
|
25
|
+
static const int kNumLevels = 7;
|
|
26
|
+
|
|
27
|
+
// Level-0 compaction is started when we hit this many files.
|
|
28
|
+
static const int kL0_CompactionTrigger = 4;
|
|
29
|
+
|
|
30
|
+
// Soft limit on number of level-0 files. We slow down writes at this point.
|
|
31
|
+
static const int kL0_SlowdownWritesTrigger = 8;
|
|
32
|
+
|
|
33
|
+
// Maximum number of level-0 files. We stop writes at this point.
|
|
34
|
+
static const int kL0_StopWritesTrigger = 12;
|
|
35
|
+
|
|
36
|
+
// Maximum level to which a new compacted memtable is pushed if it
|
|
37
|
+
// does not create overlap. We try to push to level 2 to avoid the
|
|
38
|
+
// relatively expensive level 0=>1 compactions and to avoid some
|
|
39
|
+
// expensive manifest file operations. We do not push all the way to
|
|
40
|
+
// the largest level since that can generate a lot of wasted disk
|
|
41
|
+
// space if the same key space is being repeatedly overwritten.
|
|
42
|
+
static const int kMaxMemCompactLevel = 2;
|
|
43
|
+
|
|
44
|
+
// Approximate gap in bytes between samples of data read during iteration.
|
|
45
|
+
static const int kReadBytesPeriod = 1048576;
|
|
46
|
+
|
|
47
|
+
} // namespace config
|
|
48
|
+
|
|
49
|
+
class InternalKey;
|
|
50
|
+
|
|
51
|
+
// Value types encoded as the last component of internal keys.
|
|
52
|
+
// DO NOT CHANGE THESE ENUM VALUES: they are embedded in the on-disk
|
|
53
|
+
// data structures.
|
|
54
|
+
enum ValueType { kTypeDeletion = 0x0, kTypeValue = 0x1 };
|
|
55
|
+
// kValueTypeForSeek defines the ValueType that should be passed when
|
|
56
|
+
// constructing a ParsedInternalKey object for seeking to a particular
|
|
57
|
+
// sequence number (since we sort sequence numbers in decreasing order
|
|
58
|
+
// and the value type is embedded as the low 8 bits in the sequence
|
|
59
|
+
// number in internal keys, we need to use the highest-numbered
|
|
60
|
+
// ValueType, not the lowest).
|
|
61
|
+
static const ValueType kValueTypeForSeek = kTypeValue;
|
|
62
|
+
|
|
63
|
+
typedef uint64_t SequenceNumber;
|
|
64
|
+
|
|
65
|
+
// We leave eight bits empty at the bottom so a type and sequence#
|
|
66
|
+
// can be packed together into 64-bits.
|
|
67
|
+
static const SequenceNumber kMaxSequenceNumber = ((0x1ull << 56) - 1);
|
|
68
|
+
|
|
69
|
+
struct ParsedInternalKey {
|
|
70
|
+
Slice user_key;
|
|
71
|
+
SequenceNumber sequence;
|
|
72
|
+
ValueType type;
|
|
73
|
+
|
|
74
|
+
ParsedInternalKey() {} // Intentionally left uninitialized (for speed)
|
|
75
|
+
ParsedInternalKey(const Slice& u, const SequenceNumber& seq, ValueType t)
|
|
76
|
+
: user_key(u), sequence(seq), type(t) {}
|
|
77
|
+
std::string DebugString() const;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
// Return the length of the encoding of "key".
|
|
81
|
+
inline size_t InternalKeyEncodingLength(const ParsedInternalKey& key) {
|
|
82
|
+
return key.user_key.size() + 8;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// Append the serialization of "key" to *result.
|
|
86
|
+
void AppendInternalKey(std::string* result, const ParsedInternalKey& key);
|
|
87
|
+
|
|
88
|
+
// Attempt to parse an internal key from "internal_key". On success,
|
|
89
|
+
// stores the parsed data in "*result", and returns true.
|
|
90
|
+
//
|
|
91
|
+
// On error, returns false, leaves "*result" in an undefined state.
|
|
92
|
+
bool ParseInternalKey(const Slice& internal_key, ParsedInternalKey* result);
|
|
93
|
+
|
|
94
|
+
// Returns the user key portion of an internal key.
|
|
95
|
+
inline Slice ExtractUserKey(const Slice& internal_key) {
|
|
96
|
+
assert(internal_key.size() >= 8);
|
|
97
|
+
return Slice(internal_key.data(), internal_key.size() - 8);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// A comparator for internal keys that uses a specified comparator for
|
|
101
|
+
// the user key portion and breaks ties by decreasing sequence number.
|
|
102
|
+
class InternalKeyComparator : public Comparator {
|
|
103
|
+
private:
|
|
104
|
+
const Comparator* user_comparator_;
|
|
105
|
+
|
|
106
|
+
public:
|
|
107
|
+
explicit InternalKeyComparator(const Comparator* c) : user_comparator_(c) {}
|
|
108
|
+
const char* Name() const override;
|
|
109
|
+
int Compare(const Slice& a, const Slice& b) const override;
|
|
110
|
+
void FindShortestSeparator(std::string* start,
|
|
111
|
+
const Slice& limit) const override;
|
|
112
|
+
void FindShortSuccessor(std::string* key) const override;
|
|
113
|
+
|
|
114
|
+
const Comparator* user_comparator() const { return user_comparator_; }
|
|
115
|
+
|
|
116
|
+
int Compare(const InternalKey& a, const InternalKey& b) const;
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
// Filter policy wrapper that converts from internal keys to user keys
|
|
120
|
+
class InternalFilterPolicy : public FilterPolicy {
|
|
121
|
+
private:
|
|
122
|
+
const FilterPolicy* const user_policy_;
|
|
123
|
+
|
|
124
|
+
public:
|
|
125
|
+
explicit InternalFilterPolicy(const FilterPolicy* p) : user_policy_(p) {}
|
|
126
|
+
const char* Name() const override;
|
|
127
|
+
void CreateFilter(const Slice* keys, int n, std::string* dst) const override;
|
|
128
|
+
bool KeyMayMatch(const Slice& key, const Slice& filter) const override;
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
// Modules in this directory should keep internal keys wrapped inside
|
|
132
|
+
// the following class instead of plain strings so that we do not
|
|
133
|
+
// incorrectly use string comparisons instead of an InternalKeyComparator.
|
|
134
|
+
class InternalKey {
|
|
135
|
+
private:
|
|
136
|
+
std::string rep_;
|
|
137
|
+
|
|
138
|
+
public:
|
|
139
|
+
InternalKey() {} // Leave rep_ as empty to indicate it is invalid
|
|
140
|
+
InternalKey(const Slice& user_key, SequenceNumber s, ValueType t) {
|
|
141
|
+
AppendInternalKey(&rep_, ParsedInternalKey(user_key, s, t));
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
bool DecodeFrom(const Slice& s) {
|
|
145
|
+
rep_.assign(s.data(), s.size());
|
|
146
|
+
return !rep_.empty();
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
Slice Encode() const {
|
|
150
|
+
assert(!rep_.empty());
|
|
151
|
+
return rep_;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
Slice user_key() const { return ExtractUserKey(rep_); }
|
|
155
|
+
|
|
156
|
+
void SetFrom(const ParsedInternalKey& p) {
|
|
157
|
+
rep_.clear();
|
|
158
|
+
AppendInternalKey(&rep_, p);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
void Clear() { rep_.clear(); }
|
|
162
|
+
|
|
163
|
+
std::string DebugString() const;
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
inline int InternalKeyComparator::Compare(const InternalKey& a,
|
|
167
|
+
const InternalKey& b) const {
|
|
168
|
+
return Compare(a.Encode(), b.Encode());
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
inline bool ParseInternalKey(const Slice& internal_key,
|
|
172
|
+
ParsedInternalKey* result) {
|
|
173
|
+
const size_t n = internal_key.size();
|
|
174
|
+
if (n < 8) return false;
|
|
175
|
+
uint64_t num = DecodeFixed64(internal_key.data() + n - 8);
|
|
176
|
+
uint8_t c = num & 0xff;
|
|
177
|
+
result->sequence = num >> 8;
|
|
178
|
+
result->type = static_cast<ValueType>(c);
|
|
179
|
+
result->user_key = Slice(internal_key.data(), n - 8);
|
|
180
|
+
return (c <= static_cast<uint8_t>(kTypeValue));
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
// A helper class useful for DBImpl::Get()
|
|
184
|
+
class LookupKey {
|
|
185
|
+
public:
|
|
186
|
+
// Initialize *this for looking up user_key at a snapshot with
|
|
187
|
+
// the specified sequence number.
|
|
188
|
+
LookupKey(const Slice& user_key, SequenceNumber sequence);
|
|
189
|
+
|
|
190
|
+
LookupKey(const LookupKey&) = delete;
|
|
191
|
+
LookupKey& operator=(const LookupKey&) = delete;
|
|
192
|
+
|
|
193
|
+
~LookupKey();
|
|
194
|
+
|
|
195
|
+
// Return a key suitable for lookup in a MemTable.
|
|
196
|
+
Slice memtable_key() const { return Slice(start_, end_ - start_); }
|
|
197
|
+
|
|
198
|
+
// Return an internal key (suitable for passing to an internal iterator)
|
|
199
|
+
Slice internal_key() const { return Slice(kstart_, end_ - kstart_); }
|
|
200
|
+
|
|
201
|
+
// Return the user key
|
|
202
|
+
Slice user_key() const { return Slice(kstart_, end_ - kstart_ - 8); }
|
|
203
|
+
|
|
204
|
+
private:
|
|
205
|
+
// We construct a char array of the form:
|
|
206
|
+
// klength varint32 <-- start_
|
|
207
|
+
// userkey char[klength] <-- kstart_
|
|
208
|
+
// tag uint64
|
|
209
|
+
// <-- end_
|
|
210
|
+
// The array is a suitable MemTable key.
|
|
211
|
+
// The suffix starting with "userkey" can be used as an InternalKey.
|
|
212
|
+
const char* start_;
|
|
213
|
+
const char* kstart_;
|
|
214
|
+
const char* end_;
|
|
215
|
+
char space_[200]; // Avoid allocation for short keys
|
|
216
|
+
};
|
|
217
|
+
|
|
218
|
+
inline LookupKey::~LookupKey() {
|
|
219
|
+
if (start_ != space_) delete[] start_;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
} // namespace leveldb
|
|
223
|
+
|
|
224
|
+
#endif // STORAGE_LEVELDB_DB_DBFORMAT_H_
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
|
|
2
|
+
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
+
// found in the LICENSE file. See the AUTHORS file for names of contributors.
|
|
4
|
+
|
|
5
|
+
#include "db/dbformat.h"
|
|
6
|
+
|
|
7
|
+
#include "gtest/gtest.h"
|
|
8
|
+
#include "util/logging.h"
|
|
9
|
+
|
|
10
|
+
namespace leveldb {
|
|
11
|
+
|
|
12
|
+
static std::string IKey(const std::string& user_key, uint64_t seq,
|
|
13
|
+
ValueType vt) {
|
|
14
|
+
std::string encoded;
|
|
15
|
+
AppendInternalKey(&encoded, ParsedInternalKey(user_key, seq, vt));
|
|
16
|
+
return encoded;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
static std::string Shorten(const std::string& s, const std::string& l) {
|
|
20
|
+
std::string result = s;
|
|
21
|
+
InternalKeyComparator(BytewiseComparator()).FindShortestSeparator(&result, l);
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
static std::string ShortSuccessor(const std::string& s) {
|
|
26
|
+
std::string result = s;
|
|
27
|
+
InternalKeyComparator(BytewiseComparator()).FindShortSuccessor(&result);
|
|
28
|
+
return result;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
static void TestKey(const std::string& key, uint64_t seq, ValueType vt) {
|
|
32
|
+
std::string encoded = IKey(key, seq, vt);
|
|
33
|
+
|
|
34
|
+
Slice in(encoded);
|
|
35
|
+
ParsedInternalKey decoded("", 0, kTypeValue);
|
|
36
|
+
|
|
37
|
+
ASSERT_TRUE(ParseInternalKey(in, &decoded));
|
|
38
|
+
ASSERT_EQ(key, decoded.user_key.ToString());
|
|
39
|
+
ASSERT_EQ(seq, decoded.sequence);
|
|
40
|
+
ASSERT_EQ(vt, decoded.type);
|
|
41
|
+
|
|
42
|
+
ASSERT_TRUE(!ParseInternalKey(Slice("bar"), &decoded));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
TEST(FormatTest, InternalKey_EncodeDecode) {
|
|
46
|
+
const char* keys[] = {"", "k", "hello", "longggggggggggggggggggggg"};
|
|
47
|
+
const uint64_t seq[] = {1,
|
|
48
|
+
2,
|
|
49
|
+
3,
|
|
50
|
+
(1ull << 8) - 1,
|
|
51
|
+
1ull << 8,
|
|
52
|
+
(1ull << 8) + 1,
|
|
53
|
+
(1ull << 16) - 1,
|
|
54
|
+
1ull << 16,
|
|
55
|
+
(1ull << 16) + 1,
|
|
56
|
+
(1ull << 32) - 1,
|
|
57
|
+
1ull << 32,
|
|
58
|
+
(1ull << 32) + 1};
|
|
59
|
+
for (int k = 0; k < sizeof(keys) / sizeof(keys[0]); k++) {
|
|
60
|
+
for (int s = 0; s < sizeof(seq) / sizeof(seq[0]); s++) {
|
|
61
|
+
TestKey(keys[k], seq[s], kTypeValue);
|
|
62
|
+
TestKey("hello", 1, kTypeDeletion);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
TEST(FormatTest, InternalKey_DecodeFromEmpty) {
|
|
68
|
+
InternalKey internal_key;
|
|
69
|
+
|
|
70
|
+
ASSERT_TRUE(!internal_key.DecodeFrom(""));
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
TEST(FormatTest, InternalKeyShortSeparator) {
|
|
74
|
+
// When user keys are same
|
|
75
|
+
ASSERT_EQ(IKey("foo", 100, kTypeValue),
|
|
76
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("foo", 99, kTypeValue)));
|
|
77
|
+
ASSERT_EQ(
|
|
78
|
+
IKey("foo", 100, kTypeValue),
|
|
79
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("foo", 101, kTypeValue)));
|
|
80
|
+
ASSERT_EQ(
|
|
81
|
+
IKey("foo", 100, kTypeValue),
|
|
82
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("foo", 100, kTypeValue)));
|
|
83
|
+
ASSERT_EQ(
|
|
84
|
+
IKey("foo", 100, kTypeValue),
|
|
85
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("foo", 100, kTypeDeletion)));
|
|
86
|
+
|
|
87
|
+
// When user keys are misordered
|
|
88
|
+
ASSERT_EQ(IKey("foo", 100, kTypeValue),
|
|
89
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("bar", 99, kTypeValue)));
|
|
90
|
+
|
|
91
|
+
// When user keys are different, but correctly ordered
|
|
92
|
+
ASSERT_EQ(
|
|
93
|
+
IKey("g", kMaxSequenceNumber, kValueTypeForSeek),
|
|
94
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("hello", 200, kTypeValue)));
|
|
95
|
+
|
|
96
|
+
// When start user key is prefix of limit user key
|
|
97
|
+
ASSERT_EQ(
|
|
98
|
+
IKey("foo", 100, kTypeValue),
|
|
99
|
+
Shorten(IKey("foo", 100, kTypeValue), IKey("foobar", 200, kTypeValue)));
|
|
100
|
+
|
|
101
|
+
// When limit user key is prefix of start user key
|
|
102
|
+
ASSERT_EQ(
|
|
103
|
+
IKey("foobar", 100, kTypeValue),
|
|
104
|
+
Shorten(IKey("foobar", 100, kTypeValue), IKey("foo", 200, kTypeValue)));
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
TEST(FormatTest, InternalKeyShortestSuccessor) {
|
|
108
|
+
ASSERT_EQ(IKey("g", kMaxSequenceNumber, kValueTypeForSeek),
|
|
109
|
+
ShortSuccessor(IKey("foo", 100, kTypeValue)));
|
|
110
|
+
ASSERT_EQ(IKey("\xff\xff", 100, kTypeValue),
|
|
111
|
+
ShortSuccessor(IKey("\xff\xff", 100, kTypeValue)));
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
TEST(FormatTest, ParsedInternalKeyDebugString) {
|
|
115
|
+
ParsedInternalKey key("The \"key\" in 'single quotes'", 42, kTypeValue);
|
|
116
|
+
|
|
117
|
+
ASSERT_EQ("'The \"key\" in 'single quotes'' @ 42 : 1", key.DebugString());
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
TEST(FormatTest, InternalKeyDebugString) {
|
|
121
|
+
InternalKey key("The \"key\" in 'single quotes'", 42, kTypeValue);
|
|
122
|
+
ASSERT_EQ("'The \"key\" in 'single quotes'' @ 42 : 1", key.DebugString());
|
|
123
|
+
|
|
124
|
+
InternalKey invalid_key;
|
|
125
|
+
ASSERT_EQ("(bad)", invalid_key.DebugString());
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
} // namespace leveldb
|
|
129
|
+
|
|
130
|
+
int main(int argc, char** argv) {
|
|
131
|
+
testing::InitGoogleTest(&argc, argv);
|
|
132
|
+
return RUN_ALL_TESTS();
|
|
133
|
+
}
|