zstd-native-ruby 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 (651) hide show
  1. checksums.yaml +7 -0
  2. data/CLAUDE.md +101 -0
  3. data/LICENSE +19 -0
  4. data/README.md +47 -0
  5. data/ext/zstd_ruby/extconf.rb +35 -0
  6. data/ext/zstd_ruby/zstd_ruby.c +221 -0
  7. data/lib/zstd_ruby.rb +68 -0
  8. data/vendor/zstd/CHANGELOG +863 -0
  9. data/vendor/zstd/CMakeLists.txt +11 -0
  10. data/vendor/zstd/CODE_OF_CONDUCT.md +5 -0
  11. data/vendor/zstd/CONTRIBUTING.md +494 -0
  12. data/vendor/zstd/COPYING +339 -0
  13. data/vendor/zstd/LICENSE +30 -0
  14. data/vendor/zstd/Makefile +470 -0
  15. data/vendor/zstd/Package.swift +36 -0
  16. data/vendor/zstd/README.md +244 -0
  17. data/vendor/zstd/SECURITY.md +15 -0
  18. data/vendor/zstd/TESTING.md +43 -0
  19. data/vendor/zstd/build/LICENSE +0 -0
  20. data/vendor/zstd/build/README.md +56 -0
  21. data/vendor/zstd/build/VS2008/fullbench/fullbench.vcproj +549 -0
  22. data/vendor/zstd/build/VS2008/fuzzer/fuzzer.vcproj +585 -0
  23. data/vendor/zstd/build/VS2008/zstd/zstd.vcproj +677 -0
  24. data/vendor/zstd/build/VS2008/zstd.sln +56 -0
  25. data/vendor/zstd/build/VS2008/zstdlib/zstdlib.vcproj +635 -0
  26. data/vendor/zstd/build/VS2010/CompileAsCpp.props +8 -0
  27. data/vendor/zstd/build/VS2010/datagen/datagen.vcxproj +170 -0
  28. data/vendor/zstd/build/VS2010/fullbench/fullbench.vcxproj +220 -0
  29. data/vendor/zstd/build/VS2010/fuzzer/fuzzer.vcxproj +224 -0
  30. data/vendor/zstd/build/VS2010/libzstd/libzstd.vcxproj +243 -0
  31. data/vendor/zstd/build/VS2010/libzstd-dll/libzstd-dll.rc +51 -0
  32. data/vendor/zstd/build/VS2010/libzstd-dll/libzstd-dll.vcxproj +250 -0
  33. data/vendor/zstd/build/VS2010/zstd/zstd.rc +51 -0
  34. data/vendor/zstd/build/VS2010/zstd/zstd.vcxproj +266 -0
  35. data/vendor/zstd/build/VS2010/zstd.sln +84 -0
  36. data/vendor/zstd/build/VS_scripts/README.md +64 -0
  37. data/vendor/zstd/build/VS_scripts/build.VS2010.cmd +7 -0
  38. data/vendor/zstd/build/VS_scripts/build.VS2012.cmd +6 -0
  39. data/vendor/zstd/build/VS_scripts/build.VS2013.cmd +7 -0
  40. data/vendor/zstd/build/VS_scripts/build.VS2015.cmd +7 -0
  41. data/vendor/zstd/build/VS_scripts/build.VS2017.cmd +7 -0
  42. data/vendor/zstd/build/VS_scripts/build.VS2017Community.cmd +7 -0
  43. data/vendor/zstd/build/VS_scripts/build.VS2017Enterprise.cmd +7 -0
  44. data/vendor/zstd/build/VS_scripts/build.VS2017Professional.cmd +7 -0
  45. data/vendor/zstd/build/VS_scripts/build.VSPreview.cmd +7 -0
  46. data/vendor/zstd/build/VS_scripts/build.generic.cmd +67 -0
  47. data/vendor/zstd/build/cmake/CMakeLists.txt +81 -0
  48. data/vendor/zstd/build/cmake/CMakeModules/AddZstdCompilationFlags.cmake +138 -0
  49. data/vendor/zstd/build/cmake/CMakeModules/FindLibLZ4.cmake +49 -0
  50. data/vendor/zstd/build/cmake/CMakeModules/GetZstdLibraryVersion.cmake +10 -0
  51. data/vendor/zstd/build/cmake/CMakeModules/JoinPaths.cmake +23 -0
  52. data/vendor/zstd/build/cmake/CMakeModules/ZstdBuild.cmake +42 -0
  53. data/vendor/zstd/build/cmake/CMakeModules/ZstdDependencies.cmake +30 -0
  54. data/vendor/zstd/build/cmake/CMakeModules/ZstdOptions.cmake +68 -0
  55. data/vendor/zstd/build/cmake/CMakeModules/ZstdPackage.cmake +42 -0
  56. data/vendor/zstd/build/cmake/CMakeModules/ZstdVersion.cmake +31 -0
  57. data/vendor/zstd/build/cmake/README.md +155 -0
  58. data/vendor/zstd/build/cmake/contrib/CMakeLists.txt +13 -0
  59. data/vendor/zstd/build/cmake/contrib/gen_html/CMakeLists.txt +30 -0
  60. data/vendor/zstd/build/cmake/contrib/pzstd/CMakeLists.txt +39 -0
  61. data/vendor/zstd/build/cmake/lib/CMakeLists.txt +298 -0
  62. data/vendor/zstd/build/cmake/lib/cmake_uninstall.cmake.in +22 -0
  63. data/vendor/zstd/build/cmake/programs/CMakeLists.txt +144 -0
  64. data/vendor/zstd/build/cmake/tests/CMakeLists.txt +118 -0
  65. data/vendor/zstd/build/cmake/zstdConfig.cmake.in +10 -0
  66. data/vendor/zstd/build/meson/GetZstdLibraryVersion.py +39 -0
  67. data/vendor/zstd/build/meson/InstallSymlink.py +55 -0
  68. data/vendor/zstd/build/meson/README.md +38 -0
  69. data/vendor/zstd/build/meson/contrib/gen_html/meson.build +30 -0
  70. data/vendor/zstd/build/meson/contrib/meson.build +12 -0
  71. data/vendor/zstd/build/meson/contrib/pzstd/meson.build +25 -0
  72. data/vendor/zstd/build/meson/lib/meson.build +175 -0
  73. data/vendor/zstd/build/meson/meson.build +155 -0
  74. data/vendor/zstd/build/meson/meson_options.txt +36 -0
  75. data/vendor/zstd/build/meson/programs/meson.build +124 -0
  76. data/vendor/zstd/build/meson/tests/meson.build +217 -0
  77. data/vendor/zstd/build/meson/tests/valgrindTest.py +90 -0
  78. data/vendor/zstd/build/single_file_libs/README.md +33 -0
  79. data/vendor/zstd/build/single_file_libs/build_decoder_test.sh +91 -0
  80. data/vendor/zstd/build/single_file_libs/build_library_test.sh +98 -0
  81. data/vendor/zstd/build/single_file_libs/combine.py +234 -0
  82. data/vendor/zstd/build/single_file_libs/combine.sh +249 -0
  83. data/vendor/zstd/build/single_file_libs/create_single_file_decoder.sh +19 -0
  84. data/vendor/zstd/build/single_file_libs/create_single_file_library.sh +19 -0
  85. data/vendor/zstd/build/single_file_libs/examples/README.md +11 -0
  86. data/vendor/zstd/build/single_file_libs/examples/emscripten.c +340 -0
  87. data/vendor/zstd/build/single_file_libs/examples/roundtrip.c +83 -0
  88. data/vendor/zstd/build/single_file_libs/examples/shell.html +31 -0
  89. data/vendor/zstd/build/single_file_libs/examples/simple.c +75 -0
  90. data/vendor/zstd/build/single_file_libs/examples/testcard-dxt1.inl +2731 -0
  91. data/vendor/zstd/build/single_file_libs/examples/testcard-zstd.inl +261 -0
  92. data/vendor/zstd/build/single_file_libs/examples/testcard.png +0 -0
  93. data/vendor/zstd/build/single_file_libs/zstd-in.c +91 -0
  94. data/vendor/zstd/build/single_file_libs/zstddeclib-in.c +62 -0
  95. data/vendor/zstd/contrib/VS2005/README.md +3 -0
  96. data/vendor/zstd/contrib/VS2005/fullbench/fullbench.vcproj +440 -0
  97. data/vendor/zstd/contrib/VS2005/fuzzer/fuzzer.vcproj +488 -0
  98. data/vendor/zstd/contrib/VS2005/zstd/zstd.vcproj +552 -0
  99. data/vendor/zstd/contrib/VS2005/zstd.sln +55 -0
  100. data/vendor/zstd/contrib/VS2005/zstdlib/zstdlib.vcproj +546 -0
  101. data/vendor/zstd/contrib/cleanTabs +2 -0
  102. data/vendor/zstd/contrib/diagnose_corruption/Makefile +35 -0
  103. data/vendor/zstd/contrib/diagnose_corruption/check_flipped_bits.c +400 -0
  104. data/vendor/zstd/contrib/docker/Dockerfile +20 -0
  105. data/vendor/zstd/contrib/docker/README.md +20 -0
  106. data/vendor/zstd/contrib/externalSequenceProducer/Makefile +40 -0
  107. data/vendor/zstd/contrib/externalSequenceProducer/README.md +14 -0
  108. data/vendor/zstd/contrib/externalSequenceProducer/main.c +108 -0
  109. data/vendor/zstd/contrib/externalSequenceProducer/sequence_producer.c +80 -0
  110. data/vendor/zstd/contrib/externalSequenceProducer/sequence_producer.h +26 -0
  111. data/vendor/zstd/contrib/freestanding_lib/freestanding.py +774 -0
  112. data/vendor/zstd/contrib/gen_html/Makefile +51 -0
  113. data/vendor/zstd/contrib/gen_html/README.md +31 -0
  114. data/vendor/zstd/contrib/gen_html/gen-zstd-manual.sh +9 -0
  115. data/vendor/zstd/contrib/gen_html/gen_html.cpp +225 -0
  116. data/vendor/zstd/contrib/largeNbDicts/Makefile +58 -0
  117. data/vendor/zstd/contrib/largeNbDicts/README.md +33 -0
  118. data/vendor/zstd/contrib/largeNbDicts/largeNbDicts.c +1087 -0
  119. data/vendor/zstd/contrib/linux-kernel/Makefile +108 -0
  120. data/vendor/zstd/contrib/linux-kernel/README.md +14 -0
  121. data/vendor/zstd/contrib/linux-kernel/btrfs-benchmark.sh +104 -0
  122. data/vendor/zstd/contrib/linux-kernel/btrfs-extract-benchmark.sh +99 -0
  123. data/vendor/zstd/contrib/linux-kernel/decompress_sources.h +34 -0
  124. data/vendor/zstd/contrib/linux-kernel/linux.mk +44 -0
  125. data/vendor/zstd/contrib/linux-kernel/linux_zstd.h +691 -0
  126. data/vendor/zstd/contrib/linux-kernel/mem.h +262 -0
  127. data/vendor/zstd/contrib/linux-kernel/squashfs-benchmark.sh +39 -0
  128. data/vendor/zstd/contrib/linux-kernel/test/Makefile +49 -0
  129. data/vendor/zstd/contrib/linux-kernel/test/include/linux/compiler.h +23 -0
  130. data/vendor/zstd/contrib/linux-kernel/test/include/linux/errno.h +15 -0
  131. data/vendor/zstd/contrib/linux-kernel/test/include/linux/kernel.h +19 -0
  132. data/vendor/zstd/contrib/linux-kernel/test/include/linux/limits.h +15 -0
  133. data/vendor/zstd/contrib/linux-kernel/test/include/linux/math64.h +15 -0
  134. data/vendor/zstd/contrib/linux-kernel/test/include/linux/module.h +20 -0
  135. data/vendor/zstd/contrib/linux-kernel/test/include/linux/printk.h +15 -0
  136. data/vendor/zstd/contrib/linux-kernel/test/include/linux/stddef.h +15 -0
  137. data/vendor/zstd/contrib/linux-kernel/test/include/linux/swab.h +16 -0
  138. data/vendor/zstd/contrib/linux-kernel/test/include/linux/types.h +16 -0
  139. data/vendor/zstd/contrib/linux-kernel/test/include/linux/unaligned.h +187 -0
  140. data/vendor/zstd/contrib/linux-kernel/test/include/linux/xxhash.h +745 -0
  141. data/vendor/zstd/contrib/linux-kernel/test/macro-test.sh +44 -0
  142. data/vendor/zstd/contrib/linux-kernel/test/static_test.c +52 -0
  143. data/vendor/zstd/contrib/linux-kernel/test/test.c +229 -0
  144. data/vendor/zstd/contrib/linux-kernel/zstd_common_module.c +29 -0
  145. data/vendor/zstd/contrib/linux-kernel/zstd_compress_module.c +286 -0
  146. data/vendor/zstd/contrib/linux-kernel/zstd_decompress_module.c +141 -0
  147. data/vendor/zstd/contrib/linux-kernel/zstd_deps.h +121 -0
  148. data/vendor/zstd/contrib/match_finders/README.md +42 -0
  149. data/vendor/zstd/contrib/match_finders/zstd_edist.c +558 -0
  150. data/vendor/zstd/contrib/match_finders/zstd_edist.h +70 -0
  151. data/vendor/zstd/contrib/premake/premake4.lua +6 -0
  152. data/vendor/zstd/contrib/premake/zstd.lua +81 -0
  153. data/vendor/zstd/contrib/pzstd/BUCK +72 -0
  154. data/vendor/zstd/contrib/pzstd/ErrorHolder.h +54 -0
  155. data/vendor/zstd/contrib/pzstd/Logging.h +73 -0
  156. data/vendor/zstd/contrib/pzstd/Makefile +265 -0
  157. data/vendor/zstd/contrib/pzstd/Options.cpp +424 -0
  158. data/vendor/zstd/contrib/pzstd/Options.h +71 -0
  159. data/vendor/zstd/contrib/pzstd/Pzstd.cpp +626 -0
  160. data/vendor/zstd/contrib/pzstd/Pzstd.h +153 -0
  161. data/vendor/zstd/contrib/pzstd/README.md +56 -0
  162. data/vendor/zstd/contrib/pzstd/SkippableFrame.cpp +30 -0
  163. data/vendor/zstd/contrib/pzstd/SkippableFrame.h +64 -0
  164. data/vendor/zstd/contrib/pzstd/images/Cspeed.png +0 -0
  165. data/vendor/zstd/contrib/pzstd/images/Dspeed.png +0 -0
  166. data/vendor/zstd/contrib/pzstd/main.cpp +27 -0
  167. data/vendor/zstd/contrib/pzstd/test/BUCK +37 -0
  168. data/vendor/zstd/contrib/pzstd/test/OptionsTest.cpp +536 -0
  169. data/vendor/zstd/contrib/pzstd/test/PzstdTest.cpp +147 -0
  170. data/vendor/zstd/contrib/pzstd/test/RoundTrip.h +86 -0
  171. data/vendor/zstd/contrib/pzstd/test/RoundTripTest.cpp +84 -0
  172. data/vendor/zstd/contrib/pzstd/utils/BUCK +75 -0
  173. data/vendor/zstd/contrib/pzstd/utils/Buffer.h +99 -0
  174. data/vendor/zstd/contrib/pzstd/utils/FileSystem.h +96 -0
  175. data/vendor/zstd/contrib/pzstd/utils/Likely.h +28 -0
  176. data/vendor/zstd/contrib/pzstd/utils/Portability.h +16 -0
  177. data/vendor/zstd/contrib/pzstd/utils/Range.h +133 -0
  178. data/vendor/zstd/contrib/pzstd/utils/ResourcePool.h +96 -0
  179. data/vendor/zstd/contrib/pzstd/utils/ScopeGuard.h +50 -0
  180. data/vendor/zstd/contrib/pzstd/utils/ThreadPool.h +58 -0
  181. data/vendor/zstd/contrib/pzstd/utils/WorkQueue.h +182 -0
  182. data/vendor/zstd/contrib/pzstd/utils/test/BUCK +35 -0
  183. data/vendor/zstd/contrib/pzstd/utils/test/BufferTest.cpp +89 -0
  184. data/vendor/zstd/contrib/pzstd/utils/test/RangeTest.cpp +82 -0
  185. data/vendor/zstd/contrib/pzstd/utils/test/ResourcePoolTest.cpp +72 -0
  186. data/vendor/zstd/contrib/pzstd/utils/test/ScopeGuardTest.cpp +28 -0
  187. data/vendor/zstd/contrib/pzstd/utils/test/ThreadPoolTest.cpp +71 -0
  188. data/vendor/zstd/contrib/pzstd/utils/test/WorkQueueTest.cpp +282 -0
  189. data/vendor/zstd/contrib/recovery/Makefile +35 -0
  190. data/vendor/zstd/contrib/recovery/recover_directory.c +152 -0
  191. data/vendor/zstd/contrib/seekable_format/README.md +42 -0
  192. data/vendor/zstd/contrib/seekable_format/examples/Makefile +55 -0
  193. data/vendor/zstd/contrib/seekable_format/examples/parallel_compression.c +254 -0
  194. data/vendor/zstd/contrib/seekable_format/examples/parallel_processing.c +191 -0
  195. data/vendor/zstd/contrib/seekable_format/examples/seekable_compression.c +136 -0
  196. data/vendor/zstd/contrib/seekable_format/examples/seekable_decompression.c +141 -0
  197. data/vendor/zstd/contrib/seekable_format/examples/seekable_decompression_mem.c +147 -0
  198. data/vendor/zstd/contrib/seekable_format/tests/Makefile +58 -0
  199. data/vendor/zstd/contrib/seekable_format/tests/seekable_tests.c +375 -0
  200. data/vendor/zstd/contrib/seekable_format/zstd_seekable.h +226 -0
  201. data/vendor/zstd/contrib/seekable_format/zstd_seekable_compression_format.md +116 -0
  202. data/vendor/zstd/contrib/seekable_format/zstdseek_compress.c +365 -0
  203. data/vendor/zstd/contrib/seekable_format/zstdseek_decompress.c +600 -0
  204. data/vendor/zstd/contrib/seqBench/Makefile +58 -0
  205. data/vendor/zstd/contrib/seqBench/seqBench.c +53 -0
  206. data/vendor/zstd/contrib/snap/snapcraft.yaml +28 -0
  207. data/vendor/zstd/doc/README.md +26 -0
  208. data/vendor/zstd/doc/decompressor_errata.md +148 -0
  209. data/vendor/zstd/doc/decompressor_permissive.md +80 -0
  210. data/vendor/zstd/doc/educational_decoder/Makefile +62 -0
  211. data/vendor/zstd/doc/educational_decoder/README.md +36 -0
  212. data/vendor/zstd/doc/educational_decoder/harness.c +119 -0
  213. data/vendor/zstd/doc/educational_decoder/zstd_decompress.c +2323 -0
  214. data/vendor/zstd/doc/educational_decoder/zstd_decompress.h +61 -0
  215. data/vendor/zstd/doc/images/CSpeed2.png +0 -0
  216. data/vendor/zstd/doc/images/DCspeed5.png +0 -0
  217. data/vendor/zstd/doc/images/DSpeed3.png +0 -0
  218. data/vendor/zstd/doc/images/cdict_v136.png +0 -0
  219. data/vendor/zstd/doc/images/dict-cr.png +0 -0
  220. data/vendor/zstd/doc/images/dict-cs.png +0 -0
  221. data/vendor/zstd/doc/images/dict-ds.png +0 -0
  222. data/vendor/zstd/doc/images/zstd_cdict_v1_3_5.png +0 -0
  223. data/vendor/zstd/doc/images/zstd_logo86.png +0 -0
  224. data/vendor/zstd/doc/zstd_compression_format.md +1772 -0
  225. data/vendor/zstd/doc/zstd_manual.html +2244 -0
  226. data/vendor/zstd/examples/Makefile +93 -0
  227. data/vendor/zstd/examples/README.md +46 -0
  228. data/vendor/zstd/examples/common.h +246 -0
  229. data/vendor/zstd/examples/dictionary_compression.c +107 -0
  230. data/vendor/zstd/examples/dictionary_decompression.c +99 -0
  231. data/vendor/zstd/examples/multiple_simple_compression.c +116 -0
  232. data/vendor/zstd/examples/multiple_streaming_compression.c +133 -0
  233. data/vendor/zstd/examples/simple_compression.c +68 -0
  234. data/vendor/zstd/examples/simple_decompression.c +65 -0
  235. data/vendor/zstd/examples/streaming_compression.c +146 -0
  236. data/vendor/zstd/examples/streaming_compression_thread_pool.c +180 -0
  237. data/vendor/zstd/examples/streaming_decompression.c +100 -0
  238. data/vendor/zstd/examples/streaming_memory_usage.c +137 -0
  239. data/vendor/zstd/lib/BUCK +232 -0
  240. data/vendor/zstd/lib/Makefile +389 -0
  241. data/vendor/zstd/lib/README.md +267 -0
  242. data/vendor/zstd/lib/common/allocations.h +55 -0
  243. data/vendor/zstd/lib/common/bits.h +205 -0
  244. data/vendor/zstd/lib/common/bitstream.h +454 -0
  245. data/vendor/zstd/lib/common/compiler.h +482 -0
  246. data/vendor/zstd/lib/common/cpu.h +249 -0
  247. data/vendor/zstd/lib/common/debug.c +30 -0
  248. data/vendor/zstd/lib/common/debug.h +107 -0
  249. data/vendor/zstd/lib/common/debug.o +0 -0
  250. data/vendor/zstd/lib/common/entropy_common.c +340 -0
  251. data/vendor/zstd/lib/common/entropy_common.o +0 -0
  252. data/vendor/zstd/lib/common/error_private.c +64 -0
  253. data/vendor/zstd/lib/common/error_private.h +158 -0
  254. data/vendor/zstd/lib/common/error_private.o +0 -0
  255. data/vendor/zstd/lib/common/fse.h +625 -0
  256. data/vendor/zstd/lib/common/fse_decompress.c +315 -0
  257. data/vendor/zstd/lib/common/fse_decompress.o +0 -0
  258. data/vendor/zstd/lib/common/huf.h +277 -0
  259. data/vendor/zstd/lib/common/mem.h +422 -0
  260. data/vendor/zstd/lib/common/pool.c +371 -0
  261. data/vendor/zstd/lib/common/pool.h +81 -0
  262. data/vendor/zstd/lib/common/pool.o +0 -0
  263. data/vendor/zstd/lib/common/portability_macros.h +190 -0
  264. data/vendor/zstd/lib/common/threading.c +196 -0
  265. data/vendor/zstd/lib/common/threading.h +142 -0
  266. data/vendor/zstd/lib/common/threading.o +0 -0
  267. data/vendor/zstd/lib/common/xxhash.c +18 -0
  268. data/vendor/zstd/lib/common/xxhash.h +7094 -0
  269. data/vendor/zstd/lib/common/xxhash.o +0 -0
  270. data/vendor/zstd/lib/common/zstd_common.c +57 -0
  271. data/vendor/zstd/lib/common/zstd_common.o +0 -0
  272. data/vendor/zstd/lib/common/zstd_deps.h +123 -0
  273. data/vendor/zstd/lib/common/zstd_internal.h +326 -0
  274. data/vendor/zstd/lib/common/zstd_trace.h +156 -0
  275. data/vendor/zstd/lib/compress/clevels.h +134 -0
  276. data/vendor/zstd/lib/compress/fse_compress.c +625 -0
  277. data/vendor/zstd/lib/compress/fse_compress.o +0 -0
  278. data/vendor/zstd/lib/compress/hist.c +446 -0
  279. data/vendor/zstd/lib/compress/hist.h +86 -0
  280. data/vendor/zstd/lib/compress/hist.o +0 -0
  281. data/vendor/zstd/lib/compress/huf_compress.c +1465 -0
  282. data/vendor/zstd/lib/compress/huf_compress.o +0 -0
  283. data/vendor/zstd/lib/compress/zstd_compress.c +8362 -0
  284. data/vendor/zstd/lib/compress/zstd_compress.o +0 -0
  285. data/vendor/zstd/lib/compress/zstd_compress_internal.h +1636 -0
  286. data/vendor/zstd/lib/compress/zstd_compress_literals.c +235 -0
  287. data/vendor/zstd/lib/compress/zstd_compress_literals.h +39 -0
  288. data/vendor/zstd/lib/compress/zstd_compress_literals.o +0 -0
  289. data/vendor/zstd/lib/compress/zstd_compress_sequences.c +442 -0
  290. data/vendor/zstd/lib/compress/zstd_compress_sequences.h +55 -0
  291. data/vendor/zstd/lib/compress/zstd_compress_sequences.o +0 -0
  292. data/vendor/zstd/lib/compress/zstd_compress_superblock.c +688 -0
  293. data/vendor/zstd/lib/compress/zstd_compress_superblock.h +32 -0
  294. data/vendor/zstd/lib/compress/zstd_compress_superblock.o +0 -0
  295. data/vendor/zstd/lib/compress/zstd_cwksp.h +765 -0
  296. data/vendor/zstd/lib/compress/zstd_double_fast.c +778 -0
  297. data/vendor/zstd/lib/compress/zstd_double_fast.h +42 -0
  298. data/vendor/zstd/lib/compress/zstd_double_fast.o +0 -0
  299. data/vendor/zstd/lib/compress/zstd_fast.c +985 -0
  300. data/vendor/zstd/lib/compress/zstd_fast.h +30 -0
  301. data/vendor/zstd/lib/compress/zstd_fast.o +0 -0
  302. data/vendor/zstd/lib/compress/zstd_lazy.c +2243 -0
  303. data/vendor/zstd/lib/compress/zstd_lazy.h +193 -0
  304. data/vendor/zstd/lib/compress/zstd_lazy.o +0 -0
  305. data/vendor/zstd/lib/compress/zstd_ldm.c +745 -0
  306. data/vendor/zstd/lib/compress/zstd_ldm.h +109 -0
  307. data/vendor/zstd/lib/compress/zstd_ldm.o +0 -0
  308. data/vendor/zstd/lib/compress/zstd_ldm_geartab.h +106 -0
  309. data/vendor/zstd/lib/compress/zstd_opt.c +1572 -0
  310. data/vendor/zstd/lib/compress/zstd_opt.h +72 -0
  311. data/vendor/zstd/lib/compress/zstd_opt.o +0 -0
  312. data/vendor/zstd/lib/compress/zstd_preSplit.c +238 -0
  313. data/vendor/zstd/lib/compress/zstd_preSplit.h +33 -0
  314. data/vendor/zstd/lib/compress/zstd_preSplit.o +0 -0
  315. data/vendor/zstd/lib/compress/zstdmt_compress.c +1924 -0
  316. data/vendor/zstd/lib/compress/zstdmt_compress.h +102 -0
  317. data/vendor/zstd/lib/compress/zstdmt_compress.o +0 -0
  318. data/vendor/zstd/lib/decompress/huf_decompress.c +1953 -0
  319. data/vendor/zstd/lib/decompress/huf_decompress.o +0 -0
  320. data/vendor/zstd/lib/decompress/huf_decompress_amd64.S +766 -0
  321. data/vendor/zstd/lib/decompress/zstd_ddict.c +244 -0
  322. data/vendor/zstd/lib/decompress/zstd_ddict.h +44 -0
  323. data/vendor/zstd/lib/decompress/zstd_ddict.o +0 -0
  324. data/vendor/zstd/lib/decompress/zstd_decompress.c +2410 -0
  325. data/vendor/zstd/lib/decompress/zstd_decompress.o +0 -0
  326. data/vendor/zstd/lib/decompress/zstd_decompress_block.c +2311 -0
  327. data/vendor/zstd/lib/decompress/zstd_decompress_block.h +73 -0
  328. data/vendor/zstd/lib/decompress/zstd_decompress_block.o +0 -0
  329. data/vendor/zstd/lib/decompress/zstd_decompress_internal.h +240 -0
  330. data/vendor/zstd/lib/deprecated/zbuff.h +214 -0
  331. data/vendor/zstd/lib/deprecated/zbuff_common.c +26 -0
  332. data/vendor/zstd/lib/deprecated/zbuff_compress.c +167 -0
  333. data/vendor/zstd/lib/deprecated/zbuff_decompress.c +77 -0
  334. data/vendor/zstd/lib/dictBuilder/cover.c +1333 -0
  335. data/vendor/zstd/lib/dictBuilder/cover.h +152 -0
  336. data/vendor/zstd/lib/dictBuilder/divsufsort.c +1913 -0
  337. data/vendor/zstd/lib/dictBuilder/divsufsort.h +57 -0
  338. data/vendor/zstd/lib/dictBuilder/fastcover.c +765 -0
  339. data/vendor/zstd/lib/dictBuilder/zdict.c +1137 -0
  340. data/vendor/zstd/lib/dll/example/Makefile +48 -0
  341. data/vendor/zstd/lib/dll/example/README.md +63 -0
  342. data/vendor/zstd/lib/dll/example/build_package.bat +55 -0
  343. data/vendor/zstd/lib/dll/example/fullbench-dll.sln +25 -0
  344. data/vendor/zstd/lib/dll/example/fullbench-dll.vcxproj +181 -0
  345. data/vendor/zstd/lib/install_oses.mk +17 -0
  346. data/vendor/zstd/lib/legacy/zstd_legacy.h +452 -0
  347. data/vendor/zstd/lib/legacy/zstd_v01.c +2128 -0
  348. data/vendor/zstd/lib/legacy/zstd_v01.h +94 -0
  349. data/vendor/zstd/lib/legacy/zstd_v02.c +3465 -0
  350. data/vendor/zstd/lib/legacy/zstd_v02.h +93 -0
  351. data/vendor/zstd/lib/legacy/zstd_v03.c +3105 -0
  352. data/vendor/zstd/lib/legacy/zstd_v03.h +93 -0
  353. data/vendor/zstd/lib/legacy/zstd_v04.c +3598 -0
  354. data/vendor/zstd/lib/legacy/zstd_v04.h +142 -0
  355. data/vendor/zstd/lib/legacy/zstd_v05.c +4005 -0
  356. data/vendor/zstd/lib/legacy/zstd_v05.h +162 -0
  357. data/vendor/zstd/lib/legacy/zstd_v06.c +4110 -0
  358. data/vendor/zstd/lib/legacy/zstd_v06.h +172 -0
  359. data/vendor/zstd/lib/legacy/zstd_v07.c +4490 -0
  360. data/vendor/zstd/lib/legacy/zstd_v07.h +187 -0
  361. data/vendor/zstd/lib/libzstd.mk +238 -0
  362. data/vendor/zstd/lib/libzstd.pc.in +17 -0
  363. data/vendor/zstd/lib/module.modulemap +35 -0
  364. data/vendor/zstd/lib/zdict.h +481 -0
  365. data/vendor/zstd/lib/zstd.h +3209 -0
  366. data/vendor/zstd/lib/zstd_errors.h +107 -0
  367. data/vendor/zstd/programs/BUCK +44 -0
  368. data/vendor/zstd/programs/Makefile +445 -0
  369. data/vendor/zstd/programs/README.md +344 -0
  370. data/vendor/zstd/programs/benchfn.c +256 -0
  371. data/vendor/zstd/programs/benchfn.h +173 -0
  372. data/vendor/zstd/programs/benchzstd.c +1270 -0
  373. data/vendor/zstd/programs/benchzstd.h +191 -0
  374. data/vendor/zstd/programs/datagen.c +186 -0
  375. data/vendor/zstd/programs/datagen.h +38 -0
  376. data/vendor/zstd/programs/dibio.c +447 -0
  377. data/vendor/zstd/programs/dibio.h +39 -0
  378. data/vendor/zstd/programs/fileio.c +3717 -0
  379. data/vendor/zstd/programs/fileio.h +171 -0
  380. data/vendor/zstd/programs/fileio_asyncio.c +663 -0
  381. data/vendor/zstd/programs/fileio_asyncio.h +195 -0
  382. data/vendor/zstd/programs/fileio_common.h +121 -0
  383. data/vendor/zstd/programs/fileio_types.h +86 -0
  384. data/vendor/zstd/programs/lorem.c +285 -0
  385. data/vendor/zstd/programs/lorem.h +32 -0
  386. data/vendor/zstd/programs/platform.h +217 -0
  387. data/vendor/zstd/programs/timefn.c +170 -0
  388. data/vendor/zstd/programs/timefn.h +59 -0
  389. data/vendor/zstd/programs/util.c +1731 -0
  390. data/vendor/zstd/programs/util.h +364 -0
  391. data/vendor/zstd/programs/windres/verrsrc.h +17 -0
  392. data/vendor/zstd/programs/windres/zstd.rc +51 -0
  393. data/vendor/zstd/programs/windres/zstd32.res +0 -0
  394. data/vendor/zstd/programs/windres/zstd64.res +0 -0
  395. data/vendor/zstd/programs/zstd.1 +580 -0
  396. data/vendor/zstd/programs/zstd.1.md +714 -0
  397. data/vendor/zstd/programs/zstdcli.c +1675 -0
  398. data/vendor/zstd/programs/zstdcli_trace.c +173 -0
  399. data/vendor/zstd/programs/zstdcli_trace.h +24 -0
  400. data/vendor/zstd/programs/zstdgrep +134 -0
  401. data/vendor/zstd/programs/zstdgrep.1 +26 -0
  402. data/vendor/zstd/programs/zstdgrep.1.md +30 -0
  403. data/vendor/zstd/programs/zstdless +8 -0
  404. data/vendor/zstd/programs/zstdless.1 +14 -0
  405. data/vendor/zstd/programs/zstdless.1.md +16 -0
  406. data/vendor/zstd/tests/DEPRECATED-test-zstd-speed.py +378 -0
  407. data/vendor/zstd/tests/Makefile +485 -0
  408. data/vendor/zstd/tests/README.md +184 -0
  409. data/vendor/zstd/tests/automated_benchmarking.py +326 -0
  410. data/vendor/zstd/tests/checkTag.c +65 -0
  411. data/vendor/zstd/tests/check_size.py +31 -0
  412. data/vendor/zstd/tests/cli-tests/README.md +258 -0
  413. data/vendor/zstd/tests/cli-tests/basic/args.sh +10 -0
  414. data/vendor/zstd/tests/cli-tests/basic/args.sh.exit +1 -0
  415. data/vendor/zstd/tests/cli-tests/basic/args.sh.stderr.glob +28 -0
  416. data/vendor/zstd/tests/cli-tests/basic/help.sh +10 -0
  417. data/vendor/zstd/tests/cli-tests/basic/help.sh.stdout.glob +34 -0
  418. data/vendor/zstd/tests/cli-tests/basic/memlimit.sh +40 -0
  419. data/vendor/zstd/tests/cli-tests/basic/memlimit.sh.stderr.exact +13 -0
  420. data/vendor/zstd/tests/cli-tests/basic/memlimit.sh.stdout.exact +13 -0
  421. data/vendor/zstd/tests/cli-tests/basic/output_dir.sh +7 -0
  422. data/vendor/zstd/tests/cli-tests/basic/output_dir.sh.stderr.exact +2 -0
  423. data/vendor/zstd/tests/cli-tests/basic/output_dir.sh.stdout.exact +2 -0
  424. data/vendor/zstd/tests/cli-tests/basic/version.sh +6 -0
  425. data/vendor/zstd/tests/cli-tests/basic/version.sh.stdout.glob +2 -0
  426. data/vendor/zstd/tests/cli-tests/bin/cmp_size +44 -0
  427. data/vendor/zstd/tests/cli-tests/bin/datagen +3 -0
  428. data/vendor/zstd/tests/cli-tests/bin/die +4 -0
  429. data/vendor/zstd/tests/cli-tests/bin/println +2 -0
  430. data/vendor/zstd/tests/cli-tests/bin/unzstd +1 -0
  431. data/vendor/zstd/tests/cli-tests/bin/zstd +9 -0
  432. data/vendor/zstd/tests/cli-tests/bin/zstdcat +1 -0
  433. data/vendor/zstd/tests/cli-tests/bin/zstdgrep +2 -0
  434. data/vendor/zstd/tests/cli-tests/bin/zstdless +2 -0
  435. data/vendor/zstd/tests/cli-tests/cltools/setup +6 -0
  436. data/vendor/zstd/tests/cli-tests/cltools/zstdgrep.sh +8 -0
  437. data/vendor/zstd/tests/cli-tests/cltools/zstdgrep.sh.exit +1 -0
  438. data/vendor/zstd/tests/cli-tests/cltools/zstdgrep.sh.stderr.exact +1 -0
  439. data/vendor/zstd/tests/cli-tests/cltools/zstdgrep.sh.stdout.glob +4 -0
  440. data/vendor/zstd/tests/cli-tests/cltools/zstdless.sh +10 -0
  441. data/vendor/zstd/tests/cli-tests/cltools/zstdless.sh.stderr.exact +2 -0
  442. data/vendor/zstd/tests/cli-tests/cltools/zstdless.sh.stdout.glob +5 -0
  443. data/vendor/zstd/tests/cli-tests/common/format.sh +19 -0
  444. data/vendor/zstd/tests/cli-tests/common/mtime.sh +13 -0
  445. data/vendor/zstd/tests/cli-tests/common/permissions.sh +18 -0
  446. data/vendor/zstd/tests/cli-tests/common/platform.sh +47 -0
  447. data/vendor/zstd/tests/cli-tests/compression/adapt.sh +14 -0
  448. data/vendor/zstd/tests/cli-tests/compression/basic.sh +36 -0
  449. data/vendor/zstd/tests/cli-tests/compression/compress-literals.sh +10 -0
  450. data/vendor/zstd/tests/cli-tests/compression/format.sh +16 -0
  451. data/vendor/zstd/tests/cli-tests/compression/golden.sh +16 -0
  452. data/vendor/zstd/tests/cli-tests/compression/gzip-compat.sh +17 -0
  453. data/vendor/zstd/tests/cli-tests/compression/levels.sh +75 -0
  454. data/vendor/zstd/tests/cli-tests/compression/levels.sh.stderr.exact +80 -0
  455. data/vendor/zstd/tests/cli-tests/compression/long-distance-matcher.sh +7 -0
  456. data/vendor/zstd/tests/cli-tests/compression/multi-threaded.sh +22 -0
  457. data/vendor/zstd/tests/cli-tests/compression/multi-threaded.sh.stderr.exact +21 -0
  458. data/vendor/zstd/tests/cli-tests/compression/multiple-files.sh +21 -0
  459. data/vendor/zstd/tests/cli-tests/compression/multiple-files.sh.stdout.exact +12 -0
  460. data/vendor/zstd/tests/cli-tests/compression/row-match-finder.sh +7 -0
  461. data/vendor/zstd/tests/cli-tests/compression/setup +7 -0
  462. data/vendor/zstd/tests/cli-tests/compression/stream-size.sh +7 -0
  463. data/vendor/zstd/tests/cli-tests/compression/verbose-wlog.sh +11 -0
  464. data/vendor/zstd/tests/cli-tests/compression/verbose-wlog.sh.stderr.glob +5 -0
  465. data/vendor/zstd/tests/cli-tests/compression/verbose-wlog.sh.stdout.glob +5 -0
  466. data/vendor/zstd/tests/cli-tests/compression/window-resize.sh +9 -0
  467. data/vendor/zstd/tests/cli-tests/compression/window-resize.sh.stderr.ignore +0 -0
  468. data/vendor/zstd/tests/cli-tests/compression/window-resize.sh.stdout.glob +3 -0
  469. data/vendor/zstd/tests/cli-tests/decompression/detectErrors.sh +11 -0
  470. data/vendor/zstd/tests/cli-tests/decompression/golden.sh +7 -0
  471. data/vendor/zstd/tests/cli-tests/decompression/pass-through.sh +57 -0
  472. data/vendor/zstd/tests/cli-tests/decompression/pass-through.sh.stderr.exact +11 -0
  473. data/vendor/zstd/tests/cli-tests/decompression/pass-through.sh.stdout.exact +25 -0
  474. data/vendor/zstd/tests/cli-tests/determinism/basic.sh +36 -0
  475. data/vendor/zstd/tests/cli-tests/determinism/basic.sh.stderr.exact +0 -0
  476. data/vendor/zstd/tests/cli-tests/determinism/basic.sh.stdout.exact +880 -0
  477. data/vendor/zstd/tests/cli-tests/determinism/multithread.sh +45 -0
  478. data/vendor/zstd/tests/cli-tests/determinism/multithread.sh.stderr.exact +0 -0
  479. data/vendor/zstd/tests/cli-tests/determinism/multithread.sh.stdout.exact +260 -0
  480. data/vendor/zstd/tests/cli-tests/determinism/reuse.sh +44 -0
  481. data/vendor/zstd/tests/cli-tests/determinism/reuse.sh.stderr.exact +0 -0
  482. data/vendor/zstd/tests/cli-tests/determinism/reuse.sh.stdout.exact +19 -0
  483. data/vendor/zstd/tests/cli-tests/determinism/setup +5 -0
  484. data/vendor/zstd/tests/cli-tests/determinism/setup_once +30 -0
  485. data/vendor/zstd/tests/cli-tests/dict-builder/empty-input.sh +9 -0
  486. data/vendor/zstd/tests/cli-tests/dict-builder/empty-input.sh.stderr.exact +1 -0
  487. data/vendor/zstd/tests/cli-tests/dict-builder/no-inputs.sh +3 -0
  488. data/vendor/zstd/tests/cli-tests/dict-builder/no-inputs.sh.exit +1 -0
  489. data/vendor/zstd/tests/cli-tests/dict-builder/no-inputs.sh.stderr.exact +5 -0
  490. data/vendor/zstd/tests/cli-tests/dictionaries/dictionary-mismatch.sh +29 -0
  491. data/vendor/zstd/tests/cli-tests/dictionaries/dictionary-mismatch.sh.stderr.exact +7 -0
  492. data/vendor/zstd/tests/cli-tests/dictionaries/golden.sh +9 -0
  493. data/vendor/zstd/tests/cli-tests/dictionaries/setup +6 -0
  494. data/vendor/zstd/tests/cli-tests/dictionaries/setup_once +24 -0
  495. data/vendor/zstd/tests/cli-tests/file-handling/directory-mirror.sh +49 -0
  496. data/vendor/zstd/tests/cli-tests/file-handling/directory-mirror.sh.stderr.exact +0 -0
  497. data/vendor/zstd/tests/cli-tests/file-handling/directory-mirror.sh.stdout.exact +0 -0
  498. data/vendor/zstd/tests/cli-tests/file-stat/compress-file-to-dir-without-write-perm.sh +12 -0
  499. data/vendor/zstd/tests/cli-tests/file-stat/compress-file-to-dir-without-write-perm.sh.stderr.exact +30 -0
  500. data/vendor/zstd/tests/cli-tests/file-stat/compress-file-to-file.sh +9 -0
  501. data/vendor/zstd/tests/cli-tests/file-stat/compress-file-to-file.sh.stderr.glob +46 -0
  502. data/vendor/zstd/tests/cli-tests/file-stat/compress-file-to-stdout.sh +8 -0
  503. data/vendor/zstd/tests/cli-tests/file-stat/compress-file-to-stdout.sh.stderr.exact +24 -0
  504. data/vendor/zstd/tests/cli-tests/file-stat/compress-stdin-to-file.sh +8 -0
  505. data/vendor/zstd/tests/cli-tests/file-stat/compress-stdin-to-file.sh.stderr.glob +28 -0
  506. data/vendor/zstd/tests/cli-tests/file-stat/compress-stdin-to-stdout.sh +8 -0
  507. data/vendor/zstd/tests/cli-tests/file-stat/compress-stdin-to-stdout.sh.stderr.exact +18 -0
  508. data/vendor/zstd/tests/cli-tests/file-stat/decompress-file-to-file.sh +8 -0
  509. data/vendor/zstd/tests/cli-tests/file-stat/decompress-file-to-file.sh.stderr.glob +42 -0
  510. data/vendor/zstd/tests/cli-tests/file-stat/decompress-file-to-stdout.sh +7 -0
  511. data/vendor/zstd/tests/cli-tests/file-stat/decompress-file-to-stdout.sh.stderr.exact +18 -0
  512. data/vendor/zstd/tests/cli-tests/file-stat/decompress-stdin-to-file.sh +7 -0
  513. data/vendor/zstd/tests/cli-tests/file-stat/decompress-stdin-to-file.sh.stderr.glob +24 -0
  514. data/vendor/zstd/tests/cli-tests/file-stat/decompress-stdin-to-stdout.sh +7 -0
  515. data/vendor/zstd/tests/cli-tests/file-stat/decompress-stdin-to-stdout.sh.stderr.exact +14 -0
  516. data/vendor/zstd/tests/cli-tests/progress/no-progress.sh +46 -0
  517. data/vendor/zstd/tests/cli-tests/progress/no-progress.sh.stderr.glob +96 -0
  518. data/vendor/zstd/tests/cli-tests/progress/progress.sh +41 -0
  519. data/vendor/zstd/tests/cli-tests/progress/progress.sh.stderr.glob +62 -0
  520. data/vendor/zstd/tests/cli-tests/run.py +732 -0
  521. data/vendor/zstd/tests/cli-tests/zstd-symlinks/setup +6 -0
  522. data/vendor/zstd/tests/cli-tests/zstd-symlinks/zstdcat.sh +12 -0
  523. data/vendor/zstd/tests/cli-tests/zstd-symlinks/zstdcat.sh.stdout.exact +8 -0
  524. data/vendor/zstd/tests/datagencli.c +149 -0
  525. data/vendor/zstd/tests/decodecorpus.c +1998 -0
  526. data/vendor/zstd/tests/dict-files/zero-weight-dict +0 -0
  527. data/vendor/zstd/tests/external_matchfinder.c +140 -0
  528. data/vendor/zstd/tests/external_matchfinder.h +39 -0
  529. data/vendor/zstd/tests/fullbench.c +1210 -0
  530. data/vendor/zstd/tests/fuzz/Makefile +278 -0
  531. data/vendor/zstd/tests/fuzz/README.md +161 -0
  532. data/vendor/zstd/tests/fuzz/block_decompress.c +53 -0
  533. data/vendor/zstd/tests/fuzz/block_round_trip.c +103 -0
  534. data/vendor/zstd/tests/fuzz/decompress_cross_format.c +130 -0
  535. data/vendor/zstd/tests/fuzz/decompress_dstSize_tooSmall.c +74 -0
  536. data/vendor/zstd/tests/fuzz/dictionary_decompress.c +77 -0
  537. data/vendor/zstd/tests/fuzz/dictionary_loader.c +106 -0
  538. data/vendor/zstd/tests/fuzz/dictionary_round_trip.c +155 -0
  539. data/vendor/zstd/tests/fuzz/dictionary_stream_round_trip.c +209 -0
  540. data/vendor/zstd/tests/fuzz/fse_read_ncount.c +100 -0
  541. data/vendor/zstd/tests/fuzz/fuzz.h +57 -0
  542. data/vendor/zstd/tests/fuzz/fuzz.py +910 -0
  543. data/vendor/zstd/tests/fuzz/fuzz_data_producer.c +95 -0
  544. data/vendor/zstd/tests/fuzz/fuzz_data_producer.h +66 -0
  545. data/vendor/zstd/tests/fuzz/fuzz_helpers.c +47 -0
  546. data/vendor/zstd/tests/fuzz/fuzz_helpers.h +82 -0
  547. data/vendor/zstd/tests/fuzz/fuzz_third_party_seq_prod.h +116 -0
  548. data/vendor/zstd/tests/fuzz/generate_sequences.c +88 -0
  549. data/vendor/zstd/tests/fuzz/huf_decompress.c +68 -0
  550. data/vendor/zstd/tests/fuzz/huf_round_trip.c +137 -0
  551. data/vendor/zstd/tests/fuzz/raw_dictionary_round_trip.c +119 -0
  552. data/vendor/zstd/tests/fuzz/regression_driver.c +90 -0
  553. data/vendor/zstd/tests/fuzz/seekable_roundtrip.c +88 -0
  554. data/vendor/zstd/tests/fuzz/seq_prod_fuzz_example/Makefile +16 -0
  555. data/vendor/zstd/tests/fuzz/seq_prod_fuzz_example/README.md +12 -0
  556. data/vendor/zstd/tests/fuzz/seq_prod_fuzz_example/example_seq_prod.c +52 -0
  557. data/vendor/zstd/tests/fuzz/sequence_compression_api.c +452 -0
  558. data/vendor/zstd/tests/fuzz/simple_compress.c +60 -0
  559. data/vendor/zstd/tests/fuzz/simple_decompress.c +59 -0
  560. data/vendor/zstd/tests/fuzz/simple_round_trip.c +182 -0
  561. data/vendor/zstd/tests/fuzz/stream_decompress.c +119 -0
  562. data/vendor/zstd/tests/fuzz/stream_round_trip.c +218 -0
  563. data/vendor/zstd/tests/fuzz/zstd_frame_info.c +43 -0
  564. data/vendor/zstd/tests/fuzz/zstd_helpers.c +208 -0
  565. data/vendor/zstd/tests/fuzz/zstd_helpers.h +56 -0
  566. data/vendor/zstd/tests/fuzzer.c +5482 -0
  567. data/vendor/zstd/tests/golden-compression/PR-3517-block-splitter-corruption-test +1 -0
  568. data/vendor/zstd/tests/golden-compression/http +1 -0
  569. data/vendor/zstd/tests/golden-compression/huffman-compressed-larger +0 -0
  570. data/vendor/zstd/tests/golden-compression/large-literal-and-match-lengths +0 -0
  571. data/vendor/zstd/tests/golden-decompression/block-128k.zst +0 -0
  572. data/vendor/zstd/tests/golden-decompression/empty-block.zst +0 -0
  573. data/vendor/zstd/tests/golden-decompression/rle-first-block.zst +0 -0
  574. data/vendor/zstd/tests/golden-decompression/zeroSeq_2B.zst +0 -0
  575. data/vendor/zstd/tests/golden-decompression-errors/off0.bin.zst +0 -0
  576. data/vendor/zstd/tests/golden-decompression-errors/truncated_huff_state.zst +0 -0
  577. data/vendor/zstd/tests/golden-decompression-errors/zeroSeq_extraneous.zst +0 -0
  578. data/vendor/zstd/tests/golden-dictionaries/http-dict-missing-symbols +0 -0
  579. data/vendor/zstd/tests/gzip/Makefile +45 -0
  580. data/vendor/zstd/tests/gzip/gzip-env.sh +46 -0
  581. data/vendor/zstd/tests/gzip/helin-segv.sh +31 -0
  582. data/vendor/zstd/tests/gzip/help-version.sh +270 -0
  583. data/vendor/zstd/tests/gzip/hufts-segv.gz +0 -0
  584. data/vendor/zstd/tests/gzip/hufts.sh +34 -0
  585. data/vendor/zstd/tests/gzip/init.cfg +5 -0
  586. data/vendor/zstd/tests/gzip/init.sh +616 -0
  587. data/vendor/zstd/tests/gzip/keep.sh +51 -0
  588. data/vendor/zstd/tests/gzip/list.sh +31 -0
  589. data/vendor/zstd/tests/gzip/memcpy-abuse.sh +34 -0
  590. data/vendor/zstd/tests/gzip/mixed.sh +68 -0
  591. data/vendor/zstd/tests/gzip/null-suffix-clobber.sh +35 -0
  592. data/vendor/zstd/tests/gzip/stdin.sh +31 -0
  593. data/vendor/zstd/tests/gzip/test-driver.sh +150 -0
  594. data/vendor/zstd/tests/gzip/trailing-nul.sh +37 -0
  595. data/vendor/zstd/tests/gzip/unpack-invalid.sh +36 -0
  596. data/vendor/zstd/tests/gzip/z-suffix.sh +30 -0
  597. data/vendor/zstd/tests/gzip/zdiff.sh +48 -0
  598. data/vendor/zstd/tests/gzip/zgrep-context.sh +47 -0
  599. data/vendor/zstd/tests/gzip/zgrep-f.sh +43 -0
  600. data/vendor/zstd/tests/gzip/zgrep-signal.sh +64 -0
  601. data/vendor/zstd/tests/gzip/znew-k.sh +40 -0
  602. data/vendor/zstd/tests/invalidDictionaries.c +61 -0
  603. data/vendor/zstd/tests/largeDictionary.c +131 -0
  604. data/vendor/zstd/tests/legacy.c +262 -0
  605. data/vendor/zstd/tests/libzstd_builds.sh +104 -0
  606. data/vendor/zstd/tests/longmatch.c +123 -0
  607. data/vendor/zstd/tests/loremOut.c +50 -0
  608. data/vendor/zstd/tests/loremOut.h +15 -0
  609. data/vendor/zstd/tests/paramgrill.c +2965 -0
  610. data/vendor/zstd/tests/playTests.sh +1926 -0
  611. data/vendor/zstd/tests/poolTests.c +271 -0
  612. data/vendor/zstd/tests/rateLimiter.py +41 -0
  613. data/vendor/zstd/tests/regression/Makefile +60 -0
  614. data/vendor/zstd/tests/regression/README.md +28 -0
  615. data/vendor/zstd/tests/regression/config.c +404 -0
  616. data/vendor/zstd/tests/regression/config.h +91 -0
  617. data/vendor/zstd/tests/regression/data.c +631 -0
  618. data/vendor/zstd/tests/regression/data.h +121 -0
  619. data/vendor/zstd/tests/regression/levels.h +59 -0
  620. data/vendor/zstd/tests/regression/method.c +701 -0
  621. data/vendor/zstd/tests/regression/method.h +65 -0
  622. data/vendor/zstd/tests/regression/result.c +30 -0
  623. data/vendor/zstd/tests/regression/result.h +103 -0
  624. data/vendor/zstd/tests/regression/results.csv +1480 -0
  625. data/vendor/zstd/tests/regression/test.c +362 -0
  626. data/vendor/zstd/tests/roundTripCrash.c +241 -0
  627. data/vendor/zstd/tests/seqgen.c +260 -0
  628. data/vendor/zstd/tests/seqgen.h +58 -0
  629. data/vendor/zstd/tests/test-license.py +156 -0
  630. data/vendor/zstd/tests/test-variants.sh +115 -0
  631. data/vendor/zstd/tests/test-zstd-versions.py +308 -0
  632. data/vendor/zstd/tests/test_process_substitution.bash +92 -0
  633. data/vendor/zstd/tests/zstreamtest.c +3467 -0
  634. data/vendor/zstd/zlibWrapper/BUCK +22 -0
  635. data/vendor/zstd/zlibWrapper/Makefile +120 -0
  636. data/vendor/zstd/zlibWrapper/README.md +163 -0
  637. data/vendor/zstd/zlibWrapper/examples/example.c +598 -0
  638. data/vendor/zstd/zlibWrapper/examples/example_original.c +599 -0
  639. data/vendor/zstd/zlibWrapper/examples/fitblk.c +254 -0
  640. data/vendor/zstd/zlibWrapper/examples/fitblk_original.c +233 -0
  641. data/vendor/zstd/zlibWrapper/examples/minigzip.c +605 -0
  642. data/vendor/zstd/zlibWrapper/examples/zwrapbench.c +1018 -0
  643. data/vendor/zstd/zlibWrapper/gzclose.c +26 -0
  644. data/vendor/zstd/zlibWrapper/gzcompatibility.h +68 -0
  645. data/vendor/zstd/zlibWrapper/gzguts.h +229 -0
  646. data/vendor/zstd/zlibWrapper/gzlib.c +587 -0
  647. data/vendor/zstd/zlibWrapper/gzread.c +637 -0
  648. data/vendor/zstd/zlibWrapper/gzwrite.c +632 -0
  649. data/vendor/zstd/zlibWrapper/zstd_zlibwrapper.c +1200 -0
  650. data/vendor/zstd/zlibWrapper/zstd_zlibwrapper.h +91 -0
  651. metadata +738 -0
