koffi 2.3.6-beta.6 → 2.3.7

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 (276) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/package.json +2 -2
  3. package/src/cnoke/cnoke.js +3 -7
  4. package/src/cnoke/src/builder.js +9 -6
  5. package/src/cnoke/src/index.js +2 -2
  6. package/src/koffi/build/2.3.7/koffi_darwin_arm64/koffi.node +0 -0
  7. package/src/koffi/build/2.3.7/koffi_darwin_x64/koffi.node +0 -0
  8. package/src/koffi/build/2.3.7/koffi_freebsd_arm64/koffi.node +0 -0
  9. package/src/koffi/build/2.3.7/koffi_freebsd_ia32/koffi.node +0 -0
  10. package/src/koffi/build/2.3.7/koffi_freebsd_x64/koffi.node +0 -0
  11. package/src/koffi/build/2.3.7/koffi_linux_arm32hf/koffi.node +0 -0
  12. package/src/koffi/build/2.3.7/koffi_linux_arm64/koffi.node +0 -0
  13. package/src/koffi/build/2.3.7/koffi_linux_ia32/koffi.node +0 -0
  14. package/src/koffi/build/2.3.7/koffi_linux_riscv64hf64/koffi.node +0 -0
  15. package/src/koffi/build/2.3.7/koffi_linux_x64/koffi.node +0 -0
  16. package/src/koffi/build/2.3.7/koffi_openbsd_ia32/koffi.node +0 -0
  17. package/src/koffi/build/2.3.7/koffi_openbsd_x64/koffi.node +0 -0
  18. package/src/koffi/build/2.3.7/koffi_win32_arm64/koffi.node +0 -0
  19. package/src/koffi/build/2.3.7/koffi_win32_ia32/koffi.node +0 -0
  20. package/src/koffi/build/2.3.7/koffi_win32_x64/koffi.node +0 -0
  21. package/src/koffi/src/ffi.cc +2 -2
  22. package/src/koffi/src/index.d.ts +2 -2
  23. package/src/koffi/src/index.js +1 -0
  24. package/src/koffi/build/2.3.6-beta.6/koffi_darwin_arm64/koffi.node +0 -0
  25. package/src/koffi/build/2.3.6-beta.6/koffi_darwin_x64/koffi.node +0 -0
  26. package/src/koffi/build/2.3.6-beta.6/koffi_freebsd_arm64/koffi.node +0 -0
  27. package/src/koffi/build/2.3.6-beta.6/koffi_freebsd_ia32/koffi.node +0 -0
  28. package/src/koffi/build/2.3.6-beta.6/koffi_freebsd_x64/koffi.node +0 -0
  29. package/src/koffi/build/2.3.6-beta.6/koffi_linux_arm32hf/koffi.node +0 -0
  30. package/src/koffi/build/2.3.6-beta.6/koffi_linux_arm64/koffi.node +0 -0
  31. package/src/koffi/build/2.3.6-beta.6/koffi_linux_ia32/koffi.node +0 -0
  32. package/src/koffi/build/2.3.6-beta.6/koffi_linux_riscv64hf64/koffi.node +0 -0
  33. package/src/koffi/build/2.3.6-beta.6/koffi_linux_x64/koffi.node +0 -0
  34. package/src/koffi/build/2.3.6-beta.6/koffi_openbsd_ia32/koffi.node +0 -0
  35. package/src/koffi/build/2.3.6-beta.6/koffi_openbsd_x64/koffi.node +0 -0
  36. package/src/koffi/build/2.3.6-beta.6/koffi_win32_arm64/koffi.node +0 -0
  37. package/src/koffi/build/2.3.6-beta.6/koffi_win32_arm64/koffi.pdb +0 -0
  38. package/src/koffi/build/2.3.6-beta.6/koffi_win32_ia32/koffi.node +0 -0
  39. package/src/koffi/build/2.3.6-beta.6/koffi_win32_ia32/koffi.pdb +0 -0
  40. package/src/koffi/build/2.3.6-beta.6/koffi_win32_x64/koffi.node +0 -0
  41. package/src/koffi/build/2.3.6-beta.6/koffi_win32_x64/koffi.pdb +0 -0
  42. package/vendor/brotli/BUILD +0 -144
  43. package/vendor/brotli/CMakeLists.txt +0 -421
  44. package/vendor/brotli/CONTRIBUTING.md +0 -27
  45. package/vendor/brotli/LICENSE +0 -19
  46. package/vendor/brotli/MANIFEST.in +0 -17
  47. package/vendor/brotli/Makefile +0 -55
  48. package/vendor/brotli/Makefile.am +0 -38
  49. package/vendor/brotli/README +0 -15
  50. package/vendor/brotli/README.md +0 -104
  51. package/vendor/brotli/WORKSPACE +0 -21
  52. package/vendor/brotli/bootstrap +0 -35
  53. package/vendor/brotli/c/common/constants.c +0 -15
  54. package/vendor/brotli/c/common/constants.h +0 -200
  55. package/vendor/brotli/c/common/context.c +0 -156
  56. package/vendor/brotli/c/common/context.h +0 -113
  57. package/vendor/brotli/c/common/dictionary.c +0 -5914
  58. package/vendor/brotli/c/common/dictionary.h +0 -64
  59. package/vendor/brotli/c/common/platform.c +0 -22
  60. package/vendor/brotli/c/common/platform.h +0 -596
  61. package/vendor/brotli/c/common/transform.c +0 -291
  62. package/vendor/brotli/c/common/transform.h +0 -85
  63. package/vendor/brotli/c/common/version.h +0 -26
  64. package/vendor/brotli/c/dec/bit_reader.c +0 -76
  65. package/vendor/brotli/c/dec/bit_reader.h +0 -351
  66. package/vendor/brotli/c/dec/decode.c +0 -2608
  67. package/vendor/brotli/c/dec/huffman.c +0 -339
  68. package/vendor/brotli/c/dec/huffman.h +0 -121
  69. package/vendor/brotli/c/dec/prefix.h +0 -732
  70. package/vendor/brotli/c/dec/state.c +0 -159
  71. package/vendor/brotli/c/dec/state.h +0 -365
  72. package/vendor/brotli/c/enc/backward_references.c +0 -145
  73. package/vendor/brotli/c/enc/backward_references.h +0 -39
  74. package/vendor/brotli/c/enc/backward_references_hq.c +0 -843
  75. package/vendor/brotli/c/enc/backward_references_hq.h +0 -95
  76. package/vendor/brotli/c/enc/backward_references_inc.h +0 -163
  77. package/vendor/brotli/c/enc/bit_cost.c +0 -35
  78. package/vendor/brotli/c/enc/bit_cost.h +0 -63
  79. package/vendor/brotli/c/enc/bit_cost_inc.h +0 -127
  80. package/vendor/brotli/c/enc/block_encoder_inc.h +0 -34
  81. package/vendor/brotli/c/enc/block_splitter.c +0 -194
  82. package/vendor/brotli/c/enc/block_splitter.h +0 -51
  83. package/vendor/brotli/c/enc/block_splitter_inc.h +0 -440
  84. package/vendor/brotli/c/enc/brotli_bit_stream.c +0 -1314
  85. package/vendor/brotli/c/enc/brotli_bit_stream.h +0 -84
  86. package/vendor/brotli/c/enc/cluster.c +0 -56
  87. package/vendor/brotli/c/enc/cluster.h +0 -48
  88. package/vendor/brotli/c/enc/cluster_inc.h +0 -320
  89. package/vendor/brotli/c/enc/command.c +0 -28
  90. package/vendor/brotli/c/enc/command.h +0 -190
  91. package/vendor/brotli/c/enc/compress_fragment.c +0 -790
  92. package/vendor/brotli/c/enc/compress_fragment.h +0 -61
  93. package/vendor/brotli/c/enc/compress_fragment_two_pass.c +0 -645
  94. package/vendor/brotli/c/enc/compress_fragment_two_pass.h +0 -54
  95. package/vendor/brotli/c/enc/dictionary_hash.c +0 -1846
  96. package/vendor/brotli/c/enc/dictionary_hash.h +0 -25
  97. package/vendor/brotli/c/enc/encode.c +0 -1927
  98. package/vendor/brotli/c/enc/encoder_dict.c +0 -33
  99. package/vendor/brotli/c/enc/encoder_dict.h +0 -43
  100. package/vendor/brotli/c/enc/entropy_encode.c +0 -503
  101. package/vendor/brotli/c/enc/entropy_encode.h +0 -122
  102. package/vendor/brotli/c/enc/entropy_encode_static.h +0 -539
  103. package/vendor/brotli/c/enc/fast_log.c +0 -105
  104. package/vendor/brotli/c/enc/fast_log.h +0 -66
  105. package/vendor/brotli/c/enc/find_match_length.h +0 -79
  106. package/vendor/brotli/c/enc/hash.h +0 -488
  107. package/vendor/brotli/c/enc/hash_composite_inc.h +0 -125
  108. package/vendor/brotli/c/enc/hash_forgetful_chain_inc.h +0 -293
  109. package/vendor/brotli/c/enc/hash_longest_match64_inc.h +0 -267
  110. package/vendor/brotli/c/enc/hash_longest_match_inc.h +0 -262
  111. package/vendor/brotli/c/enc/hash_longest_match_quickly_inc.h +0 -266
  112. package/vendor/brotli/c/enc/hash_rolling_inc.h +0 -212
  113. package/vendor/brotli/c/enc/hash_to_binary_tree_inc.h +0 -329
  114. package/vendor/brotli/c/enc/histogram.c +0 -100
  115. package/vendor/brotli/c/enc/histogram.h +0 -63
  116. package/vendor/brotli/c/enc/histogram_inc.h +0 -51
  117. package/vendor/brotli/c/enc/literal_cost.c +0 -175
  118. package/vendor/brotli/c/enc/literal_cost.h +0 -30
  119. package/vendor/brotli/c/enc/memory.c +0 -170
  120. package/vendor/brotli/c/enc/memory.h +0 -114
  121. package/vendor/brotli/c/enc/metablock.c +0 -663
  122. package/vendor/brotli/c/enc/metablock.h +0 -105
  123. package/vendor/brotli/c/enc/metablock_inc.h +0 -183
  124. package/vendor/brotli/c/enc/params.h +0 -46
  125. package/vendor/brotli/c/enc/prefix.h +0 -53
  126. package/vendor/brotli/c/enc/quality.h +0 -165
  127. package/vendor/brotli/c/enc/ringbuffer.h +0 -167
  128. package/vendor/brotli/c/enc/static_dict.c +0 -486
  129. package/vendor/brotli/c/enc/static_dict.h +0 -40
  130. package/vendor/brotli/c/enc/static_dict_lut.h +0 -5864
  131. package/vendor/brotli/c/enc/utf8_util.c +0 -85
  132. package/vendor/brotli/c/enc/utf8_util.h +0 -32
  133. package/vendor/brotli/c/enc/write_bits.h +0 -87
  134. package/vendor/brotli/c/include/brotli/decode.h +0 -344
  135. package/vendor/brotli/c/include/brotli/encode.h +0 -448
  136. package/vendor/brotli/c/include/brotli/port.h +0 -288
  137. package/vendor/brotli/c/include/brotli/types.h +0 -83
  138. package/vendor/brotli/c/tools/brotli.c +0 -1116
  139. package/vendor/brotli/c/tools/brotli.md +0 -107
  140. package/vendor/brotli/compiler_config_setting.bzl +0 -28
  141. package/vendor/brotli/configure +0 -8
  142. package/vendor/brotli/configure-cmake +0 -318
  143. package/vendor/brotli/configure.ac +0 -14
  144. package/vendor/brotli/docs/brotli.1 +0 -132
  145. package/vendor/brotli/docs/constants.h.3 +0 -47
  146. package/vendor/brotli/docs/decode.h.3 +0 -415
  147. package/vendor/brotli/docs/encode.h.3 +0 -586
  148. package/vendor/brotli/docs/types.h.3 +0 -117
  149. package/vendor/brotli/premake5.lua +0 -78
  150. package/vendor/brotli/python/Makefile +0 -57
  151. package/vendor/brotli/python/README.md +0 -54
  152. package/vendor/brotli/python/_brotli.cc +0 -753
  153. package/vendor/brotli/python/bro.py +0 -160
  154. package/vendor/brotli/python/brotli.py +0 -56
  155. package/vendor/brotli/python/tests/__init__.py +0 -0
  156. package/vendor/brotli/python/tests/_test_utils.py +0 -112
  157. package/vendor/brotli/python/tests/bro_test.py +0 -102
  158. package/vendor/brotli/python/tests/compress_test.py +0 -41
  159. package/vendor/brotli/python/tests/compressor_test.py +0 -94
  160. package/vendor/brotli/python/tests/decompress_test.py +0 -42
  161. package/vendor/brotli/python/tests/decompressor_test.py +0 -59
  162. package/vendor/brotli/scripts/libbrotlicommon.pc.in +0 -11
  163. package/vendor/brotli/scripts/libbrotlidec.pc.in +0 -12
  164. package/vendor/brotli/scripts/libbrotlienc.pc.in +0 -12
  165. package/vendor/brotli/scripts/sources.lst +0 -104
  166. package/vendor/brotli/setup.cfg +0 -5
  167. package/vendor/brotli/setup.py +0 -293
  168. package/vendor/brotli/tests/Makefile +0 -17
  169. package/vendor/brotli/tests/compatibility_test.sh +0 -25
  170. package/vendor/brotli/tests/roundtrip_test.sh +0 -36
  171. package/vendor/brotli/tests/run-compatibility-test.cmake +0 -31
  172. package/vendor/brotli/tests/run-roundtrip-test.cmake +0 -36
  173. package/vendor/brotli/tests/testdata/empty +0 -0
  174. package/vendor/brotli/tests/testdata/empty.compressed +0 -1
  175. package/vendor/brotli/tests/testdata/ukkonooa +0 -1
  176. package/vendor/brotli/tests/testdata/ukkonooa.compressed +0 -0
  177. package/vendor/dragonbox/CMakeLists.txt +0 -123
  178. package/vendor/dragonbox/LICENSE-Apache2-LLVM +0 -218
  179. package/vendor/dragonbox/LICENSE-Boost +0 -23
  180. package/vendor/dragonbox/README.md +0 -277
  181. package/vendor/dragonbox/cmake/dragonboxConfig.cmake +0 -1
  182. package/vendor/dragonbox/include/dragonbox/dragonbox.h +0 -2674
  183. package/vendor/dragonbox/include/dragonbox/dragonbox_to_chars.h +0 -108
  184. package/vendor/dragonbox/other_files/Dragonbox.pdf +0 -0
  185. package/vendor/dragonbox/other_files/Dragonbox_old.pdf +0 -0
  186. package/vendor/dragonbox/other_files/milo_benchmark.png +0 -0
  187. package/vendor/dragonbox/other_files/unknown_win64_vc2019.html +0 -540
  188. package/vendor/dragonbox/other_files/unknown_win64_vc2019_randomdigit_time.png +0 -0
  189. package/vendor/dragonbox/source/dragonbox_to_chars.cpp +0 -303
  190. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/CMakeLists.txt +0 -24
  191. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.cpp +0 -238
  192. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.h +0 -95
  193. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/grisu_exact.h +0 -2666
  194. package/vendor/dragonbox/subproject/3rdparty/ryu/CMakeLists.txt +0 -16
  195. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/common.h +0 -114
  196. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s.c +0 -509
  197. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_full_table.h +0 -367
  198. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_intrinsics.h +0 -357
  199. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/digit_table.h +0 -35
  200. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s.c +0 -345
  201. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_full_table.h +0 -55
  202. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_intrinsics.h +0 -128
  203. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/ryu.h +0 -46
  204. package/vendor/dragonbox/subproject/3rdparty/schubfach/CMakeLists.txt +0 -22
  205. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.cc +0 -699
  206. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.h +0 -31
  207. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.cc +0 -1354
  208. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.h +0 -31
  209. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/example_shaded_plots.m +0 -68
  210. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/license.txt +0 -25
  211. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution.m +0 -92
  212. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution_prctile.m +0 -121
  213. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_histogram_shaded.m +0 -99
  214. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_shaded.m +0 -93
  215. package/vendor/dragonbox/subproject/benchmark/CMakeLists.txt +0 -65
  216. package/vendor/dragonbox/subproject/benchmark/include/benchmark.h +0 -40
  217. package/vendor/dragonbox/subproject/benchmark/matlab/plot_benchmarks.m +0 -22
  218. package/vendor/dragonbox/subproject/benchmark/matlab/plot_digit_benchmark.m +0 -78
  219. package/vendor/dragonbox/subproject/benchmark/matlab/plot_uniform_benchmark.m +0 -95
  220. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_clang.png +0 -0
  221. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_msvc.png +0 -0
  222. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_clang.png +0 -0
  223. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_msvc.png +0 -0
  224. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_clang.png +0 -0
  225. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_msvc.png +0 -0
  226. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_clang.png +0 -0
  227. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_msvc.png +0 -0
  228. package/vendor/dragonbox/subproject/benchmark/source/benchmark.cpp +0 -238
  229. package/vendor/dragonbox/subproject/benchmark/source/dragonbox.cpp +0 -30
  230. package/vendor/dragonbox/subproject/benchmark/source/grisu_exact.cpp +0 -36
  231. package/vendor/dragonbox/subproject/benchmark/source/ryu.cpp +0 -27
  232. package/vendor/dragonbox/subproject/benchmark/source/schubfach.cpp +0 -31
  233. package/vendor/dragonbox/subproject/common/CMakeLists.txt +0 -42
  234. package/vendor/dragonbox/subproject/common/include/best_rational_approx.h +0 -97
  235. package/vendor/dragonbox/subproject/common/include/big_uint.h +0 -218
  236. package/vendor/dragonbox/subproject/common/include/continued_fractions.h +0 -174
  237. package/vendor/dragonbox/subproject/common/include/good_rational_approx.h +0 -267
  238. package/vendor/dragonbox/subproject/common/include/random_float.h +0 -182
  239. package/vendor/dragonbox/subproject/common/include/rational_continued_fractions.h +0 -57
  240. package/vendor/dragonbox/subproject/common/source/big_uint.cpp +0 -602
  241. package/vendor/dragonbox/subproject/meta/CMakeLists.txt +0 -41
  242. package/vendor/dragonbox/subproject/meta/results/binary32_generated_cache.txt +0 -82
  243. package/vendor/dragonbox/subproject/meta/results/binary64_compressed_cache_error_table.txt +0 -10
  244. package/vendor/dragonbox/subproject/meta/results/binary64_generated_cache.txt +0 -623
  245. package/vendor/dragonbox/subproject/meta/source/generate_cache.cpp +0 -126
  246. package/vendor/dragonbox/subproject/meta/source/live_test.cpp +0 -81
  247. package/vendor/dragonbox/subproject/meta/source/perf_test.cpp +0 -104
  248. package/vendor/dragonbox/subproject/meta/source/sandbox.cpp +0 -20
  249. package/vendor/dragonbox/subproject/test/CMakeLists.txt +0 -70
  250. package/vendor/dragonbox/subproject/test/results/binary32.csv +0 -255
  251. package/vendor/dragonbox/subproject/test/results/binary64.csv +0 -2047
  252. package/vendor/dragonbox/subproject/test/results/plot_required_bits.m +0 -18
  253. package/vendor/dragonbox/subproject/test/source/test_all_shorter_interval_cases.cpp +0 -88
  254. package/vendor/dragonbox/subproject/test/source/uniform_random_test.cpp +0 -95
  255. package/vendor/dragonbox/subproject/test/source/verify_cache_precision.cpp +0 -338
  256. package/vendor/dragonbox/subproject/test/source/verify_compressed_cache.cpp +0 -154
  257. package/vendor/dragonbox/subproject/test/source/verify_fast_multiplication.cpp +0 -168
  258. package/vendor/dragonbox/subproject/test/source/verify_log_computation.cpp +0 -251
  259. package/vendor/dragonbox/subproject/test/source/verify_magic_division.cpp +0 -113
  260. package/vendor/miniz/ChangeLog.md +0 -239
  261. package/vendor/miniz/LICENSE +0 -22
  262. package/vendor/miniz/examples/example1.c +0 -105
  263. package/vendor/miniz/examples/example2.c +0 -164
  264. package/vendor/miniz/examples/example3.c +0 -269
  265. package/vendor/miniz/examples/example4.c +0 -102
  266. package/vendor/miniz/examples/example5.c +0 -327
  267. package/vendor/miniz/examples/example6.c +0 -166
  268. package/vendor/miniz/miniz.c +0 -7835
  269. package/vendor/miniz/miniz.h +0 -1422
  270. package/vendor/miniz/readme.md +0 -46
  271. /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_arm64/koffi.exp +0 -0
  272. /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_arm64/koffi.lib +0 -0
  273. /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_ia32/koffi.exp +0 -0
  274. /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_ia32/koffi.lib +0 -0
  275. /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_x64/koffi.exp +0 -0
  276. /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_x64/koffi.lib +0 -0
