@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,1835 @@
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
+ // Copyright (c) 2011 The LevelDB Authors. All rights reserved.
7
+ // Use of this source code is governed by a BSD-style license that can be
8
+ // found in the LICENSE file. See the AUTHORS file for names of contributors.
9
+
10
+ #include "table/block_based/block_based_table_builder.h"
11
+
12
+ #include <assert.h>
13
+ #include <stdio.h>
14
+ #include <atomic>
15
+ #include <list>
16
+ #include <map>
17
+ #include <memory>
18
+ #include <string>
19
+ #include <unordered_map>
20
+ #include <utility>
21
+
22
+ #include "db/dbformat.h"
23
+ #include "index_builder.h"
24
+
25
+ #include "rocksdb/cache.h"
26
+ #include "rocksdb/comparator.h"
27
+ #include "rocksdb/env.h"
28
+ #include "rocksdb/flush_block_policy.h"
29
+ #include "rocksdb/merge_operator.h"
30
+ #include "rocksdb/table.h"
31
+
32
+ #include "table/block_based/block.h"
33
+ #include "table/block_based/block_based_filter_block.h"
34
+ #include "table/block_based/block_based_table_factory.h"
35
+ #include "table/block_based/block_based_table_reader.h"
36
+ #include "table/block_based/block_builder.h"
37
+ #include "table/block_based/filter_block.h"
38
+ #include "table/block_based/filter_policy_internal.h"
39
+ #include "table/block_based/full_filter_block.h"
40
+ #include "table/block_based/partitioned_filter_block.h"
41
+ #include "table/format.h"
42
+ #include "table/table_builder.h"
43
+
44
+ #include "memory/memory_allocator.h"
45
+ #include "util/coding.h"
46
+ #include "util/compression.h"
47
+ #include "util/crc32c.h"
48
+ #include "util/stop_watch.h"
49
+ #include "util/string_util.h"
50
+ #include "util/work_queue.h"
51
+ #include "util/xxhash.h"
52
+
53
+ namespace ROCKSDB_NAMESPACE {
54
+
55
+ extern const std::string kHashIndexPrefixesBlock;
56
+ extern const std::string kHashIndexPrefixesMetadataBlock;
57
+
58
+
59
+ // Without anonymous namespace here, we fail the warning -Wmissing-prototypes
60
+ namespace {
61
+
62
+ // Create a filter block builder based on its type.
63
+ FilterBlockBuilder* CreateFilterBlockBuilder(
64
+ const ImmutableCFOptions& /*opt*/, const MutableCFOptions& mopt,
65
+ const FilterBuildingContext& context,
66
+ const bool use_delta_encoding_for_index_values,
67
+ PartitionedIndexBuilder* const p_index_builder) {
68
+ const BlockBasedTableOptions& table_opt = context.table_options;
69
+ if (table_opt.filter_policy == nullptr) return nullptr;
70
+
71
+ FilterBitsBuilder* filter_bits_builder =
72
+ BloomFilterPolicy::GetBuilderFromContext(context);
73
+ if (filter_bits_builder == nullptr) {
74
+ return new BlockBasedFilterBlockBuilder(mopt.prefix_extractor.get(),
75
+ table_opt);
76
+ } else {
77
+ if (table_opt.partition_filters) {
78
+ assert(p_index_builder != nullptr);
79
+ // Since after partition cut request from filter builder it takes time
80
+ // until index builder actully cuts the partition, until the end of a
81
+ // data block potentially with many keys, we take the lower bound as
82
+ // partition size.
83
+ assert(table_opt.block_size_deviation <= 100);
84
+ auto partition_size =
85
+ static_cast<uint32_t>(((table_opt.metadata_block_size *
86
+ (100 - table_opt.block_size_deviation)) +
87
+ 99) /
88
+ 100);
89
+ partition_size = std::max(partition_size, static_cast<uint32_t>(1));
90
+ return new PartitionedFilterBlockBuilder(
91
+ mopt.prefix_extractor.get(), table_opt.whole_key_filtering,
92
+ filter_bits_builder, table_opt.index_block_restart_interval,
93
+ use_delta_encoding_for_index_values, p_index_builder, partition_size);
94
+ } else {
95
+ return new FullFilterBlockBuilder(mopt.prefix_extractor.get(),
96
+ table_opt.whole_key_filtering,
97
+ filter_bits_builder);
98
+ }
99
+ }
100
+ }
101
+
102
+ bool GoodCompressionRatio(size_t compressed_size, size_t raw_size) {
103
+ // Check to see if compressed less than 12.5%
104
+ return compressed_size < raw_size - (raw_size / 8u);
105
+ }
106
+
107
+ } // namespace
108
+
109
+ // format_version is the block format as defined in include/rocksdb/table.h
110
+ Slice CompressBlock(const Slice& raw, const CompressionInfo& info,
111
+ CompressionType* type, uint32_t format_version,
112
+ bool do_sample, std::string* compressed_output,
113
+ std::string* sampled_output_fast,
114
+ std::string* sampled_output_slow) {
115
+ assert(type);
116
+ assert(compressed_output);
117
+ assert(compressed_output->empty());
118
+
119
+ // If requested, we sample one in every N block with a
120
+ // fast and slow compression algorithm and report the stats.
121
+ // The users can use these stats to decide if it is worthwhile
122
+ // enabling compression and they also get a hint about which
123
+ // compression algorithm wil be beneficial.
124
+ if (do_sample && info.SampleForCompression() &&
125
+ Random::GetTLSInstance()->OneIn(
126
+ static_cast<int>(info.SampleForCompression()))) {
127
+ // Sampling with a fast compression algorithm
128
+ if (sampled_output_fast && (LZ4_Supported() || Snappy_Supported())) {
129
+ CompressionType c =
130
+ LZ4_Supported() ? kLZ4Compression : kSnappyCompression;
131
+ CompressionContext context(c);
132
+ CompressionOptions options;
133
+ CompressionInfo info_tmp(options, context,
134
+ CompressionDict::GetEmptyDict(), c,
135
+ info.SampleForCompression());
136
+
137
+ CompressData(raw, info_tmp, GetCompressFormatForVersion(format_version),
138
+ sampled_output_fast);
139
+ }
140
+
141
+ // Sampling with a slow but high-compression algorithm
142
+ if (sampled_output_slow && (ZSTD_Supported() || Zlib_Supported())) {
143
+ CompressionType c = ZSTD_Supported() ? kZSTD : kZlibCompression;
144
+ CompressionContext context(c);
145
+ CompressionOptions options;
146
+ CompressionInfo info_tmp(options, context,
147
+ CompressionDict::GetEmptyDict(), c,
148
+ info.SampleForCompression());
149
+
150
+ CompressData(raw, info_tmp, GetCompressFormatForVersion(format_version),
151
+ sampled_output_slow);
152
+ }
153
+ }
154
+
155
+ if (info.type() == kNoCompression) {
156
+ *type = kNoCompression;
157
+ return raw;
158
+ }
159
+
160
+ // Actually compress the data; if the compression method is not supported,
161
+ // or the compression fails etc., just fall back to uncompressed
162
+ if (!CompressData(raw, info, GetCompressFormatForVersion(format_version),
163
+ compressed_output)) {
164
+ *type = kNoCompression;
165
+ return raw;
166
+ }
167
+
168
+ // Check the compression ratio; if it's not good enough, just fall back to
169
+ // uncompressed
170
+ if (!GoodCompressionRatio(compressed_output->size(), raw.size())) {
171
+ *type = kNoCompression;
172
+ return raw;
173
+ }
174
+
175
+ *type = info.type();
176
+ return *compressed_output;
177
+ }
178
+
179
+ // kBlockBasedTableMagicNumber was picked by running
180
+ // echo rocksdb.table.block_based | sha1sum
181
+ // and taking the leading 64 bits.
182
+ // Please note that kBlockBasedTableMagicNumber may also be accessed by other
183
+ // .cc files
184
+ // for that reason we declare it extern in the header but to get the space
185
+ // allocated
186
+ // it must be not extern in one place.
187
+ const uint64_t kBlockBasedTableMagicNumber = 0x88e241b785f4cff7ull;
188
+ // We also support reading and writing legacy block based table format (for
189
+ // backwards compatibility)
190
+ const uint64_t kLegacyBlockBasedTableMagicNumber = 0xdb4775248b80fb57ull;
191
+
192
+ // A collector that collects properties of interest to block-based table.
193
+ // For now this class looks heavy-weight since we only write one additional
194
+ // property.
195
+ // But in the foreseeable future, we will add more and more properties that are
196
+ // specific to block-based table.
197
+ class BlockBasedTableBuilder::BlockBasedTablePropertiesCollector
198
+ : public IntTblPropCollector {
199
+ public:
200
+ explicit BlockBasedTablePropertiesCollector(
201
+ BlockBasedTableOptions::IndexType index_type, bool whole_key_filtering,
202
+ bool prefix_filtering)
203
+ : index_type_(index_type),
204
+ whole_key_filtering_(whole_key_filtering),
205
+ prefix_filtering_(prefix_filtering) {}
206
+
207
+ Status InternalAdd(const Slice& /*key*/, const Slice& /*value*/,
208
+ uint64_t /*file_size*/) override {
209
+ // Intentionally left blank. Have no interest in collecting stats for
210
+ // individual key/value pairs.
211
+ return Status::OK();
212
+ }
213
+
214
+ virtual void BlockAdd(uint64_t /* blockRawBytes */,
215
+ uint64_t /* blockCompressedBytesFast */,
216
+ uint64_t /* blockCompressedBytesSlow */) override {
217
+ // Intentionally left blank. No interest in collecting stats for
218
+ // blocks.
219
+ return;
220
+ }
221
+
222
+ Status Finish(UserCollectedProperties* properties) override {
223
+ std::string val;
224
+ PutFixed32(&val, static_cast<uint32_t>(index_type_));
225
+ properties->insert({BlockBasedTablePropertyNames::kIndexType, val});
226
+ properties->insert({BlockBasedTablePropertyNames::kWholeKeyFiltering,
227
+ whole_key_filtering_ ? kPropTrue : kPropFalse});
228
+ properties->insert({BlockBasedTablePropertyNames::kPrefixFiltering,
229
+ prefix_filtering_ ? kPropTrue : kPropFalse});
230
+ return Status::OK();
231
+ }
232
+
233
+ // The name of the properties collector can be used for debugging purpose.
234
+ const char* Name() const override {
235
+ return "BlockBasedTablePropertiesCollector";
236
+ }
237
+
238
+ UserCollectedProperties GetReadableProperties() const override {
239
+ // Intentionally left blank.
240
+ return UserCollectedProperties();
241
+ }
242
+
243
+ private:
244
+ BlockBasedTableOptions::IndexType index_type_;
245
+ bool whole_key_filtering_;
246
+ bool prefix_filtering_;
247
+ };
248
+
249
+ struct BlockBasedTableBuilder::Rep {
250
+ const ImmutableCFOptions ioptions;
251
+ const MutableCFOptions moptions;
252
+ const BlockBasedTableOptions table_options;
253
+ const InternalKeyComparator& internal_comparator;
254
+ WritableFileWriter* file;
255
+ std::atomic<uint64_t> offset;
256
+ size_t alignment;
257
+ BlockBuilder data_block;
258
+ // Buffers uncompressed data blocks and keys to replay later. Needed when
259
+ // compression dictionary is enabled so we can finalize the dictionary before
260
+ // compressing any data blocks.
261
+ // TODO(ajkr): ideally we don't buffer all keys and all uncompressed data
262
+ // blocks as it's redundant, but it's easier to implement for now.
263
+ std::vector<std::pair<std::string, std::vector<std::string>>>
264
+ data_block_and_keys_buffers;
265
+ BlockBuilder range_del_block;
266
+
267
+ InternalKeySliceTransform internal_prefix_transform;
268
+ std::unique_ptr<IndexBuilder> index_builder;
269
+ PartitionedIndexBuilder* p_index_builder_ = nullptr;
270
+
271
+ std::string last_key;
272
+ const Slice* first_key_in_next_block = nullptr;
273
+ CompressionType compression_type;
274
+ uint64_t sample_for_compression;
275
+ CompressionOptions compression_opts;
276
+ std::unique_ptr<CompressionDict> compression_dict;
277
+ std::vector<std::unique_ptr<CompressionContext>> compression_ctxs;
278
+ std::vector<std::unique_ptr<UncompressionContext>> verify_ctxs;
279
+ std::unique_ptr<UncompressionDict> verify_dict;
280
+
281
+ size_t data_begin_offset = 0;
282
+
283
+ TableProperties props;
284
+
285
+ // States of the builder.
286
+ //
287
+ // - `kBuffered`: This is the initial state where zero or more data blocks are
288
+ // accumulated uncompressed in-memory. From this state, call
289
+ // `EnterUnbuffered()` to finalize the compression dictionary if enabled,
290
+ // compress/write out any buffered blocks, and proceed to the `kUnbuffered`
291
+ // state.
292
+ //
293
+ // - `kUnbuffered`: This is the state when compression dictionary is finalized
294
+ // either because it wasn't enabled in the first place or it's been created
295
+ // from sampling previously buffered data. In this state, blocks are simply
296
+ // compressed/written out as they fill up. From this state, call `Finish()`
297
+ // to complete the file (write meta-blocks, etc.), or `Abandon()` to delete
298
+ // the partially created file.
299
+ //
300
+ // - `kClosed`: This indicates either `Finish()` or `Abandon()` has been
301
+ // called, so the table builder is no longer usable. We must be in this
302
+ // state by the time the destructor runs.
303
+ enum class State {
304
+ kBuffered,
305
+ kUnbuffered,
306
+ kClosed,
307
+ };
308
+ State state;
309
+
310
+ const bool use_delta_encoding_for_index_values;
311
+ std::unique_ptr<FilterBlockBuilder> filter_builder;
312
+ char compressed_cache_key_prefix[BlockBasedTable::kMaxCacheKeyPrefixSize];
313
+ size_t compressed_cache_key_prefix_size;
314
+
315
+ BlockHandle pending_handle; // Handle to add to index block
316
+
317
+ std::string compressed_output;
318
+ std::unique_ptr<FlushBlockPolicy> flush_block_policy;
319
+ int level_at_creation;
320
+ uint32_t column_family_id;
321
+ const std::string& column_family_name;
322
+ uint64_t creation_time = 0;
323
+ uint64_t oldest_key_time = 0;
324
+ const uint64_t target_file_size;
325
+ uint64_t file_creation_time = 0;
326
+
327
+ // DB IDs
328
+ const std::string db_id;
329
+ const std::string db_session_id;
330
+ std::string db_host_id;
331
+
332
+ std::vector<std::unique_ptr<IntTblPropCollector>> table_properties_collectors;
333
+
334
+ std::unique_ptr<ParallelCompressionRep> pc_rep;
335
+
336
+ uint64_t get_offset() { return offset.load(std::memory_order_relaxed); }
337
+ void set_offset(uint64_t o) { offset.store(o, std::memory_order_relaxed); }
338
+
339
+ bool IsParallelCompressionEnabled() const {
340
+ return compression_opts.parallel_threads > 1;
341
+ }
342
+
343
+ Status GetStatus() {
344
+ // We need to make modifications of status visible when status_ok is set
345
+ // to false, and this is ensured by status_mutex, so no special memory
346
+ // order for status_ok is required.
347
+ if (status_ok.load(std::memory_order_relaxed)) {
348
+ return Status::OK();
349
+ } else {
350
+ return CopyStatus();
351
+ }
352
+ }
353
+
354
+ Status CopyStatus() {
355
+ std::lock_guard<std::mutex> lock(status_mutex);
356
+ return status;
357
+ }
358
+
359
+ IOStatus GetIOStatus() {
360
+ // We need to make modifications of io_status visible when status_ok is set
361
+ // to false, and this is ensured by io_status_mutex, so no special memory
362
+ // order for io_status_ok is required.
363
+ if (io_status_ok.load(std::memory_order_relaxed)) {
364
+ return IOStatus::OK();
365
+ } else {
366
+ return CopyIOStatus();
367
+ }
368
+ }
369
+
370
+ IOStatus CopyIOStatus() {
371
+ std::lock_guard<std::mutex> lock(io_status_mutex);
372
+ return io_status;
373
+ }
374
+
375
+ // Never erase an existing status that is not OK.
376
+ void SetStatus(Status s) {
377
+ if (!s.ok() && status_ok.load(std::memory_order_relaxed)) {
378
+ // Locking is an overkill for non compression_opts.parallel_threads
379
+ // case but since it's unlikely that s is not OK, we take this cost
380
+ // to be simplicity.
381
+ std::lock_guard<std::mutex> lock(status_mutex);
382
+ status = s;
383
+ status_ok.store(false, std::memory_order_relaxed);
384
+ }
385
+ }
386
+
387
+ // Never erase an existing I/O status that is not OK.
388
+ void SetIOStatus(IOStatus ios) {
389
+ if (!ios.ok() && io_status_ok.load(std::memory_order_relaxed)) {
390
+ // Locking is an overkill for non compression_opts.parallel_threads
391
+ // case but since it's unlikely that s is not OK, we take this cost
392
+ // to be simplicity.
393
+ std::lock_guard<std::mutex> lock(io_status_mutex);
394
+ io_status = ios;
395
+ io_status_ok.store(false, std::memory_order_relaxed);
396
+ }
397
+ }
398
+
399
+ Rep(const ImmutableCFOptions& _ioptions, const MutableCFOptions& _moptions,
400
+ const BlockBasedTableOptions& table_opt,
401
+ const InternalKeyComparator& icomparator,
402
+ const std::vector<std::unique_ptr<IntTblPropCollectorFactory>>*
403
+ int_tbl_prop_collector_factories,
404
+ uint32_t _column_family_id, WritableFileWriter* f,
405
+ const CompressionType _compression_type,
406
+ const uint64_t _sample_for_compression,
407
+ const CompressionOptions& _compression_opts, const bool skip_filters,
408
+ const int _level_at_creation, const std::string& _column_family_name,
409
+ const uint64_t _creation_time, const uint64_t _oldest_key_time,
410
+ const uint64_t _target_file_size, const uint64_t _file_creation_time,
411
+ const std::string& _db_id, const std::string& _db_session_id)
412
+ : ioptions(_ioptions),
413
+ moptions(_moptions),
414
+ table_options(table_opt),
415
+ internal_comparator(icomparator),
416
+ file(f),
417
+ offset(0),
418
+ alignment(table_options.block_align
419
+ ? std::min(table_options.block_size, kDefaultPageSize)
420
+ : 0),
421
+ data_block(table_options.block_restart_interval,
422
+ table_options.use_delta_encoding,
423
+ false /* use_value_delta_encoding */,
424
+ icomparator.user_comparator()
425
+ ->CanKeysWithDifferentByteContentsBeEqual()
426
+ ? BlockBasedTableOptions::kDataBlockBinarySearch
427
+ : table_options.data_block_index_type,
428
+ table_options.data_block_hash_table_util_ratio),
429
+ range_del_block(1 /* block_restart_interval */),
430
+ internal_prefix_transform(_moptions.prefix_extractor.get()),
431
+ compression_type(_compression_type),
432
+ sample_for_compression(_sample_for_compression),
433
+ compression_opts(_compression_opts),
434
+ compression_dict(),
435
+ compression_ctxs(_compression_opts.parallel_threads),
436
+ verify_ctxs(_compression_opts.parallel_threads),
437
+ verify_dict(),
438
+ state((_compression_opts.max_dict_bytes > 0) ? State::kBuffered
439
+ : State::kUnbuffered),
440
+ use_delta_encoding_for_index_values(table_opt.format_version >= 4 &&
441
+ !table_opt.block_align),
442
+ compressed_cache_key_prefix_size(0),
443
+ flush_block_policy(
444
+ table_options.flush_block_policy_factory->NewFlushBlockPolicy(
445
+ table_options, data_block)),
446
+ level_at_creation(_level_at_creation),
447
+ column_family_id(_column_family_id),
448
+ column_family_name(_column_family_name),
449
+ creation_time(_creation_time),
450
+ oldest_key_time(_oldest_key_time),
451
+ target_file_size(_target_file_size),
452
+ file_creation_time(_file_creation_time),
453
+ db_id(_db_id),
454
+ db_session_id(_db_session_id),
455
+ db_host_id(ioptions.db_host_id),
456
+ status_ok(true),
457
+ io_status_ok(true) {
458
+ for (uint32_t i = 0; i < compression_opts.parallel_threads; i++) {
459
+ compression_ctxs[i].reset(new CompressionContext(compression_type));
460
+ }
461
+ if (table_options.index_type ==
462
+ BlockBasedTableOptions::kTwoLevelIndexSearch) {
463
+ p_index_builder_ = PartitionedIndexBuilder::CreateIndexBuilder(
464
+ &internal_comparator, use_delta_encoding_for_index_values,
465
+ table_options);
466
+ index_builder.reset(p_index_builder_);
467
+ } else {
468
+ index_builder.reset(IndexBuilder::CreateIndexBuilder(
469
+ table_options.index_type, &internal_comparator,
470
+ &this->internal_prefix_transform, use_delta_encoding_for_index_values,
471
+ table_options));
472
+ }
473
+ if (skip_filters) {
474
+ filter_builder = nullptr;
475
+ } else {
476
+ FilterBuildingContext context(table_options);
477
+ context.column_family_name = column_family_name;
478
+ context.compaction_style = ioptions.compaction_style;
479
+ context.level_at_creation = level_at_creation;
480
+ context.info_log = ioptions.info_log;
481
+ filter_builder.reset(CreateFilterBlockBuilder(
482
+ ioptions, moptions, context, use_delta_encoding_for_index_values,
483
+ p_index_builder_));
484
+ }
485
+
486
+ for (auto& collector_factories : *int_tbl_prop_collector_factories) {
487
+ table_properties_collectors.emplace_back(
488
+ collector_factories->CreateIntTblPropCollector(column_family_id));
489
+ }
490
+ table_properties_collectors.emplace_back(
491
+ new BlockBasedTablePropertiesCollector(
492
+ table_options.index_type, table_options.whole_key_filtering,
493
+ _moptions.prefix_extractor != nullptr));
494
+ if (table_options.verify_compression) {
495
+ for (uint32_t i = 0; i < compression_opts.parallel_threads; i++) {
496
+ verify_ctxs[i].reset(new UncompressionContext(compression_type));
497
+ }
498
+ }
499
+
500
+ if (!ReifyDbHostIdProperty(ioptions.env, &db_host_id).ok()) {
501
+ ROCKS_LOG_INFO(ioptions.info_log, "db_host_id property will not be set");
502
+ }
503
+ }
504
+
505
+ Rep(const Rep&) = delete;
506
+ Rep& operator=(const Rep&) = delete;
507
+
508
+ private:
509
+ // Synchronize status & io_status accesses across threads from main thread,
510
+ // compression thread and write thread in parallel compression.
511
+ std::mutex status_mutex;
512
+ std::atomic<bool> status_ok;
513
+ Status status;
514
+ std::mutex io_status_mutex;
515
+ std::atomic<bool> io_status_ok;
516
+ IOStatus io_status;
517
+ };
518
+
519
+ struct BlockBasedTableBuilder::ParallelCompressionRep {
520
+ // Keys is a wrapper of vector of strings avoiding
521
+ // releasing string memories during vector clear()
522
+ // in order to save memory allocation overhead
523
+ class Keys {
524
+ public:
525
+ Keys() : keys_(kKeysInitSize), size_(0) {}
526
+ void PushBack(const Slice& key) {
527
+ if (size_ == keys_.size()) {
528
+ keys_.emplace_back(key.data(), key.size());
529
+ } else {
530
+ keys_[size_].assign(key.data(), key.size());
531
+ }
532
+ size_++;
533
+ }
534
+ void SwapAssign(std::vector<std::string>& keys) {
535
+ size_ = keys.size();
536
+ std::swap(keys_, keys);
537
+ }
538
+ void Clear() { size_ = 0; }
539
+ size_t Size() { return size_; }
540
+ std::string& Back() { return keys_[size_ - 1]; }
541
+ std::string& operator[](size_t idx) {
542
+ assert(idx < size_);
543
+ return keys_[idx];
544
+ }
545
+
546
+ private:
547
+ const size_t kKeysInitSize = 32;
548
+ std::vector<std::string> keys_;
549
+ size_t size_;
550
+ };
551
+ std::unique_ptr<Keys> curr_block_keys;
552
+
553
+ class BlockRepSlot;
554
+
555
+ // BlockRep instances are fetched from and recycled to
556
+ // block_rep_pool during parallel compression.
557
+ struct BlockRep {
558
+ Slice contents;
559
+ Slice compressed_contents;
560
+ std::unique_ptr<std::string> data;
561
+ std::unique_ptr<std::string> compressed_data;
562
+ CompressionType compression_type;
563
+ std::unique_ptr<std::string> first_key_in_next_block;
564
+ std::unique_ptr<Keys> keys;
565
+ std::unique_ptr<BlockRepSlot> slot;
566
+ Status status;
567
+ };
568
+ // Use a vector of BlockRep as a buffer for a determined number
569
+ // of BlockRep structures. All data referenced by pointers in
570
+ // BlockRep will be freed when this vector is destructed.
571
+ typedef std::vector<BlockRep> BlockRepBuffer;
572
+ BlockRepBuffer block_rep_buf;
573
+ // Use a thread-safe queue for concurrent access from block
574
+ // building thread and writer thread.
575
+ typedef WorkQueue<BlockRep*> BlockRepPool;
576
+ BlockRepPool block_rep_pool;
577
+
578
+ // Use BlockRepSlot to keep block order in write thread.
579
+ // slot_ will pass references to BlockRep
580
+ class BlockRepSlot {
581
+ public:
582
+ BlockRepSlot() : slot_(1) {}
583
+ template <typename T>
584
+ void Fill(T&& rep) {
585
+ slot_.push(std::forward<T>(rep));
586
+ };
587
+ void Take(BlockRep*& rep) { slot_.pop(rep); }
588
+
589
+ private:
590
+ // slot_ will pass references to BlockRep in block_rep_buf,
591
+ // and those references are always valid before the destruction of
592
+ // block_rep_buf.
593
+ WorkQueue<BlockRep*> slot_;
594
+ };
595
+
596
+ // Compression queue will pass references to BlockRep in block_rep_buf,
597
+ // and those references are always valid before the destruction of
598
+ // block_rep_buf.
599
+ typedef WorkQueue<BlockRep*> CompressQueue;
600
+ CompressQueue compress_queue;
601
+ std::vector<port::Thread> compress_thread_pool;
602
+
603
+ // Write queue will pass references to BlockRep::slot in block_rep_buf,
604
+ // and those references are always valid before the corresponding
605
+ // BlockRep::slot is destructed, which is before the destruction of
606
+ // block_rep_buf.
607
+ typedef WorkQueue<BlockRepSlot*> WriteQueue;
608
+ WriteQueue write_queue;
609
+ std::unique_ptr<port::Thread> write_thread;
610
+
611
+ // Estimate output file size when parallel compression is enabled. This is
612
+ // necessary because compression & flush are no longer synchronized,
613
+ // and BlockBasedTableBuilder::FileSize() is no longer accurate.
614
+ // memory_order_relaxed suffices because accurate statistics is not required.
615
+ class FileSizeEstimator {
616
+ public:
617
+ explicit FileSizeEstimator()
618
+ : raw_bytes_compressed(0),
619
+ raw_bytes_curr_block(0),
620
+ raw_bytes_curr_block_set(false),
621
+ raw_bytes_inflight(0),
622
+ blocks_inflight(0),
623
+ curr_compression_ratio(0),
624
+ estimated_file_size(0) {}
625
+
626
+ // Estimate file size when a block is about to be emitted to
627
+ // compression thread
628
+ void EmitBlock(uint64_t raw_block_size, uint64_t curr_file_size) {
629
+ uint64_t new_raw_bytes_inflight =
630
+ raw_bytes_inflight.fetch_add(raw_block_size,
631
+ std::memory_order_relaxed) +
632
+ raw_block_size;
633
+
634
+ uint64_t new_blocks_inflight =
635
+ blocks_inflight.fetch_add(1, std::memory_order_relaxed) + 1;
636
+
637
+ estimated_file_size.store(
638
+ curr_file_size +
639
+ static_cast<uint64_t>(
640
+ static_cast<double>(new_raw_bytes_inflight) *
641
+ curr_compression_ratio.load(std::memory_order_relaxed)) +
642
+ new_blocks_inflight * kBlockTrailerSize,
643
+ std::memory_order_relaxed);
644
+ }
645
+
646
+ // Estimate file size when a block is already reaped from
647
+ // compression thread
648
+ void ReapBlock(uint64_t compressed_block_size, uint64_t curr_file_size) {
649
+ assert(raw_bytes_curr_block_set);
650
+
651
+ uint64_t new_raw_bytes_compressed =
652
+ raw_bytes_compressed + raw_bytes_curr_block;
653
+ assert(new_raw_bytes_compressed > 0);
654
+
655
+ curr_compression_ratio.store(
656
+ (curr_compression_ratio.load(std::memory_order_relaxed) *
657
+ raw_bytes_compressed +
658
+ compressed_block_size) /
659
+ static_cast<double>(new_raw_bytes_compressed),
660
+ std::memory_order_relaxed);
661
+ raw_bytes_compressed = new_raw_bytes_compressed;
662
+
663
+ uint64_t new_raw_bytes_inflight =
664
+ raw_bytes_inflight.fetch_sub(raw_bytes_curr_block,
665
+ std::memory_order_relaxed) -
666
+ raw_bytes_curr_block;
667
+
668
+ uint64_t new_blocks_inflight =
669
+ blocks_inflight.fetch_sub(1, std::memory_order_relaxed) - 1;
670
+
671
+ estimated_file_size.store(
672
+ curr_file_size +
673
+ static_cast<uint64_t>(
674
+ static_cast<double>(new_raw_bytes_inflight) *
675
+ curr_compression_ratio.load(std::memory_order_relaxed)) +
676
+ new_blocks_inflight * kBlockTrailerSize,
677
+ std::memory_order_relaxed);
678
+
679
+ raw_bytes_curr_block_set = false;
680
+ }
681
+
682
+ void SetEstimatedFileSize(uint64_t size) {
683
+ estimated_file_size.store(size, std::memory_order_relaxed);
684
+ }
685
+
686
+ uint64_t GetEstimatedFileSize() {
687
+ return estimated_file_size.load(std::memory_order_relaxed);
688
+ }
689
+
690
+ void SetCurrBlockRawSize(uint64_t size) {
691
+ raw_bytes_curr_block = size;
692
+ raw_bytes_curr_block_set = true;
693
+ }
694
+
695
+ private:
696
+ // Raw bytes compressed so far.
697
+ uint64_t raw_bytes_compressed;
698
+ // Size of current block being appended.
699
+ uint64_t raw_bytes_curr_block;
700
+ // Whether raw_bytes_curr_block has been set for next
701
+ // ReapBlock call.
702
+ bool raw_bytes_curr_block_set;
703
+ // Raw bytes under compression and not appended yet.
704
+ std::atomic<uint64_t> raw_bytes_inflight;
705
+ // Number of blocks under compression and not appended yet.
706
+ std::atomic<uint64_t> blocks_inflight;
707
+ // Current compression ratio, maintained by BGWorkWriteRawBlock.
708
+ std::atomic<double> curr_compression_ratio;
709
+ // Estimated SST file size.
710
+ std::atomic<uint64_t> estimated_file_size;
711
+ };
712
+ FileSizeEstimator file_size_estimator;
713
+
714
+ // Facilities used for waiting first block completion. Need to Wait for
715
+ // the completion of first block compression and flush to get a non-zero
716
+ // compression ratio.
717
+ std::atomic<bool> first_block_processed;
718
+ std::condition_variable first_block_cond;
719
+ std::mutex first_block_mutex;
720
+
721
+ explicit ParallelCompressionRep(uint32_t parallel_threads)
722
+ : curr_block_keys(new Keys()),
723
+ block_rep_buf(parallel_threads),
724
+ block_rep_pool(parallel_threads),
725
+ compress_queue(parallel_threads),
726
+ write_queue(parallel_threads),
727
+ first_block_processed(false) {
728
+ for (uint32_t i = 0; i < parallel_threads; i++) {
729
+ block_rep_buf[i].contents = Slice();
730
+ block_rep_buf[i].compressed_contents = Slice();
731
+ block_rep_buf[i].data.reset(new std::string());
732
+ block_rep_buf[i].compressed_data.reset(new std::string());
733
+ block_rep_buf[i].compression_type = CompressionType();
734
+ block_rep_buf[i].first_key_in_next_block.reset(new std::string());
735
+ block_rep_buf[i].keys.reset(new Keys());
736
+ block_rep_buf[i].slot.reset(new BlockRepSlot());
737
+ block_rep_buf[i].status = Status::OK();
738
+ block_rep_pool.push(&block_rep_buf[i]);
739
+ }
740
+ }
741
+
742
+ ~ParallelCompressionRep() { block_rep_pool.finish(); }
743
+
744
+ // Make a block prepared to be emitted to compression thread
745
+ // Used in non-buffered mode
746
+ BlockRep* PrepareBlock(CompressionType compression_type,
747
+ const Slice* first_key_in_next_block,
748
+ BlockBuilder* data_block) {
749
+ BlockRep* block_rep =
750
+ PrepareBlockInternal(compression_type, first_key_in_next_block);
751
+ assert(block_rep != nullptr);
752
+ data_block->SwapAndReset(*(block_rep->data));
753
+ block_rep->contents = *(block_rep->data);
754
+ std::swap(block_rep->keys, curr_block_keys);
755
+ curr_block_keys->Clear();
756
+ return block_rep;
757
+ }
758
+
759
+ // Used in EnterUnbuffered
760
+ BlockRep* PrepareBlock(CompressionType compression_type,
761
+ const Slice* first_key_in_next_block,
762
+ std::string* data_block,
763
+ std::vector<std::string>* keys) {
764
+ BlockRep* block_rep =
765
+ PrepareBlockInternal(compression_type, first_key_in_next_block);
766
+ assert(block_rep != nullptr);
767
+ std::swap(*(block_rep->data), *data_block);
768
+ block_rep->contents = *(block_rep->data);
769
+ block_rep->keys->SwapAssign(*keys);
770
+ return block_rep;
771
+ }
772
+
773
+ // Emit a block to compression thread
774
+ void EmitBlock(BlockRep* block_rep) {
775
+ assert(block_rep != nullptr);
776
+ assert(block_rep->status.ok());
777
+ if (!write_queue.push(block_rep->slot.get())) {
778
+ return;
779
+ }
780
+ if (!compress_queue.push(block_rep)) {
781
+ return;
782
+ }
783
+
784
+ if (!first_block_processed.load(std::memory_order_relaxed)) {
785
+ std::unique_lock<std::mutex> lock(first_block_mutex);
786
+ first_block_cond.wait(lock, [this] {
787
+ return first_block_processed.load(std::memory_order_relaxed);
788
+ });
789
+ }
790
+ }
791
+
792
+ // Reap a block from compression thread
793
+ void ReapBlock(BlockRep* block_rep) {
794
+ assert(block_rep != nullptr);
795
+ block_rep->compressed_data->clear();
796
+ block_rep_pool.push(block_rep);
797
+
798
+ if (!first_block_processed.load(std::memory_order_relaxed)) {
799
+ std::lock_guard<std::mutex> lock(first_block_mutex);
800
+ first_block_processed.store(true, std::memory_order_relaxed);
801
+ first_block_cond.notify_one();
802
+ }
803
+ }
804
+
805
+ private:
806
+ BlockRep* PrepareBlockInternal(CompressionType compression_type,
807
+ const Slice* first_key_in_next_block) {
808
+ BlockRep* block_rep = nullptr;
809
+ block_rep_pool.pop(block_rep);
810
+ assert(block_rep != nullptr);
811
+
812
+ assert(block_rep->data);
813
+
814
+ block_rep->compression_type = compression_type;
815
+
816
+ if (first_key_in_next_block == nullptr) {
817
+ block_rep->first_key_in_next_block.reset(nullptr);
818
+ } else {
819
+ block_rep->first_key_in_next_block->assign(
820
+ first_key_in_next_block->data(), first_key_in_next_block->size());
821
+ }
822
+
823
+ return block_rep;
824
+ }
825
+ };
826
+
827
+ BlockBasedTableBuilder::BlockBasedTableBuilder(
828
+ const ImmutableCFOptions& ioptions, const MutableCFOptions& moptions,
829
+ const BlockBasedTableOptions& table_options,
830
+ const InternalKeyComparator& internal_comparator,
831
+ const std::vector<std::unique_ptr<IntTblPropCollectorFactory>>*
832
+ int_tbl_prop_collector_factories,
833
+ uint32_t column_family_id, WritableFileWriter* file,
834
+ const CompressionType compression_type,
835
+ const uint64_t sample_for_compression,
836
+ const CompressionOptions& compression_opts, const bool skip_filters,
837
+ const std::string& column_family_name, const int level_at_creation,
838
+ const uint64_t creation_time, const uint64_t oldest_key_time,
839
+ const uint64_t target_file_size, const uint64_t file_creation_time,
840
+ const std::string& db_id, const std::string& db_session_id) {
841
+ BlockBasedTableOptions sanitized_table_options(table_options);
842
+ if (sanitized_table_options.format_version == 0 &&
843
+ sanitized_table_options.checksum != kCRC32c) {
844
+ ROCKS_LOG_WARN(
845
+ ioptions.info_log,
846
+ "Silently converting format_version to 1 because checksum is "
847
+ "non-default");
848
+ // silently convert format_version to 1 to keep consistent with current
849
+ // behavior
850
+ sanitized_table_options.format_version = 1;
851
+ }
852
+
853
+ rep_ = new Rep(
854
+ ioptions, moptions, sanitized_table_options, internal_comparator,
855
+ int_tbl_prop_collector_factories, column_family_id, file,
856
+ compression_type, sample_for_compression, compression_opts, skip_filters,
857
+ level_at_creation, column_family_name, creation_time, oldest_key_time,
858
+ target_file_size, file_creation_time, db_id, db_session_id);
859
+
860
+ if (rep_->filter_builder != nullptr) {
861
+ rep_->filter_builder->StartBlock(0);
862
+ }
863
+ if (table_options.block_cache_compressed.get() != nullptr) {
864
+ BlockBasedTable::GenerateCachePrefix<Cache, FSWritableFile>(
865
+ table_options.block_cache_compressed.get(), file->writable_file(),
866
+ &rep_->compressed_cache_key_prefix[0],
867
+ &rep_->compressed_cache_key_prefix_size);
868
+ }
869
+
870
+ if (rep_->IsParallelCompressionEnabled()) {
871
+ StartParallelCompression();
872
+ }
873
+ }
874
+
875
+ BlockBasedTableBuilder::~BlockBasedTableBuilder() {
876
+ // Catch errors where caller forgot to call Finish()
877
+ assert(rep_->state == Rep::State::kClosed);
878
+ delete rep_;
879
+ }
880
+
881
+ void BlockBasedTableBuilder::Add(const Slice& key, const Slice& value) {
882
+ Rep* r = rep_;
883
+ assert(rep_->state != Rep::State::kClosed);
884
+ if (!ok()) return;
885
+ ValueType value_type = ExtractValueType(key);
886
+ if (IsValueType(value_type)) {
887
+ #ifndef NDEBUG
888
+ if (r->props.num_entries > r->props.num_range_deletions) {
889
+ assert(r->internal_comparator.Compare(key, Slice(r->last_key)) > 0);
890
+ }
891
+ #endif // !NDEBUG
892
+
893
+ auto should_flush = r->flush_block_policy->Update(key, value);
894
+ if (should_flush) {
895
+ assert(!r->data_block.empty());
896
+ r->first_key_in_next_block = &key;
897
+ Flush();
898
+
899
+ if (r->state == Rep::State::kBuffered && r->target_file_size != 0 &&
900
+ r->data_begin_offset > r->target_file_size) {
901
+ EnterUnbuffered();
902
+ }
903
+
904
+ // Add item to index block.
905
+ // We do not emit the index entry for a block until we have seen the
906
+ // first key for the next data block. This allows us to use shorter
907
+ // keys in the index block. For example, consider a block boundary
908
+ // between the keys "the quick brown fox" and "the who". We can use
909
+ // "the r" as the key for the index block entry since it is >= all
910
+ // entries in the first block and < all entries in subsequent
911
+ // blocks.
912
+ if (ok() && r->state == Rep::State::kUnbuffered) {
913
+ if (r->IsParallelCompressionEnabled()) {
914
+ r->pc_rep->curr_block_keys->Clear();
915
+ } else {
916
+ r->index_builder->AddIndexEntry(&r->last_key, &key,
917
+ r->pending_handle);
918
+ }
919
+ }
920
+ }
921
+
922
+ // Note: PartitionedFilterBlockBuilder requires key being added to filter
923
+ // builder after being added to index builder.
924
+ if (r->state == Rep::State::kUnbuffered) {
925
+ if (r->IsParallelCompressionEnabled()) {
926
+ r->pc_rep->curr_block_keys->PushBack(key);
927
+ } else {
928
+ if (r->filter_builder != nullptr) {
929
+ size_t ts_sz =
930
+ r->internal_comparator.user_comparator()->timestamp_size();
931
+ r->filter_builder->Add(ExtractUserKeyAndStripTimestamp(key, ts_sz));
932
+ }
933
+ }
934
+ }
935
+
936
+ r->last_key.assign(key.data(), key.size());
937
+ r->data_block.Add(key, value);
938
+ if (r->state == Rep::State::kBuffered) {
939
+ // Buffer keys to be replayed during `Finish()` once compression
940
+ // dictionary has been finalized.
941
+ if (r->data_block_and_keys_buffers.empty() || should_flush) {
942
+ r->data_block_and_keys_buffers.emplace_back();
943
+ }
944
+ r->data_block_and_keys_buffers.back().second.emplace_back(key.ToString());
945
+ } else {
946
+ if (!r->IsParallelCompressionEnabled()) {
947
+ r->index_builder->OnKeyAdded(key);
948
+ }
949
+ }
950
+ // TODO offset passed in is not accurate for parallel compression case
951
+ NotifyCollectTableCollectorsOnAdd(key, value, r->get_offset(),
952
+ r->table_properties_collectors,
953
+ r->ioptions.info_log);
954
+
955
+ } else if (value_type == kTypeRangeDeletion) {
956
+ r->range_del_block.Add(key, value);
957
+ // TODO offset passed in is not accurate for parallel compression case
958
+ NotifyCollectTableCollectorsOnAdd(key, value, r->get_offset(),
959
+ r->table_properties_collectors,
960
+ r->ioptions.info_log);
961
+ } else {
962
+ assert(false);
963
+ }
964
+
965
+ r->props.num_entries++;
966
+ r->props.raw_key_size += key.size();
967
+ r->props.raw_value_size += value.size();
968
+ if (value_type == kTypeDeletion || value_type == kTypeSingleDeletion) {
969
+ r->props.num_deletions++;
970
+ } else if (value_type == kTypeRangeDeletion) {
971
+ r->props.num_deletions++;
972
+ r->props.num_range_deletions++;
973
+ } else if (value_type == kTypeMerge) {
974
+ r->props.num_merge_operands++;
975
+ }
976
+ }
977
+
978
+ void BlockBasedTableBuilder::Flush() {
979
+ Rep* r = rep_;
980
+ assert(rep_->state != Rep::State::kClosed);
981
+ if (!ok()) return;
982
+ if (r->data_block.empty()) return;
983
+ if (r->IsParallelCompressionEnabled() &&
984
+ r->state == Rep::State::kUnbuffered) {
985
+ r->data_block.Finish();
986
+ ParallelCompressionRep::BlockRep* block_rep = r->pc_rep->PrepareBlock(
987
+ r->compression_type, r->first_key_in_next_block, &(r->data_block));
988
+ assert(block_rep != nullptr);
989
+ r->pc_rep->file_size_estimator.EmitBlock(block_rep->data->size(),
990
+ r->get_offset());
991
+ r->pc_rep->EmitBlock(block_rep);
992
+ } else {
993
+ WriteBlock(&r->data_block, &r->pending_handle, true /* is_data_block */);
994
+ }
995
+ }
996
+
997
+ void BlockBasedTableBuilder::WriteBlock(BlockBuilder* block,
998
+ BlockHandle* handle,
999
+ bool is_data_block) {
1000
+ WriteBlock(block->Finish(), handle, is_data_block);
1001
+ block->Reset();
1002
+ }
1003
+
1004
+ void BlockBasedTableBuilder::WriteBlock(const Slice& raw_block_contents,
1005
+ BlockHandle* handle,
1006
+ bool is_data_block) {
1007
+ Rep* r = rep_;
1008
+ Slice block_contents;
1009
+ CompressionType type;
1010
+ if (r->state == Rep::State::kBuffered) {
1011
+ assert(is_data_block);
1012
+ assert(!r->data_block_and_keys_buffers.empty());
1013
+ r->data_block_and_keys_buffers.back().first = raw_block_contents.ToString();
1014
+ r->data_begin_offset += r->data_block_and_keys_buffers.back().first.size();
1015
+ return;
1016
+ }
1017
+ Status compress_status;
1018
+ CompressAndVerifyBlock(raw_block_contents, is_data_block,
1019
+ *(r->compression_ctxs[0]), r->verify_ctxs[0].get(),
1020
+ &(r->compressed_output), &(block_contents), &type,
1021
+ &compress_status);
1022
+ r->SetStatus(compress_status);
1023
+ if (!ok()) {
1024
+ return;
1025
+ }
1026
+ WriteRawBlock(block_contents, type, handle, is_data_block);
1027
+ r->compressed_output.clear();
1028
+ if (is_data_block) {
1029
+ if (r->filter_builder != nullptr) {
1030
+ r->filter_builder->StartBlock(r->get_offset());
1031
+ }
1032
+ r->props.data_size = r->get_offset();
1033
+ ++r->props.num_data_blocks;
1034
+ }
1035
+ }
1036
+
1037
+ void BlockBasedTableBuilder::BGWorkCompression(
1038
+ const CompressionContext& compression_ctx,
1039
+ UncompressionContext* verify_ctx) {
1040
+ ParallelCompressionRep::BlockRep* block_rep = nullptr;
1041
+ while (rep_->pc_rep->compress_queue.pop(block_rep)) {
1042
+ assert(block_rep != nullptr);
1043
+ CompressAndVerifyBlock(block_rep->contents, true, /* is_data_block*/
1044
+ compression_ctx, verify_ctx,
1045
+ block_rep->compressed_data.get(),
1046
+ &block_rep->compressed_contents,
1047
+ &(block_rep->compression_type), &block_rep->status);
1048
+ block_rep->slot->Fill(block_rep);
1049
+ }
1050
+ }
1051
+
1052
+ void BlockBasedTableBuilder::CompressAndVerifyBlock(
1053
+ const Slice& raw_block_contents, bool is_data_block,
1054
+ const CompressionContext& compression_ctx, UncompressionContext* verify_ctx,
1055
+ std::string* compressed_output, Slice* block_contents,
1056
+ CompressionType* type, Status* out_status) {
1057
+ // File format contains a sequence of blocks where each block has:
1058
+ // block_data: uint8[n]
1059
+ // type: uint8
1060
+ // crc: uint32
1061
+ Rep* r = rep_;
1062
+ bool is_status_ok = ok();
1063
+ if (!r->IsParallelCompressionEnabled()) {
1064
+ assert(is_status_ok);
1065
+ }
1066
+
1067
+ *type = r->compression_type;
1068
+ uint64_t sample_for_compression = r->sample_for_compression;
1069
+ bool abort_compression = false;
1070
+
1071
+ StopWatchNano timer(
1072
+ r->ioptions.env,
1073
+ ShouldReportDetailedTime(r->ioptions.env, r->ioptions.statistics));
1074
+
1075
+ if (is_status_ok && raw_block_contents.size() < kCompressionSizeLimit) {
1076
+ const CompressionDict* compression_dict;
1077
+ if (!is_data_block || r->compression_dict == nullptr) {
1078
+ compression_dict = &CompressionDict::GetEmptyDict();
1079
+ } else {
1080
+ compression_dict = r->compression_dict.get();
1081
+ }
1082
+ assert(compression_dict != nullptr);
1083
+ CompressionInfo compression_info(r->compression_opts, compression_ctx,
1084
+ *compression_dict, *type,
1085
+ sample_for_compression);
1086
+
1087
+ std::string sampled_output_fast;
1088
+ std::string sampled_output_slow;
1089
+ *block_contents = CompressBlock(
1090
+ raw_block_contents, compression_info, type,
1091
+ r->table_options.format_version, is_data_block /* do_sample */,
1092
+ compressed_output, &sampled_output_fast, &sampled_output_slow);
1093
+
1094
+ // notify collectors on block add
1095
+ NotifyCollectTableCollectorsOnBlockAdd(
1096
+ r->table_properties_collectors, raw_block_contents.size(),
1097
+ sampled_output_fast.size(), sampled_output_slow.size());
1098
+
1099
+ // Some of the compression algorithms are known to be unreliable. If
1100
+ // the verify_compression flag is set then try to de-compress the
1101
+ // compressed data and compare to the input.
1102
+ if (*type != kNoCompression && r->table_options.verify_compression) {
1103
+ // Retrieve the uncompressed contents into a new buffer
1104
+ const UncompressionDict* verify_dict;
1105
+ if (!is_data_block || r->verify_dict == nullptr) {
1106
+ verify_dict = &UncompressionDict::GetEmptyDict();
1107
+ } else {
1108
+ verify_dict = r->verify_dict.get();
1109
+ }
1110
+ assert(verify_dict != nullptr);
1111
+ BlockContents contents;
1112
+ UncompressionInfo uncompression_info(*verify_ctx, *verify_dict,
1113
+ r->compression_type);
1114
+ Status stat = UncompressBlockContentsForCompressionType(
1115
+ uncompression_info, block_contents->data(), block_contents->size(),
1116
+ &contents, r->table_options.format_version, r->ioptions);
1117
+
1118
+ if (stat.ok()) {
1119
+ bool compressed_ok = contents.data.compare(raw_block_contents) == 0;
1120
+ if (!compressed_ok) {
1121
+ // The result of the compression was invalid. abort.
1122
+ abort_compression = true;
1123
+ ROCKS_LOG_ERROR(r->ioptions.info_log,
1124
+ "Decompressed block did not match raw block");
1125
+ *out_status =
1126
+ Status::Corruption("Decompressed block did not match raw block");
1127
+ }
1128
+ } else {
1129
+ // Decompression reported an error. abort.
1130
+ *out_status = Status::Corruption(std::string("Could not decompress: ") +
1131
+ stat.getState());
1132
+ abort_compression = true;
1133
+ }
1134
+ }
1135
+ } else {
1136
+ // Block is too big to be compressed.
1137
+ abort_compression = true;
1138
+ }
1139
+
1140
+ // Abort compression if the block is too big, or did not pass
1141
+ // verification.
1142
+ if (abort_compression) {
1143
+ RecordTick(r->ioptions.statistics, NUMBER_BLOCK_NOT_COMPRESSED);
1144
+ *type = kNoCompression;
1145
+ *block_contents = raw_block_contents;
1146
+ } else if (*type != kNoCompression) {
1147
+ if (ShouldReportDetailedTime(r->ioptions.env, r->ioptions.statistics)) {
1148
+ RecordTimeToHistogram(r->ioptions.statistics, COMPRESSION_TIMES_NANOS,
1149
+ timer.ElapsedNanos());
1150
+ }
1151
+ RecordInHistogram(r->ioptions.statistics, BYTES_COMPRESSED,
1152
+ raw_block_contents.size());
1153
+ RecordTick(r->ioptions.statistics, NUMBER_BLOCK_COMPRESSED);
1154
+ } else if (*type != r->compression_type) {
1155
+ RecordTick(r->ioptions.statistics, NUMBER_BLOCK_NOT_COMPRESSED);
1156
+ }
1157
+ }
1158
+
1159
+ void BlockBasedTableBuilder::WriteRawBlock(const Slice& block_contents,
1160
+ CompressionType type,
1161
+ BlockHandle* handle,
1162
+ bool is_data_block) {
1163
+ Rep* r = rep_;
1164
+ Status s = Status::OK();
1165
+ IOStatus io_s = IOStatus::OK();
1166
+ StopWatch sw(r->ioptions.env, r->ioptions.statistics, WRITE_RAW_BLOCK_MICROS);
1167
+ handle->set_offset(r->get_offset());
1168
+ handle->set_size(block_contents.size());
1169
+ assert(status().ok());
1170
+ assert(io_status().ok());
1171
+ io_s = r->file->Append(block_contents);
1172
+ if (io_s.ok()) {
1173
+ char trailer[kBlockTrailerSize];
1174
+ trailer[0] = type;
1175
+ uint32_t checksum = 0;
1176
+ switch (r->table_options.checksum) {
1177
+ case kNoChecksum:
1178
+ break;
1179
+ case kCRC32c: {
1180
+ uint32_t crc =
1181
+ crc32c::Value(block_contents.data(), block_contents.size());
1182
+ // Extend to cover compression type
1183
+ crc = crc32c::Extend(crc, trailer, 1);
1184
+ checksum = crc32c::Mask(crc);
1185
+ break;
1186
+ }
1187
+ case kxxHash: {
1188
+ XXH32_state_t* const state = XXH32_createState();
1189
+ XXH32_reset(state, 0);
1190
+ XXH32_update(state, block_contents.data(), block_contents.size());
1191
+ // Extend to cover compression type
1192
+ XXH32_update(state, trailer, 1);
1193
+ checksum = XXH32_digest(state);
1194
+ XXH32_freeState(state);
1195
+ break;
1196
+ }
1197
+ case kxxHash64: {
1198
+ XXH64_state_t* const state = XXH64_createState();
1199
+ XXH64_reset(state, 0);
1200
+ XXH64_update(state, block_contents.data(), block_contents.size());
1201
+ // Extend to cover compression type
1202
+ XXH64_update(state, trailer, 1);
1203
+ checksum = Lower32of64(XXH64_digest(state));
1204
+ XXH64_freeState(state);
1205
+ break;
1206
+ }
1207
+ default:
1208
+ assert(false);
1209
+ break;
1210
+ }
1211
+ EncodeFixed32(trailer + 1, checksum);
1212
+ assert(io_s.ok());
1213
+ TEST_SYNC_POINT_CALLBACK(
1214
+ "BlockBasedTableBuilder::WriteRawBlock:TamperWithChecksum",
1215
+ static_cast<char*>(trailer));
1216
+ io_s = r->file->Append(Slice(trailer, kBlockTrailerSize));
1217
+ if (io_s.ok()) {
1218
+ assert(s.ok());
1219
+ s = InsertBlockInCache(block_contents, type, handle);
1220
+ if (!s.ok()) {
1221
+ r->SetStatus(s);
1222
+ }
1223
+ } else {
1224
+ r->SetIOStatus(io_s);
1225
+ }
1226
+ if (s.ok() && io_s.ok()) {
1227
+ r->set_offset(r->get_offset() + block_contents.size() +
1228
+ kBlockTrailerSize);
1229
+ if (r->table_options.block_align && is_data_block) {
1230
+ size_t pad_bytes =
1231
+ (r->alignment - ((block_contents.size() + kBlockTrailerSize) &
1232
+ (r->alignment - 1))) &
1233
+ (r->alignment - 1);
1234
+ io_s = r->file->Pad(pad_bytes);
1235
+ if (io_s.ok()) {
1236
+ r->set_offset(r->get_offset() + pad_bytes);
1237
+ } else {
1238
+ r->SetIOStatus(io_s);
1239
+ }
1240
+ }
1241
+ if (r->IsParallelCompressionEnabled()) {
1242
+ if (is_data_block) {
1243
+ r->pc_rep->file_size_estimator.ReapBlock(block_contents.size(),
1244
+ r->get_offset());
1245
+ } else {
1246
+ r->pc_rep->file_size_estimator.SetEstimatedFileSize(r->get_offset());
1247
+ }
1248
+ }
1249
+ }
1250
+ } else {
1251
+ r->SetIOStatus(io_s);
1252
+ }
1253
+ if (!io_s.ok() && s.ok()) {
1254
+ r->SetStatus(io_s);
1255
+ }
1256
+ }
1257
+
1258
+ void BlockBasedTableBuilder::BGWorkWriteRawBlock() {
1259
+ Rep* r = rep_;
1260
+ ParallelCompressionRep::BlockRepSlot* slot = nullptr;
1261
+ ParallelCompressionRep::BlockRep* block_rep = nullptr;
1262
+ while (r->pc_rep->write_queue.pop(slot)) {
1263
+ assert(slot != nullptr);
1264
+ slot->Take(block_rep);
1265
+ assert(block_rep != nullptr);
1266
+ if (!block_rep->status.ok()) {
1267
+ r->SetStatus(block_rep->status);
1268
+ // Reap block so that blocked Flush() can finish
1269
+ // if there is one, and Flush() will notice !ok() next time.
1270
+ block_rep->status = Status::OK();
1271
+ r->pc_rep->ReapBlock(block_rep);
1272
+ continue;
1273
+ }
1274
+
1275
+ for (size_t i = 0; i < block_rep->keys->Size(); i++) {
1276
+ auto& key = (*block_rep->keys)[i];
1277
+ if (r->filter_builder != nullptr) {
1278
+ size_t ts_sz =
1279
+ r->internal_comparator.user_comparator()->timestamp_size();
1280
+ r->filter_builder->Add(ExtractUserKeyAndStripTimestamp(key, ts_sz));
1281
+ }
1282
+ r->index_builder->OnKeyAdded(key);
1283
+ }
1284
+
1285
+ r->pc_rep->file_size_estimator.SetCurrBlockRawSize(block_rep->data->size());
1286
+ WriteRawBlock(block_rep->compressed_contents, block_rep->compression_type,
1287
+ &r->pending_handle, true /* is_data_block*/);
1288
+ if (!ok()) {
1289
+ break;
1290
+ }
1291
+
1292
+ if (r->filter_builder != nullptr) {
1293
+ r->filter_builder->StartBlock(r->get_offset());
1294
+ }
1295
+ r->props.data_size = r->get_offset();
1296
+ ++r->props.num_data_blocks;
1297
+
1298
+ if (block_rep->first_key_in_next_block == nullptr) {
1299
+ r->index_builder->AddIndexEntry(&(block_rep->keys->Back()), nullptr,
1300
+ r->pending_handle);
1301
+ } else {
1302
+ Slice first_key_in_next_block =
1303
+ Slice(*block_rep->first_key_in_next_block);
1304
+ r->index_builder->AddIndexEntry(&(block_rep->keys->Back()),
1305
+ &first_key_in_next_block,
1306
+ r->pending_handle);
1307
+ }
1308
+
1309
+ r->pc_rep->ReapBlock(block_rep);
1310
+ }
1311
+ }
1312
+
1313
+ void BlockBasedTableBuilder::StartParallelCompression() {
1314
+ rep_->pc_rep.reset(
1315
+ new ParallelCompressionRep(rep_->compression_opts.parallel_threads));
1316
+ rep_->pc_rep->compress_thread_pool.reserve(
1317
+ rep_->compression_opts.parallel_threads);
1318
+ for (uint32_t i = 0; i < rep_->compression_opts.parallel_threads; i++) {
1319
+ rep_->pc_rep->compress_thread_pool.emplace_back([this, i] {
1320
+ BGWorkCompression(*(rep_->compression_ctxs[i]),
1321
+ rep_->verify_ctxs[i].get());
1322
+ });
1323
+ }
1324
+ rep_->pc_rep->write_thread.reset(
1325
+ new port::Thread([this] { BGWorkWriteRawBlock(); }));
1326
+ }
1327
+
1328
+ void BlockBasedTableBuilder::StopParallelCompression() {
1329
+ rep_->pc_rep->compress_queue.finish();
1330
+ for (auto& thread : rep_->pc_rep->compress_thread_pool) {
1331
+ thread.join();
1332
+ }
1333
+ rep_->pc_rep->write_queue.finish();
1334
+ rep_->pc_rep->write_thread->join();
1335
+ }
1336
+
1337
+ Status BlockBasedTableBuilder::status() const { return rep_->GetStatus(); }
1338
+
1339
+ IOStatus BlockBasedTableBuilder::io_status() const {
1340
+ return rep_->GetIOStatus();
1341
+ }
1342
+
1343
+ static void DeleteCachedBlockContents(const Slice& /*key*/, void* value) {
1344
+ BlockContents* bc = reinterpret_cast<BlockContents*>(value);
1345
+ delete bc;
1346
+ }
1347
+
1348
+ //
1349
+ // Make a copy of the block contents and insert into compressed block cache
1350
+ //
1351
+ Status BlockBasedTableBuilder::InsertBlockInCache(const Slice& block_contents,
1352
+ const CompressionType type,
1353
+ const BlockHandle* handle) {
1354
+ Rep* r = rep_;
1355
+ Cache* block_cache_compressed = r->table_options.block_cache_compressed.get();
1356
+
1357
+ if (type != kNoCompression && block_cache_compressed != nullptr) {
1358
+ size_t size = block_contents.size();
1359
+
1360
+ auto ubuf =
1361
+ AllocateBlock(size + 1, block_cache_compressed->memory_allocator());
1362
+ memcpy(ubuf.get(), block_contents.data(), size);
1363
+ ubuf[size] = type;
1364
+
1365
+ BlockContents* block_contents_to_cache =
1366
+ new BlockContents(std::move(ubuf), size);
1367
+ #ifndef NDEBUG
1368
+ block_contents_to_cache->is_raw_block = true;
1369
+ #endif // NDEBUG
1370
+
1371
+ // make cache key by appending the file offset to the cache prefix id
1372
+ char* end = EncodeVarint64(
1373
+ r->compressed_cache_key_prefix + r->compressed_cache_key_prefix_size,
1374
+ handle->offset());
1375
+ Slice key(r->compressed_cache_key_prefix,
1376
+ static_cast<size_t>(end - r->compressed_cache_key_prefix));
1377
+
1378
+ // Insert into compressed block cache.
1379
+ // How should we deal with compressed cache full?
1380
+ block_cache_compressed
1381
+ ->Insert(key, block_contents_to_cache,
1382
+ block_contents_to_cache->ApproximateMemoryUsage(),
1383
+ &DeleteCachedBlockContents)
1384
+ .PermitUncheckedError();
1385
+
1386
+ // Invalidate OS cache.
1387
+ r->file->InvalidateCache(static_cast<size_t>(r->get_offset()), size)
1388
+ .PermitUncheckedError();
1389
+ }
1390
+ return Status::OK();
1391
+ }
1392
+
1393
+ void BlockBasedTableBuilder::WriteFilterBlock(
1394
+ MetaIndexBuilder* meta_index_builder) {
1395
+ BlockHandle filter_block_handle;
1396
+ bool empty_filter_block = (rep_->filter_builder == nullptr ||
1397
+ rep_->filter_builder->NumAdded() == 0);
1398
+ if (ok() && !empty_filter_block) {
1399
+ Status s = Status::Incomplete();
1400
+ while (ok() && s.IsIncomplete()) {
1401
+ Slice filter_content =
1402
+ rep_->filter_builder->Finish(filter_block_handle, &s);
1403
+ assert(s.ok() || s.IsIncomplete());
1404
+ rep_->props.filter_size += filter_content.size();
1405
+ WriteRawBlock(filter_content, kNoCompression, &filter_block_handle);
1406
+ }
1407
+ }
1408
+ if (ok() && !empty_filter_block) {
1409
+ // Add mapping from "<filter_block_prefix>.Name" to location
1410
+ // of filter data.
1411
+ std::string key;
1412
+ if (rep_->filter_builder->IsBlockBased()) {
1413
+ key = BlockBasedTable::kFilterBlockPrefix;
1414
+ } else {
1415
+ key = rep_->table_options.partition_filters
1416
+ ? BlockBasedTable::kPartitionedFilterBlockPrefix
1417
+ : BlockBasedTable::kFullFilterBlockPrefix;
1418
+ }
1419
+ key.append(rep_->table_options.filter_policy->Name());
1420
+ meta_index_builder->Add(key, filter_block_handle);
1421
+ }
1422
+ }
1423
+
1424
+ void BlockBasedTableBuilder::WriteIndexBlock(
1425
+ MetaIndexBuilder* meta_index_builder, BlockHandle* index_block_handle) {
1426
+ IndexBuilder::IndexBlocks index_blocks;
1427
+ auto index_builder_status = rep_->index_builder->Finish(&index_blocks);
1428
+ if (index_builder_status.IsIncomplete()) {
1429
+ // We we have more than one index partition then meta_blocks are not
1430
+ // supported for the index. Currently meta_blocks are used only by
1431
+ // HashIndexBuilder which is not multi-partition.
1432
+ assert(index_blocks.meta_blocks.empty());
1433
+ } else if (ok() && !index_builder_status.ok()) {
1434
+ rep_->SetStatus(index_builder_status);
1435
+ }
1436
+ if (ok()) {
1437
+ for (const auto& item : index_blocks.meta_blocks) {
1438
+ BlockHandle block_handle;
1439
+ WriteBlock(item.second, &block_handle, false /* is_data_block */);
1440
+ if (!ok()) {
1441
+ break;
1442
+ }
1443
+ meta_index_builder->Add(item.first, block_handle);
1444
+ }
1445
+ }
1446
+ if (ok()) {
1447
+ if (rep_->table_options.enable_index_compression) {
1448
+ WriteBlock(index_blocks.index_block_contents, index_block_handle, false);
1449
+ } else {
1450
+ WriteRawBlock(index_blocks.index_block_contents, kNoCompression,
1451
+ index_block_handle);
1452
+ }
1453
+ }
1454
+ // If there are more index partitions, finish them and write them out
1455
+ if (index_builder_status.IsIncomplete()) {
1456
+ Status s = Status::Incomplete();
1457
+ while (ok() && s.IsIncomplete()) {
1458
+ s = rep_->index_builder->Finish(&index_blocks, *index_block_handle);
1459
+ if (!s.ok() && !s.IsIncomplete()) {
1460
+ rep_->SetStatus(s);
1461
+ return;
1462
+ }
1463
+ if (rep_->table_options.enable_index_compression) {
1464
+ WriteBlock(index_blocks.index_block_contents, index_block_handle,
1465
+ false);
1466
+ } else {
1467
+ WriteRawBlock(index_blocks.index_block_contents, kNoCompression,
1468
+ index_block_handle);
1469
+ }
1470
+ // The last index_block_handle will be for the partition index block
1471
+ }
1472
+ }
1473
+ }
1474
+
1475
+ void BlockBasedTableBuilder::WritePropertiesBlock(
1476
+ MetaIndexBuilder* meta_index_builder) {
1477
+ BlockHandle properties_block_handle;
1478
+ if (ok()) {
1479
+ PropertyBlockBuilder property_block_builder;
1480
+ rep_->props.column_family_id = rep_->column_family_id;
1481
+ rep_->props.column_family_name = rep_->column_family_name;
1482
+ rep_->props.filter_policy_name =
1483
+ rep_->table_options.filter_policy != nullptr
1484
+ ? rep_->table_options.filter_policy->Name()
1485
+ : "";
1486
+ rep_->props.index_size =
1487
+ rep_->index_builder->IndexSize() + kBlockTrailerSize;
1488
+ rep_->props.comparator_name = rep_->ioptions.user_comparator != nullptr
1489
+ ? rep_->ioptions.user_comparator->Name()
1490
+ : "nullptr";
1491
+ rep_->props.merge_operator_name =
1492
+ rep_->ioptions.merge_operator != nullptr
1493
+ ? rep_->ioptions.merge_operator->Name()
1494
+ : "nullptr";
1495
+ rep_->props.compression_name =
1496
+ CompressionTypeToString(rep_->compression_type);
1497
+ rep_->props.compression_options =
1498
+ CompressionOptionsToString(rep_->compression_opts);
1499
+ rep_->props.prefix_extractor_name =
1500
+ rep_->moptions.prefix_extractor != nullptr
1501
+ ? rep_->moptions.prefix_extractor->Name()
1502
+ : "nullptr";
1503
+
1504
+ std::string property_collectors_names = "[";
1505
+ for (size_t i = 0;
1506
+ i < rep_->ioptions.table_properties_collector_factories.size(); ++i) {
1507
+ if (i != 0) {
1508
+ property_collectors_names += ",";
1509
+ }
1510
+ property_collectors_names +=
1511
+ rep_->ioptions.table_properties_collector_factories[i]->Name();
1512
+ }
1513
+ property_collectors_names += "]";
1514
+ rep_->props.property_collectors_names = property_collectors_names;
1515
+ if (rep_->table_options.index_type ==
1516
+ BlockBasedTableOptions::kTwoLevelIndexSearch) {
1517
+ assert(rep_->p_index_builder_ != nullptr);
1518
+ rep_->props.index_partitions = rep_->p_index_builder_->NumPartitions();
1519
+ rep_->props.top_level_index_size =
1520
+ rep_->p_index_builder_->TopLevelIndexSize(rep_->offset);
1521
+ }
1522
+ rep_->props.index_key_is_user_key =
1523
+ !rep_->index_builder->seperator_is_key_plus_seq();
1524
+ rep_->props.index_value_is_delta_encoded =
1525
+ rep_->use_delta_encoding_for_index_values;
1526
+ rep_->props.creation_time = rep_->creation_time;
1527
+ rep_->props.oldest_key_time = rep_->oldest_key_time;
1528
+ rep_->props.file_creation_time = rep_->file_creation_time;
1529
+ rep_->props.db_id = rep_->db_id;
1530
+ rep_->props.db_session_id = rep_->db_session_id;
1531
+ rep_->props.db_host_id = rep_->db_host_id;
1532
+
1533
+ // Add basic properties
1534
+ property_block_builder.AddTableProperty(rep_->props);
1535
+
1536
+ // Add use collected properties
1537
+ NotifyCollectTableCollectorsOnFinish(rep_->table_properties_collectors,
1538
+ rep_->ioptions.info_log,
1539
+ &property_block_builder);
1540
+
1541
+ WriteRawBlock(property_block_builder.Finish(), kNoCompression,
1542
+ &properties_block_handle);
1543
+ }
1544
+ if (ok()) {
1545
+ #ifndef NDEBUG
1546
+ {
1547
+ uint64_t props_block_offset = properties_block_handle.offset();
1548
+ uint64_t props_block_size = properties_block_handle.size();
1549
+ TEST_SYNC_POINT_CALLBACK(
1550
+ "BlockBasedTableBuilder::WritePropertiesBlock:GetPropsBlockOffset",
1551
+ &props_block_offset);
1552
+ TEST_SYNC_POINT_CALLBACK(
1553
+ "BlockBasedTableBuilder::WritePropertiesBlock:GetPropsBlockSize",
1554
+ &props_block_size);
1555
+ }
1556
+ #endif // !NDEBUG
1557
+ meta_index_builder->Add(kPropertiesBlock, properties_block_handle);
1558
+ }
1559
+ }
1560
+
1561
+ void BlockBasedTableBuilder::WriteCompressionDictBlock(
1562
+ MetaIndexBuilder* meta_index_builder) {
1563
+ if (rep_->compression_dict != nullptr &&
1564
+ rep_->compression_dict->GetRawDict().size()) {
1565
+ BlockHandle compression_dict_block_handle;
1566
+ if (ok()) {
1567
+ WriteRawBlock(rep_->compression_dict->GetRawDict(), kNoCompression,
1568
+ &compression_dict_block_handle);
1569
+ #ifndef NDEBUG
1570
+ Slice compression_dict = rep_->compression_dict->GetRawDict();
1571
+ TEST_SYNC_POINT_CALLBACK(
1572
+ "BlockBasedTableBuilder::WriteCompressionDictBlock:RawDict",
1573
+ &compression_dict);
1574
+ #endif // NDEBUG
1575
+ }
1576
+ if (ok()) {
1577
+ meta_index_builder->Add(kCompressionDictBlock,
1578
+ compression_dict_block_handle);
1579
+ }
1580
+ }
1581
+ }
1582
+
1583
+ void BlockBasedTableBuilder::WriteRangeDelBlock(
1584
+ MetaIndexBuilder* meta_index_builder) {
1585
+ if (ok() && !rep_->range_del_block.empty()) {
1586
+ BlockHandle range_del_block_handle;
1587
+ WriteRawBlock(rep_->range_del_block.Finish(), kNoCompression,
1588
+ &range_del_block_handle);
1589
+ meta_index_builder->Add(kRangeDelBlock, range_del_block_handle);
1590
+ }
1591
+ }
1592
+
1593
+ void BlockBasedTableBuilder::WriteFooter(BlockHandle& metaindex_block_handle,
1594
+ BlockHandle& index_block_handle) {
1595
+ Rep* r = rep_;
1596
+ // No need to write out new footer if we're using default checksum.
1597
+ // We're writing legacy magic number because we want old versions of RocksDB
1598
+ // be able to read files generated with new release (just in case if
1599
+ // somebody wants to roll back after an upgrade)
1600
+ // TODO(icanadi) at some point in the future, when we're absolutely sure
1601
+ // nobody will roll back to RocksDB 2.x versions, retire the legacy magic
1602
+ // number and always write new table files with new magic number
1603
+ bool legacy = (r->table_options.format_version == 0);
1604
+ // this is guaranteed by BlockBasedTableBuilder's constructor
1605
+ assert(r->table_options.checksum == kCRC32c ||
1606
+ r->table_options.format_version != 0);
1607
+ Footer footer(
1608
+ legacy ? kLegacyBlockBasedTableMagicNumber : kBlockBasedTableMagicNumber,
1609
+ r->table_options.format_version);
1610
+ footer.set_metaindex_handle(metaindex_block_handle);
1611
+ footer.set_index_handle(index_block_handle);
1612
+ footer.set_checksum(r->table_options.checksum);
1613
+ std::string footer_encoding;
1614
+ footer.EncodeTo(&footer_encoding);
1615
+ assert(ok());
1616
+ IOStatus ios = r->file->Append(footer_encoding);
1617
+ if (ios.ok()) {
1618
+ r->set_offset(r->get_offset() + footer_encoding.size());
1619
+ } else {
1620
+ r->SetIOStatus(ios);
1621
+ r->SetStatus(ios);
1622
+ }
1623
+ }
1624
+
1625
+ void BlockBasedTableBuilder::EnterUnbuffered() {
1626
+ Rep* r = rep_;
1627
+ assert(r->state == Rep::State::kBuffered);
1628
+ r->state = Rep::State::kUnbuffered;
1629
+ const size_t kSampleBytes = r->compression_opts.zstd_max_train_bytes > 0
1630
+ ? r->compression_opts.zstd_max_train_bytes
1631
+ : r->compression_opts.max_dict_bytes;
1632
+ Random64 generator{r->creation_time};
1633
+ std::string compression_dict_samples;
1634
+ std::vector<size_t> compression_dict_sample_lens;
1635
+ if (!r->data_block_and_keys_buffers.empty()) {
1636
+ while (compression_dict_samples.size() < kSampleBytes) {
1637
+ size_t rand_idx =
1638
+ static_cast<size_t>(
1639
+ generator.Uniform(r->data_block_and_keys_buffers.size()));
1640
+ size_t copy_len =
1641
+ std::min(kSampleBytes - compression_dict_samples.size(),
1642
+ r->data_block_and_keys_buffers[rand_idx].first.size());
1643
+ compression_dict_samples.append(
1644
+ r->data_block_and_keys_buffers[rand_idx].first, 0, copy_len);
1645
+ compression_dict_sample_lens.emplace_back(copy_len);
1646
+ }
1647
+ }
1648
+
1649
+ // final data block flushed, now we can generate dictionary from the samples.
1650
+ // OK if compression_dict_samples is empty, we'll just get empty dictionary.
1651
+ std::string dict;
1652
+ if (r->compression_opts.zstd_max_train_bytes > 0) {
1653
+ dict = ZSTD_TrainDictionary(compression_dict_samples,
1654
+ compression_dict_sample_lens,
1655
+ r->compression_opts.max_dict_bytes);
1656
+ } else {
1657
+ dict = std::move(compression_dict_samples);
1658
+ }
1659
+ r->compression_dict.reset(new CompressionDict(dict, r->compression_type,
1660
+ r->compression_opts.level));
1661
+ r->verify_dict.reset(new UncompressionDict(
1662
+ dict, r->compression_type == kZSTD ||
1663
+ r->compression_type == kZSTDNotFinalCompression));
1664
+
1665
+ for (size_t i = 0; ok() && i < r->data_block_and_keys_buffers.size(); ++i) {
1666
+ auto& data_block = r->data_block_and_keys_buffers[i].first;
1667
+ auto& keys = r->data_block_and_keys_buffers[i].second;
1668
+ assert(!data_block.empty());
1669
+ assert(!keys.empty());
1670
+
1671
+ if (r->IsParallelCompressionEnabled()) {
1672
+ Slice first_key_in_next_block;
1673
+ const Slice* first_key_in_next_block_ptr = &first_key_in_next_block;
1674
+ if (i + 1 < r->data_block_and_keys_buffers.size()) {
1675
+ first_key_in_next_block =
1676
+ r->data_block_and_keys_buffers[i + 1].second.front();
1677
+ } else {
1678
+ first_key_in_next_block_ptr = r->first_key_in_next_block;
1679
+ }
1680
+
1681
+ ParallelCompressionRep::BlockRep* block_rep = r->pc_rep->PrepareBlock(
1682
+ r->compression_type, first_key_in_next_block_ptr, &data_block, &keys);
1683
+ assert(block_rep != nullptr);
1684
+ r->pc_rep->file_size_estimator.EmitBlock(block_rep->data->size(),
1685
+ r->get_offset());
1686
+ r->pc_rep->EmitBlock(block_rep);
1687
+ } else {
1688
+ for (const auto& key : keys) {
1689
+ if (r->filter_builder != nullptr) {
1690
+ size_t ts_sz =
1691
+ r->internal_comparator.user_comparator()->timestamp_size();
1692
+ r->filter_builder->Add(ExtractUserKeyAndStripTimestamp(key, ts_sz));
1693
+ }
1694
+ r->index_builder->OnKeyAdded(key);
1695
+ }
1696
+ WriteBlock(Slice(data_block), &r->pending_handle,
1697
+ true /* is_data_block */);
1698
+ if (ok() && i + 1 < r->data_block_and_keys_buffers.size()) {
1699
+ Slice first_key_in_next_block =
1700
+ r->data_block_and_keys_buffers[i + 1].second.front();
1701
+ Slice* first_key_in_next_block_ptr = &first_key_in_next_block;
1702
+ r->index_builder->AddIndexEntry(
1703
+ &keys.back(), first_key_in_next_block_ptr, r->pending_handle);
1704
+ }
1705
+ }
1706
+ }
1707
+ r->data_block_and_keys_buffers.clear();
1708
+ }
1709
+
1710
+ Status BlockBasedTableBuilder::Finish() {
1711
+ Rep* r = rep_;
1712
+ assert(r->state != Rep::State::kClosed);
1713
+ bool empty_data_block = r->data_block.empty();
1714
+ r->first_key_in_next_block = nullptr;
1715
+ Flush();
1716
+ if (r->state == Rep::State::kBuffered) {
1717
+ EnterUnbuffered();
1718
+ }
1719
+ if (r->IsParallelCompressionEnabled()) {
1720
+ StopParallelCompression();
1721
+ #ifndef NDEBUG
1722
+ for (const auto& br : r->pc_rep->block_rep_buf) {
1723
+ assert(br.status.ok());
1724
+ }
1725
+ #endif // !NDEBUG
1726
+ } else {
1727
+ // To make sure properties block is able to keep the accurate size of index
1728
+ // block, we will finish writing all index entries first.
1729
+ if (ok() && !empty_data_block) {
1730
+ r->index_builder->AddIndexEntry(
1731
+ &r->last_key, nullptr /* no next data block */, r->pending_handle);
1732
+ }
1733
+ }
1734
+
1735
+ // Write meta blocks, metaindex block and footer in the following order.
1736
+ // 1. [meta block: filter]
1737
+ // 2. [meta block: index]
1738
+ // 3. [meta block: compression dictionary]
1739
+ // 4. [meta block: range deletion tombstone]
1740
+ // 5. [meta block: properties]
1741
+ // 6. [metaindex block]
1742
+ // 7. Footer
1743
+ BlockHandle metaindex_block_handle, index_block_handle;
1744
+ MetaIndexBuilder meta_index_builder;
1745
+ WriteFilterBlock(&meta_index_builder);
1746
+ WriteIndexBlock(&meta_index_builder, &index_block_handle);
1747
+ WriteCompressionDictBlock(&meta_index_builder);
1748
+ WriteRangeDelBlock(&meta_index_builder);
1749
+ WritePropertiesBlock(&meta_index_builder);
1750
+ if (ok()) {
1751
+ // flush the meta index block
1752
+ WriteRawBlock(meta_index_builder.Finish(), kNoCompression,
1753
+ &metaindex_block_handle);
1754
+ }
1755
+ if (ok()) {
1756
+ WriteFooter(metaindex_block_handle, index_block_handle);
1757
+ }
1758
+ r->state = Rep::State::kClosed;
1759
+ r->SetStatus(r->CopyIOStatus());
1760
+ Status ret_status = r->CopyStatus();
1761
+ assert(!ret_status.ok() || io_status().ok());
1762
+ return ret_status;
1763
+ }
1764
+
1765
+ void BlockBasedTableBuilder::Abandon() {
1766
+ assert(rep_->state != Rep::State::kClosed);
1767
+ if (rep_->IsParallelCompressionEnabled()) {
1768
+ StopParallelCompression();
1769
+ }
1770
+ rep_->state = Rep::State::kClosed;
1771
+ rep_->CopyStatus().PermitUncheckedError();
1772
+ rep_->CopyIOStatus().PermitUncheckedError();
1773
+ }
1774
+
1775
+ uint64_t BlockBasedTableBuilder::NumEntries() const {
1776
+ return rep_->props.num_entries;
1777
+ }
1778
+
1779
+ bool BlockBasedTableBuilder::IsEmpty() const {
1780
+ return rep_->props.num_entries == 0 && rep_->props.num_range_deletions == 0;
1781
+ }
1782
+
1783
+ uint64_t BlockBasedTableBuilder::FileSize() const { return rep_->offset; }
1784
+
1785
+ uint64_t BlockBasedTableBuilder::EstimatedFileSize() const {
1786
+ if (rep_->IsParallelCompressionEnabled()) {
1787
+ // Use compression ratio so far and inflight raw bytes to estimate
1788
+ // final SST size.
1789
+ return rep_->pc_rep->file_size_estimator.GetEstimatedFileSize();
1790
+ } else {
1791
+ return FileSize();
1792
+ }
1793
+ }
1794
+
1795
+ bool BlockBasedTableBuilder::NeedCompact() const {
1796
+ for (const auto& collector : rep_->table_properties_collectors) {
1797
+ if (collector->NeedCompact()) {
1798
+ return true;
1799
+ }
1800
+ }
1801
+ return false;
1802
+ }
1803
+
1804
+ TableProperties BlockBasedTableBuilder::GetTableProperties() const {
1805
+ TableProperties ret = rep_->props;
1806
+ for (const auto& collector : rep_->table_properties_collectors) {
1807
+ for (const auto& prop : collector->GetReadableProperties()) {
1808
+ ret.readable_properties.insert(prop);
1809
+ }
1810
+ collector->Finish(&ret.user_collected_properties).PermitUncheckedError();
1811
+ }
1812
+ return ret;
1813
+ }
1814
+
1815
+ std::string BlockBasedTableBuilder::GetFileChecksum() const {
1816
+ if (rep_->file != nullptr) {
1817
+ return rep_->file->GetFileChecksum();
1818
+ } else {
1819
+ return kUnknownFileChecksum;
1820
+ }
1821
+ }
1822
+
1823
+ const char* BlockBasedTableBuilder::GetFileChecksumFuncName() const {
1824
+ if (rep_->file != nullptr) {
1825
+ return rep_->file->GetFileChecksumFuncName();
1826
+ } else {
1827
+ return kUnknownFileChecksumFuncName;
1828
+ }
1829
+ }
1830
+
1831
+ const std::string BlockBasedTable::kFilterBlockPrefix = "filter.";
1832
+ const std::string BlockBasedTable::kFullFilterBlockPrefix = "fullfilter.";
1833
+ const std::string BlockBasedTable::kPartitionedFilterBlockPrefix =
1834
+ "partitionedfilter.";
1835
+ } // namespace ROCKSDB_NAMESPACE