@@ -0,0 +1,1087 @@
1
+ /*
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ * All rights reserved.
4
+ *
5
+ * This source code is licensed under both the BSD-style license (found in the
6
+ * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7
+ * in the COPYING file in the root directory of this source tree).
8
+ * You may select, at your option, one of the above-listed licenses.
9
+ */
10
+
11
+ /* largeNbDicts
12
+ * This is a benchmark test tool
13
+ * dedicated to the specific case of dictionary decompression
14
+ * using a very large nb of dictionaries
15
+ * thus suffering latency from lots of cache misses.
16
+ * It's created in a bid to investigate performance and find optimizations. */
17
+
18
+
19
+ /*--- Dependencies ---*/
20
+
21
+ #include <stddef.h> /* size_t */
22
+ #include <stdlib.h> /* malloc, free, abort, qsort*/
23
+ #include <stdio.h> /* fprintf */
24
+ #include <limits.h> /* UINT_MAX */
25
+ #include <assert.h> /* assert */
26
+
27
+ #include "util.h"
28
+ #include "benchfn.h"
29
+ #define ZSTD_STATIC_LINKING_ONLY
30
+ #include "zstd.h"
31
+ #include "zdict.h"
32
+
33
+
34
+ /*--- Constants --- */
35
+
36
+ #define KB *(1<<10)
37
+ #define MB *(1<<20)
38
+
39
+ #define BLOCKSIZE_DEFAULT 0 /* no slicing into blocks */
40
+ #define DICTSIZE (4 KB)
41
+ #define CLEVEL_DEFAULT 3
42
+ #define DICT_LOAD_METHOD ZSTD_dlm_byCopy
43
+
44
+ #define BENCH_TIME_DEFAULT_S 6
45
+ #define RUN_TIME_DEFAULT_MS 1000
46
+ #define BENCH_TIME_DEFAULT_MS (BENCH_TIME_DEFAULT_S * RUN_TIME_DEFAULT_MS)
47
+
48
+ #define DISPLAY_LEVEL_DEFAULT 3
49
+
50
+ #define BENCH_SIZE_MAX (1200 MB)
51
+
52
+
53
+ /*--- Macros ---*/
54
+
55
+ #define CONTROL(c) { if (!(c)) abort(); }
56
+ #undef MIN
57
+ #define MIN(a,b) ((a) < (b) ? (a) : (b))
58
+
59
+
60
+ /*--- Display Macros ---*/
61
+
62
+ #define DISPLAY(...) fprintf(stdout, __VA_ARGS__)
63
+ #define DISPLAYLEVEL(l, ...) { if (g_displayLevel>=l) { DISPLAY(__VA_ARGS__); } }
64
+ static int g_displayLevel = DISPLAY_LEVEL_DEFAULT; /* 0 : no display, 1: errors, 2 : + result + interaction + warnings, 3 : + progression, 4 : + information */
65
+
66
+
67
+ /*--- buffer_t ---*/
68
+
69
+ typedef struct {
70
+ void* ptr;
71
+ size_t size;
72
+ size_t capacity;
73
+ } buffer_t;
74
+
75
+ static const buffer_t kBuffNull = { NULL, 0, 0 };
76
+
77
+ /* @return : kBuffNull if any error */
78
+ static buffer_t createBuffer(size_t capacity)
79
+ {
80
+ assert(capacity > 0);
81
+ void* const ptr = malloc(capacity);
82
+ if (ptr==NULL) return kBuffNull;
83
+
84
+ buffer_t buffer;
85
+ buffer.ptr = ptr;
86
+ buffer.capacity = capacity;
87
+ buffer.size = 0;
88
+ return buffer;
89
+ }
90
+
91
+ static void freeBuffer(buffer_t buff)
92
+ {
93
+ free(buff.ptr);
94
+ }
95
+
96
+
97
+ static void fillBuffer_fromHandle(buffer_t* buff, FILE* f)
98
+ {
99
+ size_t const readSize = fread(buff->ptr, 1, buff->capacity, f);
100
+ buff->size = readSize;
101
+ }
102
+
103
+
104
+ /* @return : kBuffNull if any error */
105
+ static buffer_t createBuffer_fromFile(const char* fileName)
106
+ {
107
+ U64 const fileSize = UTIL_getFileSize(fileName);
108
+ size_t const bufferSize = (size_t) fileSize;
109
+
110
+ if (fileSize == UTIL_FILESIZE_UNKNOWN) return kBuffNull;
111
+ assert((U64)bufferSize == fileSize); /* check overflow */
112
+
113
+ { FILE* const f = fopen(fileName, "rb");
114
+ if (f == NULL) return kBuffNull;
115
+
116
+ buffer_t buff = createBuffer(bufferSize);
117
+ CONTROL(buff.ptr != NULL);
118
+
119
+ fillBuffer_fromHandle(&buff, f);
120
+ CONTROL(buff.size == buff.capacity);
121
+
122
+ fclose(f); /* do nothing specific if fclose() fails */
123
+ return buff;
124
+ }
125
+ }
126
+
127
+
128
+ /* @return : kBuffNull if any error */
129
+ static buffer_t
130
+ createDictionaryBuffer(const char* dictionaryName,
131
+ const void* srcBuffer,
132
+ const size_t* srcBlockSizes, size_t nbBlocks,
133
+ size_t requestedDictSize)
134
+ {
135
+ if (dictionaryName) {
136
+ DISPLAYLEVEL(3, "loading dictionary %s \n", dictionaryName);
137
+ return createBuffer_fromFile(dictionaryName); /* note : result might be kBuffNull */
138
+
139
+ } else {
140
+
141
+ DISPLAYLEVEL(3, "creating dictionary, of target size %u bytes \n",
142
+ (unsigned)requestedDictSize);
143
+ void* const dictBuffer = malloc(requestedDictSize);
144
+ CONTROL(dictBuffer != NULL);
145
+
146
+ assert(nbBlocks <= UINT_MAX);
147
+ size_t const dictSize = ZDICT_trainFromBuffer(dictBuffer, requestedDictSize,
148
+ srcBuffer,
149
+ srcBlockSizes, (unsigned)nbBlocks);
150
+ CONTROL(!ZSTD_isError(dictSize));
151
+
152
+ buffer_t result;
153
+ result.ptr = dictBuffer;
154
+ result.capacity = requestedDictSize;
155
+ result.size = dictSize;
156
+ return result;
157
+ }
158
+ }
159
+
160
+ /*! BMK_loadFiles() :
161
+ * Loads `buffer`, with content from files listed within `fileNamesTable`.
162
+ * Fills `buffer` entirely.
163
+ * @return : 0 on success, !=0 on error */
164
+ static int loadFiles(void* buffer, size_t bufferSize,
165
+ size_t* fileSizes,
166
+ const char* const * fileNamesTable, unsigned nbFiles)
167
+ {
168
+ size_t pos = 0, totalSize = 0;
169
+
170
+ for (unsigned n=0; n<nbFiles; n++) {
171
+ U64 fileSize = UTIL_getFileSize(fileNamesTable[n]);
172
+ if (UTIL_isDirectory(fileNamesTable[n])) {
173
+ fileSizes[n] = 0;
174
+ continue;
175
+ }
176
+ if (fileSize == UTIL_FILESIZE_UNKNOWN) {
177
+ fileSizes[n] = 0;
178
+ continue;
179
+ }
180
+
181
+ FILE* const f = fopen(fileNamesTable[n], "rb");
182
+ assert(f!=NULL);
183
+
184
+ assert(pos <= bufferSize);
185
+ assert(fileSize <= bufferSize - pos);
186
+
187
+ { size_t const readSize = fread(((char*)buffer)+pos, 1, (size_t)fileSize, f);
188
+ assert(readSize == fileSize);
189
+ pos += readSize;
190
+ }
191
+ fileSizes[n] = (size_t)fileSize;
192
+ totalSize += (size_t)fileSize;
193
+ fclose(f);
194
+ }
195
+
196
+ assert(totalSize == bufferSize);
197
+ return 0;
198
+ }
199
+
200
+
201
+
202
+ /*--- slice_collection_t ---*/
203
+
204
+ typedef struct {
205
+ void** slicePtrs;
206
+ size_t* capacities;
207
+ size_t nbSlices;
208
+ } slice_collection_t;
209
+
210
+ static const slice_collection_t kNullCollection = { NULL, NULL, 0 };
211
+
212
+ static void freeSliceCollection(slice_collection_t collection)
213
+ {
214
+ free(collection.slicePtrs);
215
+ free(collection.capacities);
216
+ }
217
+
218
+ /* shrinkSizes() :
219
+ * downsizes sizes of slices within collection, according to `newSizes`.
220
+ * every `newSizes` entry must be <= than its corresponding collection size */
221
+ void shrinkSizes(slice_collection_t collection,
222
+ const size_t* newSizes) /* presumed same size as collection */
223
+ {
224
+ size_t const nbSlices = collection.nbSlices;
225
+ for (size_t blockNb = 0; blockNb < nbSlices; blockNb++) {
226
+ assert(newSizes[blockNb] <= collection.capacities[blockNb]);
227
+ collection.capacities[blockNb] = newSizes[blockNb];
228
+ }
229
+ }
230
+
231
+
232
+ /* splitSlices() :
233
+ * nbSlices : if == 0, nbSlices is automatically determined from srcSlices and blockSize.
234
+ * otherwise, creates exactly nbSlices slices,
235
+ * by either truncating input (when smaller)
236
+ * or repeating input from beginning */
237
+ static slice_collection_t
238
+ splitSlices(slice_collection_t srcSlices, size_t blockSize, size_t nbSlices)
239
+ {
240
+ if (blockSize==0) blockSize = (size_t)(-1); /* means "do not cut" */
241
+ size_t nbSrcBlocks = 0;
242
+ for (size_t ssnb=0; ssnb < srcSlices.nbSlices; ssnb++) {
243
+ size_t pos = 0;
244
+ while (pos <= srcSlices.capacities[ssnb]) {
245
+ nbSrcBlocks++;
246
+ pos += blockSize;
247
+ }
248
+ }
249
+
250
+ if (nbSlices == 0) nbSlices = nbSrcBlocks;
251
+
252
+ void** const sliceTable = (void**)malloc(nbSlices * sizeof(*sliceTable));
253
+ size_t* const capacities = (size_t*)malloc(nbSlices * sizeof(*capacities));
254
+ if (sliceTable == NULL || capacities == NULL) {
255
+ free(sliceTable);
256
+ free(capacities);
257
+ return kNullCollection;
258
+ }
259
+
260
+ size_t ssnb = 0;
261
+ for (size_t sliceNb=0; sliceNb < nbSlices; ) {
262
+ ssnb = (ssnb + 1) % srcSlices.nbSlices;
263
+ size_t pos = 0;
264
+ char* const ptr = (char*)srcSlices.slicePtrs[ssnb];
265
+ while (pos < srcSlices.capacities[ssnb] && sliceNb < nbSlices) {
266
+ size_t const size = MIN(blockSize, srcSlices.capacities[ssnb] - pos);
267
+ sliceTable[sliceNb] = ptr + pos;
268
+ capacities[sliceNb] = size;
269
+ sliceNb++;
270
+ pos += blockSize;
271
+ }
272
+ }
273
+
274
+ slice_collection_t result;
275
+ result.nbSlices = nbSlices;
276
+ result.slicePtrs = sliceTable;
277
+ result.capacities = capacities;
278
+ return result;
279
+ }
280
+
281
+
282
+ static size_t sliceCollection_totalCapacity(slice_collection_t sc)
283
+ {
284
+ size_t totalSize = 0;
285
+ for (size_t n=0; n<sc.nbSlices; n++)
286
+ totalSize += sc.capacities[n];
287
+ return totalSize;
288
+ }
289
+
290
+
291
+ /* --- buffer collection --- */
292
+
293
+ typedef struct {
294
+ buffer_t buffer;
295
+ slice_collection_t slices;
296
+ } buffer_collection_t;
297
+
298
+
299
+ static void freeBufferCollection(buffer_collection_t bc)
300
+ {
301
+ freeBuffer(bc.buffer);
302
+ freeSliceCollection(bc.slices);
303
+ }
304
+
305
+
306
+ static buffer_collection_t
307
+ createBufferCollection_fromSliceCollectionSizes(slice_collection_t sc)
308
+ {
309
+ size_t const bufferSize = sliceCollection_totalCapacity(sc);
310
+
311
+ buffer_t buffer = createBuffer(bufferSize);
312
+ CONTROL(buffer.ptr != NULL);
313
+
314
+ size_t const nbSlices = sc.nbSlices;
315
+ void** const slices = (void**)malloc(nbSlices * sizeof(*slices));
316
+ CONTROL(slices != NULL);
317
+
318
+ size_t* const capacities = (size_t*)malloc(nbSlices * sizeof(*capacities));
319
+ CONTROL(capacities != NULL);
320
+
321
+ char* const ptr = (char*)buffer.ptr;
322
+ size_t pos = 0;
323
+ for (size_t n=0; n < nbSlices; n++) {
324
+ capacities[n] = sc.capacities[n];
325
+ slices[n] = ptr + pos;
326
+ pos += capacities[n];
327
+ }
328
+
329
+ buffer_collection_t result;
330
+ result.buffer = buffer;
331
+ result.slices.nbSlices = nbSlices;
332
+ result.slices.capacities = capacities;
333
+ result.slices.slicePtrs = slices;
334
+ return result;
335
+ }
336
+
337
+ static buffer_collection_t
338
+ createBufferCollection_fromSliceCollection(slice_collection_t sc)
339
+ {
340
+ size_t const bufferSize = sliceCollection_totalCapacity(sc);
341
+
342
+ buffer_t buffer = createBuffer(bufferSize);
343
+ CONTROL(buffer.ptr != NULL);
344
+
345
+ size_t const nbSlices = sc.nbSlices;
346
+ void** const slices = (void**)malloc(nbSlices * sizeof(*slices));
347
+ CONTROL(slices != NULL);
348
+
349
+ size_t* const capacities = (size_t*)malloc(nbSlices * sizeof(*capacities));
350
+ CONTROL(capacities != NULL);
351
+
352
+ char* const ptr = (char*)buffer.ptr;
353
+ size_t pos = 0;
354
+ for (size_t n=0; n < nbSlices; n++) {
355
+ capacities[n] = sc.capacities[n];
356
+ slices[n] = ptr + pos;
357
+ pos += capacities[n];
358
+ }
359
+
360
+ for (size_t i = 0; i < nbSlices; i++) {
361
+ memcpy(slices[i], sc.slicePtrs[i], sc.capacities[i]);
362
+ capacities[i] = sc.capacities[i];
363
+ }
364
+
365
+ buffer_collection_t result;
366
+ result.buffer = buffer;
367
+ result.slices.nbSlices = nbSlices;
368
+ result.slices.capacities = capacities;
369
+ result.slices.slicePtrs = slices;
370
+
371
+ return result;
372
+ }
373
+
374
+ /* @return : kBuffNull if any error */
375
+ static buffer_collection_t
376
+ createBufferCollection_fromFiles(const char* const * fileNamesTable, unsigned nbFiles)
377
+ {
378
+ U64 const totalSizeToLoad = UTIL_getTotalFileSize(fileNamesTable, nbFiles);
379
+ assert(totalSizeToLoad != UTIL_FILESIZE_UNKNOWN);
380
+ assert(totalSizeToLoad <= BENCH_SIZE_MAX);
381
+ size_t const loadedSize = (size_t)totalSizeToLoad;
382
+ assert(loadedSize > 0);
383
+ void* const srcBuffer = malloc(loadedSize);
384
+ assert(srcBuffer != NULL);
385
+
386
+ assert(nbFiles > 0);
387
+ size_t* const fileSizes = (size_t*)calloc(nbFiles, sizeof(*fileSizes));
388
+ assert(fileSizes != NULL);
389
+
390
+ /* Load input buffer */
391
+ int const errorCode = loadFiles(srcBuffer, loadedSize,
392
+ fileSizes,
393
+ fileNamesTable, nbFiles);
394
+ assert(errorCode == 0);
395
+
396
+ void** sliceTable = (void**)malloc(nbFiles * sizeof(*sliceTable));
397
+ assert(sliceTable != NULL);
398
+
399
+ char* const ptr = (char*)srcBuffer;
400
+ size_t pos = 0;
401
+ unsigned fileNb = 0;
402
+ for ( ; (pos < loadedSize) && (fileNb < nbFiles); fileNb++) {
403
+ sliceTable[fileNb] = ptr + pos;
404
+ pos += fileSizes[fileNb];
405
+ }
406
+ assert(pos == loadedSize);
407
+ assert(fileNb == nbFiles);
408
+
409
+
410
+ buffer_t buffer;
411
+ buffer.ptr = srcBuffer;
412
+ buffer.capacity = loadedSize;
413
+ buffer.size = loadedSize;
414
+
415
+ slice_collection_t slices;
416
+ slices.slicePtrs = sliceTable;
417
+ slices.capacities = fileSizes;
418
+ slices.nbSlices = nbFiles;
419
+
420
+ buffer_collection_t bc;
421
+ bc.buffer = buffer;
422
+ bc.slices = slices;
423
+ return bc;
424
+ }
425
+
426
+
427
+
428
+
429
+ /*--- ddict_collection_t ---*/
430
+
431
+ typedef struct {
432
+ ZSTD_DDict** ddicts;
433
+ size_t nbDDict;
434
+ } ddict_collection_t;
435
+
436
+ typedef struct {
437
+ ZSTD_CDict** cdicts;
438
+ size_t nbCDict;
439
+ } cdict_collection_t;
440
+
441
+ static const cdict_collection_t kNullCDictCollection = { NULL, 0 };
442
+
443
+ static void freeCDictCollection(cdict_collection_t cdictc)
444
+ {
445
+ for (size_t dictNb=0; dictNb < cdictc.nbCDict; dictNb++) {
446
+ ZSTD_freeCDict(cdictc.cdicts[dictNb]);
447
+ }
448
+ free(cdictc.cdicts);
449
+ }
450
+
451
+ /* returns .buffers=NULL if operation fails */
452
+ static cdict_collection_t createCDictCollection(const void* dictBuffer, size_t dictSize, size_t nbCDict, ZSTD_dictContentType_e dictContentType, ZSTD_CCtx_params* cctxParams)
453
+ {
454
+ ZSTD_CDict** const cdicts = malloc(nbCDict * sizeof(ZSTD_CDict*));
455
+ if (cdicts==NULL) return kNullCDictCollection;
456
+ for (size_t dictNb=0; dictNb < nbCDict; dictNb++) {
457
+ cdicts[dictNb] = ZSTD_createCDict_advanced2(dictBuffer, dictSize, DICT_LOAD_METHOD, dictContentType, cctxParams, ZSTD_defaultCMem);
458
+ CONTROL(cdicts[dictNb] != NULL);
459
+ }
460
+ cdict_collection_t cdictc;
461
+ cdictc.cdicts = cdicts;
462
+ cdictc.nbCDict = nbCDict;
463
+ return cdictc;
464
+ }
465
+
466
+ static const ddict_collection_t kNullDDictCollection = { NULL, 0 };
467
+
468
+ static void freeDDictCollection(ddict_collection_t ddictc)
469
+ {
470
+ for (size_t dictNb=0; dictNb < ddictc.nbDDict; dictNb++) {
471
+ ZSTD_freeDDict(ddictc.ddicts[dictNb]);
472
+ }
473
+ free(ddictc.ddicts);
474
+ }
475
+
476
+ /* returns .buffers=NULL if operation fails */
477
+ static ddict_collection_t createDDictCollection(const void* dictBuffer, size_t dictSize, size_t nbDDict)
478
+ {
479
+ ZSTD_DDict** const ddicts = malloc(nbDDict * sizeof(ZSTD_DDict*));
480
+ assert(ddicts != NULL);
481
+ if (ddicts==NULL) return kNullDDictCollection;
482
+ for (size_t dictNb=0; dictNb < nbDDict; dictNb++) {
483
+ ddicts[dictNb] = ZSTD_createDDict(dictBuffer, dictSize);
484
+ assert(ddicts[dictNb] != NULL);
485
+ }
486
+ ddict_collection_t ddictc;
487
+ ddictc.ddicts = ddicts;
488
+ ddictc.nbDDict = nbDDict;
489
+ return ddictc;
490
+ }
491
+
492
+
493
+ /* mess with addresses, so that linear scanning dictionaries != linear address scanning */
494
+ void shuffleCDictionaries(cdict_collection_t dicts)
495
+ {
496
+ size_t const nbDicts = dicts.nbCDict;
497
+ for (size_t r=0; r<nbDicts; r++) {
498
+ size_t const d = (size_t)rand() % nbDicts;
499
+ ZSTD_CDict* tmpd = dicts.cdicts[d];
500
+ dicts.cdicts[d] = dicts.cdicts[r];
501
+ dicts.cdicts[r] = tmpd;
502
+ }
503
+ for (size_t r=0; r<nbDicts; r++) {
504
+ size_t const d1 = (size_t)rand() % nbDicts;
505
+ size_t const d2 = (size_t)rand() % nbDicts;
506
+ ZSTD_CDict* tmpd = dicts.cdicts[d1];
507
+ dicts.cdicts[d1] = dicts.cdicts[d2];
508
+ dicts.cdicts[d2] = tmpd;
509
+ }
510
+ }
511
+
512
+ /* mess with addresses, so that linear scanning dictionaries != linear address scanning */
513
+ void shuffleDDictionaries(ddict_collection_t dicts)
514
+ {
515
+ size_t const nbDicts = dicts.nbDDict;
516
+ for (size_t r=0; r<nbDicts; r++) {
517
+ size_t const d = (size_t)rand() % nbDicts;
518
+ ZSTD_DDict* tmpd = dicts.ddicts[d];
519
+ dicts.ddicts[d] = dicts.ddicts[r];
520
+ dicts.ddicts[r] = tmpd;
521
+ }
522
+ for (size_t r=0; r<nbDicts; r++) {
523
+ size_t const d1 = (size_t)rand() % nbDicts;
524
+ size_t const d2 = (size_t)rand() % nbDicts;
525
+ ZSTD_DDict* tmpd = dicts.ddicts[d1];
526
+ dicts.ddicts[d1] = dicts.ddicts[d2];
527
+ dicts.ddicts[d2] = tmpd;
528
+ }
529
+ }
530
+
531
+
532
+ /* --- Compression --- */
533
+
534
+ /* compressBlocks() :
535
+ * @return : total compressed size of all blocks,
536
+ * or 0 if error.
537
+ */
538
+ static size_t compressBlocks(size_t* cSizes, /* optional (can be NULL). If present, must contain at least nbBlocks fields */
539
+ slice_collection_t dstBlockBuffers,
540
+ slice_collection_t srcBlockBuffers,
541
+ ZSTD_CDict* cdict, int cLevel)
542
+ {
543
+ size_t const nbBlocks = srcBlockBuffers.nbSlices;
544
+ assert(dstBlockBuffers.nbSlices == srcBlockBuffers.nbSlices);
545
+
546
+ ZSTD_CCtx* const cctx = ZSTD_createCCtx();
547
+ assert(cctx != NULL);
548
+
549
+ size_t totalCSize = 0;
550
+ for (size_t blockNb=0; blockNb < nbBlocks; blockNb++) {
551
+ size_t cBlockSize;
552
+ if (cdict == NULL) {
553
+ cBlockSize = ZSTD_compressCCtx(cctx,
554
+ dstBlockBuffers.slicePtrs[blockNb], dstBlockBuffers.capacities[blockNb],
555
+ srcBlockBuffers.slicePtrs[blockNb], srcBlockBuffers.capacities[blockNb],
556
+ cLevel);
557
+ } else {
558
+ cBlockSize = ZSTD_compress_usingCDict(cctx,
559
+ dstBlockBuffers.slicePtrs[blockNb], dstBlockBuffers.capacities[blockNb],
560
+ srcBlockBuffers.slicePtrs[blockNb], srcBlockBuffers.capacities[blockNb],
561
+ cdict);
562
+ }
563
+ CONTROL(!ZSTD_isError(cBlockSize));
564
+ if (cSizes) cSizes[blockNb] = cBlockSize;
565
+ totalCSize += cBlockSize;
566
+ }
567
+ return totalCSize;
568
+ }
569
+
570
+
571
+ /* --- Benchmark --- */
572
+
573
+ typedef struct {
574
+ ZSTD_CCtx* cctx;
575
+ size_t nbDicts;
576
+ size_t dictNb;
577
+ cdict_collection_t dictionaries;
578
+ } compressInstructions;
579
+
580
+ compressInstructions createCompressInstructions(cdict_collection_t dictionaries, ZSTD_CCtx_params* cctxParams)
581
+ {
582
+ compressInstructions ci;
583
+ ci.cctx = ZSTD_createCCtx();
584
+ CONTROL(ci.cctx != NULL);
585
+ if (cctxParams)
586
+ ZSTD_CCtx_setParametersUsingCCtxParams(ci.cctx, cctxParams);
587
+ ci.nbDicts = dictionaries.nbCDict;
588
+ ci.dictNb = 0;
589
+ ci.dictionaries = dictionaries;
590
+ return ci;
591
+ }
592
+
593
+ void freeCompressInstructions(compressInstructions ci)
594
+ {
595
+ ZSTD_freeCCtx(ci.cctx);
596
+ }
597
+
598
+ typedef struct {
599
+ ZSTD_DCtx* dctx;
600
+ size_t nbDicts;
601
+ size_t dictNb;
602
+ ddict_collection_t dictionaries;
603
+ } decompressInstructions;
604
+
605
+ decompressInstructions createDecompressInstructions(ddict_collection_t dictionaries)
606
+ {
607
+ decompressInstructions di;
608
+ di.dctx = ZSTD_createDCtx();
609
+ assert(di.dctx != NULL);
610
+ di.nbDicts = dictionaries.nbDDict;
611
+ di.dictNb = 0;
612
+ di.dictionaries = dictionaries;
613
+ return di;
614
+ }
615
+
616
+ void freeDecompressInstructions(decompressInstructions di)
617
+ {
618
+ ZSTD_freeDCtx(di.dctx);
619
+ }
620
+
621
+ /* benched function */
622
+ size_t compress(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* payload)
623
+ {
624
+ compressInstructions* const ci = (compressInstructions*) payload;
625
+ (void)dstCapacity;
626
+
627
+ ZSTD_CCtx_refCDict(ci->cctx, ci->dictionaries.cdicts[ci->dictNb]);
628
+ ZSTD_compress2(ci->cctx,
629
+ dst, srcSize,
630
+ src, srcSize);
631
+
632
+ ci->dictNb = ci->dictNb + 1;
633
+ if (ci->dictNb >= ci->nbDicts) ci->dictNb = 0;
634
+
635
+ return srcSize;
636
+ }
637
+
638
+ /* benched function */
639
+ size_t decompress(const void* src, size_t srcSize, void* dst, size_t dstCapacity, void* payload)
640
+ {
641
+ decompressInstructions* const di = (decompressInstructions*) payload;
642
+
643
+ size_t const result = ZSTD_decompress_usingDDict(di->dctx,
644
+ dst, dstCapacity,
645
+ src, srcSize,
646
+ di->dictionaries.ddicts[di->dictNb]);
647
+
648
+ di->dictNb = di->dictNb + 1;
649
+ if (di->dictNb >= di->nbDicts) di->dictNb = 0;
650
+
651
+ return result;
652
+ }
653
+
654
+ typedef enum {
655
+ fastest = 0,
656
+ median = 1,
657
+ } metricAggregatePref_e;
658
+
659
+ /* compareFunction() :
660
+ * Sort input in decreasing order when used with qsort() */
661
+ int compareFunction(const void *a, const void *b)
662
+ {
663
+ double x = *(const double *)a;
664
+ double y = *(const double *)b;
665
+ if (x < y)
666
+ return 1;
667
+ else if (x > y)
668
+ return -1;
669
+ return 0;
670
+ }
671
+
672
+ double aggregateData(double *data, size_t size,
673
+ metricAggregatePref_e metricAggregatePref)
674
+ {
675
+ qsort(data, size, sizeof(*data), compareFunction);
676
+ if (metricAggregatePref == fastest)
677
+ return data[0];
678
+ else /* median */
679
+ return (data[(size - 1) / 2] + data[size / 2]) / 2;
680
+ }
681
+
682
+ static int benchMem(slice_collection_t dstBlocks, slice_collection_t srcBlocks,
683
+ ddict_collection_t ddictionaries,
684
+ cdict_collection_t cdictionaries, unsigned nbRounds,
685
+ int benchCompression, const char *exeName,
686
+ ZSTD_CCtx_params *cctxParams,
687
+ metricAggregatePref_e metricAggregatePref)
688
+ {
689
+ assert(dstBlocks.nbSlices == srcBlocks.nbSlices);
690
+ if (benchCompression) assert(cctxParams);
691
+
692
+ unsigned const ms_per_round = RUN_TIME_DEFAULT_MS;
693
+ unsigned const total_time_ms = nbRounds * ms_per_round;
694
+
695
+ double *const speedPerRound = (double *)malloc(nbRounds * sizeof(double));
696
+
697
+ BMK_timedFnState_t* const benchState =
698
+ BMK_createTimedFnState(total_time_ms, ms_per_round);
699
+
700
+ decompressInstructions di = createDecompressInstructions(ddictionaries);
701
+ compressInstructions ci =
702
+ createCompressInstructions(cdictionaries, cctxParams);
703
+ void* payload = benchCompression ? (void*)&ci : (void*)&di;
704
+ BMK_benchParams_t const bp = {
705
+ .benchFn = benchCompression ? compress : decompress,
706
+ .benchPayload = payload,
707
+ .initFn = NULL,
708
+ .initPayload = NULL,
709
+ .errorFn = ZSTD_isError,
710
+ .blockCount = dstBlocks.nbSlices,
711
+ .srcBuffers = (const void* const*) srcBlocks.slicePtrs,
712
+ .srcSizes = srcBlocks.capacities,
713
+ .dstBuffers = dstBlocks.slicePtrs,
714
+ .dstCapacities = dstBlocks.capacities,
715
+ .blockResults = NULL
716
+ };
717
+
718
+ size_t roundNb = 0;
719
+ for (;;) {
720
+ BMK_runOutcome_t const outcome = BMK_benchTimedFn(benchState, bp);
721
+ CONTROL(BMK_isSuccessful_runOutcome(outcome));
722
+
723
+ BMK_runTime_t const result = BMK_extract_runTime(outcome);
724
+ double const dTime_ns = result.nanoSecPerRun;
725
+ double const dTime_sec = (double)dTime_ns / 1000000000;
726
+ size_t const srcSize = result.sumOfReturn;
727
+ double const speed_MBps = (double)srcSize / dTime_sec / (1 MB);
728
+ speedPerRound[roundNb] = speed_MBps;
729
+ if (benchCompression)
730
+ DISPLAY("Compression Speed : %.1f MB/s \r", speed_MBps);
731
+ else
732
+ DISPLAY("Decompression Speed : %.1f MB/s \r", speed_MBps);
733
+
734
+ fflush(stdout);
735
+ if (BMK_isCompleted_TimedFn(benchState)) break;
736
+ roundNb++;
737
+ }
738
+ DISPLAY("\n");
739
+ /* BMK_benchTimedFn may not run exactly nbRounds iterations */
740
+ double speedAggregated =
741
+ aggregateData(speedPerRound, roundNb + 1, metricAggregatePref);
742
+ free(speedPerRound);
743
+
744
+ if (metricAggregatePref == fastest)
745
+ DISPLAY("Fastest Speed : %.1f MB/s \n", speedAggregated);
746
+ else
747
+ DISPLAY("Median Speed : %.1f MB/s \n", speedAggregated);
748
+
749
+ char* csvFileName = malloc(strlen(exeName) + 5);
750
+ strcpy(csvFileName, exeName);
751
+ strcat(csvFileName, ".csv");
752
+ FILE* csvFile = fopen(csvFileName, "r");
753
+ if (!csvFile) {
754
+ csvFile = fopen(csvFileName, "wt");
755
+ assert(csvFile);
756
+ fprintf(csvFile, "%s\n", exeName);
757
+ /* Print table headers */
758
+ fprintf(
759
+ csvFile,
760
+ "Compression/Decompression,Level,nbDicts,dictAttachPref,metricAggregatePref,Speed\n");
761
+ } else {
762
+ fclose(csvFile);
763
+ csvFile = fopen(csvFileName, "at");
764
+ assert(csvFile);
765
+ }
766
+
767
+ int cLevel = -1;
768
+ int dictAttachPref = -1;
769
+ if (benchCompression) {
770
+ ZSTD_CCtxParams_getParameter(cctxParams, ZSTD_c_compressionLevel,
771
+ &cLevel);
772
+ ZSTD_CCtxParams_getParameter(cctxParams, ZSTD_c_forceAttachDict,
773
+ &dictAttachPref);
774
+ }
775
+ fprintf(csvFile, "%s,%d,%ld,%d,%d,%.1f\n",
776
+ benchCompression ? "Compression" : "Decompression", cLevel,
777
+ benchCompression ? ci.nbDicts : di.nbDicts, dictAttachPref,
778
+ metricAggregatePref, speedAggregated);
779
+ fclose(csvFile);
780
+ free(csvFileName);
781
+
782
+ freeDecompressInstructions(di);
783
+ freeCompressInstructions(ci);
784
+ BMK_freeTimedFnState(benchState);
785
+
786
+ return 0; /* success */
787
+ }
788
+
789
+
790
+ /*! bench() :
791
+ * fileName : file to load for benchmarking purpose
792
+ * dictionary : optional (can be NULL), file to load as dictionary,
793
+ * if none provided : will be calculated on the fly by the program.
794
+ * @return : 0 is success, 1+ otherwise */
795
+ int bench(const char **fileNameTable, unsigned nbFiles, const char *dictionary,
796
+ size_t blockSize, int clevel, unsigned nbDictMax, unsigned nbBlocks,
797
+ unsigned nbRounds, int benchCompression,
798
+ ZSTD_dictContentType_e dictContentType, ZSTD_CCtx_params *cctxParams,
799
+ const char *exeName, metricAggregatePref_e metricAggregatePref)
800
+ {
801
+ int result = 0;
802
+
803
+ DISPLAYLEVEL(3, "loading %u files... \n", nbFiles);
804
+ buffer_collection_t const srcs = createBufferCollection_fromFiles(fileNameTable, nbFiles);
805
+ CONTROL(srcs.buffer.ptr != NULL);
806
+ buffer_t srcBuffer = srcs.buffer;
807
+ size_t const srcSize = srcBuffer.size;
808
+ DISPLAYLEVEL(3, "created src buffer of size %.1f MB \n",
809
+ (double)srcSize / (1 MB));
810
+
811
+ slice_collection_t const srcSlices = splitSlices(srcs.slices, blockSize, nbBlocks);
812
+ nbBlocks = (unsigned)(srcSlices.nbSlices);
813
+ DISPLAYLEVEL(3, "split input into %u blocks ", nbBlocks);
814
+ if (blockSize)
815
+ DISPLAYLEVEL(3, "of max size %u bytes ", (unsigned)blockSize);
816
+ DISPLAYLEVEL(3, "\n");
817
+ size_t const totalSrcSlicesSize = sliceCollection_totalCapacity(srcSlices);
818
+
819
+
820
+ size_t* const dstCapacities = malloc(nbBlocks * sizeof(*dstCapacities));
821
+ CONTROL(dstCapacities != NULL);
822
+ size_t dstBufferCapacity = 0;
823
+ for (size_t bnb=0; bnb<nbBlocks; bnb++) {
824
+ dstCapacities[bnb] = ZSTD_compressBound(srcSlices.capacities[bnb]);
825
+ dstBufferCapacity += dstCapacities[bnb];
826
+ }
827
+
828
+ buffer_t dstBuffer = createBuffer(dstBufferCapacity);
829
+ CONTROL(dstBuffer.ptr != NULL);
830
+
831
+ void** const sliceTable = malloc(nbBlocks * sizeof(*sliceTable));
832
+ CONTROL(sliceTable != NULL);
833
+
834
+ { char* const ptr = dstBuffer.ptr;
835
+ size_t pos = 0;
836
+ for (size_t snb=0; snb < nbBlocks; snb++) {
837
+ sliceTable[snb] = ptr + pos;
838
+ pos += dstCapacities[snb];
839
+ } }
840
+
841
+ slice_collection_t dstSlices;
842
+ dstSlices.capacities = dstCapacities;
843
+ dstSlices.slicePtrs = sliceTable;
844
+ dstSlices.nbSlices = nbBlocks;
845
+
846
+
847
+ /* dictionary determination */
848
+ buffer_t const dictBuffer = createDictionaryBuffer(dictionary,
849
+ srcs.buffer.ptr,
850
+ srcSlices.capacities, srcSlices.nbSlices,
851
+ DICTSIZE);
852
+ CONTROL(dictBuffer.ptr != NULL);
853
+
854
+ ZSTD_CDict* const cdict = ZSTD_createCDict_advanced2(dictBuffer.ptr, dictBuffer.size, DICT_LOAD_METHOD, dictContentType, cctxParams, ZSTD_defaultCMem);
855
+ CONTROL(cdict != NULL);
856
+
857
+ size_t const cTotalSizeNoDict = compressBlocks(NULL, dstSlices, srcSlices, NULL, clevel);
858
+ CONTROL(cTotalSizeNoDict != 0);
859
+ DISPLAYLEVEL(3, "compressing at level %u without dictionary : Ratio=%.2f (%u bytes) \n",
860
+ clevel,
861
+ (double)totalSrcSlicesSize / (double)cTotalSizeNoDict, (unsigned)cTotalSizeNoDict);
862
+
863
+ size_t* const cSizes = malloc(nbBlocks * sizeof(size_t));
864
+ CONTROL(cSizes != NULL);
865
+
866
+ size_t const cTotalSize = compressBlocks(cSizes, dstSlices, srcSlices, cdict, clevel);
867
+ CONTROL(cTotalSize != 0);
868
+ DISPLAYLEVEL(3, "compressed using a %u bytes dictionary : Ratio=%.2f (%u bytes) \n",
869
+ (unsigned)dictBuffer.size,
870
+ (double)totalSrcSlicesSize / (double)cTotalSize, (unsigned)cTotalSize);
871
+
872
+ /* now dstSlices contain the real compressed size of each block, instead of the maximum capacity */
873
+ shrinkSizes(dstSlices, cSizes);
874
+
875
+ unsigned const nbDicts = nbDictMax ? nbDictMax : nbBlocks;
876
+
877
+ cdict_collection_t const cdictionaries = createCDictCollection(dictBuffer.ptr, dictBuffer.size, nbDicts, dictContentType, cctxParams);
878
+ CONTROL(cdictionaries.cdicts != NULL);
879
+
880
+ ddict_collection_t const ddictionaries = createDDictCollection(dictBuffer.ptr, dictBuffer.size, nbDicts);
881
+ CONTROL(ddictionaries.ddicts != NULL);
882
+
883
+ if (benchCompression) {
884
+ size_t const dictMem = ZSTD_sizeof_CDict(cdictionaries.cdicts[0]);
885
+ size_t const allDictMem = dictMem * nbDicts;
886
+ DISPLAYLEVEL(3, "generating %u dictionaries, using %.1f MB of memory \n",
887
+ nbDicts, (double)allDictMem / (1 MB));
888
+
889
+ shuffleCDictionaries(cdictionaries);
890
+
891
+ buffer_collection_t resultCollection = createBufferCollection_fromSliceCollection(srcSlices);
892
+ CONTROL(resultCollection.buffer.ptr != NULL);
893
+
894
+ result = benchMem(dstSlices, resultCollection.slices, ddictionaries,
895
+ cdictionaries, nbRounds, benchCompression, exeName,
896
+ cctxParams, metricAggregatePref);
897
+
898
+ freeBufferCollection(resultCollection);
899
+ } else {
900
+ size_t const dictMem = ZSTD_estimateDDictSize(dictBuffer.size, DICT_LOAD_METHOD);
901
+ size_t const allDictMem = dictMem * nbDicts;
902
+ DISPLAYLEVEL(3, "generating %u dictionaries, using %.1f MB of memory \n",
903
+ nbDicts, (double)allDictMem / (1 MB));
904
+
905
+ shuffleDDictionaries(ddictionaries);
906
+
907
+ buffer_collection_t resultCollection = createBufferCollection_fromSliceCollectionSizes(srcSlices);
908
+ CONTROL(resultCollection.buffer.ptr != NULL);
909
+
910
+ result = benchMem(resultCollection.slices, dstSlices, ddictionaries,
911
+ cdictionaries, nbRounds, benchCompression, exeName,
912
+ NULL, metricAggregatePref);
913
+
914
+ freeBufferCollection(resultCollection);
915
+ }
916
+
917
+ /* free all heap objects in reverse order */
918
+ freeCDictCollection(cdictionaries);
919
+ freeDDictCollection(ddictionaries);
920
+ free(cSizes);
921
+ ZSTD_freeCDict(cdict);
922
+ freeBuffer(dictBuffer);
923
+ freeSliceCollection(dstSlices);
924
+ freeBuffer(dstBuffer);
925
+ freeSliceCollection(srcSlices);
926
+ freeBufferCollection(srcs);
927
+
928
+ return result;
929
+ }
930
+
931
+
932
+
933
+ /* --- Command Line --- */
934
+
935
+ /*! readU32FromChar() :
936
+ * @return : unsigned integer value read from input in `char` format.
937
+ * allows and interprets K, KB, KiB, M, MB and MiB suffix.
938
+ * Will also modify `*stringPtr`, advancing it to position where it stopped reading.
939
+ * Note : function will exit() program if digit sequence overflows */
940
+ static unsigned readU32FromChar(const char** stringPtr)
941
+ {
942
+ unsigned result = 0;
943
+ while ((**stringPtr >='0') && (**stringPtr <='9')) {
944
+ unsigned const max = (((unsigned)(-1)) / 10) - 1;
945
+ assert(result <= max); /* check overflow */
946
+ result *= 10, result += (unsigned)**stringPtr - '0', (*stringPtr)++ ;
947
+ }
948
+ if ((**stringPtr=='K') || (**stringPtr=='M')) {
949
+ unsigned const maxK = ((unsigned)(-1)) >> 10;
950
+ assert(result <= maxK); /* check overflow */
951
+ result <<= 10;
952
+ if (**stringPtr=='M') {
953
+ assert(result <= maxK); /* check overflow */
954
+ result <<= 10;
955
+ }
956
+ (*stringPtr)++; /* skip `K` or `M` */
957
+ if (**stringPtr=='i') (*stringPtr)++;
958
+ if (**stringPtr=='B') (*stringPtr)++;
959
+ }
960
+ return result;
961
+ }
962
+
963
+ /** longCommandWArg() :
964
+ * check if *stringPtr is the same as longCommand.
965
+ * If yes, @return 1 and advances *stringPtr to the position which immediately follows longCommand.
966
+ * @return 0 and doesn't modify *stringPtr otherwise.
967
+ */
968
+ static int longCommandWArg(const char** stringPtr, const char* longCommand)
969
+ {
970
+ size_t const comSize = strlen(longCommand);
971
+ int const result = !strncmp(*stringPtr, longCommand, comSize);
972
+ if (result) *stringPtr += comSize;
973
+ return result;
974
+ }
975
+
976
+
977
+ int usage(const char* exeName)
978
+ {
979
+ DISPLAY (" \n");
980
+ DISPLAY (" %s [Options] filename(s) \n", exeName);
981
+ DISPLAY (" \n");
982
+ DISPLAY ("Options : \n");
983
+ DISPLAY ("-z : benchmark compression (default) \n");
984
+ DISPLAY ("-d : benchmark decompression \n");
985
+ DISPLAY ("-r : recursively load all files in subdirectories (default: off) \n");
986
+ DISPLAY ("-B# : split input into blocks of size # (default: no split) \n");
987
+ DISPLAY ("-# : use compression level # (default: %u) \n", CLEVEL_DEFAULT);
988
+ DISPLAY ("-D # : use # as a dictionary (default: create one) \n");
989
+ DISPLAY ("-i# : nb benchmark rounds (default: %u) \n", BENCH_TIME_DEFAULT_S);
990
+ DISPLAY ("-p# : print speed for all rounds 0=fastest 1=median (default: 0) \n");
991
+ DISPLAY ("--nbBlocks=#: use # blocks for bench (default: one per file) \n");
992
+ DISPLAY ("--nbDicts=# : create # dictionaries for bench (default: one per block) \n");
993
+ DISPLAY ("-h : help (this text) \n");
994
+ DISPLAY (" \n");
995
+ DISPLAY ("Advanced Options (see zstd.h for documentation) : \n");
996
+ DISPLAY ("--dedicated-dict-search\n");
997
+ DISPLAY ("--dict-content-type=#\n");
998
+ DISPLAY ("--dict-attach-pref=#\n");
999
+ return 0;
1000
+ }
1001
+
1002
+ int bad_usage(const char* exeName)
1003
+ {
1004
+ DISPLAY (" bad usage : \n");
1005
+ usage(exeName);
1006
+ return 1;
1007
+ }
1008
+
1009
+ int main (int argc, const char** argv)
1010
+ {
1011
+ int recursiveMode = 0;
1012
+ int benchCompression = 1;
1013
+ int dedicatedDictSearch = 0;
1014
+ unsigned nbRounds = BENCH_TIME_DEFAULT_S;
1015
+ const char* const exeName = argv[0];
1016
+
1017
+ if (argc < 2) return bad_usage(exeName);
1018
+
1019
+ const char** nameTable = (const char**)malloc((size_t)argc * sizeof(const char*));
1020
+ assert(nameTable != NULL);
1021
+ unsigned nameIdx = 0;
1022
+
1023
+ const char* dictionary = NULL;
1024
+ int cLevel = CLEVEL_DEFAULT;
1025
+ size_t blockSize = BLOCKSIZE_DEFAULT;
1026
+ unsigned nbDicts = 0; /* determine nbDicts automatically: 1 dictionary per block */
1027
+ unsigned nbBlocks = 0; /* determine nbBlocks automatically, from source and blockSize */
1028
+ ZSTD_dictContentType_e dictContentType = ZSTD_dct_auto;
1029
+ ZSTD_dictAttachPref_e dictAttachPref = ZSTD_dictDefaultAttach;
1030
+ ZSTD_ParamSwitch_e prefetchCDictTables = ZSTD_ps_auto;
1031
+ metricAggregatePref_e metricAggregatePref = fastest;
1032
+
1033
+ for (int argNb = 1; argNb < argc ; argNb++) {
1034
+ const char* argument = argv[argNb];
1035
+ if (!strcmp(argument, "-h")) { free(nameTable); return usage(exeName); }
1036
+ if (!strcmp(argument, "-d")) { benchCompression = 0; continue; }
1037
+ if (!strcmp(argument, "-z")) { benchCompression = 1; continue; }
1038
+ if (!strcmp(argument, "-r")) { recursiveMode = 1; continue; }
1039
+ if (!strcmp(argument, "-D")) { argNb++; assert(argNb < argc); dictionary = argv[argNb]; continue; }
1040
+ if (longCommandWArg(&argument, "-i")) { nbRounds = readU32FromChar(&argument); continue; }
1041
+ if (longCommandWArg(&argument, "-p")) { metricAggregatePref = (int)readU32FromChar(&argument); continue;}
1042
+ if (longCommandWArg(&argument, "--dictionary=")) { dictionary = argument; continue; }
1043
+ if (longCommandWArg(&argument, "-B")) { blockSize = readU32FromChar(&argument); continue; }
1044
+ if (longCommandWArg(&argument, "--blockSize=")) { blockSize = readU32FromChar(&argument); continue; }
1045
+ if (longCommandWArg(&argument, "--nbDicts=")) { nbDicts = readU32FromChar(&argument); continue; }
1046
+ if (longCommandWArg(&argument, "--nbBlocks=")) { nbBlocks = readU32FromChar(&argument); continue; }
1047
+ if (longCommandWArg(&argument, "--clevel=")) { cLevel = (int)readU32FromChar(&argument); continue; }
1048
+ if (longCommandWArg(&argument, "--dedicated-dict-search")) { dedicatedDictSearch = 1; continue; }
1049
+ if (longCommandWArg(&argument, "--dict-content-type=")) { dictContentType = (int)readU32FromChar(&argument); continue; }
1050
+ if (longCommandWArg(&argument, "--dict-attach-pref=")) { dictAttachPref = (int)readU32FromChar(&argument); continue; }
1051
+ if (longCommandWArg(&argument, "--prefetch-cdict-tables=")) { prefetchCDictTables = (int)readU32FromChar(&argument); continue; }
1052
+ if (longCommandWArg(&argument, "-")) { cLevel = (int)readU32FromChar(&argument); continue; }
1053
+ /* anything that's not a command is a filename */
1054
+ nameTable[nameIdx++] = argument;
1055
+ }
1056
+
1057
+ FileNamesTable* filenameTable;
1058
+
1059
+ if (recursiveMode) {
1060
+ #ifndef UTIL_HAS_CREATEFILELIST
1061
+ assert(0); /* missing capability, do not run */
1062
+ #endif
1063
+ filenameTable = UTIL_createExpandedFNT(nameTable, nameIdx, 1 /* follow_links */);
1064
+ } else {
1065
+ filenameTable = UTIL_assembleFileNamesTable(nameTable, nameIdx, NULL);
1066
+ nameTable = NULL; /* UTIL_createFileNamesTable() takes ownership of nameTable */
1067
+ }
1068
+
1069
+ ZSTD_CCtx_params* cctxParams = ZSTD_createCCtxParams();
1070
+ ZSTD_CCtxParams_init(cctxParams, cLevel);
1071
+ ZSTD_CCtxParams_setParameter(cctxParams, ZSTD_c_enableDedicatedDictSearch, dedicatedDictSearch);
1072
+ ZSTD_CCtxParams_setParameter(cctxParams, ZSTD_c_nbWorkers, 0);
1073
+ ZSTD_CCtxParams_setParameter(cctxParams, ZSTD_c_forceAttachDict, dictAttachPref);
1074
+ ZSTD_CCtxParams_setParameter(cctxParams, ZSTD_c_prefetchCDictTables, prefetchCDictTables);
1075
+
1076
+ int result =
1077
+ bench(filenameTable->fileNames, (unsigned)filenameTable->tableSize,
1078
+ dictionary, blockSize, cLevel, nbDicts, nbBlocks, nbRounds,
1079
+ benchCompression, dictContentType, cctxParams, exeName,
1080
+ metricAggregatePref);
1081
+
1082
+ UTIL_freeFileNamesTable(filenameTable);
1083
+ free(nameTable);
1084
+ ZSTD_freeCCtxParams(cctxParams);
1085
+
1086
+ return result;
1087
+ }