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,745 @@
1
+ /*
2
+ * xxHash - Extremely Fast Hash algorithm
3
+ * Copyright (C) 2012-2016, Yann Collet.
4
+ *
5
+ * BSD 2-Clause License (https://opensource.org/licenses/bsd-license.php)
6
+ *
7
+ * Redistribution and use in source and binary forms, with or without
8
+ * modification, are permitted provided that the following conditions are
9
+ * met:
10
+ *
11
+ * * Redistributions of source code must retain the above copyright
12
+ * notice, this list of conditions and the following disclaimer.
13
+ * * Redistributions in binary form must reproduce the above
14
+ * copyright notice, this list of conditions and the following disclaimer
15
+ * in the documentation and/or other materials provided with the
16
+ * distribution.
17
+ *
18
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
+ *
30
+ * This program is free software; you can redistribute it and/or modify it under
31
+ * the terms of the GNU General Public License version 2 as published by the
32
+ * Free Software Foundation. This program is dual-licensed; you may select
33
+ * either version 2 of the GNU General Public License ("GPL") or BSD license
34
+ * ("BSD").
35
+ *
36
+ * You can contact the author at:
37
+ * - xxHash homepage: https://cyan4973.github.io/xxHash/
38
+ * - xxHash source repository: https://github.com/Cyan4973/xxHash
39
+ */
40
+
41
+ /*
42
+ * Notice extracted from xxHash homepage:
43
+ *
44
+ * xxHash is an extremely fast Hash algorithm, running at RAM speed limits.
45
+ * It also successfully passes all tests from the SMHasher suite.
46
+ *
47
+ * Comparison (single thread, Windows Seven 32 bits, using SMHasher on a Core 2
48
+ * Duo @3GHz)
49
+ *
50
+ * Name Speed Q.Score Author
51
+ * xxHash 5.4 GB/s 10
52
+ * CrapWow 3.2 GB/s 2 Andrew
53
+ * MumurHash 3a 2.7 GB/s 10 Austin Appleby
54
+ * SpookyHash 2.0 GB/s 10 Bob Jenkins
55
+ * SBox 1.4 GB/s 9 Bret Mulvey
56
+ * Lookup3 1.2 GB/s 9 Bob Jenkins
57
+ * SuperFastHash 1.2 GB/s 1 Paul Hsieh
58
+ * CityHash64 1.05 GB/s 10 Pike & Alakuijala
59
+ * FNV 0.55 GB/s 5 Fowler, Noll, Vo
60
+ * CRC32 0.43 GB/s 9
61
+ * MD5-32 0.33 GB/s 10 Ronald L. Rivest
62
+ * SHA1-32 0.28 GB/s 10
63
+ *
64
+ * Q.Score is a measure of quality of the hash function.
65
+ * It depends on successfully passing SMHasher test set.
66
+ * 10 is a perfect score.
67
+ *
68
+ * A 64-bits version, named xxh64 offers much better speed,
69
+ * but for 64-bits applications only.
70
+ * Name Speed on 64 bits Speed on 32 bits
71
+ * xxh64 13.8 GB/s 1.9 GB/s
72
+ * xxh32 6.8 GB/s 6.0 GB/s
73
+ */
74
+
75
+ #ifndef XXHASH_H
76
+ #define XXHASH_H
77
+
78
+ #include <linux/types.h>
79
+
80
+ #define XXH_API static inline __attribute__((unused))
81
+ /*-****************************
82
+ * Simple Hash Functions
83
+ *****************************/
84
+
85
+ /**
86
+ * xxh32() - calculate the 32-bit hash of the input with a given seed.
87
+ *
88
+ * @input: The data to hash.
89
+ * @length: The length of the data to hash.
90
+ * @seed: The seed can be used to alter the result predictably.
91
+ *
92
+ * Speed on Core 2 Duo @ 3 GHz (single thread, SMHasher benchmark) : 5.4 GB/s
93
+ *
94
+ * Return: The 32-bit hash of the data.
95
+ */
96
+ XXH_API uint32_t xxh32(const void *input, size_t length, uint32_t seed);
97
+
98
+ /**
99
+ * xxh64() - calculate the 64-bit hash of the input with a given seed.
100
+ *
101
+ * @input: The data to hash.
102
+ * @length: The length of the data to hash.
103
+ * @seed: The seed can be used to alter the result predictably.
104
+ *
105
+ * This function runs 2x faster on 64-bit systems, but slower on 32-bit systems.
106
+ *
107
+ * Return: The 64-bit hash of the data.
108
+ */
109
+ XXH_API uint64_t xxh64(const void *input, size_t length, uint64_t seed);
110
+
111
+ /**
112
+ * xxhash() - calculate wordsize hash of the input with a given seed
113
+ * @input: The data to hash.
114
+ * @length: The length of the data to hash.
115
+ * @seed: The seed can be used to alter the result predictably.
116
+ *
117
+ * If the hash does not need to be comparable between machines with
118
+ * different word sizes, this function will call whichever of xxh32()
119
+ * or xxh64() is faster.
120
+ *
121
+ * Return: wordsize hash of the data.
122
+ */
123
+
124
+ static inline unsigned long xxhash(const void *input, size_t length,
125
+ uint64_t seed)
126
+ {
127
+ if (sizeof(size_t) == 8)
128
+ return xxh64(input, length, seed);
129
+ else
130
+ return xxh32(input, length, seed);
131
+ }
132
+
133
+ /*-****************************
134
+ * Streaming Hash Functions
135
+ *****************************/
136
+
137
+ /*
138
+ * These definitions are only meant to allow allocation of XXH state
139
+ * statically, on stack, or in a struct for example.
140
+ * Do not use members directly.
141
+ */
142
+
143
+ /**
144
+ * struct xxh32_state - private xxh32 state, do not use members directly
145
+ */
146
+ struct xxh32_state {
147
+ uint32_t total_len_32;
148
+ uint32_t large_len;
149
+ uint32_t v1;
150
+ uint32_t v2;
151
+ uint32_t v3;
152
+ uint32_t v4;
153
+ uint32_t mem32[4];
154
+ uint32_t memsize;
155
+ };
156
+
157
+ /**
158
+ * struct xxh32_state - private xxh64 state, do not use members directly
159
+ */
160
+ struct xxh64_state {
161
+ uint64_t total_len;
162
+ uint64_t v1;
163
+ uint64_t v2;
164
+ uint64_t v3;
165
+ uint64_t v4;
166
+ uint64_t mem64[4];
167
+ uint32_t memsize;
168
+ };
169
+
170
+ /**
171
+ * xxh32_reset() - reset the xxh32 state to start a new hashing operation
172
+ *
173
+ * @state: The xxh32 state to reset.
174
+ * @seed: Initialize the hash state with this seed.
175
+ *
176
+ * Call this function on any xxh32_state to prepare for a new hashing operation.
177
+ */
178
+ XXH_API void xxh32_reset(struct xxh32_state *state, uint32_t seed);
179
+
180
+ /**
181
+ * xxh32_update() - hash the data given and update the xxh32 state
182
+ *
183
+ * @state: The xxh32 state to update.
184
+ * @input: The data to hash.
185
+ * @length: The length of the data to hash.
186
+ *
187
+ * After calling xxh32_reset() call xxh32_update() as many times as necessary.
188
+ *
189
+ * Return: Zero on success, otherwise an error code.
190
+ */
191
+ XXH_API int xxh32_update(struct xxh32_state *state, const void *input, size_t length);
192
+
193
+ /**
194
+ * xxh32_digest() - produce the current xxh32 hash
195
+ *
196
+ * @state: Produce the current xxh32 hash of this state.
197
+ *
198
+ * A hash value can be produced at any time. It is still possible to continue
199
+ * inserting input into the hash state after a call to xxh32_digest(), and
200
+ * generate new hashes later on, by calling xxh32_digest() again.
201
+ *
202
+ * Return: The xxh32 hash stored in the state.
203
+ */
204
+ XXH_API uint32_t xxh32_digest(const struct xxh32_state *state);
205
+
206
+ /**
207
+ * xxh64_reset() - reset the xxh64 state to start a new hashing operation
208
+ *
209
+ * @state: The xxh64 state to reset.
210
+ * @seed: Initialize the hash state with this seed.
211
+ */
212
+ XXH_API void xxh64_reset(struct xxh64_state *state, uint64_t seed);
213
+
214
+ /**
215
+ * xxh64_update() - hash the data given and update the xxh64 state
216
+ * @state: The xxh64 state to update.
217
+ * @input: The data to hash.
218
+ * @length: The length of the data to hash.
219
+ *
220
+ * After calling xxh64_reset() call xxh64_update() as many times as necessary.
221
+ *
222
+ * Return: Zero on success, otherwise an error code.
223
+ */
224
+ XXH_API int xxh64_update(struct xxh64_state *state, const void *input, size_t length);
225
+
226
+ /**
227
+ * xxh64_digest() - produce the current xxh64 hash
228
+ *
229
+ * @state: Produce the current xxh64 hash of this state.
230
+ *
231
+ * A hash value can be produced at any time. It is still possible to continue
232
+ * inserting input into the hash state after a call to xxh64_digest(), and
233
+ * generate new hashes later on, by calling xxh64_digest() again.
234
+ *
235
+ * Return: The xxh64 hash stored in the state.
236
+ */
237
+ XXH_API uint64_t xxh64_digest(const struct xxh64_state *state);
238
+
239
+ /*-**************************
240
+ * Utils
241
+ ***************************/
242
+
243
+ /**
244
+ * xxh32_copy_state() - copy the source state into the destination state
245
+ *
246
+ * @src: The source xxh32 state.
247
+ * @dst: The destination xxh32 state.
248
+ */
249
+ XXH_API void xxh32_copy_state(struct xxh32_state *dst, const struct xxh32_state *src);
250
+
251
+ /**
252
+ * xxh64_copy_state() - copy the source state into the destination state
253
+ *
254
+ * @src: The source xxh64 state.
255
+ * @dst: The destination xxh64 state.
256
+ */
257
+ XXH_API void xxh64_copy_state(struct xxh64_state *dst, const struct xxh64_state *src);
258
+
259
+ /*
260
+ * xxHash - Extremely Fast Hash algorithm
261
+ * Copyright (C) 2012-2016, Yann Collet.
262
+ *
263
+ * BSD 2-Clause License (https://opensource.org/licenses/bsd-license.php)
264
+ *
265
+ * Redistribution and use in source and binary forms, with or without
266
+ * modification, are permitted provided that the following conditions are
267
+ * met:
268
+ *
269
+ * * Redistributions of source code must retain the above copyright
270
+ * notice, this list of conditions and the following disclaimer.
271
+ * * Redistributions in binary form must reproduce the above
272
+ * copyright notice, this list of conditions and the following disclaimer
273
+ * in the documentation and/or other materials provided with the
274
+ * distribution.
275
+ *
276
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
277
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
278
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
279
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
280
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
281
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
282
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
283
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
284
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
285
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
286
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
287
+ *
288
+ * This program is free software; you can redistribute it and/or modify it under
289
+ * the terms of the GNU General Public License version 2 as published by the
290
+ * Free Software Foundation. This program is dual-licensed; you may select
291
+ * either version 2 of the GNU General Public License ("GPL") or BSD license
292
+ * ("BSD").
293
+ *
294
+ * You can contact the author at:
295
+ * - xxHash homepage: https://cyan4973.github.io/xxHash/
296
+ * - xxHash source repository: https://github.com/Cyan4973/xxHash
297
+ */
298
+
299
+ #include <linux/unaligned.h>
300
+ #include <linux/errno.h>
301
+ #include <linux/kernel.h>
302
+ #include <linux/module.h>
303
+ #include <linux/xxhash.h>
304
+
305
+ /*-*************************************
306
+ * Macros
307
+ **************************************/
308
+ #define xxh_rotl32(x, r) ((x << r) | (x >> (32 - r)))
309
+ #define xxh_rotl64(x, r) ((x << r) | (x >> (64 - r)))
310
+
311
+ #ifdef __LITTLE_ENDIAN
312
+ # define XXH_CPU_LITTLE_ENDIAN 1
313
+ #else
314
+ # define XXH_CPU_LITTLE_ENDIAN 0
315
+ #endif
316
+
317
+ /*-*************************************
318
+ * Constants
319
+ **************************************/
320
+ static const uint32_t PRIME32_1 = 2654435761U;
321
+ static const uint32_t PRIME32_2 = 2246822519U;
322
+ static const uint32_t PRIME32_3 = 3266489917U;
323
+ static const uint32_t PRIME32_4 = 668265263U;
324
+ static const uint32_t PRIME32_5 = 374761393U;
325
+
326
+ static const uint64_t PRIME64_1 = 11400714785074694791ULL;
327
+ static const uint64_t PRIME64_2 = 14029467366897019727ULL;
328
+ static const uint64_t PRIME64_3 = 1609587929392839161ULL;
329
+ static const uint64_t PRIME64_4 = 9650029242287828579ULL;
330
+ static const uint64_t PRIME64_5 = 2870177450012600261ULL;
331
+
332
+ /*-**************************
333
+ * Utils
334
+ ***************************/
335
+ XXH_API void xxh32_copy_state(struct xxh32_state *dst, const struct xxh32_state *src)
336
+ {
337
+ __builtin_memcpy(dst, src, sizeof(*dst));
338
+ }
339
+
340
+ XXH_API void xxh64_copy_state(struct xxh64_state *dst, const struct xxh64_state *src)
341
+ {
342
+ __builtin_memcpy(dst, src, sizeof(*dst));
343
+ }
344
+
345
+ /*-***************************
346
+ * Simple Hash Functions
347
+ ****************************/
348
+ static uint32_t xxh32_round(uint32_t seed, const uint32_t input)
349
+ {
350
+ seed += input * PRIME32_2;
351
+ seed = xxh_rotl32(seed, 13);
352
+ seed *= PRIME32_1;
353
+ return seed;
354
+ }
355
+
356
+ XXH_API uint32_t xxh32(const void *input, const size_t len, const uint32_t seed)
357
+ {
358
+ const uint8_t *p = (const uint8_t *)input;
359
+ const uint8_t *b_end = p + len;
360
+ uint32_t h32;
361
+
362
+ if (len >= 16) {
363
+ const uint8_t *const limit = b_end - 16;
364
+ uint32_t v1 = seed + PRIME32_1 + PRIME32_2;
365
+ uint32_t v2 = seed + PRIME32_2;
366
+ uint32_t v3 = seed + 0;
367
+ uint32_t v4 = seed - PRIME32_1;
368
+
369
+ do {
370
+ v1 = xxh32_round(v1, get_unaligned_le32(p));
371
+ p += 4;
372
+ v2 = xxh32_round(v2, get_unaligned_le32(p));
373
+ p += 4;
374
+ v3 = xxh32_round(v3, get_unaligned_le32(p));
375
+ p += 4;
376
+ v4 = xxh32_round(v4, get_unaligned_le32(p));
377
+ p += 4;
378
+ } while (p <= limit);
379
+
380
+ h32 = xxh_rotl32(v1, 1) + xxh_rotl32(v2, 7) +
381
+ xxh_rotl32(v3, 12) + xxh_rotl32(v4, 18);
382
+ } else {
383
+ h32 = seed + PRIME32_5;
384
+ }
385
+
386
+ h32 += (uint32_t)len;
387
+
388
+ while (p + 4 <= b_end) {
389
+ h32 += get_unaligned_le32(p) * PRIME32_3;
390
+ h32 = xxh_rotl32(h32, 17) * PRIME32_4;
391
+ p += 4;
392
+ }
393
+
394
+ while (p < b_end) {
395
+ h32 += (*p) * PRIME32_5;
396
+ h32 = xxh_rotl32(h32, 11) * PRIME32_1;
397
+ p++;
398
+ }
399
+
400
+ h32 ^= h32 >> 15;
401
+ h32 *= PRIME32_2;
402
+ h32 ^= h32 >> 13;
403
+ h32 *= PRIME32_3;
404
+ h32 ^= h32 >> 16;
405
+
406
+ return h32;
407
+ }
408
+
409
+ static uint64_t xxh64_round(uint64_t acc, const uint64_t input)
410
+ {
411
+ acc += input * PRIME64_2;
412
+ acc = xxh_rotl64(acc, 31);
413
+ acc *= PRIME64_1;
414
+ return acc;
415
+ }
416
+
417
+ static uint64_t xxh64_merge_round(uint64_t acc, uint64_t val)
418
+ {
419
+ val = xxh64_round(0, val);
420
+ acc ^= val;
421
+ acc = acc * PRIME64_1 + PRIME64_4;
422
+ return acc;
423
+ }
424
+
425
+ XXH_API uint64_t xxh64(const void *input, const size_t len, const uint64_t seed)
426
+ {
427
+ const uint8_t *p = (const uint8_t *)input;
428
+ const uint8_t *const b_end = p + len;
429
+ uint64_t h64;
430
+
431
+ if (len >= 32) {
432
+ const uint8_t *const limit = b_end - 32;
433
+ uint64_t v1 = seed + PRIME64_1 + PRIME64_2;
434
+ uint64_t v2 = seed + PRIME64_2;
435
+ uint64_t v3 = seed + 0;
436
+ uint64_t v4 = seed - PRIME64_1;
437
+
438
+ do {
439
+ v1 = xxh64_round(v1, get_unaligned_le64(p));
440
+ p += 8;
441
+ v2 = xxh64_round(v2, get_unaligned_le64(p));
442
+ p += 8;
443
+ v3 = xxh64_round(v3, get_unaligned_le64(p));
444
+ p += 8;
445
+ v4 = xxh64_round(v4, get_unaligned_le64(p));
446
+ p += 8;
447
+ } while (p <= limit);
448
+
449
+ h64 = xxh_rotl64(v1, 1) + xxh_rotl64(v2, 7) +
450
+ xxh_rotl64(v3, 12) + xxh_rotl64(v4, 18);
451
+ h64 = xxh64_merge_round(h64, v1);
452
+ h64 = xxh64_merge_round(h64, v2);
453
+ h64 = xxh64_merge_round(h64, v3);
454
+ h64 = xxh64_merge_round(h64, v4);
455
+
456
+ } else {
457
+ h64 = seed + PRIME64_5;
458
+ }
459
+
460
+ h64 += (uint64_t)len;
461
+
462
+ while (p + 8 <= b_end) {
463
+ const uint64_t k1 = xxh64_round(0, get_unaligned_le64(p));
464
+
465
+ h64 ^= k1;
466
+ h64 = xxh_rotl64(h64, 27) * PRIME64_1 + PRIME64_4;
467
+ p += 8;
468
+ }
469
+
470
+ if (p + 4 <= b_end) {
471
+ h64 ^= (uint64_t)(get_unaligned_le32(p)) * PRIME64_1;
472
+ h64 = xxh_rotl64(h64, 23) * PRIME64_2 + PRIME64_3;
473
+ p += 4;
474
+ }
475
+
476
+ while (p < b_end) {
477
+ h64 ^= (*p) * PRIME64_5;
478
+ h64 = xxh_rotl64(h64, 11) * PRIME64_1;
479
+ p++;
480
+ }
481
+
482
+ h64 ^= h64 >> 33;
483
+ h64 *= PRIME64_2;
484
+ h64 ^= h64 >> 29;
485
+ h64 *= PRIME64_3;
486
+ h64 ^= h64 >> 32;
487
+
488
+ return h64;
489
+ }
490
+
491
+ /*-**************************************************
492
+ * Advanced Hash Functions
493
+ ***************************************************/
494
+ XXH_API void xxh32_reset(struct xxh32_state *statePtr, const uint32_t seed)
495
+ {
496
+ /* use a local state for memcpy() to avoid strict-aliasing warnings */
497
+ struct xxh32_state state;
498
+
499
+ __builtin_memset(&state, 0, sizeof(state));
500
+ state.v1 = seed + PRIME32_1 + PRIME32_2;
501
+ state.v2 = seed + PRIME32_2;
502
+ state.v3 = seed + 0;
503
+ state.v4 = seed - PRIME32_1;
504
+ __builtin_memcpy(statePtr, &state, sizeof(state));
505
+ }
506
+
507
+ XXH_API void xxh64_reset(struct xxh64_state *statePtr, const uint64_t seed)
508
+ {
509
+ /* use a local state for memcpy() to avoid strict-aliasing warnings */
510
+ struct xxh64_state state;
511
+
512
+ __builtin_memset(&state, 0, sizeof(state));
513
+ state.v1 = seed + PRIME64_1 + PRIME64_2;
514
+ state.v2 = seed + PRIME64_2;
515
+ state.v3 = seed + 0;
516
+ state.v4 = seed - PRIME64_1;
517
+ __builtin_memcpy(statePtr, &state, sizeof(state));
518
+ }
519
+
520
+ XXH_API int xxh32_update(struct xxh32_state *state, const void *input, const size_t len)
521
+ {
522
+ const uint8_t *p = (const uint8_t *)input;
523
+ const uint8_t *const b_end = p + len;
524
+
525
+ if (input == NULL)
526
+ return -EINVAL;
527
+
528
+ state->total_len_32 += (uint32_t)len;
529
+ state->large_len |= (len >= 16) | (state->total_len_32 >= 16);
530
+
531
+ if (state->memsize + len < 16) { /* fill in tmp buffer */
532
+ __builtin_memcpy((uint8_t *)(state->mem32) + state->memsize, input, len);
533
+ state->memsize += (uint32_t)len;
534
+ return 0;
535
+ }
536
+
537
+ if (state->memsize) { /* some data left from previous update */
538
+ const uint32_t *p32 = state->mem32;
539
+
540
+ __builtin_memcpy((uint8_t *)(state->mem32) + state->memsize, input,
541
+ 16 - state->memsize);
542
+
543
+ state->v1 = xxh32_round(state->v1, get_unaligned_le32(p32));
544
+ p32++;
545
+ state->v2 = xxh32_round(state->v2, get_unaligned_le32(p32));
546
+ p32++;
547
+ state->v3 = xxh32_round(state->v3, get_unaligned_le32(p32));
548
+ p32++;
549
+ state->v4 = xxh32_round(state->v4, get_unaligned_le32(p32));
550
+ p32++;
551
+
552
+ p += 16-state->memsize;
553
+ state->memsize = 0;
554
+ }
555
+
556
+ if (p <= b_end - 16) {
557
+ const uint8_t *const limit = b_end - 16;
558
+ uint32_t v1 = state->v1;
559
+ uint32_t v2 = state->v2;
560
+ uint32_t v3 = state->v3;
561
+ uint32_t v4 = state->v4;
562
+
563
+ do {
564
+ v1 = xxh32_round(v1, get_unaligned_le32(p));
565
+ p += 4;
566
+ v2 = xxh32_round(v2, get_unaligned_le32(p));
567
+ p += 4;
568
+ v3 = xxh32_round(v3, get_unaligned_le32(p));
569
+ p += 4;
570
+ v4 = xxh32_round(v4, get_unaligned_le32(p));
571
+ p += 4;
572
+ } while (p <= limit);
573
+
574
+ state->v1 = v1;
575
+ state->v2 = v2;
576
+ state->v3 = v3;
577
+ state->v4 = v4;
578
+ }
579
+
580
+ if (p < b_end) {
581
+ __builtin_memcpy(state->mem32, p, (size_t)(b_end-p));
582
+ state->memsize = (uint32_t)(b_end-p);
583
+ }
584
+
585
+ return 0;
586
+ }
587
+
588
+ XXH_API uint32_t xxh32_digest(const struct xxh32_state *state)
589
+ {
590
+ const uint8_t *p = (const uint8_t *)state->mem32;
591
+ const uint8_t *const b_end = (const uint8_t *)(state->mem32) +
592
+ state->memsize;
593
+ uint32_t h32;
594
+
595
+ if (state->large_len) {
596
+ h32 = xxh_rotl32(state->v1, 1) + xxh_rotl32(state->v2, 7) +
597
+ xxh_rotl32(state->v3, 12) + xxh_rotl32(state->v4, 18);
598
+ } else {
599
+ h32 = state->v3 /* == seed */ + PRIME32_5;
600
+ }
601
+
602
+ h32 += state->total_len_32;
603
+
604
+ while (p + 4 <= b_end) {
605
+ h32 += get_unaligned_le32(p) * PRIME32_3;
606
+ h32 = xxh_rotl32(h32, 17) * PRIME32_4;
607
+ p += 4;
608
+ }
609
+
610
+ while (p < b_end) {
611
+ h32 += (*p) * PRIME32_5;
612
+ h32 = xxh_rotl32(h32, 11) * PRIME32_1;
613
+ p++;
614
+ }
615
+
616
+ h32 ^= h32 >> 15;
617
+ h32 *= PRIME32_2;
618
+ h32 ^= h32 >> 13;
619
+ h32 *= PRIME32_3;
620
+ h32 ^= h32 >> 16;
621
+
622
+ return h32;
623
+ }
624
+
625
+ XXH_API int xxh64_update(struct xxh64_state *state, const void *input, const size_t len)
626
+ {
627
+ const uint8_t *p = (const uint8_t *)input;
628
+ const uint8_t *const b_end = p + len;
629
+
630
+ if (input == NULL)
631
+ return -EINVAL;
632
+
633
+ state->total_len += len;
634
+
635
+ if (state->memsize + len < 32) { /* fill in tmp buffer */
636
+ __builtin_memcpy(((uint8_t *)state->mem64) + state->memsize, input, len);
637
+ state->memsize += (uint32_t)len;
638
+ return 0;
639
+ }
640
+
641
+ if (state->memsize) { /* tmp buffer is full */
642
+ uint64_t *p64 = state->mem64;
643
+
644
+ __builtin_memcpy(((uint8_t *)p64) + state->memsize, input,
645
+ 32 - state->memsize);
646
+
647
+ state->v1 = xxh64_round(state->v1, get_unaligned_le64(p64));
648
+ p64++;
649
+ state->v2 = xxh64_round(state->v2, get_unaligned_le64(p64));
650
+ p64++;
651
+ state->v3 = xxh64_round(state->v3, get_unaligned_le64(p64));
652
+ p64++;
653
+ state->v4 = xxh64_round(state->v4, get_unaligned_le64(p64));
654
+
655
+ p += 32 - state->memsize;
656
+ state->memsize = 0;
657
+ }
658
+
659
+ if (p + 32 <= b_end) {
660
+ const uint8_t *const limit = b_end - 32;
661
+ uint64_t v1 = state->v1;
662
+ uint64_t v2 = state->v2;
663
+ uint64_t v3 = state->v3;
664
+ uint64_t v4 = state->v4;
665
+
666
+ do {
667
+ v1 = xxh64_round(v1, get_unaligned_le64(p));
668
+ p += 8;
669
+ v2 = xxh64_round(v2, get_unaligned_le64(p));
670
+ p += 8;
671
+ v3 = xxh64_round(v3, get_unaligned_le64(p));
672
+ p += 8;
673
+ v4 = xxh64_round(v4, get_unaligned_le64(p));
674
+ p += 8;
675
+ } while (p <= limit);
676
+
677
+ state->v1 = v1;
678
+ state->v2 = v2;
679
+ state->v3 = v3;
680
+ state->v4 = v4;
681
+ }
682
+
683
+ if (p < b_end) {
684
+ __builtin_memcpy(state->mem64, p, (size_t)(b_end-p));
685
+ state->memsize = (uint32_t)(b_end - p);
686
+ }
687
+
688
+ return 0;
689
+ }
690
+
691
+ XXH_API uint64_t xxh64_digest(const struct xxh64_state *state)
692
+ {
693
+ const uint8_t *p = (const uint8_t *)state->mem64;
694
+ const uint8_t *const b_end = (const uint8_t *)state->mem64 +
695
+ state->memsize;
696
+ uint64_t h64;
697
+
698
+ if (state->total_len >= 32) {
699
+ const uint64_t v1 = state->v1;
700
+ const uint64_t v2 = state->v2;
701
+ const uint64_t v3 = state->v3;
702
+ const uint64_t v4 = state->v4;
703
+
704
+ h64 = xxh_rotl64(v1, 1) + xxh_rotl64(v2, 7) +
705
+ xxh_rotl64(v3, 12) + xxh_rotl64(v4, 18);
706
+ h64 = xxh64_merge_round(h64, v1);
707
+ h64 = xxh64_merge_round(h64, v2);
708
+ h64 = xxh64_merge_round(h64, v3);
709
+ h64 = xxh64_merge_round(h64, v4);
710
+ } else {
711
+ h64 = state->v3 + PRIME64_5;
712
+ }
713
+
714
+ h64 += (uint64_t)state->total_len;
715
+
716
+ while (p + 8 <= b_end) {
717
+ const uint64_t k1 = xxh64_round(0, get_unaligned_le64(p));
718
+
719
+ h64 ^= k1;
720
+ h64 = xxh_rotl64(h64, 27) * PRIME64_1 + PRIME64_4;
721
+ p += 8;
722
+ }
723
+
724
+ if (p + 4 <= b_end) {
725
+ h64 ^= (uint64_t)(get_unaligned_le32(p)) * PRIME64_1;
726
+ h64 = xxh_rotl64(h64, 23) * PRIME64_2 + PRIME64_3;
727
+ p += 4;
728
+ }
729
+
730
+ while (p < b_end) {
731
+ h64 ^= (*p) * PRIME64_5;
732
+ h64 = xxh_rotl64(h64, 11) * PRIME64_1;
733
+ p++;
734
+ }
735
+
736
+ h64 ^= h64 >> 33;
737
+ h64 *= PRIME64_2;
738
+ h64 ^= h64 >> 29;
739
+ h64 *= PRIME64_3;
740
+ h64 ^= h64 >> 32;
741
+
742
+ return h64;
743
+ }
744
+
745
+ #endif /* XXHASH_H */