@@ -1,339 +0,0 @@
1
- /* Copyright 2013 Google Inc. All Rights Reserved.
2
-
3
- Distributed under MIT license.
4
- See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
5
- */
6
-
7
- /* Utilities for building Huffman decoding tables. */
8
-
9
- #include "./huffman.h"
10
-
11
- #include <string.h> /* memcpy, memset */
12
-
13
- #include "../common/constants.h"
14
- #include "../common/platform.h"
15
- #include <brotli/types.h>
16
-
17
- #if defined(__cplusplus) || defined(c_plusplus)
18
- extern "C" {
19
- #endif
20
-
21
- #define BROTLI_REVERSE_BITS_MAX 8
22
-
23
- #if defined(BROTLI_RBIT)
24
- #define BROTLI_REVERSE_BITS_BASE \
25
- ((sizeof(brotli_reg_t) << 3) - BROTLI_REVERSE_BITS_MAX)
26
- #else
27
- #define BROTLI_REVERSE_BITS_BASE 0
28
- static uint8_t kReverseBits[1 << BROTLI_REVERSE_BITS_MAX] = {
29
- 0x00, 0x80, 0x40, 0xC0, 0x20, 0xA0, 0x60, 0xE0,
30
- 0x10, 0x90, 0x50, 0xD0, 0x30, 0xB0, 0x70, 0xF0,
31
- 0x08, 0x88, 0x48, 0xC8, 0x28, 0xA8, 0x68, 0xE8,
32
- 0x18, 0x98, 0x58, 0xD8, 0x38, 0xB8, 0x78, 0xF8,
33
- 0x04, 0x84, 0x44, 0xC4, 0x24, 0xA4, 0x64, 0xE4,
34
- 0x14, 0x94, 0x54, 0xD4, 0x34, 0xB4, 0x74, 0xF4,
35
- 0x0C, 0x8C, 0x4C, 0xCC, 0x2C, 0xAC, 0x6C, 0xEC,
36
- 0x1C, 0x9C, 0x5C, 0xDC, 0x3C, 0xBC, 0x7C, 0xFC,
37
- 0x02, 0x82, 0x42, 0xC2, 0x22, 0xA2, 0x62, 0xE2,
38
- 0x12, 0x92, 0x52, 0xD2, 0x32, 0xB2, 0x72, 0xF2,
39
- 0x0A, 0x8A, 0x4A, 0xCA, 0x2A, 0xAA, 0x6A, 0xEA,
40
- 0x1A, 0x9A, 0x5A, 0xDA, 0x3A, 0xBA, 0x7A, 0xFA,
41
- 0x06, 0x86, 0x46, 0xC6, 0x26, 0xA6, 0x66, 0xE6,
42
- 0x16, 0x96, 0x56, 0xD6, 0x36, 0xB6, 0x76, 0xF6,
43
- 0x0E, 0x8E, 0x4E, 0xCE, 0x2E, 0xAE, 0x6E, 0xEE,
44
- 0x1E, 0x9E, 0x5E, 0xDE, 0x3E, 0xBE, 0x7E, 0xFE,
45
- 0x01, 0x81, 0x41, 0xC1, 0x21, 0xA1, 0x61, 0xE1,
46
- 0x11, 0x91, 0x51, 0xD1, 0x31, 0xB1, 0x71, 0xF1,
47
- 0x09, 0x89, 0x49, 0xC9, 0x29, 0xA9, 0x69, 0xE9,
48
- 0x19, 0x99, 0x59, 0xD9, 0x39, 0xB9, 0x79, 0xF9,
49
- 0x05, 0x85, 0x45, 0xC5, 0x25, 0xA5, 0x65, 0xE5,
50
- 0x15, 0x95, 0x55, 0xD5, 0x35, 0xB5, 0x75, 0xF5,
51
- 0x0D, 0x8D, 0x4D, 0xCD, 0x2D, 0xAD, 0x6D, 0xED,
52
- 0x1D, 0x9D, 0x5D, 0xDD, 0x3D, 0xBD, 0x7D, 0xFD,
53
- 0x03, 0x83, 0x43, 0xC3, 0x23, 0xA3, 0x63, 0xE3,
54
- 0x13, 0x93, 0x53, 0xD3, 0x33, 0xB3, 0x73, 0xF3,
55
- 0x0B, 0x8B, 0x4B, 0xCB, 0x2B, 0xAB, 0x6B, 0xEB,
56
- 0x1B, 0x9B, 0x5B, 0xDB, 0x3B, 0xBB, 0x7B, 0xFB,
57
- 0x07, 0x87, 0x47, 0xC7, 0x27, 0xA7, 0x67, 0xE7,
58
- 0x17, 0x97, 0x57, 0xD7, 0x37, 0xB7, 0x77, 0xF7,
59
- 0x0F, 0x8F, 0x4F, 0xCF, 0x2F, 0xAF, 0x6F, 0xEF,
60
- 0x1F, 0x9F, 0x5F, 0xDF, 0x3F, 0xBF, 0x7F, 0xFF
61
- };
62
- #endif /* BROTLI_RBIT */
63
-
64
- #define BROTLI_REVERSE_BITS_LOWEST \
65
- ((brotli_reg_t)1 << (BROTLI_REVERSE_BITS_MAX - 1 + BROTLI_REVERSE_BITS_BASE))
66
-
67
- /* Returns reverse(num >> BROTLI_REVERSE_BITS_BASE, BROTLI_REVERSE_BITS_MAX),
68
- where reverse(value, len) is the bit-wise reversal of the len least
69
- significant bits of value. */
70
- static BROTLI_INLINE brotli_reg_t BrotliReverseBits(brotli_reg_t num) {
71
- #if defined(BROTLI_RBIT)
72
- return BROTLI_RBIT(num);
73
- #else
74
- return kReverseBits[num];
75
- #endif
76
- }
77
-
78
- /* Stores code in table[0], table[step], table[2*step], ..., table[end] */
79
- /* Assumes that end is an integer multiple of step */
80
- static BROTLI_INLINE void ReplicateValue(HuffmanCode* table,
81
- int step, int end,
82
- HuffmanCode code) {
83
- do {
84
- end -= step;
85
- table[end] = code;
86
- } while (end > 0);
87
- }
88
-
89
- /* Returns the table width of the next 2nd level table. |count| is the histogram
90
- of bit lengths for the remaining symbols, |len| is the code length of the
91
- next processed symbol. */
92
- static BROTLI_INLINE int NextTableBitSize(const uint16_t* const count,
93
- int len, int root_bits) {
94
- int left = 1 << (len - root_bits);
95
- while (len < BROTLI_HUFFMAN_MAX_CODE_LENGTH) {
96
- left -= count[len];
97
- if (left <= 0) break;
98
- ++len;
99
- left <<= 1;
100
- }
101
- return len - root_bits;
102
- }
103
-
104
- void BrotliBuildCodeLengthsHuffmanTable(HuffmanCode* table,
105
- const uint8_t* const code_lengths,
106
- uint16_t* count) {
107
- HuffmanCode code; /* current table entry */
108
- int symbol; /* symbol index in original or sorted table */
109
- brotli_reg_t key; /* prefix code */
110
- brotli_reg_t key_step; /* prefix code addend */
111
- int step; /* step size to replicate values in current table */
112
- int table_size; /* size of current table */
113
- int sorted[BROTLI_CODE_LENGTH_CODES]; /* symbols sorted by code length */
114
- /* offsets in sorted table for each length */
115
- int offset[BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH + 1];
116
- int bits;
117
- int bits_count;
118
- BROTLI_DCHECK(BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH <=
119
- BROTLI_REVERSE_BITS_MAX);
120
-
121
- /* Generate offsets into sorted symbol table by code length. */
122
- symbol = -1;
123
- bits = 1;
124
- BROTLI_REPEAT(BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH, {
125
- symbol += count[bits];
126
- offset[bits] = symbol;
127
- bits++;
128
- });
129
- /* Symbols with code length 0 are placed after all other symbols. */
130
- offset[0] = BROTLI_CODE_LENGTH_CODES - 1;
131
-
132
- /* Sort symbols by length, by symbol order within each length. */
133
- symbol = BROTLI_CODE_LENGTH_CODES;
134
- do {
135
- BROTLI_REPEAT(6, {
136
- symbol--;
137
- sorted[offset[code_lengths[symbol]]--] = symbol;
138
- });
139
- } while (symbol != 0);
140
-
141
- table_size = 1 << BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH;
142
-
143
- /* Special case: all symbols but one have 0 code length. */
144
- if (offset[0] == 0) {
145
- code = ConstructHuffmanCode(0, (uint16_t)sorted[0]);
146
- for (key = 0; key < (brotli_reg_t)table_size; ++key) {
147
- table[key] = code;
148
- }
149
- return;
150
- }
151
-
152
- /* Fill in table. */
153
- key = 0;
154
- key_step = BROTLI_REVERSE_BITS_LOWEST;
155
- symbol = 0;
156
- bits = 1;
157
- step = 2;
158
- do {
159
- for (bits_count = count[bits]; bits_count != 0; --bits_count) {
160
- code = ConstructHuffmanCode((uint8_t)bits, (uint16_t)sorted[symbol++]);
161
- ReplicateValue(&table[BrotliReverseBits(key)], step, table_size, code);
162
- key += key_step;
163
- }
164
- step <<= 1;
165
- key_step >>= 1;
166
- } while (++bits <= BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH);
167
- }
168
-
169
- uint32_t BrotliBuildHuffmanTable(HuffmanCode* root_table,
170
- int root_bits,
171
- const uint16_t* const symbol_lists,
172
- uint16_t* count) {
173
- HuffmanCode code; /* current table entry */
174
- HuffmanCode* table; /* next available space in table */
175
- int len; /* current code length */
176
- int symbol; /* symbol index in original or sorted table */
177
- brotli_reg_t key; /* prefix code */
178
- brotli_reg_t key_step; /* prefix code addend */
179
- brotli_reg_t sub_key; /* 2nd level table prefix code */
180
- brotli_reg_t sub_key_step; /* 2nd level table prefix code addend */
181
- int step; /* step size to replicate values in current table */
182
- int table_bits; /* key length of current table */
183
- int table_size; /* size of current table */
184
- int total_size; /* sum of root table size and 2nd level table sizes */
185
- int max_length = -1;
186
- int bits;
187
- int bits_count;
188
-
189
- BROTLI_DCHECK(root_bits <= BROTLI_REVERSE_BITS_MAX);
190
- BROTLI_DCHECK(BROTLI_HUFFMAN_MAX_CODE_LENGTH - root_bits <=
191
- BROTLI_REVERSE_BITS_MAX);
192
-
193
- while (symbol_lists[max_length] == 0xFFFF) max_length--;
194
- max_length += BROTLI_HUFFMAN_MAX_CODE_LENGTH + 1;
195
-
196
- table = root_table;
197
- table_bits = root_bits;
198
- table_size = 1 << table_bits;
199
- total_size = table_size;
200
-
201
- /* Fill in the root table. Reduce the table size to if possible,
202
- and create the repetitions by memcpy. */
203
- if (table_bits > max_length) {
204
- table_bits = max_length;
205
- table_size = 1 << table_bits;
206
- }
207
- key = 0;
208
- key_step = BROTLI_REVERSE_BITS_LOWEST;
209
- bits = 1;
210
- step = 2;
211
- do {
212
- symbol = bits - (BROTLI_HUFFMAN_MAX_CODE_LENGTH + 1);
213
- for (bits_count = count[bits]; bits_count != 0; --bits_count) {
214
- symbol = symbol_lists[symbol];
215
- code = ConstructHuffmanCode((uint8_t)bits, (uint16_t)symbol);
216
- ReplicateValue(&table[BrotliReverseBits(key)], step, table_size, code);
217
- key += key_step;
218
- }
219
- step <<= 1;
220
- key_step >>= 1;
221
- } while (++bits <= table_bits);
222
-
223
- /* If root_bits != table_bits then replicate to fill the remaining slots. */
224
- while (total_size != table_size) {
225
- memcpy(&table[table_size], &table[0],
226
- (size_t)table_size * sizeof(table[0]));
227
- table_size <<= 1;
228
- }
229
-
230
- /* Fill in 2nd level tables and add pointers to root table. */
231
- key_step = BROTLI_REVERSE_BITS_LOWEST >> (root_bits - 1);
232
- sub_key = (BROTLI_REVERSE_BITS_LOWEST << 1);
233
- sub_key_step = BROTLI_REVERSE_BITS_LOWEST;
234
- for (len = root_bits + 1, step = 2; len <= max_length; ++len) {
235
- symbol = len - (BROTLI_HUFFMAN_MAX_CODE_LENGTH + 1);
236
- for (; count[len] != 0; --count[len]) {
237
- if (sub_key == (BROTLI_REVERSE_BITS_LOWEST << 1U)) {
238
- table += table_size;
239
- table_bits = NextTableBitSize(count, len, root_bits);
240
- table_size = 1 << table_bits;
241
- total_size += table_size;
242
- sub_key = BrotliReverseBits(key);
243
- key += key_step;
244
- root_table[sub_key] = ConstructHuffmanCode(
245
- (uint8_t)(table_bits + root_bits),
246
- (uint16_t)(((size_t)(table - root_table)) - sub_key));
247
- sub_key = 0;
248
- }
249
- symbol = symbol_lists[symbol];
250
- code = ConstructHuffmanCode((uint8_t)(len - root_bits), (uint16_t)symbol);
251
- ReplicateValue(
252
- &table[BrotliReverseBits(sub_key)], step, table_size, code);
253
- sub_key += sub_key_step;
254
- }
255
- step <<= 1;
256
- sub_key_step >>= 1;
257
- }
258
- return (uint32_t)total_size;
259
- }
260
-
261
- uint32_t BrotliBuildSimpleHuffmanTable(HuffmanCode* table,
262
- int root_bits,
263
- uint16_t* val,
264
- uint32_t num_symbols) {
265
- uint32_t table_size = 1;
266
- const uint32_t goal_size = 1U << root_bits;
267
- switch (num_symbols) {
268
- case 0:
269
- table[0] = ConstructHuffmanCode(0, val[0]);
270
- break;
271
- case 1:
272
- if (val[1] > val[0]) {
273
- table[0] = ConstructHuffmanCode(1, val[0]);
274
- table[1] = ConstructHuffmanCode(1, val[1]);
275
- } else {
276
- table[0] = ConstructHuffmanCode(1, val[1]);
277
- table[1] = ConstructHuffmanCode(1, val[0]);
278
- }
279
- table_size = 2;
280
- break;
281
- case 2:
282
- table[0] = ConstructHuffmanCode(1, val[0]);
283
- table[2] = ConstructHuffmanCode(1, val[0]);
284
- if (val[2] > val[1]) {
285
- table[1] = ConstructHuffmanCode(2, val[1]);
286
- table[3] = ConstructHuffmanCode(2, val[2]);
287
- } else {
288
- table[1] = ConstructHuffmanCode(2, val[2]);
289
- table[3] = ConstructHuffmanCode(2, val[1]);
290
- }
291
- table_size = 4;
292
- break;
293
- case 3: {
294
- int i, k;
295
- for (i = 0; i < 3; ++i) {
296
- for (k = i + 1; k < 4; ++k) {
297
- if (val[k] < val[i]) {
298
- uint16_t t = val[k];
299
- val[k] = val[i];
300
- val[i] = t;
301
- }
302
- }
303
- }
304
- table[0] = ConstructHuffmanCode(2, val[0]);
305
- table[2] = ConstructHuffmanCode(2, val[1]);
306
- table[1] = ConstructHuffmanCode(2, val[2]);
307
- table[3] = ConstructHuffmanCode(2, val[3]);
308
- table_size = 4;
309
- break;
310
- }
311
- case 4: {
312
- if (val[3] < val[2]) {
313
- uint16_t t = val[3];
314
- val[3] = val[2];
315
- val[2] = t;
316
- }
317
- table[0] = ConstructHuffmanCode(1, val[0]);
318
- table[1] = ConstructHuffmanCode(2, val[1]);
319
- table[2] = ConstructHuffmanCode(1, val[0]);
320
- table[3] = ConstructHuffmanCode(3, val[2]);
321
- table[4] = ConstructHuffmanCode(1, val[0]);
322
- table[5] = ConstructHuffmanCode(2, val[1]);
323
- table[6] = ConstructHuffmanCode(1, val[0]);
324
- table[7] = ConstructHuffmanCode(3, val[3]);
325
- table_size = 8;
326
- break;
327
- }
328
- }
329
- while (table_size != goal_size) {
330
- memcpy(&table[table_size], &table[0],
331
- (size_t)table_size * sizeof(table[0]));
332
- table_size <<= 1;
333
- }
334
- return goal_size;
335
- }
336
-
337
- #if defined(__cplusplus) || defined(c_plusplus)
338
- } /* extern "C" */
339
- #endif
@@ -1,121 +0,0 @@
1
- /* Copyright 2013 Google Inc. All Rights Reserved.
2
-
3
- Distributed under MIT license.
4
- See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
5
- */
6
-
7
- /* Utilities for building Huffman decoding tables. */
8
-
9
- #ifndef BROTLI_DEC_HUFFMAN_H_
10
- #define BROTLI_DEC_HUFFMAN_H_
11
-
12
- #include "../common/platform.h"
13
- #include <brotli/types.h>
14
-
15
- #if defined(__cplusplus) || defined(c_plusplus)
16
- extern "C" {
17
- #endif
18
-
19
- #define BROTLI_HUFFMAN_MAX_CODE_LENGTH 15
20
-
21
- /* BROTLI_NUM_BLOCK_LEN_SYMBOLS == 26 */
22
- #define BROTLI_HUFFMAN_MAX_SIZE_26 396
23
- /* BROTLI_MAX_BLOCK_TYPE_SYMBOLS == 258 */
24
- #define BROTLI_HUFFMAN_MAX_SIZE_258 632
25
- /* BROTLI_MAX_CONTEXT_MAP_SYMBOLS == 272 */
26
- #define BROTLI_HUFFMAN_MAX_SIZE_272 646
27
-
28
- #define BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH 5
29
-
30
- #if ((defined(BROTLI_TARGET_ARMV7) || defined(BROTLI_TARGET_ARMV8_32)) && \
31
- BROTLI_GNUC_HAS_ATTRIBUTE(aligned, 2, 7, 0))
32
- #define BROTLI_HUFFMAN_CODE_FAST_LOAD
33
- #endif
34
-
35
- #if !defined(BROTLI_HUFFMAN_CODE_FAST_LOAD)
36
- /* Do not create this struct directly - use the ConstructHuffmanCode
37
- * constructor below! */
38
- typedef struct {
39
- uint8_t bits; /* number of bits used for this symbol */
40
- uint16_t value; /* symbol value or table offset */
41
- } HuffmanCode;
42
-
43
- static BROTLI_INLINE HuffmanCode ConstructHuffmanCode(const uint8_t bits,
44
- const uint16_t value) {
45
- HuffmanCode h;
46
- h.bits = bits;
47
- h.value = value;
48
- return h;
49
- }
50
-
51
- /* Please use the following macros to optimize HuffmanCode accesses in hot
52
- * paths.
53
- *
54
- * For example, assuming |table| contains a HuffmanCode pointer:
55
- *
56
- * BROTLI_HC_MARK_TABLE_FOR_FAST_LOAD(table);
57
- * BROTLI_HC_ADJUST_TABLE_INDEX(table, index_into_table);
58
- * *bits = BROTLI_HC_GET_BITS(table);
59
- * *value = BROTLI_HC_GET_VALUE(table);
60
- * BROTLI_HC_ADJUST_TABLE_INDEX(table, offset);
61
- * *bits2 = BROTLI_HC_GET_BITS(table);
62
- * *value2 = BROTLI_HC_GET_VALUE(table);
63
- *
64
- */
65
-
66
- #define BROTLI_HC_MARK_TABLE_FOR_FAST_LOAD(H)
67
- #define BROTLI_HC_ADJUST_TABLE_INDEX(H, V) H += (V)
68
-
69
- /* These must be given a HuffmanCode pointer! */
70
- #define BROTLI_HC_FAST_LOAD_BITS(H) (H->bits)
71
- #define BROTLI_HC_FAST_LOAD_VALUE(H) (H->value)
72
-
73
- #else /* BROTLI_HUFFMAN_CODE_FAST_LOAD */
74
-
75
- typedef BROTLI_ALIGNED(4) uint32_t HuffmanCode;
76
-
77
- static BROTLI_INLINE HuffmanCode ConstructHuffmanCode(const uint8_t bits,
78
- const uint16_t value) {
79
- return (HuffmanCode) ((value & 0xFFFF) << 16) | (bits & 0xFF);
80
- }
81
-
82
- #define BROTLI_HC_MARK_TABLE_FOR_FAST_LOAD(H) uint32_t __fastload_##H = (*H)
83
- #define BROTLI_HC_ADJUST_TABLE_INDEX(H, V) H += (V); __fastload_##H = (*H)
84
-
85
- /* These must be given a HuffmanCode pointer! */
86
- #define BROTLI_HC_FAST_LOAD_BITS(H) ((__fastload_##H) & 0xFF)
87
- #define BROTLI_HC_FAST_LOAD_VALUE(H) ((__fastload_##H) >> 16)
88
- #endif /* BROTLI_HUFFMAN_CODE_FAST_LOAD */
89
-
90
- /* Builds Huffman lookup table assuming code lengths are in symbol order. */
91
- BROTLI_INTERNAL void BrotliBuildCodeLengthsHuffmanTable(HuffmanCode* root_table,
92
- const uint8_t* const code_lengths, uint16_t* count);
93
-
94
- /* Builds Huffman lookup table assuming code lengths are in symbol order.
95
- Returns size of resulting table. */
96
- BROTLI_INTERNAL uint32_t BrotliBuildHuffmanTable(HuffmanCode* root_table,
97
- int root_bits, const uint16_t* const symbol_lists, uint16_t* count);
98
-
99
- /* Builds a simple Huffman table. The |num_symbols| parameter is to be
100
- interpreted as follows: 0 means 1 symbol, 1 means 2 symbols,
101
- 2 means 3 symbols, 3 means 4 symbols with lengths [2, 2, 2, 2],
102
- 4 means 4 symbols with lengths [1, 2, 3, 3]. */
103
- BROTLI_INTERNAL uint32_t BrotliBuildSimpleHuffmanTable(HuffmanCode* table,
104
- int root_bits, uint16_t* symbols, uint32_t num_symbols);
105
-
106
- /* Contains a collection of Huffman trees with the same alphabet size. */
107
- /* alphabet_size_limit is needed due to simple codes, since
108
- log2(alphabet_size_max) could be greater than log2(alphabet_size_limit). */
109
- typedef struct {
110
- HuffmanCode** htrees;
111
- HuffmanCode* codes;
112
- uint16_t alphabet_size_max;
113
- uint16_t alphabet_size_limit;
114
- uint16_t num_htrees;
115
- } HuffmanTreeGroup;
116
-
117
- #if defined(__cplusplus) || defined(c_plusplus)
118
- } /* extern "C" */
119
- #endif
120
-
121
- #endif /* BROTLI_DEC_HUFFMAN_H_ */