@nxtedition/rocksdb 1.0.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.
Files changed (1088) hide show
  1. package/CHANGELOG.md +294 -0
  2. package/LICENSE +21 -0
  3. package/README.md +102 -0
  4. package/UPGRADING.md +91 -0
  5. package/binding.cc +1276 -0
  6. package/binding.gyp +73 -0
  7. package/binding.js +1 -0
  8. package/chained-batch.js +44 -0
  9. package/deps/rocksdb/build_version.cc +4 -0
  10. package/deps/rocksdb/rocksdb/CMakeLists.txt +1356 -0
  11. package/deps/rocksdb/rocksdb/COPYING +339 -0
  12. package/deps/rocksdb/rocksdb/LICENSE.Apache +202 -0
  13. package/deps/rocksdb/rocksdb/LICENSE.leveldb +29 -0
  14. package/deps/rocksdb/rocksdb/Makefile +2521 -0
  15. package/deps/rocksdb/rocksdb/TARGETS +2100 -0
  16. package/deps/rocksdb/rocksdb/cache/cache.cc +63 -0
  17. package/deps/rocksdb/rocksdb/cache/cache_bench.cc +381 -0
  18. package/deps/rocksdb/rocksdb/cache/cache_helpers.h +114 -0
  19. package/deps/rocksdb/rocksdb/cache/cache_test.cc +775 -0
  20. package/deps/rocksdb/rocksdb/cache/clock_cache.cc +769 -0
  21. package/deps/rocksdb/rocksdb/cache/clock_cache.h +16 -0
  22. package/deps/rocksdb/rocksdb/cache/lru_cache.cc +574 -0
  23. package/deps/rocksdb/rocksdb/cache/lru_cache.h +339 -0
  24. package/deps/rocksdb/rocksdb/cache/lru_cache_test.cc +199 -0
  25. package/deps/rocksdb/rocksdb/cache/sharded_cache.cc +162 -0
  26. package/deps/rocksdb/rocksdb/cache/sharded_cache.h +111 -0
  27. package/deps/rocksdb/rocksdb/cmake/RocksDBConfig.cmake.in +54 -0
  28. package/deps/rocksdb/rocksdb/cmake/modules/CxxFlags.cmake +7 -0
  29. package/deps/rocksdb/rocksdb/cmake/modules/FindJeMalloc.cmake +29 -0
  30. package/deps/rocksdb/rocksdb/cmake/modules/FindNUMA.cmake +29 -0
  31. package/deps/rocksdb/rocksdb/cmake/modules/FindSnappy.cmake +29 -0
  32. package/deps/rocksdb/rocksdb/cmake/modules/FindTBB.cmake +33 -0
  33. package/deps/rocksdb/rocksdb/cmake/modules/Findgflags.cmake +29 -0
  34. package/deps/rocksdb/rocksdb/cmake/modules/Findlz4.cmake +29 -0
  35. package/deps/rocksdb/rocksdb/cmake/modules/Findzstd.cmake +29 -0
  36. package/deps/rocksdb/rocksdb/cmake/modules/ReadVersion.cmake +10 -0
  37. package/deps/rocksdb/rocksdb/db/arena_wrapped_db_iter.cc +108 -0
  38. package/deps/rocksdb/rocksdb/db/arena_wrapped_db_iter.h +115 -0
  39. package/deps/rocksdb/rocksdb/db/blob/blob_constants.h +16 -0
  40. package/deps/rocksdb/rocksdb/db/blob/blob_file_addition.cc +154 -0
  41. package/deps/rocksdb/rocksdb/db/blob/blob_file_addition.h +67 -0
  42. package/deps/rocksdb/rocksdb/db/blob/blob_file_addition_test.cc +206 -0
  43. package/deps/rocksdb/rocksdb/db/blob/blob_file_builder.cc +316 -0
  44. package/deps/rocksdb/rocksdb/db/blob/blob_file_builder.h +91 -0
  45. package/deps/rocksdb/rocksdb/db/blob/blob_file_builder_test.cc +660 -0
  46. package/deps/rocksdb/rocksdb/db/blob/blob_file_cache.cc +99 -0
  47. package/deps/rocksdb/rocksdb/db/blob/blob_file_cache.h +49 -0
  48. package/deps/rocksdb/rocksdb/db/blob/blob_file_cache_test.cc +268 -0
  49. package/deps/rocksdb/rocksdb/db/blob/blob_file_garbage.cc +134 -0
  50. package/deps/rocksdb/rocksdb/db/blob/blob_file_garbage.h +57 -0
  51. package/deps/rocksdb/rocksdb/db/blob/blob_file_garbage_test.cc +173 -0
  52. package/deps/rocksdb/rocksdb/db/blob/blob_file_meta.cc +55 -0
  53. package/deps/rocksdb/rocksdb/db/blob/blob_file_meta.h +164 -0
  54. package/deps/rocksdb/rocksdb/db/blob/blob_file_reader.cc +423 -0
  55. package/deps/rocksdb/rocksdb/db/blob/blob_file_reader.h +81 -0
  56. package/deps/rocksdb/rocksdb/db/blob/blob_file_reader_test.cc +771 -0
  57. package/deps/rocksdb/rocksdb/db/blob/blob_index.h +184 -0
  58. package/deps/rocksdb/rocksdb/db/blob/blob_log_format.cc +145 -0
  59. package/deps/rocksdb/rocksdb/db/blob/blob_log_format.h +148 -0
  60. package/deps/rocksdb/rocksdb/db/blob/blob_log_sequential_reader.cc +132 -0
  61. package/deps/rocksdb/rocksdb/db/blob/blob_log_sequential_reader.h +76 -0
  62. package/deps/rocksdb/rocksdb/db/blob/blob_log_writer.cc +168 -0
  63. package/deps/rocksdb/rocksdb/db/blob/blob_log_writer.h +83 -0
  64. package/deps/rocksdb/rocksdb/db/blob/db_blob_basic_test.cc +307 -0
  65. package/deps/rocksdb/rocksdb/db/blob/db_blob_index_test.cc +464 -0
  66. package/deps/rocksdb/rocksdb/db/builder.cc +358 -0
  67. package/deps/rocksdb/rocksdb/db/builder.h +95 -0
  68. package/deps/rocksdb/rocksdb/db/c.cc +5281 -0
  69. package/deps/rocksdb/rocksdb/db/c_test.c +2883 -0
  70. package/deps/rocksdb/rocksdb/db/column_family.cc +1602 -0
  71. package/deps/rocksdb/rocksdb/db/column_family.h +787 -0
  72. package/deps/rocksdb/rocksdb/db/column_family_test.cc +3427 -0
  73. package/deps/rocksdb/rocksdb/db/compact_files_test.cc +425 -0
  74. package/deps/rocksdb/rocksdb/db/compacted_db_impl.cc +169 -0
  75. package/deps/rocksdb/rocksdb/db/compacted_db_impl.h +118 -0
  76. package/deps/rocksdb/rocksdb/db/compaction/compaction.cc +591 -0
  77. package/deps/rocksdb/rocksdb/db/compaction/compaction.h +389 -0
  78. package/deps/rocksdb/rocksdb/db/compaction/compaction_iteration_stats.h +37 -0
  79. package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator.cc +1023 -0
  80. package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator.h +353 -0
  81. package/deps/rocksdb/rocksdb/db/compaction/compaction_iterator_test.cc +1254 -0
  82. package/deps/rocksdb/rocksdb/db/compaction/compaction_job.cc +1917 -0
  83. package/deps/rocksdb/rocksdb/db/compaction/compaction_job.h +208 -0
  84. package/deps/rocksdb/rocksdb/db/compaction/compaction_job_stats_test.cc +1037 -0
  85. package/deps/rocksdb/rocksdb/db/compaction/compaction_job_test.cc +1224 -0
  86. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker.cc +1135 -0
  87. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker.h +318 -0
  88. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_fifo.cc +255 -0
  89. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_fifo.h +57 -0
  90. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_level.cc +510 -0
  91. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_level.h +33 -0
  92. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_test.cc +2190 -0
  93. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_universal.cc +1103 -0
  94. package/deps/rocksdb/rocksdb/db/compaction/compaction_picker_universal.h +32 -0
  95. package/deps/rocksdb/rocksdb/db/compaction/sst_partitioner.cc +44 -0
  96. package/deps/rocksdb/rocksdb/db/comparator_db_test.cc +660 -0
  97. package/deps/rocksdb/rocksdb/db/convenience.cc +78 -0
  98. package/deps/rocksdb/rocksdb/db/corruption_test.cc +921 -0
  99. package/deps/rocksdb/rocksdb/db/cuckoo_table_db_test.cc +359 -0
  100. package/deps/rocksdb/rocksdb/db/db_basic_test.cc +3820 -0
  101. package/deps/rocksdb/rocksdb/db/db_block_cache_test.cc +1058 -0
  102. package/deps/rocksdb/rocksdb/db/db_bloom_filter_test.cc +2128 -0
  103. package/deps/rocksdb/rocksdb/db/db_compaction_filter_test.cc +851 -0
  104. package/deps/rocksdb/rocksdb/db/db_compaction_test.cc +6292 -0
  105. package/deps/rocksdb/rocksdb/db/db_dynamic_level_test.cc +509 -0
  106. package/deps/rocksdb/rocksdb/db/db_encryption_test.cc +130 -0
  107. package/deps/rocksdb/rocksdb/db/db_filesnapshot.cc +137 -0
  108. package/deps/rocksdb/rocksdb/db/db_flush_test.cc +1119 -0
  109. package/deps/rocksdb/rocksdb/db/db_impl/db_impl.cc +5057 -0
  110. package/deps/rocksdb/rocksdb/db/db_impl/db_impl.h +2274 -0
  111. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_compaction_flush.cc +3421 -0
  112. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_debug.cc +298 -0
  113. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_experimental.cc +151 -0
  114. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_files.cc +967 -0
  115. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_open.cc +1806 -0
  116. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.cc +270 -0
  117. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_readonly.h +146 -0
  118. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_secondary.cc +683 -0
  119. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_secondary.h +333 -0
  120. package/deps/rocksdb/rocksdb/db/db_impl/db_impl_write.cc +2024 -0
  121. package/deps/rocksdb/rocksdb/db/db_impl/db_secondary_test.cc +932 -0
  122. package/deps/rocksdb/rocksdb/db/db_info_dumper.cc +137 -0
  123. package/deps/rocksdb/rocksdb/db/db_info_dumper.h +15 -0
  124. package/deps/rocksdb/rocksdb/db/db_inplace_update_test.cc +178 -0
  125. package/deps/rocksdb/rocksdb/db/db_io_failure_test.cc +592 -0
  126. package/deps/rocksdb/rocksdb/db/db_iter.cc +1493 -0
  127. package/deps/rocksdb/rocksdb/db/db_iter.h +390 -0
  128. package/deps/rocksdb/rocksdb/db/db_iter_stress_test.cc +657 -0
  129. package/deps/rocksdb/rocksdb/db/db_iter_test.cc +3268 -0
  130. package/deps/rocksdb/rocksdb/db/db_iterator_test.cc +3197 -0
  131. package/deps/rocksdb/rocksdb/db/db_log_iter_test.cc +299 -0
  132. package/deps/rocksdb/rocksdb/db/db_logical_block_size_cache_test.cc +513 -0
  133. package/deps/rocksdb/rocksdb/db/db_memtable_test.cc +329 -0
  134. package/deps/rocksdb/rocksdb/db/db_merge_operand_test.cc +241 -0
  135. package/deps/rocksdb/rocksdb/db/db_merge_operator_test.cc +671 -0
  136. package/deps/rocksdb/rocksdb/db/db_options_test.cc +1022 -0
  137. package/deps/rocksdb/rocksdb/db/db_properties_test.cc +1723 -0
  138. package/deps/rocksdb/rocksdb/db/db_range_del_test.cc +1694 -0
  139. package/deps/rocksdb/rocksdb/db/db_sst_test.cc +1261 -0
  140. package/deps/rocksdb/rocksdb/db/db_statistics_test.cc +164 -0
  141. package/deps/rocksdb/rocksdb/db/db_table_properties_test.cc +488 -0
  142. package/deps/rocksdb/rocksdb/db/db_tailing_iter_test.cc +567 -0
  143. package/deps/rocksdb/rocksdb/db/db_test.cc +6736 -0
  144. package/deps/rocksdb/rocksdb/db/db_test2.cc +5408 -0
  145. package/deps/rocksdb/rocksdb/db/db_test_util.cc +1633 -0
  146. package/deps/rocksdb/rocksdb/db/db_test_util.h +1194 -0
  147. package/deps/rocksdb/rocksdb/db/db_universal_compaction_test.cc +2235 -0
  148. package/deps/rocksdb/rocksdb/db/db_wal_test.cc +1780 -0
  149. package/deps/rocksdb/rocksdb/db/db_with_timestamp_basic_test.cc +2520 -0
  150. package/deps/rocksdb/rocksdb/db/db_with_timestamp_compaction_test.cc +119 -0
  151. package/deps/rocksdb/rocksdb/db/db_write_test.cc +465 -0
  152. package/deps/rocksdb/rocksdb/db/dbformat.cc +222 -0
  153. package/deps/rocksdb/rocksdb/db/dbformat.h +786 -0
  154. package/deps/rocksdb/rocksdb/db/dbformat_test.cc +206 -0
  155. package/deps/rocksdb/rocksdb/db/deletefile_test.cc +580 -0
  156. package/deps/rocksdb/rocksdb/db/error_handler.cc +726 -0
  157. package/deps/rocksdb/rocksdb/db/error_handler.h +117 -0
  158. package/deps/rocksdb/rocksdb/db/error_handler_fs_test.cc +2598 -0
  159. package/deps/rocksdb/rocksdb/db/event_helpers.cc +233 -0
  160. package/deps/rocksdb/rocksdb/db/event_helpers.h +57 -0
  161. package/deps/rocksdb/rocksdb/db/experimental.cc +50 -0
  162. package/deps/rocksdb/rocksdb/db/external_sst_file_basic_test.cc +1559 -0
  163. package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.cc +910 -0
  164. package/deps/rocksdb/rocksdb/db/external_sst_file_ingestion_job.h +195 -0
  165. package/deps/rocksdb/rocksdb/db/external_sst_file_test.cc +2936 -0
  166. package/deps/rocksdb/rocksdb/db/fault_injection_test.cc +556 -0
  167. package/deps/rocksdb/rocksdb/db/file_indexer.cc +216 -0
  168. package/deps/rocksdb/rocksdb/db/file_indexer.h +142 -0
  169. package/deps/rocksdb/rocksdb/db/file_indexer_test.cc +350 -0
  170. package/deps/rocksdb/rocksdb/db/filename_test.cc +179 -0
  171. package/deps/rocksdb/rocksdb/db/flush_job.cc +514 -0
  172. package/deps/rocksdb/rocksdb/db/flush_job.h +169 -0
  173. package/deps/rocksdb/rocksdb/db/flush_job_test.cc +647 -0
  174. package/deps/rocksdb/rocksdb/db/flush_scheduler.cc +86 -0
  175. package/deps/rocksdb/rocksdb/db/flush_scheduler.h +54 -0
  176. package/deps/rocksdb/rocksdb/db/forward_iterator.cc +1023 -0
  177. package/deps/rocksdb/rocksdb/db/forward_iterator.h +163 -0
  178. package/deps/rocksdb/rocksdb/db/forward_iterator_bench.cc +377 -0
  179. package/deps/rocksdb/rocksdb/db/import_column_family_job.cc +282 -0
  180. package/deps/rocksdb/rocksdb/db/import_column_family_job.h +75 -0
  181. package/deps/rocksdb/rocksdb/db/import_column_family_test.cc +632 -0
  182. package/deps/rocksdb/rocksdb/db/internal_stats.cc +1461 -0
  183. package/deps/rocksdb/rocksdb/db/internal_stats.h +712 -0
  184. package/deps/rocksdb/rocksdb/db/job_context.h +226 -0
  185. package/deps/rocksdb/rocksdb/db/listener_test.cc +1118 -0
  186. package/deps/rocksdb/rocksdb/db/log_format.h +48 -0
  187. package/deps/rocksdb/rocksdb/db/log_reader.cc +654 -0
  188. package/deps/rocksdb/rocksdb/db/log_reader.h +192 -0
  189. package/deps/rocksdb/rocksdb/db/log_test.cc +901 -0
  190. package/deps/rocksdb/rocksdb/db/log_writer.cc +164 -0
  191. package/deps/rocksdb/rocksdb/db/log_writer.h +115 -0
  192. package/deps/rocksdb/rocksdb/db/logs_with_prep_tracker.cc +67 -0
  193. package/deps/rocksdb/rocksdb/db/logs_with_prep_tracker.h +63 -0
  194. package/deps/rocksdb/rocksdb/db/lookup_key.h +66 -0
  195. package/deps/rocksdb/rocksdb/db/malloc_stats.cc +54 -0
  196. package/deps/rocksdb/rocksdb/db/malloc_stats.h +24 -0
  197. package/deps/rocksdb/rocksdb/db/manual_compaction_test.cc +296 -0
  198. package/deps/rocksdb/rocksdb/db/memtable.cc +1169 -0
  199. package/deps/rocksdb/rocksdb/db/memtable.h +554 -0
  200. package/deps/rocksdb/rocksdb/db/memtable_list.cc +888 -0
  201. package/deps/rocksdb/rocksdb/db/memtable_list.h +438 -0
  202. package/deps/rocksdb/rocksdb/db/memtable_list_test.cc +935 -0
  203. package/deps/rocksdb/rocksdb/db/merge_context.h +134 -0
  204. package/deps/rocksdb/rocksdb/db/merge_helper.cc +421 -0
  205. package/deps/rocksdb/rocksdb/db/merge_helper.h +197 -0
  206. package/deps/rocksdb/rocksdb/db/merge_helper_test.cc +290 -0
  207. package/deps/rocksdb/rocksdb/db/merge_operator.cc +86 -0
  208. package/deps/rocksdb/rocksdb/db/merge_test.cc +608 -0
  209. package/deps/rocksdb/rocksdb/db/obsolete_files_test.cc +338 -0
  210. package/deps/rocksdb/rocksdb/db/options_file_test.cc +119 -0
  211. package/deps/rocksdb/rocksdb/db/output_validator.cc +30 -0
  212. package/deps/rocksdb/rocksdb/db/output_validator.h +47 -0
  213. package/deps/rocksdb/rocksdb/db/perf_context_test.cc +993 -0
  214. package/deps/rocksdb/rocksdb/db/periodic_work_scheduler.cc +113 -0
  215. package/deps/rocksdb/rocksdb/db/periodic_work_scheduler.h +76 -0
  216. package/deps/rocksdb/rocksdb/db/periodic_work_scheduler_test.cc +231 -0
  217. package/deps/rocksdb/rocksdb/db/pinned_iterators_manager.h +87 -0
  218. package/deps/rocksdb/rocksdb/db/plain_table_db_test.cc +1374 -0
  219. package/deps/rocksdb/rocksdb/db/pre_release_callback.h +38 -0
  220. package/deps/rocksdb/rocksdb/db/prefix_test.cc +910 -0
  221. package/deps/rocksdb/rocksdb/db/range_del_aggregator.cc +489 -0
  222. package/deps/rocksdb/rocksdb/db/range_del_aggregator.h +446 -0
  223. package/deps/rocksdb/rocksdb/db/range_del_aggregator_bench.cc +260 -0
  224. package/deps/rocksdb/rocksdb/db/range_del_aggregator_test.cc +709 -0
  225. package/deps/rocksdb/rocksdb/db/range_tombstone_fragmenter.cc +439 -0
  226. package/deps/rocksdb/rocksdb/db/range_tombstone_fragmenter.h +256 -0
  227. package/deps/rocksdb/rocksdb/db/range_tombstone_fragmenter_test.cc +552 -0
  228. package/deps/rocksdb/rocksdb/db/read_callback.h +53 -0
  229. package/deps/rocksdb/rocksdb/db/repair.cc +722 -0
  230. package/deps/rocksdb/rocksdb/db/repair_test.cc +390 -0
  231. package/deps/rocksdb/rocksdb/db/snapshot_checker.h +61 -0
  232. package/deps/rocksdb/rocksdb/db/snapshot_impl.cc +26 -0
  233. package/deps/rocksdb/rocksdb/db/snapshot_impl.h +167 -0
  234. package/deps/rocksdb/rocksdb/db/table_cache.cc +704 -0
  235. package/deps/rocksdb/rocksdb/db/table_cache.h +233 -0
  236. package/deps/rocksdb/rocksdb/db/table_properties_collector.cc +75 -0
  237. package/deps/rocksdb/rocksdb/db/table_properties_collector.h +107 -0
  238. package/deps/rocksdb/rocksdb/db/table_properties_collector_test.cc +517 -0
  239. package/deps/rocksdb/rocksdb/db/transaction_log_impl.cc +318 -0
  240. package/deps/rocksdb/rocksdb/db/transaction_log_impl.h +128 -0
  241. package/deps/rocksdb/rocksdb/db/trim_history_scheduler.cc +54 -0
  242. package/deps/rocksdb/rocksdb/db/trim_history_scheduler.h +44 -0
  243. package/deps/rocksdb/rocksdb/db/version_builder.cc +1078 -0
  244. package/deps/rocksdb/rocksdb/db/version_builder.h +69 -0
  245. package/deps/rocksdb/rocksdb/db/version_builder_test.cc +1551 -0
  246. package/deps/rocksdb/rocksdb/db/version_edit.cc +955 -0
  247. package/deps/rocksdb/rocksdb/db/version_edit.h +609 -0
  248. package/deps/rocksdb/rocksdb/db/version_edit_handler.cc +699 -0
  249. package/deps/rocksdb/rocksdb/db/version_edit_handler.h +252 -0
  250. package/deps/rocksdb/rocksdb/db/version_edit_test.cc +597 -0
  251. package/deps/rocksdb/rocksdb/db/version_set.cc +6333 -0
  252. package/deps/rocksdb/rocksdb/db/version_set.h +1485 -0
  253. package/deps/rocksdb/rocksdb/db/version_set_test.cc +3035 -0
  254. package/deps/rocksdb/rocksdb/db/wal_edit.cc +204 -0
  255. package/deps/rocksdb/rocksdb/db/wal_edit.h +166 -0
  256. package/deps/rocksdb/rocksdb/db/wal_edit_test.cc +214 -0
  257. package/deps/rocksdb/rocksdb/db/wal_manager.cc +517 -0
  258. package/deps/rocksdb/rocksdb/db/wal_manager.h +119 -0
  259. package/deps/rocksdb/rocksdb/db/wal_manager_test.cc +340 -0
  260. package/deps/rocksdb/rocksdb/db/write_batch.cc +2174 -0
  261. package/deps/rocksdb/rocksdb/db/write_batch_base.cc +94 -0
  262. package/deps/rocksdb/rocksdb/db/write_batch_internal.h +250 -0
  263. package/deps/rocksdb/rocksdb/db/write_batch_test.cc +907 -0
  264. package/deps/rocksdb/rocksdb/db/write_callback.h +27 -0
  265. package/deps/rocksdb/rocksdb/db/write_callback_test.cc +457 -0
  266. package/deps/rocksdb/rocksdb/db/write_controller.cc +128 -0
  267. package/deps/rocksdb/rocksdb/db/write_controller.h +144 -0
  268. package/deps/rocksdb/rocksdb/db/write_controller_test.cc +135 -0
  269. package/deps/rocksdb/rocksdb/db/write_thread.cc +796 -0
  270. package/deps/rocksdb/rocksdb/db/write_thread.h +433 -0
  271. package/deps/rocksdb/rocksdb/db_stress_tool/CMakeLists.txt +14 -0
  272. package/deps/rocksdb/rocksdb/db_stress_tool/batched_ops_stress.cc +341 -0
  273. package/deps/rocksdb/rocksdb/db_stress_tool/cf_consistency_stress.cc +520 -0
  274. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress.cc +23 -0
  275. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.cc +337 -0
  276. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_common.h +554 -0
  277. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_compaction_filter.h +79 -0
  278. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_driver.cc +173 -0
  279. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_driver.h +17 -0
  280. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_env_wrapper.h +38 -0
  281. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_gflags.cc +763 -0
  282. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_listener.h +222 -0
  283. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_shared_state.cc +27 -0
  284. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_shared_state.h +428 -0
  285. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_stat.h +218 -0
  286. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_table_properties_collector.h +64 -0
  287. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.cc +2430 -0
  288. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_test_base.h +237 -0
  289. package/deps/rocksdb/rocksdb/db_stress_tool/db_stress_tool.cc +343 -0
  290. package/deps/rocksdb/rocksdb/db_stress_tool/no_batched_ops_stress.cc +800 -0
  291. package/deps/rocksdb/rocksdb/env/composite_env_wrapper.h +920 -0
  292. package/deps/rocksdb/rocksdb/env/env.cc +733 -0
  293. package/deps/rocksdb/rocksdb/env/env_basic_test.cc +352 -0
  294. package/deps/rocksdb/rocksdb/env/env_chroot.cc +346 -0
  295. package/deps/rocksdb/rocksdb/env/env_chroot.h +22 -0
  296. package/deps/rocksdb/rocksdb/env/env_encryption.cc +1148 -0
  297. package/deps/rocksdb/rocksdb/env/env_encryption_ctr.h +137 -0
  298. package/deps/rocksdb/rocksdb/env/env_hdfs.cc +648 -0
  299. package/deps/rocksdb/rocksdb/env/env_posix.cc +514 -0
  300. package/deps/rocksdb/rocksdb/env/env_test.cc +2230 -0
  301. package/deps/rocksdb/rocksdb/env/file_system.cc +132 -0
  302. package/deps/rocksdb/rocksdb/env/file_system_tracer.cc +448 -0
  303. package/deps/rocksdb/rocksdb/env/file_system_tracer.h +415 -0
  304. package/deps/rocksdb/rocksdb/env/fs_posix.cc +1086 -0
  305. package/deps/rocksdb/rocksdb/env/io_posix.cc +1499 -0
  306. package/deps/rocksdb/rocksdb/env/io_posix.h +402 -0
  307. package/deps/rocksdb/rocksdb/env/io_posix_test.cc +140 -0
  308. package/deps/rocksdb/rocksdb/env/mock_env.cc +1066 -0
  309. package/deps/rocksdb/rocksdb/env/mock_env.h +41 -0
  310. package/deps/rocksdb/rocksdb/env/mock_env_test.cc +85 -0
  311. package/deps/rocksdb/rocksdb/file/delete_scheduler.cc +402 -0
  312. package/deps/rocksdb/rocksdb/file/delete_scheduler.h +150 -0
  313. package/deps/rocksdb/rocksdb/file/delete_scheduler_test.cc +717 -0
  314. package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.cc +156 -0
  315. package/deps/rocksdb/rocksdb/file/file_prefetch_buffer.h +99 -0
  316. package/deps/rocksdb/rocksdb/file/file_util.cc +268 -0
  317. package/deps/rocksdb/rocksdb/file/file_util.h +96 -0
  318. package/deps/rocksdb/rocksdb/file/filename.cc +473 -0
  319. package/deps/rocksdb/rocksdb/file/filename.h +182 -0
  320. package/deps/rocksdb/rocksdb/file/prefetch_test.cc +188 -0
  321. package/deps/rocksdb/rocksdb/file/random_access_file_reader.cc +315 -0
  322. package/deps/rocksdb/rocksdb/file/random_access_file_reader.h +142 -0
  323. package/deps/rocksdb/rocksdb/file/random_access_file_reader_test.cc +482 -0
  324. package/deps/rocksdb/rocksdb/file/read_write_util.cc +67 -0
  325. package/deps/rocksdb/rocksdb/file/read_write_util.h +34 -0
  326. package/deps/rocksdb/rocksdb/file/readahead_raf.cc +169 -0
  327. package/deps/rocksdb/rocksdb/file/readahead_raf.h +29 -0
  328. package/deps/rocksdb/rocksdb/file/sequence_file_reader.cc +237 -0
  329. package/deps/rocksdb/rocksdb/file/sequence_file_reader.h +63 -0
  330. package/deps/rocksdb/rocksdb/file/sst_file_manager_impl.cc +552 -0
  331. package/deps/rocksdb/rocksdb/file/sst_file_manager_impl.h +203 -0
  332. package/deps/rocksdb/rocksdb/file/writable_file_writer.cc +523 -0
  333. package/deps/rocksdb/rocksdb/file/writable_file_writer.h +251 -0
  334. package/deps/rocksdb/rocksdb/hdfs/env_hdfs.h +386 -0
  335. package/deps/rocksdb/rocksdb/include/rocksdb/advanced_options.h +839 -0
  336. package/deps/rocksdb/rocksdb/include/rocksdb/c.h +2218 -0
  337. package/deps/rocksdb/rocksdb/include/rocksdb/cache.h +294 -0
  338. package/deps/rocksdb/rocksdb/include/rocksdb/cleanable.h +71 -0
  339. package/deps/rocksdb/rocksdb/include/rocksdb/compaction_filter.h +214 -0
  340. package/deps/rocksdb/rocksdb/include/rocksdb/compaction_job_stats.h +98 -0
  341. package/deps/rocksdb/rocksdb/include/rocksdb/comparator.h +137 -0
  342. package/deps/rocksdb/rocksdb/include/rocksdb/compression_type.h +40 -0
  343. package/deps/rocksdb/rocksdb/include/rocksdb/concurrent_task_limiter.h +46 -0
  344. package/deps/rocksdb/rocksdb/include/rocksdb/configurable.h +359 -0
  345. package/deps/rocksdb/rocksdb/include/rocksdb/convenience.h +499 -0
  346. package/deps/rocksdb/rocksdb/include/rocksdb/customizable.h +138 -0
  347. package/deps/rocksdb/rocksdb/include/rocksdb/db.h +1697 -0
  348. package/deps/rocksdb/rocksdb/include/rocksdb/db_bench_tool.h +11 -0
  349. package/deps/rocksdb/rocksdb/include/rocksdb/db_dump_tool.h +45 -0
  350. package/deps/rocksdb/rocksdb/include/rocksdb/db_stress_tool.h +11 -0
  351. package/deps/rocksdb/rocksdb/include/rocksdb/env.h +1671 -0
  352. package/deps/rocksdb/rocksdb/include/rocksdb/env_encryption.h +405 -0
  353. package/deps/rocksdb/rocksdb/include/rocksdb/experimental.h +29 -0
  354. package/deps/rocksdb/rocksdb/include/rocksdb/file_checksum.h +129 -0
  355. package/deps/rocksdb/rocksdb/include/rocksdb/file_system.h +1472 -0
  356. package/deps/rocksdb/rocksdb/include/rocksdb/filter_policy.h +238 -0
  357. package/deps/rocksdb/rocksdb/include/rocksdb/flush_block_policy.h +61 -0
  358. package/deps/rocksdb/rocksdb/include/rocksdb/io_status.h +269 -0
  359. package/deps/rocksdb/rocksdb/include/rocksdb/iostats_context.h +56 -0
  360. package/deps/rocksdb/rocksdb/include/rocksdb/iterator.h +128 -0
  361. package/deps/rocksdb/rocksdb/include/rocksdb/ldb_tool.h +43 -0
  362. package/deps/rocksdb/rocksdb/include/rocksdb/listener.h +556 -0
  363. package/deps/rocksdb/rocksdb/include/rocksdb/memory_allocator.h +77 -0
  364. package/deps/rocksdb/rocksdb/include/rocksdb/memtablerep.h +385 -0
  365. package/deps/rocksdb/rocksdb/include/rocksdb/merge_operator.h +257 -0
  366. package/deps/rocksdb/rocksdb/include/rocksdb/metadata.h +155 -0
  367. package/deps/rocksdb/rocksdb/include/rocksdb/options.h +1702 -0
  368. package/deps/rocksdb/rocksdb/include/rocksdb/perf_context.h +237 -0
  369. package/deps/rocksdb/rocksdb/include/rocksdb/perf_level.h +35 -0
  370. package/deps/rocksdb/rocksdb/include/rocksdb/persistent_cache.h +73 -0
  371. package/deps/rocksdb/rocksdb/include/rocksdb/rate_limiter.h +139 -0
  372. package/deps/rocksdb/rocksdb/include/rocksdb/rocksdb_namespace.h +10 -0
  373. package/deps/rocksdb/rocksdb/include/rocksdb/slice.h +269 -0
  374. package/deps/rocksdb/rocksdb/include/rocksdb/slice_transform.h +103 -0
  375. package/deps/rocksdb/rocksdb/include/rocksdb/snapshot.h +48 -0
  376. package/deps/rocksdb/rocksdb/include/rocksdb/sst_dump_tool.h +19 -0
  377. package/deps/rocksdb/rocksdb/include/rocksdb/sst_file_manager.h +136 -0
  378. package/deps/rocksdb/rocksdb/include/rocksdb/sst_file_reader.h +47 -0
  379. package/deps/rocksdb/rocksdb/include/rocksdb/sst_file_writer.h +145 -0
  380. package/deps/rocksdb/rocksdb/include/rocksdb/sst_partitioner.h +135 -0
  381. package/deps/rocksdb/rocksdb/include/rocksdb/statistics.h +592 -0
  382. package/deps/rocksdb/rocksdb/include/rocksdb/stats_history.h +69 -0
  383. package/deps/rocksdb/rocksdb/include/rocksdb/status.h +608 -0
  384. package/deps/rocksdb/rocksdb/include/rocksdb/table.h +711 -0
  385. package/deps/rocksdb/rocksdb/include/rocksdb/table_properties.h +280 -0
  386. package/deps/rocksdb/rocksdb/include/rocksdb/thread_status.h +188 -0
  387. package/deps/rocksdb/rocksdb/include/rocksdb/threadpool.h +58 -0
  388. package/deps/rocksdb/rocksdb/include/rocksdb/trace_reader_writer.h +48 -0
  389. package/deps/rocksdb/rocksdb/include/rocksdb/transaction_log.h +121 -0
  390. package/deps/rocksdb/rocksdb/include/rocksdb/types.h +74 -0
  391. package/deps/rocksdb/rocksdb/include/rocksdb/universal_compaction.h +86 -0
  392. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/backupable_db.h +535 -0
  393. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/checkpoint.h +61 -0
  394. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/convenience.h +10 -0
  395. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/db_ttl.h +72 -0
  396. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/debug.h +49 -0
  397. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/env_librados.h +175 -0
  398. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/env_mirror.h +180 -0
  399. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/info_log_finder.h +19 -0
  400. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/ldb_cmd.h +288 -0
  401. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/ldb_cmd_execute_result.h +71 -0
  402. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/leveldb_options.h +145 -0
  403. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/lua/rocks_lua_custom_library.h +43 -0
  404. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/lua/rocks_lua_util.h +55 -0
  405. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/memory_util.h +50 -0
  406. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/object_registry.h +205 -0
  407. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/optimistic_transaction_db.h +100 -0
  408. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/option_change_migration.h +19 -0
  409. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/options_type.h +876 -0
  410. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/options_util.h +128 -0
  411. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/sim_cache.h +94 -0
  412. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/stackable_db.h +504 -0
  413. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/table_properties_collectors.h +95 -0
  414. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction.h +626 -0
  415. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction_db.h +432 -0
  416. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/transaction_db_mutex.h +92 -0
  417. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/utility_db.h +34 -0
  418. package/deps/rocksdb/rocksdb/include/rocksdb/utilities/write_batch_with_index.h +279 -0
  419. package/deps/rocksdb/rocksdb/include/rocksdb/version.h +16 -0
  420. package/deps/rocksdb/rocksdb/include/rocksdb/wal_filter.h +102 -0
  421. package/deps/rocksdb/rocksdb/include/rocksdb/write_batch.h +377 -0
  422. package/deps/rocksdb/rocksdb/include/rocksdb/write_batch_base.h +127 -0
  423. package/deps/rocksdb/rocksdb/include/rocksdb/write_buffer_manager.h +106 -0
  424. package/deps/rocksdb/rocksdb/logging/auto_roll_logger.cc +300 -0
  425. package/deps/rocksdb/rocksdb/logging/auto_roll_logger.h +165 -0
  426. package/deps/rocksdb/rocksdb/logging/auto_roll_logger_test.cc +684 -0
  427. package/deps/rocksdb/rocksdb/logging/env_logger.h +165 -0
  428. package/deps/rocksdb/rocksdb/logging/env_logger_test.cc +162 -0
  429. package/deps/rocksdb/rocksdb/logging/event_logger.cc +70 -0
  430. package/deps/rocksdb/rocksdb/logging/event_logger.h +203 -0
  431. package/deps/rocksdb/rocksdb/logging/event_logger_test.cc +43 -0
  432. package/deps/rocksdb/rocksdb/logging/log_buffer.cc +92 -0
  433. package/deps/rocksdb/rocksdb/logging/log_buffer.h +56 -0
  434. package/deps/rocksdb/rocksdb/logging/logging.h +68 -0
  435. package/deps/rocksdb/rocksdb/logging/posix_logger.h +185 -0
  436. package/deps/rocksdb/rocksdb/memory/allocator.h +57 -0
  437. package/deps/rocksdb/rocksdb/memory/arena.cc +233 -0
  438. package/deps/rocksdb/rocksdb/memory/arena.h +141 -0
  439. package/deps/rocksdb/rocksdb/memory/arena_test.cc +204 -0
  440. package/deps/rocksdb/rocksdb/memory/concurrent_arena.cc +47 -0
  441. package/deps/rocksdb/rocksdb/memory/concurrent_arena.h +218 -0
  442. package/deps/rocksdb/rocksdb/memory/jemalloc_nodump_allocator.cc +206 -0
  443. package/deps/rocksdb/rocksdb/memory/jemalloc_nodump_allocator.h +78 -0
  444. package/deps/rocksdb/rocksdb/memory/memkind_kmem_allocator.cc +33 -0
  445. package/deps/rocksdb/rocksdb/memory/memkind_kmem_allocator.h +27 -0
  446. package/deps/rocksdb/rocksdb/memory/memkind_kmem_allocator_test.cc +102 -0
  447. package/deps/rocksdb/rocksdb/memory/memory_allocator.h +38 -0
  448. package/deps/rocksdb/rocksdb/memory/memory_usage.h +25 -0
  449. package/deps/rocksdb/rocksdb/memtable/alloc_tracker.cc +62 -0
  450. package/deps/rocksdb/rocksdb/memtable/hash_linklist_rep.cc +844 -0
  451. package/deps/rocksdb/rocksdb/memtable/hash_linklist_rep.h +49 -0
  452. package/deps/rocksdb/rocksdb/memtable/hash_skiplist_rep.cc +349 -0
  453. package/deps/rocksdb/rocksdb/memtable/hash_skiplist_rep.h +44 -0
  454. package/deps/rocksdb/rocksdb/memtable/inlineskiplist.h +997 -0
  455. package/deps/rocksdb/rocksdb/memtable/inlineskiplist_test.cc +663 -0
  456. package/deps/rocksdb/rocksdb/memtable/memtablerep_bench.cc +677 -0
  457. package/deps/rocksdb/rocksdb/memtable/skiplist.h +496 -0
  458. package/deps/rocksdb/rocksdb/memtable/skiplist_test.cc +388 -0
  459. package/deps/rocksdb/rocksdb/memtable/skiplistrep.cc +280 -0
  460. package/deps/rocksdb/rocksdb/memtable/stl_wrappers.h +33 -0
  461. package/deps/rocksdb/rocksdb/memtable/vectorrep.cc +301 -0
  462. package/deps/rocksdb/rocksdb/memtable/write_buffer_manager.cc +148 -0
  463. package/deps/rocksdb/rocksdb/memtable/write_buffer_manager_test.cc +203 -0
  464. package/deps/rocksdb/rocksdb/monitoring/file_read_sample.h +23 -0
  465. package/deps/rocksdb/rocksdb/monitoring/histogram.cc +287 -0
  466. package/deps/rocksdb/rocksdb/monitoring/histogram.h +149 -0
  467. package/deps/rocksdb/rocksdb/monitoring/histogram_test.cc +231 -0
  468. package/deps/rocksdb/rocksdb/monitoring/histogram_windowing.cc +200 -0
  469. package/deps/rocksdb/rocksdb/monitoring/histogram_windowing.h +84 -0
  470. package/deps/rocksdb/rocksdb/monitoring/in_memory_stats_history.cc +49 -0
  471. package/deps/rocksdb/rocksdb/monitoring/in_memory_stats_history.h +74 -0
  472. package/deps/rocksdb/rocksdb/monitoring/instrumented_mutex.cc +71 -0
  473. package/deps/rocksdb/rocksdb/monitoring/instrumented_mutex.h +98 -0
  474. package/deps/rocksdb/rocksdb/monitoring/iostats_context.cc +62 -0
  475. package/deps/rocksdb/rocksdb/monitoring/iostats_context_imp.h +60 -0
  476. package/deps/rocksdb/rocksdb/monitoring/iostats_context_test.cc +29 -0
  477. package/deps/rocksdb/rocksdb/monitoring/perf_context.cc +566 -0
  478. package/deps/rocksdb/rocksdb/monitoring/perf_context_imp.h +97 -0
  479. package/deps/rocksdb/rocksdb/monitoring/perf_level.cc +28 -0
  480. package/deps/rocksdb/rocksdb/monitoring/perf_level_imp.h +18 -0
  481. package/deps/rocksdb/rocksdb/monitoring/perf_step_timer.h +79 -0
  482. package/deps/rocksdb/rocksdb/monitoring/persistent_stats_history.cc +169 -0
  483. package/deps/rocksdb/rocksdb/monitoring/persistent_stats_history.h +83 -0
  484. package/deps/rocksdb/rocksdb/monitoring/statistics.cc +431 -0
  485. package/deps/rocksdb/rocksdb/monitoring/statistics.h +138 -0
  486. package/deps/rocksdb/rocksdb/monitoring/statistics_test.cc +47 -0
  487. package/deps/rocksdb/rocksdb/monitoring/stats_history_test.cc +652 -0
  488. package/deps/rocksdb/rocksdb/monitoring/thread_status_impl.cc +163 -0
  489. package/deps/rocksdb/rocksdb/monitoring/thread_status_updater.cc +314 -0
  490. package/deps/rocksdb/rocksdb/monitoring/thread_status_updater.h +233 -0
  491. package/deps/rocksdb/rocksdb/monitoring/thread_status_updater_debug.cc +43 -0
  492. package/deps/rocksdb/rocksdb/monitoring/thread_status_util.cc +206 -0
  493. package/deps/rocksdb/rocksdb/monitoring/thread_status_util.h +134 -0
  494. package/deps/rocksdb/rocksdb/monitoring/thread_status_util_debug.cc +32 -0
  495. package/deps/rocksdb/rocksdb/options/cf_options.cc +1026 -0
  496. package/deps/rocksdb/rocksdb/options/cf_options.h +308 -0
  497. package/deps/rocksdb/rocksdb/options/configurable.cc +681 -0
  498. package/deps/rocksdb/rocksdb/options/configurable_helper.h +251 -0
  499. package/deps/rocksdb/rocksdb/options/configurable_test.cc +757 -0
  500. package/deps/rocksdb/rocksdb/options/configurable_test.h +127 -0
  501. package/deps/rocksdb/rocksdb/options/customizable.cc +77 -0
  502. package/deps/rocksdb/rocksdb/options/customizable_helper.h +216 -0
  503. package/deps/rocksdb/rocksdb/options/customizable_test.cc +625 -0
  504. package/deps/rocksdb/rocksdb/options/db_options.cc +835 -0
  505. package/deps/rocksdb/rocksdb/options/db_options.h +126 -0
  506. package/deps/rocksdb/rocksdb/options/options.cc +664 -0
  507. package/deps/rocksdb/rocksdb/options/options_helper.cc +1391 -0
  508. package/deps/rocksdb/rocksdb/options/options_helper.h +118 -0
  509. package/deps/rocksdb/rocksdb/options/options_parser.cc +721 -0
  510. package/deps/rocksdb/rocksdb/options/options_parser.h +151 -0
  511. package/deps/rocksdb/rocksdb/options/options_settable_test.cc +583 -0
  512. package/deps/rocksdb/rocksdb/options/options_test.cc +3794 -0
  513. package/deps/rocksdb/rocksdb/port/jemalloc_helper.h +106 -0
  514. package/deps/rocksdb/rocksdb/port/lang.h +16 -0
  515. package/deps/rocksdb/rocksdb/port/likely.h +18 -0
  516. package/deps/rocksdb/rocksdb/port/malloc.h +17 -0
  517. package/deps/rocksdb/rocksdb/port/port.h +21 -0
  518. package/deps/rocksdb/rocksdb/port/port_dirent.h +44 -0
  519. package/deps/rocksdb/rocksdb/port/port_example.h +101 -0
  520. package/deps/rocksdb/rocksdb/port/port_posix.cc +266 -0
  521. package/deps/rocksdb/rocksdb/port/port_posix.h +223 -0
  522. package/deps/rocksdb/rocksdb/port/stack_trace.cc +179 -0
  523. package/deps/rocksdb/rocksdb/port/stack_trace.h +28 -0
  524. package/deps/rocksdb/rocksdb/port/sys_time.h +47 -0
  525. package/deps/rocksdb/rocksdb/port/util_logger.h +20 -0
  526. package/deps/rocksdb/rocksdb/port/win/env_default.cc +45 -0
  527. package/deps/rocksdb/rocksdb/port/win/env_win.cc +1449 -0
  528. package/deps/rocksdb/rocksdb/port/win/env_win.h +294 -0
  529. package/deps/rocksdb/rocksdb/port/win/io_win.cc +1084 -0
  530. package/deps/rocksdb/rocksdb/port/win/io_win.h +494 -0
  531. package/deps/rocksdb/rocksdb/port/win/port_win.cc +283 -0
  532. package/deps/rocksdb/rocksdb/port/win/port_win.h +411 -0
  533. package/deps/rocksdb/rocksdb/port/win/win_jemalloc.cc +79 -0
  534. package/deps/rocksdb/rocksdb/port/win/win_logger.cc +194 -0
  535. package/deps/rocksdb/rocksdb/port/win/win_logger.h +67 -0
  536. package/deps/rocksdb/rocksdb/port/win/win_thread.cc +183 -0
  537. package/deps/rocksdb/rocksdb/port/win/win_thread.h +122 -0
  538. package/deps/rocksdb/rocksdb/port/win/xpress_win.cc +221 -0
  539. package/deps/rocksdb/rocksdb/port/win/xpress_win.h +26 -0
  540. package/deps/rocksdb/rocksdb/port/xpress.h +17 -0
  541. package/deps/rocksdb/rocksdb/src.mk +631 -0
  542. package/deps/rocksdb/rocksdb/table/adaptive/adaptive_table_factory.cc +126 -0
  543. package/deps/rocksdb/rocksdb/table/adaptive/adaptive_table_factory.h +57 -0
  544. package/deps/rocksdb/rocksdb/table/block_based/binary_search_index_reader.cc +73 -0
  545. package/deps/rocksdb/rocksdb/table/block_based/binary_search_index_reader.h +48 -0
  546. package/deps/rocksdb/rocksdb/table/block_based/block.cc +1049 -0
  547. package/deps/rocksdb/rocksdb/table/block_based/block.h +720 -0
  548. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.cc +348 -0
  549. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block.h +119 -0
  550. package/deps/rocksdb/rocksdb/table/block_based/block_based_filter_block_test.cc +434 -0
  551. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.cc +1835 -0
  552. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_builder.h +193 -0
  553. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_factory.cc +839 -0
  554. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_factory.h +95 -0
  555. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.cc +383 -0
  556. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_iterator.h +251 -0
  557. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.cc +3563 -0
  558. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader.h +681 -0
  559. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_impl.h +190 -0
  560. package/deps/rocksdb/rocksdb/table/block_based/block_based_table_reader_test.cc +347 -0
  561. package/deps/rocksdb/rocksdb/table/block_based/block_builder.cc +201 -0
  562. package/deps/rocksdb/rocksdb/table/block_based/block_builder.h +78 -0
  563. package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.cc +66 -0
  564. package/deps/rocksdb/rocksdb/table/block_based/block_prefetcher.h +32 -0
  565. package/deps/rocksdb/rocksdb/table/block_based/block_prefix_index.cc +232 -0
  566. package/deps/rocksdb/rocksdb/table/block_based/block_prefix_index.h +66 -0
  567. package/deps/rocksdb/rocksdb/table/block_based/block_test.cc +623 -0
  568. package/deps/rocksdb/rocksdb/table/block_based/block_type.h +30 -0
  569. package/deps/rocksdb/rocksdb/table/block_based/cachable_entry.h +220 -0
  570. package/deps/rocksdb/rocksdb/table/block_based/data_block_footer.cc +59 -0
  571. package/deps/rocksdb/rocksdb/table/block_based/data_block_footer.h +25 -0
  572. package/deps/rocksdb/rocksdb/table/block_based/data_block_hash_index.cc +93 -0
  573. package/deps/rocksdb/rocksdb/table/block_based/data_block_hash_index.h +136 -0
  574. package/deps/rocksdb/rocksdb/table/block_based/data_block_hash_index_test.cc +717 -0
  575. package/deps/rocksdb/rocksdb/table/block_based/filter_block.h +180 -0
  576. package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.cc +102 -0
  577. package/deps/rocksdb/rocksdb/table/block_based/filter_block_reader_common.h +55 -0
  578. package/deps/rocksdb/rocksdb/table/block_based/filter_policy.cc +1407 -0
  579. package/deps/rocksdb/rocksdb/table/block_based/filter_policy_internal.h +168 -0
  580. package/deps/rocksdb/rocksdb/table/block_based/flush_block_policy.cc +88 -0
  581. package/deps/rocksdb/rocksdb/table/block_based/flush_block_policy.h +41 -0
  582. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.cc +344 -0
  583. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block.h +139 -0
  584. package/deps/rocksdb/rocksdb/table/block_based/full_filter_block_test.cc +333 -0
  585. package/deps/rocksdb/rocksdb/table/block_based/hash_index_reader.cc +147 -0
  586. package/deps/rocksdb/rocksdb/table/block_based/hash_index_reader.h +49 -0
  587. package/deps/rocksdb/rocksdb/table/block_based/index_builder.cc +248 -0
  588. package/deps/rocksdb/rocksdb/table/block_based/index_builder.h +444 -0
  589. package/deps/rocksdb/rocksdb/table/block_based/index_reader_common.cc +54 -0
  590. package/deps/rocksdb/rocksdb/table/block_based/index_reader_common.h +85 -0
  591. package/deps/rocksdb/rocksdb/table/block_based/mock_block_based_table.h +56 -0
  592. package/deps/rocksdb/rocksdb/table/block_based/parsed_full_filter_block.cc +22 -0
  593. package/deps/rocksdb/rocksdb/table/block_based/parsed_full_filter_block.h +40 -0
  594. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.cc +521 -0
  595. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block.h +144 -0
  596. package/deps/rocksdb/rocksdb/table/block_based/partitioned_filter_block_test.cc +424 -0
  597. package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_iterator.cc +163 -0
  598. package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_iterator.h +142 -0
  599. package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_reader.cc +186 -0
  600. package/deps/rocksdb/rocksdb/table/block_based/partitioned_index_reader.h +51 -0
  601. package/deps/rocksdb/rocksdb/table/block_based/reader_common.cc +64 -0
  602. package/deps/rocksdb/rocksdb/table/block_based/reader_common.h +38 -0
  603. package/deps/rocksdb/rocksdb/table/block_based/uncompression_dict_reader.cc +120 -0
  604. package/deps/rocksdb/rocksdb/table/block_based/uncompression_dict_reader.h +59 -0
  605. package/deps/rocksdb/rocksdb/table/block_fetcher.cc +324 -0
  606. package/deps/rocksdb/rocksdb/table/block_fetcher.h +129 -0
  607. package/deps/rocksdb/rocksdb/table/block_fetcher_test.cc +534 -0
  608. package/deps/rocksdb/rocksdb/table/cleanable_test.cc +277 -0
  609. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder.cc +543 -0
  610. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder.h +136 -0
  611. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_builder_test.cc +663 -0
  612. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_factory.cc +107 -0
  613. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_factory.h +81 -0
  614. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader.cc +404 -0
  615. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader.h +101 -0
  616. package/deps/rocksdb/rocksdb/table/cuckoo/cuckoo_table_reader_test.cc +585 -0
  617. package/deps/rocksdb/rocksdb/table/format.cc +422 -0
  618. package/deps/rocksdb/rocksdb/table/format.h +348 -0
  619. package/deps/rocksdb/rocksdb/table/get_context.cc +408 -0
  620. package/deps/rocksdb/rocksdb/table/get_context.h +212 -0
  621. package/deps/rocksdb/rocksdb/table/internal_iterator.h +205 -0
  622. package/deps/rocksdb/rocksdb/table/iter_heap.h +42 -0
  623. package/deps/rocksdb/rocksdb/table/iterator.cc +210 -0
  624. package/deps/rocksdb/rocksdb/table/iterator_wrapper.h +180 -0
  625. package/deps/rocksdb/rocksdb/table/merger_test.cc +180 -0
  626. package/deps/rocksdb/rocksdb/table/merging_iterator.cc +481 -0
  627. package/deps/rocksdb/rocksdb/table/merging_iterator.h +64 -0
  628. package/deps/rocksdb/rocksdb/table/meta_blocks.cc +541 -0
  629. package/deps/rocksdb/rocksdb/table/meta_blocks.h +154 -0
  630. package/deps/rocksdb/rocksdb/table/mock_table.cc +328 -0
  631. package/deps/rocksdb/rocksdb/table/mock_table.h +89 -0
  632. package/deps/rocksdb/rocksdb/table/multiget_context.h +282 -0
  633. package/deps/rocksdb/rocksdb/table/persistent_cache_helper.cc +116 -0
  634. package/deps/rocksdb/rocksdb/table/persistent_cache_helper.h +44 -0
  635. package/deps/rocksdb/rocksdb/table/persistent_cache_options.h +34 -0
  636. package/deps/rocksdb/rocksdb/table/plain/plain_table_bloom.cc +78 -0
  637. package/deps/rocksdb/rocksdb/table/plain/plain_table_bloom.h +135 -0
  638. package/deps/rocksdb/rocksdb/table/plain/plain_table_builder.cc +332 -0
  639. package/deps/rocksdb/rocksdb/table/plain/plain_table_builder.h +153 -0
  640. package/deps/rocksdb/rocksdb/table/plain/plain_table_factory.cc +263 -0
  641. package/deps/rocksdb/rocksdb/table/plain/plain_table_factory.h +182 -0
  642. package/deps/rocksdb/rocksdb/table/plain/plain_table_index.cc +211 -0
  643. package/deps/rocksdb/rocksdb/table/plain/plain_table_index.h +249 -0
  644. package/deps/rocksdb/rocksdb/table/plain/plain_table_key_coding.cc +506 -0
  645. package/deps/rocksdb/rocksdb/table/plain/plain_table_key_coding.h +201 -0
  646. package/deps/rocksdb/rocksdb/table/plain/plain_table_reader.cc +781 -0
  647. package/deps/rocksdb/rocksdb/table/plain/plain_table_reader.h +247 -0
  648. package/deps/rocksdb/rocksdb/table/scoped_arena_iterator.h +61 -0
  649. package/deps/rocksdb/rocksdb/table/sst_file_dumper.cc +502 -0
  650. package/deps/rocksdb/rocksdb/table/sst_file_dumper.h +96 -0
  651. package/deps/rocksdb/rocksdb/table/sst_file_reader.cc +98 -0
  652. package/deps/rocksdb/rocksdb/table/sst_file_reader_test.cc +228 -0
  653. package/deps/rocksdb/rocksdb/table/sst_file_writer.cc +340 -0
  654. package/deps/rocksdb/rocksdb/table/sst_file_writer_collectors.h +94 -0
  655. package/deps/rocksdb/rocksdb/table/table_builder.h +203 -0
  656. package/deps/rocksdb/rocksdb/table/table_factory.cc +38 -0
  657. package/deps/rocksdb/rocksdb/table/table_properties.cc +300 -0
  658. package/deps/rocksdb/rocksdb/table/table_properties_internal.h +30 -0
  659. package/deps/rocksdb/rocksdb/table/table_reader.h +147 -0
  660. package/deps/rocksdb/rocksdb/table/table_reader_bench.cc +347 -0
  661. package/deps/rocksdb/rocksdb/table/table_reader_caller.h +39 -0
  662. package/deps/rocksdb/rocksdb/table/table_test.cc +4769 -0
  663. package/deps/rocksdb/rocksdb/table/two_level_iterator.cc +215 -0
  664. package/deps/rocksdb/rocksdb/table/two_level_iterator.h +43 -0
  665. package/deps/rocksdb/rocksdb/test_util/mock_time_env.cc +38 -0
  666. package/deps/rocksdb/rocksdb/test_util/mock_time_env.h +74 -0
  667. package/deps/rocksdb/rocksdb/test_util/sync_point.cc +93 -0
  668. package/deps/rocksdb/rocksdb/test_util/sync_point.h +161 -0
  669. package/deps/rocksdb/rocksdb/test_util/sync_point_impl.cc +129 -0
  670. package/deps/rocksdb/rocksdb/test_util/sync_point_impl.h +74 -0
  671. package/deps/rocksdb/rocksdb/test_util/testharness.cc +56 -0
  672. package/deps/rocksdb/rocksdb/test_util/testharness.h +53 -0
  673. package/deps/rocksdb/rocksdb/test_util/testutil.cc +566 -0
  674. package/deps/rocksdb/rocksdb/test_util/testutil.h +887 -0
  675. package/deps/rocksdb/rocksdb/test_util/testutil_test.cc +43 -0
  676. package/deps/rocksdb/rocksdb/test_util/transaction_test_util.cc +388 -0
  677. package/deps/rocksdb/rocksdb/test_util/transaction_test_util.h +132 -0
  678. package/deps/rocksdb/rocksdb/third-party/folly/folly/CPortability.h +27 -0
  679. package/deps/rocksdb/rocksdb/third-party/folly/folly/ConstexprMath.h +45 -0
  680. package/deps/rocksdb/rocksdb/third-party/folly/folly/Indestructible.h +166 -0
  681. package/deps/rocksdb/rocksdb/third-party/folly/folly/Optional.h +570 -0
  682. package/deps/rocksdb/rocksdb/third-party/folly/folly/Portability.h +92 -0
  683. package/deps/rocksdb/rocksdb/third-party/folly/folly/ScopeGuard.h +54 -0
  684. package/deps/rocksdb/rocksdb/third-party/folly/folly/Traits.h +152 -0
  685. package/deps/rocksdb/rocksdb/third-party/folly/folly/Unit.h +59 -0
  686. package/deps/rocksdb/rocksdb/third-party/folly/folly/Utility.h +141 -0
  687. package/deps/rocksdb/rocksdb/third-party/folly/folly/chrono/Hardware.h +33 -0
  688. package/deps/rocksdb/rocksdb/third-party/folly/folly/container/Array.h +74 -0
  689. package/deps/rocksdb/rocksdb/third-party/folly/folly/detail/Futex-inl.h +117 -0
  690. package/deps/rocksdb/rocksdb/third-party/folly/folly/detail/Futex.cpp +263 -0
  691. package/deps/rocksdb/rocksdb/third-party/folly/folly/detail/Futex.h +96 -0
  692. package/deps/rocksdb/rocksdb/third-party/folly/folly/functional/Invoke.h +40 -0
  693. package/deps/rocksdb/rocksdb/third-party/folly/folly/hash/Hash.h +29 -0
  694. package/deps/rocksdb/rocksdb/third-party/folly/folly/lang/Align.h +144 -0
  695. package/deps/rocksdb/rocksdb/third-party/folly/folly/lang/Bits.h +30 -0
  696. package/deps/rocksdb/rocksdb/third-party/folly/folly/lang/Launder.h +51 -0
  697. package/deps/rocksdb/rocksdb/third-party/folly/folly/portability/Asm.h +28 -0
  698. package/deps/rocksdb/rocksdb/third-party/folly/folly/portability/SysSyscall.h +10 -0
  699. package/deps/rocksdb/rocksdb/third-party/folly/folly/portability/SysTypes.h +26 -0
  700. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicNotification-inl.h +138 -0
  701. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicNotification.cpp +23 -0
  702. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicNotification.h +57 -0
  703. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicUtil-inl.h +260 -0
  704. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/AtomicUtil.h +52 -0
  705. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/Baton.h +328 -0
  706. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutex-inl.h +1703 -0
  707. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutex.cpp +16 -0
  708. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutex.h +304 -0
  709. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/DistributedMutexSpecializations.h +39 -0
  710. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/ParkingLot.cpp +26 -0
  711. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/ParkingLot.h +318 -0
  712. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/WaitOptions.cpp +12 -0
  713. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/WaitOptions.h +57 -0
  714. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/InlineFunctionRef.h +219 -0
  715. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/ProxyLockable-inl.h +207 -0
  716. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/ProxyLockable.h +164 -0
  717. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/Sleeper.h +57 -0
  718. package/deps/rocksdb/rocksdb/third-party/folly/folly/synchronization/detail/Spin.h +77 -0
  719. package/deps/rocksdb/rocksdb/third-party/gcc/ppc-asm.h +390 -0
  720. package/deps/rocksdb/rocksdb/thirdparty.inc +268 -0
  721. package/deps/rocksdb/rocksdb/tools/CMakeLists.txt +30 -0
  722. package/deps/rocksdb/rocksdb/tools/blob_dump.cc +110 -0
  723. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/__init__.py +2 -0
  724. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_pysim.py +2000 -0
  725. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_pysim.sh +156 -0
  726. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_pysim_test.py +734 -0
  727. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.cc +2307 -0
  728. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer.h +395 -0
  729. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer_plot.py +721 -0
  730. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer_test.cc +719 -0
  731. package/deps/rocksdb/rocksdb/tools/block_cache_analyzer/block_cache_trace_analyzer_tool.cc +25 -0
  732. package/deps/rocksdb/rocksdb/tools/db_bench.cc +21 -0
  733. package/deps/rocksdb/rocksdb/tools/db_bench_tool.cc +7416 -0
  734. package/deps/rocksdb/rocksdb/tools/db_bench_tool_test.cc +328 -0
  735. package/deps/rocksdb/rocksdb/tools/db_repl_stress.cc +130 -0
  736. package/deps/rocksdb/rocksdb/tools/db_sanity_test.cc +297 -0
  737. package/deps/rocksdb/rocksdb/tools/dump/db_dump_tool.cc +259 -0
  738. package/deps/rocksdb/rocksdb/tools/dump/rocksdb_dump.cc +63 -0
  739. package/deps/rocksdb/rocksdb/tools/dump/rocksdb_undump.cc +62 -0
  740. package/deps/rocksdb/rocksdb/tools/io_tracer_parser.cc +25 -0
  741. package/deps/rocksdb/rocksdb/tools/io_tracer_parser_test.cc +187 -0
  742. package/deps/rocksdb/rocksdb/tools/io_tracer_parser_tool.cc +120 -0
  743. package/deps/rocksdb/rocksdb/tools/io_tracer_parser_tool.h +40 -0
  744. package/deps/rocksdb/rocksdb/tools/ldb.cc +21 -0
  745. package/deps/rocksdb/rocksdb/tools/ldb_cmd.cc +3609 -0
  746. package/deps/rocksdb/rocksdb/tools/ldb_cmd_impl.h +665 -0
  747. package/deps/rocksdb/rocksdb/tools/ldb_cmd_test.cc +746 -0
  748. package/deps/rocksdb/rocksdb/tools/ldb_tool.cc +159 -0
  749. package/deps/rocksdb/rocksdb/tools/reduce_levels_test.cc +221 -0
  750. package/deps/rocksdb/rocksdb/tools/sst_dump.cc +20 -0
  751. package/deps/rocksdb/rocksdb/tools/sst_dump_test.cc +427 -0
  752. package/deps/rocksdb/rocksdb/tools/sst_dump_tool.cc +541 -0
  753. package/deps/rocksdb/rocksdb/tools/trace_analyzer.cc +25 -0
  754. package/deps/rocksdb/rocksdb/tools/trace_analyzer_test.cc +752 -0
  755. package/deps/rocksdb/rocksdb/tools/trace_analyzer_tool.cc +2001 -0
  756. package/deps/rocksdb/rocksdb/tools/trace_analyzer_tool.h +292 -0
  757. package/deps/rocksdb/rocksdb/tools/write_stress.cc +305 -0
  758. package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer.cc +496 -0
  759. package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer.h +294 -0
  760. package/deps/rocksdb/rocksdb/trace_replay/block_cache_tracer_test.cc +379 -0
  761. package/deps/rocksdb/rocksdb/trace_replay/io_tracer.cc +229 -0
  762. package/deps/rocksdb/rocksdb/trace_replay/io_tracer.h +174 -0
  763. package/deps/rocksdb/rocksdb/trace_replay/io_tracer_test.cc +215 -0
  764. package/deps/rocksdb/rocksdb/trace_replay/trace_replay.cc +491 -0
  765. package/deps/rocksdb/rocksdb/trace_replay/trace_replay.h +195 -0
  766. package/deps/rocksdb/rocksdb/util/aligned_buffer.h +255 -0
  767. package/deps/rocksdb/rocksdb/util/autovector.h +367 -0
  768. package/deps/rocksdb/rocksdb/util/autovector_test.cc +330 -0
  769. package/deps/rocksdb/rocksdb/util/bloom_impl.h +485 -0
  770. package/deps/rocksdb/rocksdb/util/bloom_test.cc +1191 -0
  771. package/deps/rocksdb/rocksdb/util/build_version.cc.in +5 -0
  772. package/deps/rocksdb/rocksdb/util/build_version.h +15 -0
  773. package/deps/rocksdb/rocksdb/util/cast_util.h +20 -0
  774. package/deps/rocksdb/rocksdb/util/channel.h +67 -0
  775. package/deps/rocksdb/rocksdb/util/coding.cc +89 -0
  776. package/deps/rocksdb/rocksdb/util/coding.h +419 -0
  777. package/deps/rocksdb/rocksdb/util/coding_lean.h +101 -0
  778. package/deps/rocksdb/rocksdb/util/coding_test.cc +217 -0
  779. package/deps/rocksdb/rocksdb/util/compaction_job_stats_impl.cc +92 -0
  780. package/deps/rocksdb/rocksdb/util/comparator.cc +219 -0
  781. package/deps/rocksdb/rocksdb/util/compression.h +1529 -0
  782. package/deps/rocksdb/rocksdb/util/compression_context_cache.cc +108 -0
  783. package/deps/rocksdb/rocksdb/util/compression_context_cache.h +47 -0
  784. package/deps/rocksdb/rocksdb/util/concurrent_task_limiter_impl.cc +67 -0
  785. package/deps/rocksdb/rocksdb/util/concurrent_task_limiter_impl.h +67 -0
  786. package/deps/rocksdb/rocksdb/util/core_local.h +83 -0
  787. package/deps/rocksdb/rocksdb/util/crc32c.cc +1283 -0
  788. package/deps/rocksdb/rocksdb/util/crc32c.h +51 -0
  789. package/deps/rocksdb/rocksdb/util/crc32c_arm64.cc +169 -0
  790. package/deps/rocksdb/rocksdb/util/crc32c_arm64.h +50 -0
  791. package/deps/rocksdb/rocksdb/util/crc32c_ppc.c +94 -0
  792. package/deps/rocksdb/rocksdb/util/crc32c_ppc.h +19 -0
  793. package/deps/rocksdb/rocksdb/util/crc32c_ppc_asm.S +756 -0
  794. package/deps/rocksdb/rocksdb/util/crc32c_ppc_constants.h +900 -0
  795. package/deps/rocksdb/rocksdb/util/crc32c_test.cc +180 -0
  796. package/deps/rocksdb/rocksdb/util/defer.h +52 -0
  797. package/deps/rocksdb/rocksdb/util/defer_test.cc +39 -0
  798. package/deps/rocksdb/rocksdb/util/duplicate_detector.h +68 -0
  799. package/deps/rocksdb/rocksdb/util/dynamic_bloom.cc +70 -0
  800. package/deps/rocksdb/rocksdb/util/dynamic_bloom.h +214 -0
  801. package/deps/rocksdb/rocksdb/util/dynamic_bloom_test.cc +323 -0
  802. package/deps/rocksdb/rocksdb/util/fastrange.h +112 -0
  803. package/deps/rocksdb/rocksdb/util/file_checksum_helper.cc +136 -0
  804. package/deps/rocksdb/rocksdb/util/file_checksum_helper.h +98 -0
  805. package/deps/rocksdb/rocksdb/util/file_reader_writer_test.cc +449 -0
  806. package/deps/rocksdb/rocksdb/util/filelock_test.cc +152 -0
  807. package/deps/rocksdb/rocksdb/util/filter_bench.cc +781 -0
  808. package/deps/rocksdb/rocksdb/util/gflags_compat.h +20 -0
  809. package/deps/rocksdb/rocksdb/util/hash.cc +83 -0
  810. package/deps/rocksdb/rocksdb/util/hash.h +107 -0
  811. package/deps/rocksdb/rocksdb/util/hash_map.h +67 -0
  812. package/deps/rocksdb/rocksdb/util/hash_test.cc +593 -0
  813. package/deps/rocksdb/rocksdb/util/heap.h +166 -0
  814. package/deps/rocksdb/rocksdb/util/heap_test.cc +139 -0
  815. package/deps/rocksdb/rocksdb/util/kv_map.h +33 -0
  816. package/deps/rocksdb/rocksdb/util/log_write_bench.cc +86 -0
  817. package/deps/rocksdb/rocksdb/util/math.h +186 -0
  818. package/deps/rocksdb/rocksdb/util/math128.h +298 -0
  819. package/deps/rocksdb/rocksdb/util/murmurhash.cc +191 -0
  820. package/deps/rocksdb/rocksdb/util/murmurhash.h +42 -0
  821. package/deps/rocksdb/rocksdb/util/mutexlock.h +186 -0
  822. package/deps/rocksdb/rocksdb/util/ppc-opcode.h +27 -0
  823. package/deps/rocksdb/rocksdb/util/random.cc +56 -0
  824. package/deps/rocksdb/rocksdb/util/random.h +186 -0
  825. package/deps/rocksdb/rocksdb/util/random_test.cc +105 -0
  826. package/deps/rocksdb/rocksdb/util/rate_limiter.cc +340 -0
  827. package/deps/rocksdb/rocksdb/util/rate_limiter.h +113 -0
  828. package/deps/rocksdb/rocksdb/util/rate_limiter_test.cc +251 -0
  829. package/deps/rocksdb/rocksdb/util/repeatable_thread.h +151 -0
  830. package/deps/rocksdb/rocksdb/util/repeatable_thread_test.cc +107 -0
  831. package/deps/rocksdb/rocksdb/util/ribbon_alg.h +1201 -0
  832. package/deps/rocksdb/rocksdb/util/ribbon_impl.h +1062 -0
  833. package/deps/rocksdb/rocksdb/util/ribbon_test.cc +931 -0
  834. package/deps/rocksdb/rocksdb/util/set_comparator.h +22 -0
  835. package/deps/rocksdb/rocksdb/util/slice.cc +243 -0
  836. package/deps/rocksdb/rocksdb/util/slice_test.cc +163 -0
  837. package/deps/rocksdb/rocksdb/util/slice_transform_test.cc +153 -0
  838. package/deps/rocksdb/rocksdb/util/status.cc +149 -0
  839. package/deps/rocksdb/rocksdb/util/stderr_logger.h +31 -0
  840. package/deps/rocksdb/rocksdb/util/stop_watch.h +118 -0
  841. package/deps/rocksdb/rocksdb/util/string_util.cc +422 -0
  842. package/deps/rocksdb/rocksdb/util/string_util.h +144 -0
  843. package/deps/rocksdb/rocksdb/util/thread_list_test.cc +354 -0
  844. package/deps/rocksdb/rocksdb/util/thread_local.cc +554 -0
  845. package/deps/rocksdb/rocksdb/util/thread_local.h +101 -0
  846. package/deps/rocksdb/rocksdb/util/thread_local_test.cc +583 -0
  847. package/deps/rocksdb/rocksdb/util/thread_operation.h +121 -0
  848. package/deps/rocksdb/rocksdb/util/threadpool_imp.cc +506 -0
  849. package/deps/rocksdb/rocksdb/util/threadpool_imp.h +112 -0
  850. package/deps/rocksdb/rocksdb/util/timer.h +331 -0
  851. package/deps/rocksdb/rocksdb/util/timer_queue.h +230 -0
  852. package/deps/rocksdb/rocksdb/util/timer_queue_test.cc +72 -0
  853. package/deps/rocksdb/rocksdb/util/timer_test.cc +399 -0
  854. package/deps/rocksdb/rocksdb/util/user_comparator_wrapper.h +80 -0
  855. package/deps/rocksdb/rocksdb/util/vector_iterator.h +101 -0
  856. package/deps/rocksdb/rocksdb/util/work_queue.h +148 -0
  857. package/deps/rocksdb/rocksdb/util/work_queue_test.cc +268 -0
  858. package/deps/rocksdb/rocksdb/util/xxh3p.h +1392 -0
  859. package/deps/rocksdb/rocksdb/util/xxhash.cc +1158 -0
  860. package/deps/rocksdb/rocksdb/util/xxhash.h +598 -0
  861. package/deps/rocksdb/rocksdb/utilities/backupable/backupable_db.cc +2354 -0
  862. package/deps/rocksdb/rocksdb/utilities/backupable/backupable_db_test.cc +2955 -0
  863. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_compaction_filter.cc +488 -0
  864. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_compaction_filter.h +199 -0
  865. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db.cc +112 -0
  866. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db.h +266 -0
  867. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_gc_stats.h +52 -0
  868. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_impl.cc +2167 -0
  869. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_impl.h +500 -0
  870. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_impl_filesnapshot.cc +113 -0
  871. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_iterator.h +147 -0
  872. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_listener.h +66 -0
  873. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_db_test.cc +2386 -0
  874. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_dump_tool.cc +281 -0
  875. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_dump_tool.h +58 -0
  876. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_file.cc +314 -0
  877. package/deps/rocksdb/rocksdb/utilities/blob_db/blob_file.h +244 -0
  878. package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_compaction_filter.cc +47 -0
  879. package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_compaction_filter.h +42 -0
  880. package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_format_test.cc +375 -0
  881. package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_functional_test.cc +327 -0
  882. package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_row_merge_test.cc +114 -0
  883. package/deps/rocksdb/rocksdb/utilities/cassandra/cassandra_serialize_test.cc +187 -0
  884. package/deps/rocksdb/rocksdb/utilities/cassandra/format.cc +390 -0
  885. package/deps/rocksdb/rocksdb/utilities/cassandra/format.h +184 -0
  886. package/deps/rocksdb/rocksdb/utilities/cassandra/merge_operator.cc +67 -0
  887. package/deps/rocksdb/rocksdb/utilities/cassandra/merge_operator.h +44 -0
  888. package/deps/rocksdb/rocksdb/utilities/cassandra/serialize.h +75 -0
  889. package/deps/rocksdb/rocksdb/utilities/cassandra/test_utils.cc +72 -0
  890. package/deps/rocksdb/rocksdb/utilities/cassandra/test_utils.h +43 -0
  891. package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_impl.cc +588 -0
  892. package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_impl.h +82 -0
  893. package/deps/rocksdb/rocksdb/utilities/checkpoint/checkpoint_test.cc +821 -0
  894. package/deps/rocksdb/rocksdb/utilities/compaction_filters/layered_compaction_filter_base.h +37 -0
  895. package/deps/rocksdb/rocksdb/utilities/compaction_filters/remove_emptyvalue_compactionfilter.cc +29 -0
  896. package/deps/rocksdb/rocksdb/utilities/compaction_filters/remove_emptyvalue_compactionfilter.h +27 -0
  897. package/deps/rocksdb/rocksdb/utilities/convenience/info_log_finder.cc +25 -0
  898. package/deps/rocksdb/rocksdb/utilities/debug.cc +82 -0
  899. package/deps/rocksdb/rocksdb/utilities/env_librados.cc +1497 -0
  900. package/deps/rocksdb/rocksdb/utilities/env_librados_test.cc +1146 -0
  901. package/deps/rocksdb/rocksdb/utilities/env_mirror.cc +262 -0
  902. package/deps/rocksdb/rocksdb/utilities/env_mirror_test.cc +223 -0
  903. package/deps/rocksdb/rocksdb/utilities/env_timed.cc +145 -0
  904. package/deps/rocksdb/rocksdb/utilities/env_timed_test.cc +44 -0
  905. package/deps/rocksdb/rocksdb/utilities/fault_injection_env.cc +490 -0
  906. package/deps/rocksdb/rocksdb/utilities/fault_injection_env.h +242 -0
  907. package/deps/rocksdb/rocksdb/utilities/fault_injection_fs.cc +581 -0
  908. package/deps/rocksdb/rocksdb/utilities/fault_injection_fs.h +437 -0
  909. package/deps/rocksdb/rocksdb/utilities/leveldb_options/leveldb_options.cc +56 -0
  910. package/deps/rocksdb/rocksdb/utilities/memory/memory_test.cc +275 -0
  911. package/deps/rocksdb/rocksdb/utilities/memory/memory_util.cc +52 -0
  912. package/deps/rocksdb/rocksdb/utilities/merge_operators/bytesxor.cc +59 -0
  913. package/deps/rocksdb/rocksdb/utilities/merge_operators/bytesxor.h +39 -0
  914. package/deps/rocksdb/rocksdb/utilities/merge_operators/max.cc +77 -0
  915. package/deps/rocksdb/rocksdb/utilities/merge_operators/put.cc +83 -0
  916. package/deps/rocksdb/rocksdb/utilities/merge_operators/sortlist.cc +97 -0
  917. package/deps/rocksdb/rocksdb/utilities/merge_operators/sortlist.h +38 -0
  918. package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend.cc +59 -0
  919. package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend.h +31 -0
  920. package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend2.cc +117 -0
  921. package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend2.h +49 -0
  922. package/deps/rocksdb/rocksdb/utilities/merge_operators/string_append/stringappend_test.cc +598 -0
  923. package/deps/rocksdb/rocksdb/utilities/merge_operators/uint64add.cc +69 -0
  924. package/deps/rocksdb/rocksdb/utilities/merge_operators.h +55 -0
  925. package/deps/rocksdb/rocksdb/utilities/object_registry.cc +87 -0
  926. package/deps/rocksdb/rocksdb/utilities/object_registry_test.cc +174 -0
  927. package/deps/rocksdb/rocksdb/utilities/option_change_migration/option_change_migration.cc +168 -0
  928. package/deps/rocksdb/rocksdb/utilities/option_change_migration/option_change_migration_test.cc +431 -0
  929. package/deps/rocksdb/rocksdb/utilities/options/options_util.cc +159 -0
  930. package/deps/rocksdb/rocksdb/utilities/options/options_util_test.cc +655 -0
  931. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier.cc +425 -0
  932. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier.h +156 -0
  933. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_file.cc +609 -0
  934. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_file.h +296 -0
  935. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_file_buffer.h +127 -0
  936. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_metadata.cc +86 -0
  937. package/deps/rocksdb/rocksdb/utilities/persistent_cache/block_cache_tier_metadata.h +125 -0
  938. package/deps/rocksdb/rocksdb/utilities/persistent_cache/hash_table.h +238 -0
  939. package/deps/rocksdb/rocksdb/utilities/persistent_cache/hash_table_bench.cc +308 -0
  940. package/deps/rocksdb/rocksdb/utilities/persistent_cache/hash_table_evictable.h +168 -0
  941. package/deps/rocksdb/rocksdb/utilities/persistent_cache/hash_table_test.cc +160 -0
  942. package/deps/rocksdb/rocksdb/utilities/persistent_cache/lrulist.h +174 -0
  943. package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_bench.cc +360 -0
  944. package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_test.cc +456 -0
  945. package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_test.h +286 -0
  946. package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_tier.cc +167 -0
  947. package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_tier.h +339 -0
  948. package/deps/rocksdb/rocksdb/utilities/persistent_cache/persistent_cache_util.h +67 -0
  949. package/deps/rocksdb/rocksdb/utilities/persistent_cache/volatile_tier_impl.cc +140 -0
  950. package/deps/rocksdb/rocksdb/utilities/persistent_cache/volatile_tier_impl.h +142 -0
  951. package/deps/rocksdb/rocksdb/utilities/simulator_cache/cache_simulator.cc +285 -0
  952. package/deps/rocksdb/rocksdb/utilities/simulator_cache/cache_simulator.h +231 -0
  953. package/deps/rocksdb/rocksdb/utilities/simulator_cache/cache_simulator_test.cc +494 -0
  954. package/deps/rocksdb/rocksdb/utilities/simulator_cache/sim_cache.cc +356 -0
  955. package/deps/rocksdb/rocksdb/utilities/simulator_cache/sim_cache_test.cc +224 -0
  956. package/deps/rocksdb/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector.cc +122 -0
  957. package/deps/rocksdb/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector.h +72 -0
  958. package/deps/rocksdb/rocksdb/utilities/table_properties_collectors/compact_on_deletion_collector_test.cc +244 -0
  959. package/deps/rocksdb/rocksdb/utilities/trace/file_trace_reader_writer.cc +125 -0
  960. package/deps/rocksdb/rocksdb/utilities/trace/file_trace_reader_writer.h +48 -0
  961. package/deps/rocksdb/rocksdb/utilities/transactions/lock/lock_manager.cc +29 -0
  962. package/deps/rocksdb/rocksdb/utilities/transactions/lock/lock_manager.h +82 -0
  963. package/deps/rocksdb/rocksdb/utilities/transactions/lock/lock_tracker.h +209 -0
  964. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager.cc +720 -0
  965. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager.h +223 -0
  966. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager_test.cc +181 -0
  967. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_manager_test.h +319 -0
  968. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_tracker.cc +270 -0
  969. package/deps/rocksdb/rocksdb/utilities/transactions/lock/point/point_lock_tracker.h +99 -0
  970. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_lock_manager.h +30 -0
  971. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_locking_test.cc +306 -0
  972. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/COPYING.AGPLv3 +661 -0
  973. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/COPYING.APACHEv2 +174 -0
  974. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/COPYING.GPLv2 +339 -0
  975. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/db.h +76 -0
  976. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/ft/comparator.h +138 -0
  977. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/ft/ft-status.h +102 -0
  978. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/concurrent_tree.cc +139 -0
  979. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/concurrent_tree.h +174 -0
  980. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/keyrange.cc +222 -0
  981. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/keyrange.h +141 -0
  982. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/lock_request.cc +525 -0
  983. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/lock_request.h +253 -0
  984. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/locktree.cc +1007 -0
  985. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/locktree.h +560 -0
  986. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/manager.cc +527 -0
  987. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/range_buffer.cc +265 -0
  988. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/range_buffer.h +178 -0
  989. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/treenode.cc +520 -0
  990. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/treenode.h +302 -0
  991. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/txnid_set.cc +120 -0
  992. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/txnid_set.h +92 -0
  993. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/wfg.cc +213 -0
  994. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/locktree/wfg.h +124 -0
  995. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/memory.h +215 -0
  996. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_assert_subst.h +39 -0
  997. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_atomic.h +130 -0
  998. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_external_pthread.h +82 -0
  999. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_instrumentation.h +286 -0
  1000. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_portability.h +87 -0
  1001. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_pthread.h +520 -0
  1002. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_race_tools.h +179 -0
  1003. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/toku_time.h +172 -0
  1004. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/portability/txn_subst.h +27 -0
  1005. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/standalone_port.cc +132 -0
  1006. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/dbt.cc +153 -0
  1007. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/dbt.h +98 -0
  1008. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/growable_array.h +144 -0
  1009. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/memarena.cc +201 -0
  1010. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/memarena.h +141 -0
  1011. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/omt.h +794 -0
  1012. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/omt_impl.h +1295 -0
  1013. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/partitioned_counter.h +165 -0
  1014. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/lib/util/status.h +76 -0
  1015. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.cc +479 -0
  1016. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_manager.h +130 -0
  1017. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_tracker.cc +156 -0
  1018. package/deps/rocksdb/rocksdb/utilities/transactions/lock/range/range_tree/range_tree_lock_tracker.h +146 -0
  1019. package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction.cc +196 -0
  1020. package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction.h +101 -0
  1021. package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction_db_impl.cc +111 -0
  1022. package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction_db_impl.h +87 -0
  1023. package/deps/rocksdb/rocksdb/utilities/transactions/optimistic_transaction_test.cc +1418 -0
  1024. package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction.cc +752 -0
  1025. package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction.h +232 -0
  1026. package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction_db.cc +628 -0
  1027. package/deps/rocksdb/rocksdb/utilities/transactions/pessimistic_transaction_db.h +228 -0
  1028. package/deps/rocksdb/rocksdb/utilities/transactions/snapshot_checker.cc +49 -0
  1029. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_base.cc +678 -0
  1030. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_base.h +373 -0
  1031. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_db_mutex_impl.cc +135 -0
  1032. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_db_mutex_impl.h +26 -0
  1033. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_test.cc +6350 -0
  1034. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_test.h +522 -0
  1035. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_util.cc +188 -0
  1036. package/deps/rocksdb/rocksdb/utilities/transactions/transaction_util.h +80 -0
  1037. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_transaction_test.cc +3531 -0
  1038. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn.cc +483 -0
  1039. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn.h +119 -0
  1040. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.cc +999 -0
  1041. package/deps/rocksdb/rocksdb/utilities/transactions/write_prepared_txn_db.h +1109 -0
  1042. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_transaction_test.cc +786 -0
  1043. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn.cc +1039 -0
  1044. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn.h +341 -0
  1045. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn_db.cc +470 -0
  1046. package/deps/rocksdb/rocksdb/utilities/transactions/write_unprepared_txn_db.h +108 -0
  1047. package/deps/rocksdb/rocksdb/utilities/ttl/db_ttl_impl.cc +332 -0
  1048. package/deps/rocksdb/rocksdb/utilities/ttl/db_ttl_impl.h +353 -0
  1049. package/deps/rocksdb/rocksdb/utilities/ttl/ttl_test.cc +703 -0
  1050. package/deps/rocksdb/rocksdb/utilities/util_merge_operators_test.cc +99 -0
  1051. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index.cc +617 -0
  1052. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.cc +345 -0
  1053. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_internal.h +569 -0
  1054. package/deps/rocksdb/rocksdb/utilities/write_batch_with_index/write_batch_with_index_test.cc +1867 -0
  1055. package/deps/rocksdb/rocksdb.gyp +475 -0
  1056. package/deps/snappy/freebsd/config.h +135 -0
  1057. package/deps/snappy/freebsd/snappy-stubs-public.h +100 -0
  1058. package/deps/snappy/linux/config.h +135 -0
  1059. package/deps/snappy/linux/snappy-stubs-public.h +100 -0
  1060. package/deps/snappy/mac/config.h +137 -0
  1061. package/deps/snappy/mac/snappy-stubs-public.h +100 -0
  1062. package/deps/snappy/openbsd/config.h +135 -0
  1063. package/deps/snappy/openbsd/snappy-stubs-public.h +100 -0
  1064. package/deps/snappy/snappy-1.1.7/COPYING +54 -0
  1065. package/deps/snappy/snappy-1.1.7/cmake/SnappyConfig.cmake +1 -0
  1066. package/deps/snappy/snappy-1.1.7/cmake/config.h.in +62 -0
  1067. package/deps/snappy/snappy-1.1.7/snappy-c.cc +90 -0
  1068. package/deps/snappy/snappy-1.1.7/snappy-c.h +138 -0
  1069. package/deps/snappy/snappy-1.1.7/snappy-internal.h +224 -0
  1070. package/deps/snappy/snappy-1.1.7/snappy-sinksource.cc +104 -0
  1071. package/deps/snappy/snappy-1.1.7/snappy-sinksource.h +182 -0
  1072. package/deps/snappy/snappy-1.1.7/snappy-stubs-internal.cc +42 -0
  1073. package/deps/snappy/snappy-1.1.7/snappy-stubs-internal.h +561 -0
  1074. package/deps/snappy/snappy-1.1.7/snappy-stubs-public.h.in +94 -0
  1075. package/deps/snappy/snappy-1.1.7/snappy-test.cc +612 -0
  1076. package/deps/snappy/snappy-1.1.7/snappy-test.h +573 -0
  1077. package/deps/snappy/snappy-1.1.7/snappy.cc +1515 -0
  1078. package/deps/snappy/snappy-1.1.7/snappy.h +203 -0
  1079. package/deps/snappy/snappy-1.1.7/snappy_unittest.cc +1410 -0
  1080. package/deps/snappy/snappy.gyp +90 -0
  1081. package/deps/snappy/solaris/config.h +135 -0
  1082. package/deps/snappy/solaris/snappy-stubs-public.h +100 -0
  1083. package/deps/snappy/win32/config.h +29 -0
  1084. package/deps/snappy/win32/snappy-stubs-public.h +100 -0
  1085. package/iterator.js +55 -0
  1086. package/leveldown.js +113 -0
  1087. package/package-lock.json +23687 -0
  1088. package/package.json +70 -0
@@ -0,0 +1,999 @@
1
+ // Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
2
+ // This source code is licensed under both the GPLv2 (found in the
3
+ // COPYING file in the root directory) and Apache 2.0 License
4
+ // (found in the LICENSE.Apache file in the root directory).
5
+
6
+ #ifndef ROCKSDB_LITE
7
+
8
+ #include "utilities/transactions/write_prepared_txn_db.h"
9
+
10
+ #include <algorithm>
11
+ #include <cinttypes>
12
+ #include <string>
13
+ #include <unordered_set>
14
+ #include <vector>
15
+
16
+ #include "db/arena_wrapped_db_iter.h"
17
+ #include "db/db_impl/db_impl.h"
18
+ #include "rocksdb/db.h"
19
+ #include "rocksdb/options.h"
20
+ #include "rocksdb/utilities/transaction_db.h"
21
+ #include "test_util/sync_point.h"
22
+ #include "util/cast_util.h"
23
+ #include "util/mutexlock.h"
24
+ #include "util/string_util.h"
25
+ #include "utilities/transactions/pessimistic_transaction.h"
26
+ #include "utilities/transactions/transaction_db_mutex_impl.h"
27
+
28
+ namespace ROCKSDB_NAMESPACE {
29
+
30
+ Status WritePreparedTxnDB::Initialize(
31
+ const std::vector<size_t>& compaction_enabled_cf_indices,
32
+ const std::vector<ColumnFamilyHandle*>& handles) {
33
+ auto dbimpl = static_cast_with_check<DBImpl>(GetRootDB());
34
+ assert(dbimpl != nullptr);
35
+ auto rtxns = dbimpl->recovered_transactions();
36
+ std::map<SequenceNumber, SequenceNumber> ordered_seq_cnt;
37
+ for (auto rtxn : rtxns) {
38
+ // There should only one batch for WritePrepared policy.
39
+ assert(rtxn.second->batches_.size() == 1);
40
+ const auto& seq = rtxn.second->batches_.begin()->first;
41
+ const auto& batch_info = rtxn.second->batches_.begin()->second;
42
+ auto cnt = batch_info.batch_cnt_ ? batch_info.batch_cnt_ : 1;
43
+ ordered_seq_cnt[seq] = cnt;
44
+ }
45
+ // AddPrepared must be called in order
46
+ for (auto seq_cnt : ordered_seq_cnt) {
47
+ auto seq = seq_cnt.first;
48
+ auto cnt = seq_cnt.second;
49
+ for (size_t i = 0; i < cnt; i++) {
50
+ AddPrepared(seq + i);
51
+ }
52
+ }
53
+ SequenceNumber prev_max = max_evicted_seq_;
54
+ SequenceNumber last_seq = db_impl_->GetLatestSequenceNumber();
55
+ AdvanceMaxEvictedSeq(prev_max, last_seq);
56
+ // Create a gap between max and the next snapshot. This simplifies the logic
57
+ // in IsInSnapshot by not having to consider the special case of max ==
58
+ // snapshot after recovery. This is tested in IsInSnapshotEmptyMapTest.
59
+ if (last_seq) {
60
+ db_impl_->versions_->SetLastAllocatedSequence(last_seq + 1);
61
+ db_impl_->versions_->SetLastSequence(last_seq + 1);
62
+ db_impl_->versions_->SetLastPublishedSequence(last_seq + 1);
63
+ }
64
+
65
+ db_impl_->SetSnapshotChecker(new WritePreparedSnapshotChecker(this));
66
+ // A callback to commit a single sub-batch
67
+ class CommitSubBatchPreReleaseCallback : public PreReleaseCallback {
68
+ public:
69
+ explicit CommitSubBatchPreReleaseCallback(WritePreparedTxnDB* db)
70
+ : db_(db) {}
71
+ Status Callback(SequenceNumber commit_seq,
72
+ bool is_mem_disabled __attribute__((__unused__)), uint64_t,
73
+ size_t /*index*/, size_t /*total*/) override {
74
+ assert(!is_mem_disabled);
75
+ db_->AddCommitted(commit_seq, commit_seq);
76
+ return Status::OK();
77
+ }
78
+
79
+ private:
80
+ WritePreparedTxnDB* db_;
81
+ };
82
+ db_impl_->SetRecoverableStatePreReleaseCallback(
83
+ new CommitSubBatchPreReleaseCallback(this));
84
+
85
+ auto s = PessimisticTransactionDB::Initialize(compaction_enabled_cf_indices,
86
+ handles);
87
+ return s;
88
+ }
89
+
90
+ Status WritePreparedTxnDB::VerifyCFOptions(
91
+ const ColumnFamilyOptions& cf_options) {
92
+ Status s = PessimisticTransactionDB::VerifyCFOptions(cf_options);
93
+ if (!s.ok()) {
94
+ return s;
95
+ }
96
+ if (!cf_options.memtable_factory->CanHandleDuplicatedKey()) {
97
+ return Status::InvalidArgument(
98
+ "memtable_factory->CanHandleDuplicatedKey() cannot be false with "
99
+ "WritePrpeared transactions");
100
+ }
101
+ return Status::OK();
102
+ }
103
+
104
+ Transaction* WritePreparedTxnDB::BeginTransaction(
105
+ const WriteOptions& write_options, const TransactionOptions& txn_options,
106
+ Transaction* old_txn) {
107
+ if (old_txn != nullptr) {
108
+ ReinitializeTransaction(old_txn, write_options, txn_options);
109
+ return old_txn;
110
+ } else {
111
+ return new WritePreparedTxn(this, write_options, txn_options);
112
+ }
113
+ }
114
+
115
+ Status WritePreparedTxnDB::Write(const WriteOptions& opts,
116
+ WriteBatch* updates) {
117
+ if (txn_db_options_.skip_concurrency_control) {
118
+ // Skip locking the rows
119
+ const size_t UNKNOWN_BATCH_CNT = 0;
120
+ WritePreparedTxn* NO_TXN = nullptr;
121
+ return WriteInternal(opts, updates, UNKNOWN_BATCH_CNT, NO_TXN);
122
+ } else {
123
+ return PessimisticTransactionDB::WriteWithConcurrencyControl(opts, updates);
124
+ }
125
+ }
126
+
127
+ Status WritePreparedTxnDB::Write(
128
+ const WriteOptions& opts,
129
+ const TransactionDBWriteOptimizations& optimizations, WriteBatch* updates) {
130
+ if (optimizations.skip_concurrency_control) {
131
+ // Skip locking the rows
132
+ const size_t UNKNOWN_BATCH_CNT = 0;
133
+ const size_t ONE_BATCH_CNT = 1;
134
+ const size_t batch_cnt = optimizations.skip_duplicate_key_check
135
+ ? ONE_BATCH_CNT
136
+ : UNKNOWN_BATCH_CNT;
137
+ WritePreparedTxn* NO_TXN = nullptr;
138
+ return WriteInternal(opts, updates, batch_cnt, NO_TXN);
139
+ } else {
140
+ // TODO(myabandeh): Make use of skip_duplicate_key_check hint
141
+ // Fall back to unoptimized version
142
+ return PessimisticTransactionDB::WriteWithConcurrencyControl(opts, updates);
143
+ }
144
+ }
145
+
146
+ Status WritePreparedTxnDB::WriteInternal(const WriteOptions& write_options_orig,
147
+ WriteBatch* batch, size_t batch_cnt,
148
+ WritePreparedTxn* txn) {
149
+ ROCKS_LOG_DETAILS(db_impl_->immutable_db_options().info_log,
150
+ "CommitBatchInternal");
151
+ if (batch->Count() == 0) {
152
+ // Otherwise our 1 seq per batch logic will break since there is no seq
153
+ // increased for this batch.
154
+ return Status::OK();
155
+ }
156
+ if (batch_cnt == 0) { // not provided, then compute it
157
+ // TODO(myabandeh): add an option to allow user skipping this cost
158
+ SubBatchCounter counter(*GetCFComparatorMap());
159
+ auto s = batch->Iterate(&counter);
160
+ if (!s.ok()) {
161
+ return s;
162
+ }
163
+ batch_cnt = counter.BatchCount();
164
+ WPRecordTick(TXN_DUPLICATE_KEY_OVERHEAD);
165
+ ROCKS_LOG_DETAILS(info_log_, "Duplicate key overhead: %" PRIu64 " batches",
166
+ static_cast<uint64_t>(batch_cnt));
167
+ }
168
+ assert(batch_cnt);
169
+
170
+ bool do_one_write = !db_impl_->immutable_db_options().two_write_queues;
171
+ WriteOptions write_options(write_options_orig);
172
+ // In the absence of Prepare markers, use Noop as a batch separator
173
+ auto s = WriteBatchInternal::InsertNoop(batch);
174
+ assert(s.ok());
175
+ const bool DISABLE_MEMTABLE = true;
176
+ const uint64_t no_log_ref = 0;
177
+ uint64_t seq_used = kMaxSequenceNumber;
178
+ const size_t ZERO_PREPARES = 0;
179
+ const bool kSeperatePrepareCommitBatches = true;
180
+ // Since this is not 2pc, there is no need for AddPrepared but having it in
181
+ // the PreReleaseCallback enables an optimization. Refer to
182
+ // SmallestUnCommittedSeq for more details.
183
+ AddPreparedCallback add_prepared_callback(
184
+ this, db_impl_, batch_cnt,
185
+ db_impl_->immutable_db_options().two_write_queues,
186
+ !kSeperatePrepareCommitBatches);
187
+ WritePreparedCommitEntryPreReleaseCallback update_commit_map(
188
+ this, db_impl_, kMaxSequenceNumber, ZERO_PREPARES, batch_cnt);
189
+ PreReleaseCallback* pre_release_callback;
190
+ if (do_one_write) {
191
+ pre_release_callback = &update_commit_map;
192
+ } else {
193
+ pre_release_callback = &add_prepared_callback;
194
+ }
195
+ s = db_impl_->WriteImpl(write_options, batch, nullptr, nullptr, no_log_ref,
196
+ !DISABLE_MEMTABLE, &seq_used, batch_cnt,
197
+ pre_release_callback);
198
+ assert(!s.ok() || seq_used != kMaxSequenceNumber);
199
+ uint64_t prepare_seq = seq_used;
200
+ if (txn != nullptr) {
201
+ txn->SetId(prepare_seq);
202
+ }
203
+ if (!s.ok()) {
204
+ return s;
205
+ }
206
+ if (do_one_write) {
207
+ return s;
208
+ } // else do the 2nd write for commit
209
+ ROCKS_LOG_DETAILS(db_impl_->immutable_db_options().info_log,
210
+ "CommitBatchInternal 2nd write prepare_seq: %" PRIu64,
211
+ prepare_seq);
212
+ // Commit the batch by writing an empty batch to the 2nd queue that will
213
+ // release the commit sequence number to readers.
214
+ const size_t ZERO_COMMITS = 0;
215
+ WritePreparedCommitEntryPreReleaseCallback update_commit_map_with_prepare(
216
+ this, db_impl_, prepare_seq, batch_cnt, ZERO_COMMITS);
217
+ WriteBatch empty_batch;
218
+ write_options.disableWAL = true;
219
+ write_options.sync = false;
220
+ const size_t ONE_BATCH = 1; // Just to inc the seq
221
+ s = db_impl_->WriteImpl(write_options, &empty_batch, nullptr, nullptr,
222
+ no_log_ref, DISABLE_MEMTABLE, &seq_used, ONE_BATCH,
223
+ &update_commit_map_with_prepare);
224
+ assert(!s.ok() || seq_used != kMaxSequenceNumber);
225
+ // Note: RemovePrepared is called from within PreReleaseCallback
226
+ return s;
227
+ }
228
+
229
+ Status WritePreparedTxnDB::Get(const ReadOptions& options,
230
+ ColumnFamilyHandle* column_family,
231
+ const Slice& key, PinnableSlice* value) {
232
+ SequenceNumber min_uncommitted, snap_seq;
233
+ const SnapshotBackup backed_by_snapshot =
234
+ AssignMinMaxSeqs(options.snapshot, &min_uncommitted, &snap_seq);
235
+ WritePreparedTxnReadCallback callback(this, snap_seq, min_uncommitted,
236
+ backed_by_snapshot);
237
+ bool* dont_care = nullptr;
238
+ DBImpl::GetImplOptions get_impl_options;
239
+ get_impl_options.column_family = column_family;
240
+ get_impl_options.value = value;
241
+ get_impl_options.value_found = dont_care;
242
+ get_impl_options.callback = &callback;
243
+ auto res = db_impl_->GetImpl(options, key, get_impl_options);
244
+ if (LIKELY(callback.valid() && ValidateSnapshot(callback.max_visible_seq(),
245
+ backed_by_snapshot))) {
246
+ return res;
247
+ } else {
248
+ WPRecordTick(TXN_GET_TRY_AGAIN);
249
+ return Status::TryAgain();
250
+ }
251
+ }
252
+
253
+ void WritePreparedTxnDB::UpdateCFComparatorMap(
254
+ const std::vector<ColumnFamilyHandle*>& handles) {
255
+ auto cf_map = new std::map<uint32_t, const Comparator*>();
256
+ auto handle_map = new std::map<uint32_t, ColumnFamilyHandle*>();
257
+ for (auto h : handles) {
258
+ auto id = h->GetID();
259
+ const Comparator* comparator = h->GetComparator();
260
+ (*cf_map)[id] = comparator;
261
+ if (id != 0) {
262
+ (*handle_map)[id] = h;
263
+ } else {
264
+ // The pointer to the default cf handle in the handles will be deleted.
265
+ // Use the pointer maintained by the db instead.
266
+ (*handle_map)[id] = DefaultColumnFamily();
267
+ }
268
+ }
269
+ cf_map_.reset(cf_map);
270
+ handle_map_.reset(handle_map);
271
+ }
272
+
273
+ void WritePreparedTxnDB::UpdateCFComparatorMap(ColumnFamilyHandle* h) {
274
+ auto old_cf_map_ptr = cf_map_.get();
275
+ assert(old_cf_map_ptr);
276
+ auto cf_map = new std::map<uint32_t, const Comparator*>(*old_cf_map_ptr);
277
+ auto old_handle_map_ptr = handle_map_.get();
278
+ assert(old_handle_map_ptr);
279
+ auto handle_map =
280
+ new std::map<uint32_t, ColumnFamilyHandle*>(*old_handle_map_ptr);
281
+ auto id = h->GetID();
282
+ const Comparator* comparator = h->GetComparator();
283
+ (*cf_map)[id] = comparator;
284
+ (*handle_map)[id] = h;
285
+ cf_map_.reset(cf_map);
286
+ handle_map_.reset(handle_map);
287
+ }
288
+
289
+
290
+ std::vector<Status> WritePreparedTxnDB::MultiGet(
291
+ const ReadOptions& options,
292
+ const std::vector<ColumnFamilyHandle*>& column_family,
293
+ const std::vector<Slice>& keys, std::vector<std::string>* values) {
294
+ assert(values);
295
+ size_t num_keys = keys.size();
296
+ values->resize(num_keys);
297
+
298
+ std::vector<Status> stat_list(num_keys);
299
+ for (size_t i = 0; i < num_keys; ++i) {
300
+ stat_list[i] = this->Get(options, column_family[i], keys[i], &(*values)[i]);
301
+ }
302
+ return stat_list;
303
+ }
304
+
305
+ // Struct to hold ownership of snapshot and read callback for iterator cleanup.
306
+ struct WritePreparedTxnDB::IteratorState {
307
+ IteratorState(WritePreparedTxnDB* txn_db, SequenceNumber sequence,
308
+ std::shared_ptr<ManagedSnapshot> s,
309
+ SequenceNumber min_uncommitted)
310
+ : callback(txn_db, sequence, min_uncommitted, kBackedByDBSnapshot),
311
+ snapshot(s) {}
312
+
313
+ WritePreparedTxnReadCallback callback;
314
+ std::shared_ptr<ManagedSnapshot> snapshot;
315
+ };
316
+
317
+ namespace {
318
+ static void CleanupWritePreparedTxnDBIterator(void* arg1, void* /*arg2*/) {
319
+ delete reinterpret_cast<WritePreparedTxnDB::IteratorState*>(arg1);
320
+ }
321
+ } // anonymous namespace
322
+
323
+ Iterator* WritePreparedTxnDB::NewIterator(const ReadOptions& options,
324
+ ColumnFamilyHandle* column_family) {
325
+ constexpr bool expose_blob_index = false;
326
+ constexpr bool allow_refresh = false;
327
+ std::shared_ptr<ManagedSnapshot> own_snapshot = nullptr;
328
+ SequenceNumber snapshot_seq = kMaxSequenceNumber;
329
+ SequenceNumber min_uncommitted = 0;
330
+ if (options.snapshot != nullptr) {
331
+ snapshot_seq = options.snapshot->GetSequenceNumber();
332
+ min_uncommitted =
333
+ static_cast_with_check<const SnapshotImpl>(options.snapshot)
334
+ ->min_uncommitted_;
335
+ } else {
336
+ auto* snapshot = GetSnapshot();
337
+ // We take a snapshot to make sure that the related data in the commit map
338
+ // are not deleted.
339
+ snapshot_seq = snapshot->GetSequenceNumber();
340
+ min_uncommitted =
341
+ static_cast_with_check<const SnapshotImpl>(snapshot)->min_uncommitted_;
342
+ own_snapshot = std::make_shared<ManagedSnapshot>(db_impl_, snapshot);
343
+ }
344
+ assert(snapshot_seq != kMaxSequenceNumber);
345
+ auto* cfd =
346
+ static_cast_with_check<ColumnFamilyHandleImpl>(column_family)->cfd();
347
+ auto* state =
348
+ new IteratorState(this, snapshot_seq, own_snapshot, min_uncommitted);
349
+ auto* db_iter =
350
+ db_impl_->NewIteratorImpl(options, cfd, snapshot_seq, &state->callback,
351
+ expose_blob_index, allow_refresh);
352
+ db_iter->RegisterCleanup(CleanupWritePreparedTxnDBIterator, state, nullptr);
353
+ return db_iter;
354
+ }
355
+
356
+ Status WritePreparedTxnDB::NewIterators(
357
+ const ReadOptions& options,
358
+ const std::vector<ColumnFamilyHandle*>& column_families,
359
+ std::vector<Iterator*>* iterators) {
360
+ constexpr bool expose_blob_index = false;
361
+ constexpr bool allow_refresh = false;
362
+ std::shared_ptr<ManagedSnapshot> own_snapshot = nullptr;
363
+ SequenceNumber snapshot_seq = kMaxSequenceNumber;
364
+ SequenceNumber min_uncommitted = 0;
365
+ if (options.snapshot != nullptr) {
366
+ snapshot_seq = options.snapshot->GetSequenceNumber();
367
+ min_uncommitted =
368
+ static_cast_with_check<const SnapshotImpl>(options.snapshot)
369
+ ->min_uncommitted_;
370
+ } else {
371
+ auto* snapshot = GetSnapshot();
372
+ // We take a snapshot to make sure that the related data in the commit map
373
+ // are not deleted.
374
+ snapshot_seq = snapshot->GetSequenceNumber();
375
+ own_snapshot = std::make_shared<ManagedSnapshot>(db_impl_, snapshot);
376
+ min_uncommitted =
377
+ static_cast_with_check<const SnapshotImpl>(snapshot)->min_uncommitted_;
378
+ }
379
+ iterators->clear();
380
+ iterators->reserve(column_families.size());
381
+ for (auto* column_family : column_families) {
382
+ auto* cfd =
383
+ static_cast_with_check<ColumnFamilyHandleImpl>(column_family)->cfd();
384
+ auto* state =
385
+ new IteratorState(this, snapshot_seq, own_snapshot, min_uncommitted);
386
+ auto* db_iter =
387
+ db_impl_->NewIteratorImpl(options, cfd, snapshot_seq, &state->callback,
388
+ expose_blob_index, allow_refresh);
389
+ db_iter->RegisterCleanup(CleanupWritePreparedTxnDBIterator, state, nullptr);
390
+ iterators->push_back(db_iter);
391
+ }
392
+ return Status::OK();
393
+ }
394
+
395
+ void WritePreparedTxnDB::Init(const TransactionDBOptions& /* unused */) {
396
+ // Adcance max_evicted_seq_ no more than 100 times before the cache wraps
397
+ // around.
398
+ INC_STEP_FOR_MAX_EVICTED =
399
+ std::max(COMMIT_CACHE_SIZE / 100, static_cast<size_t>(1));
400
+ snapshot_cache_ = std::unique_ptr<std::atomic<SequenceNumber>[]>(
401
+ new std::atomic<SequenceNumber>[SNAPSHOT_CACHE_SIZE] {});
402
+ commit_cache_ = std::unique_ptr<std::atomic<CommitEntry64b>[]>(
403
+ new std::atomic<CommitEntry64b>[COMMIT_CACHE_SIZE] {});
404
+ dummy_max_snapshot_.number_ = kMaxSequenceNumber;
405
+ }
406
+
407
+ void WritePreparedTxnDB::CheckPreparedAgainstMax(SequenceNumber new_max,
408
+ bool locked) {
409
+ // When max_evicted_seq_ advances, move older entries from prepared_txns_
410
+ // to delayed_prepared_. This guarantees that if a seq is lower than max,
411
+ // then it is not in prepared_txns_ and save an expensive, synchronized
412
+ // lookup from a shared set. delayed_prepared_ is expected to be empty in
413
+ // normal cases.
414
+ ROCKS_LOG_DETAILS(
415
+ info_log_,
416
+ "CheckPreparedAgainstMax prepared_txns_.empty() %d top: %" PRIu64,
417
+ prepared_txns_.empty(),
418
+ prepared_txns_.empty() ? 0 : prepared_txns_.top());
419
+ const SequenceNumber prepared_top = prepared_txns_.top();
420
+ const bool empty = prepared_top == kMaxSequenceNumber;
421
+ // Preliminary check to avoid the synchronization cost
422
+ if (!empty && prepared_top <= new_max) {
423
+ if (locked) {
424
+ // Needed to avoid double locking in pop().
425
+ prepared_txns_.push_pop_mutex()->Unlock();
426
+ }
427
+ WriteLock wl(&prepared_mutex_);
428
+ // Need to fetch fresh values of ::top after mutex is acquired
429
+ while (!prepared_txns_.empty() && prepared_txns_.top() <= new_max) {
430
+ auto to_be_popped = prepared_txns_.top();
431
+ delayed_prepared_.insert(to_be_popped);
432
+ ROCKS_LOG_WARN(info_log_,
433
+ "prepared_mutex_ overhead %" PRIu64 " (prep=%" PRIu64
434
+ " new_max=%" PRIu64,
435
+ static_cast<uint64_t>(delayed_prepared_.size()),
436
+ to_be_popped, new_max);
437
+ delayed_prepared_empty_.store(false, std::memory_order_release);
438
+ // Update prepared_txns_ after updating delayed_prepared_empty_ otherwise
439
+ // there will be a point in time that the entry is neither in
440
+ // prepared_txns_ nor in delayed_prepared_, which will not be checked if
441
+ // delayed_prepared_empty_ is false.
442
+ prepared_txns_.pop();
443
+ }
444
+ if (locked) {
445
+ prepared_txns_.push_pop_mutex()->Lock();
446
+ }
447
+ }
448
+ }
449
+
450
+ void WritePreparedTxnDB::AddPrepared(uint64_t seq, bool locked) {
451
+ ROCKS_LOG_DETAILS(info_log_, "Txn %" PRIu64 " Preparing with max %" PRIu64,
452
+ seq, max_evicted_seq_.load());
453
+ TEST_SYNC_POINT("AddPrepared::begin:pause");
454
+ TEST_SYNC_POINT("AddPrepared::begin:resume");
455
+ if (!locked) {
456
+ prepared_txns_.push_pop_mutex()->Lock();
457
+ }
458
+ prepared_txns_.push_pop_mutex()->AssertHeld();
459
+ prepared_txns_.push(seq);
460
+ auto new_max = future_max_evicted_seq_.load();
461
+ if (UNLIKELY(seq <= new_max)) {
462
+ // This should not happen in normal case
463
+ ROCKS_LOG_ERROR(
464
+ info_log_,
465
+ "Added prepare_seq is not larger than max_evicted_seq_: %" PRIu64
466
+ " <= %" PRIu64,
467
+ seq, new_max);
468
+ CheckPreparedAgainstMax(new_max, true /*locked*/);
469
+ }
470
+ if (!locked) {
471
+ prepared_txns_.push_pop_mutex()->Unlock();
472
+ }
473
+ TEST_SYNC_POINT("AddPrepared::end");
474
+ }
475
+
476
+ void WritePreparedTxnDB::AddCommitted(uint64_t prepare_seq, uint64_t commit_seq,
477
+ uint8_t loop_cnt) {
478
+ ROCKS_LOG_DETAILS(info_log_, "Txn %" PRIu64 " Committing with %" PRIu64,
479
+ prepare_seq, commit_seq);
480
+ TEST_SYNC_POINT("WritePreparedTxnDB::AddCommitted:start");
481
+ TEST_SYNC_POINT("WritePreparedTxnDB::AddCommitted:start:pause");
482
+ auto indexed_seq = prepare_seq % COMMIT_CACHE_SIZE;
483
+ CommitEntry64b evicted_64b;
484
+ CommitEntry evicted;
485
+ bool to_be_evicted = GetCommitEntry(indexed_seq, &evicted_64b, &evicted);
486
+ if (LIKELY(to_be_evicted)) {
487
+ assert(evicted.prep_seq != prepare_seq);
488
+ auto prev_max = max_evicted_seq_.load(std::memory_order_acquire);
489
+ ROCKS_LOG_DETAILS(info_log_,
490
+ "Evicting %" PRIu64 ",%" PRIu64 " with max %" PRIu64,
491
+ evicted.prep_seq, evicted.commit_seq, prev_max);
492
+ if (prev_max < evicted.commit_seq) {
493
+ auto last = db_impl_->GetLastPublishedSequence(); // could be 0
494
+ SequenceNumber max_evicted_seq;
495
+ if (LIKELY(evicted.commit_seq < last)) {
496
+ assert(last > 0);
497
+ // Inc max in larger steps to avoid frequent updates
498
+ max_evicted_seq =
499
+ std::min(evicted.commit_seq + INC_STEP_FOR_MAX_EVICTED, last - 1);
500
+ } else {
501
+ // legit when a commit entry in a write batch overwrite the previous one
502
+ max_evicted_seq = evicted.commit_seq;
503
+ }
504
+ ROCKS_LOG_DETAILS(info_log_,
505
+ "%lu Evicting %" PRIu64 ",%" PRIu64 " with max %" PRIu64
506
+ " => %lu",
507
+ prepare_seq, evicted.prep_seq, evicted.commit_seq,
508
+ prev_max, max_evicted_seq);
509
+ AdvanceMaxEvictedSeq(prev_max, max_evicted_seq);
510
+ }
511
+ // After each eviction from commit cache, check if the commit entry should
512
+ // be kept around because it overlaps with a live snapshot.
513
+ CheckAgainstSnapshots(evicted);
514
+ if (UNLIKELY(!delayed_prepared_empty_.load(std::memory_order_acquire))) {
515
+ WriteLock wl(&prepared_mutex_);
516
+ for (auto dp : delayed_prepared_) {
517
+ if (dp == evicted.prep_seq) {
518
+ // This is a rare case that txn is committed but prepared_txns_ is not
519
+ // cleaned up yet. Refer to delayed_prepared_commits_ definition for
520
+ // why it should be kept updated.
521
+ delayed_prepared_commits_[evicted.prep_seq] = evicted.commit_seq;
522
+ ROCKS_LOG_DEBUG(info_log_,
523
+ "delayed_prepared_commits_[%" PRIu64 "]=%" PRIu64,
524
+ evicted.prep_seq, evicted.commit_seq);
525
+ break;
526
+ }
527
+ }
528
+ }
529
+ }
530
+ bool succ =
531
+ ExchangeCommitEntry(indexed_seq, evicted_64b, {prepare_seq, commit_seq});
532
+ if (UNLIKELY(!succ)) {
533
+ ROCKS_LOG_ERROR(info_log_,
534
+ "ExchangeCommitEntry failed on [%" PRIu64 "] %" PRIu64
535
+ ",%" PRIu64 " retrying...",
536
+ indexed_seq, prepare_seq, commit_seq);
537
+ // A very rare event, in which the commit entry is updated before we do.
538
+ // Here we apply a very simple solution of retrying.
539
+ if (loop_cnt > 100) {
540
+ throw std::runtime_error("Infinite loop in AddCommitted!");
541
+ }
542
+ AddCommitted(prepare_seq, commit_seq, ++loop_cnt);
543
+ return;
544
+ }
545
+ TEST_SYNC_POINT("WritePreparedTxnDB::AddCommitted:end");
546
+ TEST_SYNC_POINT("WritePreparedTxnDB::AddCommitted:end:pause");
547
+ }
548
+
549
+ void WritePreparedTxnDB::RemovePrepared(const uint64_t prepare_seq,
550
+ const size_t batch_cnt) {
551
+ TEST_SYNC_POINT_CALLBACK(
552
+ "RemovePrepared:Start",
553
+ const_cast<void*>(reinterpret_cast<const void*>(&prepare_seq)));
554
+ TEST_SYNC_POINT("WritePreparedTxnDB::RemovePrepared:pause");
555
+ TEST_SYNC_POINT("WritePreparedTxnDB::RemovePrepared:resume");
556
+ ROCKS_LOG_DETAILS(info_log_,
557
+ "RemovePrepared %" PRIu64 " cnt: %" ROCKSDB_PRIszt,
558
+ prepare_seq, batch_cnt);
559
+ WriteLock wl(&prepared_mutex_);
560
+ for (size_t i = 0; i < batch_cnt; i++) {
561
+ prepared_txns_.erase(prepare_seq + i);
562
+ bool was_empty = delayed_prepared_.empty();
563
+ if (!was_empty) {
564
+ delayed_prepared_.erase(prepare_seq + i);
565
+ auto it = delayed_prepared_commits_.find(prepare_seq + i);
566
+ if (it != delayed_prepared_commits_.end()) {
567
+ ROCKS_LOG_DETAILS(info_log_, "delayed_prepared_commits_.erase %" PRIu64,
568
+ prepare_seq + i);
569
+ delayed_prepared_commits_.erase(it);
570
+ }
571
+ bool is_empty = delayed_prepared_.empty();
572
+ if (was_empty != is_empty) {
573
+ delayed_prepared_empty_.store(is_empty, std::memory_order_release);
574
+ }
575
+ }
576
+ }
577
+ }
578
+
579
+ bool WritePreparedTxnDB::GetCommitEntry(const uint64_t indexed_seq,
580
+ CommitEntry64b* entry_64b,
581
+ CommitEntry* entry) const {
582
+ *entry_64b = commit_cache_[static_cast<size_t>(indexed_seq)].load(std::memory_order_acquire);
583
+ bool valid = entry_64b->Parse(indexed_seq, entry, FORMAT);
584
+ return valid;
585
+ }
586
+
587
+ bool WritePreparedTxnDB::AddCommitEntry(const uint64_t indexed_seq,
588
+ const CommitEntry& new_entry,
589
+ CommitEntry* evicted_entry) {
590
+ CommitEntry64b new_entry_64b(new_entry, FORMAT);
591
+ CommitEntry64b evicted_entry_64b = commit_cache_[static_cast<size_t>(indexed_seq)].exchange(
592
+ new_entry_64b, std::memory_order_acq_rel);
593
+ bool valid = evicted_entry_64b.Parse(indexed_seq, evicted_entry, FORMAT);
594
+ return valid;
595
+ }
596
+
597
+ bool WritePreparedTxnDB::ExchangeCommitEntry(const uint64_t indexed_seq,
598
+ CommitEntry64b& expected_entry_64b,
599
+ const CommitEntry& new_entry) {
600
+ auto& atomic_entry = commit_cache_[static_cast<size_t>(indexed_seq)];
601
+ CommitEntry64b new_entry_64b(new_entry, FORMAT);
602
+ bool succ = atomic_entry.compare_exchange_strong(
603
+ expected_entry_64b, new_entry_64b, std::memory_order_acq_rel,
604
+ std::memory_order_acquire);
605
+ return succ;
606
+ }
607
+
608
+ void WritePreparedTxnDB::AdvanceMaxEvictedSeq(const SequenceNumber& prev_max,
609
+ const SequenceNumber& new_max) {
610
+ ROCKS_LOG_DETAILS(info_log_,
611
+ "AdvanceMaxEvictedSeq overhead %" PRIu64 " => %" PRIu64,
612
+ prev_max, new_max);
613
+ // Declare the intention before getting snapshot from the DB. This helps a
614
+ // concurrent GetSnapshot to wait to catch up with future_max_evicted_seq_ if
615
+ // it has not already. Otherwise the new snapshot is when we ask DB for
616
+ // snapshots smaller than future max.
617
+ auto updated_future_max = prev_max;
618
+ while (updated_future_max < new_max &&
619
+ !future_max_evicted_seq_.compare_exchange_weak(
620
+ updated_future_max, new_max, std::memory_order_acq_rel,
621
+ std::memory_order_relaxed)) {
622
+ };
623
+
624
+ CheckPreparedAgainstMax(new_max, false /*locked*/);
625
+
626
+ // With each change to max_evicted_seq_ fetch the live snapshots behind it.
627
+ // We use max as the version of snapshots to identify how fresh are the
628
+ // snapshot list. This works because the snapshots are between 0 and
629
+ // max, so the larger the max, the more complete they are.
630
+ SequenceNumber new_snapshots_version = new_max;
631
+ std::vector<SequenceNumber> snapshots;
632
+ bool update_snapshots = false;
633
+ if (new_snapshots_version > snapshots_version_) {
634
+ // This is to avoid updating the snapshots_ if it already updated
635
+ // with a more recent vesion by a concrrent thread
636
+ update_snapshots = true;
637
+ // We only care about snapshots lower then max
638
+ snapshots = GetSnapshotListFromDB(new_max);
639
+ }
640
+ if (update_snapshots) {
641
+ UpdateSnapshots(snapshots, new_snapshots_version);
642
+ if (!snapshots.empty()) {
643
+ WriteLock wl(&old_commit_map_mutex_);
644
+ for (auto snap : snapshots) {
645
+ // This allows IsInSnapshot to tell apart the reads from in valid
646
+ // snapshots from the reads from committed values in valid snapshots.
647
+ old_commit_map_[snap];
648
+ }
649
+ old_commit_map_empty_.store(false, std::memory_order_release);
650
+ }
651
+ }
652
+ auto updated_prev_max = prev_max;
653
+ TEST_SYNC_POINT("AdvanceMaxEvictedSeq::update_max:pause");
654
+ TEST_SYNC_POINT("AdvanceMaxEvictedSeq::update_max:resume");
655
+ while (updated_prev_max < new_max &&
656
+ !max_evicted_seq_.compare_exchange_weak(updated_prev_max, new_max,
657
+ std::memory_order_acq_rel,
658
+ std::memory_order_relaxed)) {
659
+ };
660
+ }
661
+
662
+ const Snapshot* WritePreparedTxnDB::GetSnapshot() {
663
+ const bool kForWWConflictCheck = true;
664
+ return GetSnapshotInternal(!kForWWConflictCheck);
665
+ }
666
+
667
+ SnapshotImpl* WritePreparedTxnDB::GetSnapshotInternal(
668
+ bool for_ww_conflict_check) {
669
+ // Note: for this optimization setting the last sequence number and obtaining
670
+ // the smallest uncommitted seq should be done atomically. However to avoid
671
+ // the mutex overhead, we call SmallestUnCommittedSeq BEFORE taking the
672
+ // snapshot. Since we always updated the list of unprepared seq (via
673
+ // AddPrepared) AFTER the last sequence is updated, this guarantees that the
674
+ // smallest uncommitted seq that we pair with the snapshot is smaller or equal
675
+ // the value that would be obtained otherwise atomically. That is ok since
676
+ // this optimization works as long as min_uncommitted is less than or equal
677
+ // than the smallest uncommitted seq when the snapshot was taken.
678
+ auto min_uncommitted = WritePreparedTxnDB::SmallestUnCommittedSeq();
679
+ SnapshotImpl* snap_impl = db_impl_->GetSnapshotImpl(for_ww_conflict_check);
680
+ TEST_SYNC_POINT("WritePreparedTxnDB::GetSnapshotInternal:first");
681
+ assert(snap_impl);
682
+ SequenceNumber snap_seq = snap_impl->GetSequenceNumber();
683
+ // Note: Check against future_max_evicted_seq_ (in contrast with
684
+ // max_evicted_seq_) in case there is a concurrent AdvanceMaxEvictedSeq.
685
+ if (UNLIKELY(snap_seq != 0 && snap_seq <= future_max_evicted_seq_)) {
686
+ // There is a very rare case in which the commit entry evicts another commit
687
+ // entry that is not published yet thus advancing max evicted seq beyond the
688
+ // last published seq. This case is not likely in real-world setup so we
689
+ // handle it with a few retries.
690
+ size_t retry = 0;
691
+ SequenceNumber max;
692
+ while ((max = future_max_evicted_seq_.load()) != 0 &&
693
+ snap_impl->GetSequenceNumber() <= max && retry < 100) {
694
+ ROCKS_LOG_WARN(info_log_,
695
+ "GetSnapshot snap: %" PRIu64 " max: %" PRIu64
696
+ " retry %" ROCKSDB_PRIszt,
697
+ snap_impl->GetSequenceNumber(), max, retry);
698
+ ReleaseSnapshot(snap_impl);
699
+ // Wait for last visible seq to catch up with max, and also go beyond it
700
+ // by one.
701
+ AdvanceSeqByOne();
702
+ snap_impl = db_impl_->GetSnapshotImpl(for_ww_conflict_check);
703
+ assert(snap_impl);
704
+ retry++;
705
+ }
706
+ assert(snap_impl->GetSequenceNumber() > max);
707
+ if (snap_impl->GetSequenceNumber() <= max) {
708
+ throw std::runtime_error(
709
+ "Snapshot seq " + ToString(snap_impl->GetSequenceNumber()) +
710
+ " after " + ToString(retry) +
711
+ " retries is still less than futre_max_evicted_seq_" + ToString(max));
712
+ }
713
+ }
714
+ EnhanceSnapshot(snap_impl, min_uncommitted);
715
+ ROCKS_LOG_DETAILS(
716
+ db_impl_->immutable_db_options().info_log,
717
+ "GetSnapshot %" PRIu64 " ww:%" PRIi32 " min_uncommitted: %" PRIu64,
718
+ snap_impl->GetSequenceNumber(), for_ww_conflict_check, min_uncommitted);
719
+ TEST_SYNC_POINT("WritePreparedTxnDB::GetSnapshotInternal:end");
720
+ return snap_impl;
721
+ }
722
+
723
+ void WritePreparedTxnDB::AdvanceSeqByOne() {
724
+ // Inserting an empty value will i) let the max evicted entry to be
725
+ // published, i.e., max == last_published, increase the last published to
726
+ // be one beyond max, i.e., max < last_published.
727
+ WriteOptions woptions;
728
+ TransactionOptions txn_options;
729
+ Transaction* txn0 = BeginTransaction(woptions, txn_options, nullptr);
730
+ std::hash<std::thread::id> hasher;
731
+ char name[64];
732
+ snprintf(name, 64, "txn%" ROCKSDB_PRIszt, hasher(std::this_thread::get_id()));
733
+ assert(strlen(name) < 64 - 1);
734
+ Status s = txn0->SetName(name);
735
+ assert(s.ok());
736
+ if (s.ok()) {
737
+ // Without prepare it would simply skip the commit
738
+ s = txn0->Prepare();
739
+ }
740
+ assert(s.ok());
741
+ if (s.ok()) {
742
+ s = txn0->Commit();
743
+ }
744
+ assert(s.ok());
745
+ delete txn0;
746
+ }
747
+
748
+ const std::vector<SequenceNumber> WritePreparedTxnDB::GetSnapshotListFromDB(
749
+ SequenceNumber max) {
750
+ ROCKS_LOG_DETAILS(info_log_, "GetSnapshotListFromDB with max %" PRIu64, max);
751
+ InstrumentedMutexLock dblock(db_impl_->mutex());
752
+ db_impl_->mutex()->AssertHeld();
753
+ return db_impl_->snapshots().GetAll(nullptr, max);
754
+ }
755
+
756
+ void WritePreparedTxnDB::ReleaseSnapshotInternal(
757
+ const SequenceNumber snap_seq) {
758
+ // TODO(myabandeh): relax should enough since the synchronizatin is already
759
+ // done by snapshots_mutex_ under which this function is called.
760
+ if (snap_seq <= max_evicted_seq_.load(std::memory_order_acquire)) {
761
+ // Then this is a rare case that transaction did not finish before max
762
+ // advances. It is expected for a few read-only backup snapshots. For such
763
+ // snapshots we might have kept around a couple of entries in the
764
+ // old_commit_map_. Check and do garbage collection if that is the case.
765
+ bool need_gc = false;
766
+ {
767
+ WPRecordTick(TXN_OLD_COMMIT_MAP_MUTEX_OVERHEAD);
768
+ ROCKS_LOG_WARN(info_log_, "old_commit_map_mutex_ overhead for %" PRIu64,
769
+ snap_seq);
770
+ ReadLock rl(&old_commit_map_mutex_);
771
+ auto prep_set_entry = old_commit_map_.find(snap_seq);
772
+ need_gc = prep_set_entry != old_commit_map_.end();
773
+ }
774
+ if (need_gc) {
775
+ WPRecordTick(TXN_OLD_COMMIT_MAP_MUTEX_OVERHEAD);
776
+ ROCKS_LOG_WARN(info_log_, "old_commit_map_mutex_ overhead for %" PRIu64,
777
+ snap_seq);
778
+ WriteLock wl(&old_commit_map_mutex_);
779
+ old_commit_map_.erase(snap_seq);
780
+ old_commit_map_empty_.store(old_commit_map_.empty(),
781
+ std::memory_order_release);
782
+ }
783
+ }
784
+ }
785
+
786
+ void WritePreparedTxnDB::CleanupReleasedSnapshots(
787
+ const std::vector<SequenceNumber>& new_snapshots,
788
+ const std::vector<SequenceNumber>& old_snapshots) {
789
+ auto newi = new_snapshots.begin();
790
+ auto oldi = old_snapshots.begin();
791
+ for (; newi != new_snapshots.end() && oldi != old_snapshots.end();) {
792
+ assert(*newi >= *oldi); // cannot have new snapshots with lower seq
793
+ if (*newi == *oldi) { // still not released
794
+ auto value = *newi;
795
+ while (newi != new_snapshots.end() && *newi == value) {
796
+ newi++;
797
+ }
798
+ while (oldi != old_snapshots.end() && *oldi == value) {
799
+ oldi++;
800
+ }
801
+ } else {
802
+ assert(*newi > *oldi); // *oldi is released
803
+ ReleaseSnapshotInternal(*oldi);
804
+ oldi++;
805
+ }
806
+ }
807
+ // Everything remained in old_snapshots is released and must be cleaned up
808
+ for (; oldi != old_snapshots.end(); oldi++) {
809
+ ReleaseSnapshotInternal(*oldi);
810
+ }
811
+ }
812
+
813
+ void WritePreparedTxnDB::UpdateSnapshots(
814
+ const std::vector<SequenceNumber>& snapshots,
815
+ const SequenceNumber& version) {
816
+ ROCKS_LOG_DETAILS(info_log_, "UpdateSnapshots with version %" PRIu64,
817
+ version);
818
+ TEST_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:p:start");
819
+ TEST_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:s:start");
820
+ #ifndef NDEBUG
821
+ size_t sync_i = 0;
822
+ #endif
823
+ ROCKS_LOG_DETAILS(info_log_, "snapshots_mutex_ overhead");
824
+ WriteLock wl(&snapshots_mutex_);
825
+ snapshots_version_ = version;
826
+ // We update the list concurrently with the readers.
827
+ // Both new and old lists are sorted and the new list is subset of the
828
+ // previous list plus some new items. Thus if a snapshot repeats in
829
+ // both new and old lists, it will appear upper in the new list. So if
830
+ // we simply insert the new snapshots in order, if an overwritten item
831
+ // is still valid in the new list is either written to the same place in
832
+ // the array or it is written in a higher palce before it gets
833
+ // overwritten by another item. This guarantess a reader that reads the
834
+ // list bottom-up will eventaully see a snapshot that repeats in the
835
+ // update, either before it gets overwritten by the writer or
836
+ // afterwards.
837
+ size_t i = 0;
838
+ auto it = snapshots.begin();
839
+ for (; it != snapshots.end() && i < SNAPSHOT_CACHE_SIZE; ++it, ++i) {
840
+ snapshot_cache_[i].store(*it, std::memory_order_release);
841
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:p:", ++sync_i);
842
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:s:", sync_i);
843
+ }
844
+ #ifndef NDEBUG
845
+ // Release the remaining sync points since they are useless given that the
846
+ // reader would also use lock to access snapshots
847
+ for (++sync_i; sync_i <= 10; ++sync_i) {
848
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:p:", sync_i);
849
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:s:", sync_i);
850
+ }
851
+ #endif
852
+ snapshots_.clear();
853
+ for (; it != snapshots.end(); ++it) {
854
+ // Insert them to a vector that is less efficient to access
855
+ // concurrently
856
+ snapshots_.push_back(*it);
857
+ }
858
+ // Update the size at the end. Otherwise a parallel reader might read
859
+ // items that are not set yet.
860
+ snapshots_total_.store(snapshots.size(), std::memory_order_release);
861
+
862
+ // Note: this must be done after the snapshots data structures are updated
863
+ // with the new list of snapshots.
864
+ CleanupReleasedSnapshots(snapshots, snapshots_all_);
865
+ snapshots_all_ = snapshots;
866
+
867
+ TEST_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:p:end");
868
+ TEST_SYNC_POINT("WritePreparedTxnDB::UpdateSnapshots:s:end");
869
+ }
870
+
871
+ void WritePreparedTxnDB::CheckAgainstSnapshots(const CommitEntry& evicted) {
872
+ TEST_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:p:start");
873
+ TEST_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:s:start");
874
+ #ifndef NDEBUG
875
+ size_t sync_i = 0;
876
+ #endif
877
+ // First check the snapshot cache that is efficient for concurrent access
878
+ auto cnt = snapshots_total_.load(std::memory_order_acquire);
879
+ // The list might get updated concurrently as we are reading from it. The
880
+ // reader should be able to read all the snapshots that are still valid
881
+ // after the update. Since the survived snapshots are written in a higher
882
+ // place before gets overwritten the reader that reads bottom-up will
883
+ // eventully see it.
884
+ const bool next_is_larger = true;
885
+ // We will set to true if the border line snapshot suggests that.
886
+ bool search_larger_list = false;
887
+ size_t ip1 = std::min(cnt, SNAPSHOT_CACHE_SIZE);
888
+ for (; 0 < ip1; ip1--) {
889
+ SequenceNumber snapshot_seq =
890
+ snapshot_cache_[ip1 - 1].load(std::memory_order_acquire);
891
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:p:",
892
+ ++sync_i);
893
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:s:", sync_i);
894
+ if (ip1 == SNAPSHOT_CACHE_SIZE) { // border line snapshot
895
+ // snapshot_seq < commit_seq => larger_snapshot_seq <= commit_seq
896
+ // then later also continue the search to larger snapshots
897
+ search_larger_list = snapshot_seq < evicted.commit_seq;
898
+ }
899
+ if (!MaybeUpdateOldCommitMap(evicted.prep_seq, evicted.commit_seq,
900
+ snapshot_seq, !next_is_larger)) {
901
+ break;
902
+ }
903
+ }
904
+ #ifndef NDEBUG
905
+ // Release the remaining sync points before accquiring the lock
906
+ for (++sync_i; sync_i <= 10; ++sync_i) {
907
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:p:", sync_i);
908
+ TEST_IDX_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:s:", sync_i);
909
+ }
910
+ #endif
911
+ TEST_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:p:end");
912
+ TEST_SYNC_POINT("WritePreparedTxnDB::CheckAgainstSnapshots:s:end");
913
+ if (UNLIKELY(SNAPSHOT_CACHE_SIZE < cnt && search_larger_list)) {
914
+ // Then access the less efficient list of snapshots_
915
+ WPRecordTick(TXN_SNAPSHOT_MUTEX_OVERHEAD);
916
+ ROCKS_LOG_WARN(info_log_,
917
+ "snapshots_mutex_ overhead for <%" PRIu64 ",%" PRIu64
918
+ "> with %" ROCKSDB_PRIszt " snapshots",
919
+ evicted.prep_seq, evicted.commit_seq, cnt);
920
+ ReadLock rl(&snapshots_mutex_);
921
+ // Items could have moved from the snapshots_ to snapshot_cache_ before
922
+ // accquiring the lock. To make sure that we do not miss a valid snapshot,
923
+ // read snapshot_cache_ again while holding the lock.
924
+ for (size_t i = 0; i < SNAPSHOT_CACHE_SIZE; i++) {
925
+ SequenceNumber snapshot_seq =
926
+ snapshot_cache_[i].load(std::memory_order_acquire);
927
+ if (!MaybeUpdateOldCommitMap(evicted.prep_seq, evicted.commit_seq,
928
+ snapshot_seq, next_is_larger)) {
929
+ break;
930
+ }
931
+ }
932
+ for (auto snapshot_seq_2 : snapshots_) {
933
+ if (!MaybeUpdateOldCommitMap(evicted.prep_seq, evicted.commit_seq,
934
+ snapshot_seq_2, next_is_larger)) {
935
+ break;
936
+ }
937
+ }
938
+ }
939
+ }
940
+
941
+ bool WritePreparedTxnDB::MaybeUpdateOldCommitMap(
942
+ const uint64_t& prep_seq, const uint64_t& commit_seq,
943
+ const uint64_t& snapshot_seq, const bool next_is_larger = true) {
944
+ // If we do not store an entry in old_commit_map_ we assume it is committed in
945
+ // all snapshots. If commit_seq <= snapshot_seq, it is considered already in
946
+ // the snapshot so we need not to keep the entry around for this snapshot.
947
+ if (commit_seq <= snapshot_seq) {
948
+ // continue the search if the next snapshot could be smaller than commit_seq
949
+ return !next_is_larger;
950
+ }
951
+ // then snapshot_seq < commit_seq
952
+ if (prep_seq <= snapshot_seq) { // overlapping range
953
+ WPRecordTick(TXN_OLD_COMMIT_MAP_MUTEX_OVERHEAD);
954
+ ROCKS_LOG_WARN(info_log_,
955
+ "old_commit_map_mutex_ overhead for %" PRIu64
956
+ " commit entry: <%" PRIu64 ",%" PRIu64 ">",
957
+ snapshot_seq, prep_seq, commit_seq);
958
+ WriteLock wl(&old_commit_map_mutex_);
959
+ old_commit_map_empty_.store(false, std::memory_order_release);
960
+ auto& vec = old_commit_map_[snapshot_seq];
961
+ vec.insert(std::upper_bound(vec.begin(), vec.end(), prep_seq), prep_seq);
962
+ // We need to store it once for each overlapping snapshot. Returning true to
963
+ // continue the search if there is more overlapping snapshot.
964
+ return true;
965
+ }
966
+ // continue the search if the next snapshot could be larger than prep_seq
967
+ return next_is_larger;
968
+ }
969
+
970
+ WritePreparedTxnDB::~WritePreparedTxnDB() {
971
+ // At this point there could be running compaction/flush holding a
972
+ // SnapshotChecker, which holds a pointer back to WritePreparedTxnDB.
973
+ // Make sure those jobs finished before destructing WritePreparedTxnDB.
974
+ if (!db_impl_->shutting_down_) {
975
+ db_impl_->CancelAllBackgroundWork(true /*wait*/);
976
+ }
977
+ }
978
+
979
+ void SubBatchCounter::InitWithComp(const uint32_t cf) {
980
+ auto cmp = comparators_[cf];
981
+ keys_[cf] = CFKeys(SetComparator(cmp));
982
+ }
983
+
984
+ void SubBatchCounter::AddKey(const uint32_t cf, const Slice& key) {
985
+ CFKeys& cf_keys = keys_[cf];
986
+ if (cf_keys.size() == 0) { // just inserted
987
+ InitWithComp(cf);
988
+ }
989
+ auto it = cf_keys.insert(key);
990
+ if (it.second == false) { // second is false if a element already existed.
991
+ batches_++;
992
+ keys_.clear();
993
+ InitWithComp(cf);
994
+ keys_[cf].insert(key);
995
+ }
996
+ }
997
+
998
+ } // namespace ROCKSDB_NAMESPACE
999
+ #endif // ROCKSDB_LITE