koffi 2.3.6 → 2.3.8

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 (280) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/package.json +2 -2
  3. package/src/cnoke/cnoke.js +3 -7
  4. package/src/cnoke/src/builder.js +7 -4
  5. package/src/cnoke/src/index.js +2 -2
  6. package/src/koffi/build/2.3.8/koffi_darwin_arm64/koffi.node +0 -0
  7. package/src/koffi/build/2.3.8/koffi_darwin_x64/koffi.node +0 -0
  8. package/src/koffi/build/2.3.8/koffi_freebsd_arm64/koffi.node +0 -0
  9. package/src/koffi/build/2.3.8/koffi_freebsd_ia32/koffi.node +0 -0
  10. package/src/koffi/build/2.3.8/koffi_freebsd_x64/koffi.node +0 -0
  11. package/src/koffi/build/2.3.8/koffi_linux_arm32hf/koffi.node +0 -0
  12. package/src/koffi/build/2.3.8/koffi_linux_arm64/koffi.node +0 -0
  13. package/src/koffi/build/2.3.8/koffi_linux_ia32/koffi.node +0 -0
  14. package/src/koffi/build/2.3.8/koffi_linux_riscv64hf64/koffi.node +0 -0
  15. package/src/koffi/build/2.3.8/koffi_linux_x64/koffi.node +0 -0
  16. package/src/koffi/build/2.3.8/koffi_openbsd_ia32/koffi.node +0 -0
  17. package/src/koffi/build/2.3.8/koffi_openbsd_x64/koffi.node +0 -0
  18. package/src/koffi/build/2.3.8/koffi_win32_arm64/koffi.node +0 -0
  19. package/src/koffi/build/2.3.8/koffi_win32_ia32/koffi.node +0 -0
  20. package/src/koffi/build/2.3.8/koffi_win32_x64/koffi.node +0 -0
  21. package/src/koffi/src/abi_arm64.cc +8 -2
  22. package/src/koffi/src/abi_x64_win.cc +8 -2
  23. package/src/koffi/src/abi_x86.cc +8 -2
  24. package/src/koffi/src/ffi.cc +3 -22
  25. package/src/koffi/src/index.d.ts +1 -1
  26. package/src/koffi/src/index.js +1 -0
  27. package/src/koffi/src/win32.hh +10 -4
  28. package/src/koffi/build/2.3.6/koffi_darwin_arm64/koffi.node +0 -0
  29. package/src/koffi/build/2.3.6/koffi_darwin_x64/koffi.node +0 -0
  30. package/src/koffi/build/2.3.6/koffi_freebsd_arm64/koffi.node +0 -0
  31. package/src/koffi/build/2.3.6/koffi_freebsd_ia32/koffi.node +0 -0
  32. package/src/koffi/build/2.3.6/koffi_freebsd_x64/koffi.node +0 -0
  33. package/src/koffi/build/2.3.6/koffi_linux_arm32hf/koffi.node +0 -0
  34. package/src/koffi/build/2.3.6/koffi_linux_arm64/koffi.node +0 -0
  35. package/src/koffi/build/2.3.6/koffi_linux_ia32/koffi.node +0 -0
  36. package/src/koffi/build/2.3.6/koffi_linux_riscv64hf64/koffi.node +0 -0
  37. package/src/koffi/build/2.3.6/koffi_linux_x64/koffi.node +0 -0
  38. package/src/koffi/build/2.3.6/koffi_openbsd_ia32/koffi.node +0 -0
  39. package/src/koffi/build/2.3.6/koffi_openbsd_x64/koffi.node +0 -0
  40. package/src/koffi/build/2.3.6/koffi_win32_arm64/koffi.node +0 -0
  41. package/src/koffi/build/2.3.6/koffi_win32_arm64/koffi.pdb +0 -0
  42. package/src/koffi/build/2.3.6/koffi_win32_ia32/koffi.node +0 -0
  43. package/src/koffi/build/2.3.6/koffi_win32_ia32/koffi.pdb +0 -0
  44. package/src/koffi/build/2.3.6/koffi_win32_x64/koffi.node +0 -0
  45. package/src/koffi/build/2.3.6/koffi_win32_x64/koffi.pdb +0 -0
  46. package/vendor/brotli/BUILD +0 -144
  47. package/vendor/brotli/CMakeLists.txt +0 -421
  48. package/vendor/brotli/CONTRIBUTING.md +0 -27
  49. package/vendor/brotli/LICENSE +0 -19
  50. package/vendor/brotli/MANIFEST.in +0 -17
  51. package/vendor/brotli/Makefile +0 -55
  52. package/vendor/brotli/Makefile.am +0 -38
  53. package/vendor/brotli/README +0 -15
  54. package/vendor/brotli/README.md +0 -104
  55. package/vendor/brotli/WORKSPACE +0 -21
  56. package/vendor/brotli/bootstrap +0 -35
  57. package/vendor/brotli/c/common/constants.c +0 -15
  58. package/vendor/brotli/c/common/constants.h +0 -200
  59. package/vendor/brotli/c/common/context.c +0 -156
  60. package/vendor/brotli/c/common/context.h +0 -113
  61. package/vendor/brotli/c/common/dictionary.c +0 -5914
  62. package/vendor/brotli/c/common/dictionary.h +0 -64
  63. package/vendor/brotli/c/common/platform.c +0 -22
  64. package/vendor/brotli/c/common/platform.h +0 -596
  65. package/vendor/brotli/c/common/transform.c +0 -291
  66. package/vendor/brotli/c/common/transform.h +0 -85
  67. package/vendor/brotli/c/common/version.h +0 -26
  68. package/vendor/brotli/c/dec/bit_reader.c +0 -76
  69. package/vendor/brotli/c/dec/bit_reader.h +0 -351
  70. package/vendor/brotli/c/dec/decode.c +0 -2608
  71. package/vendor/brotli/c/dec/huffman.c +0 -339
  72. package/vendor/brotli/c/dec/huffman.h +0 -121
  73. package/vendor/brotli/c/dec/prefix.h +0 -732
  74. package/vendor/brotli/c/dec/state.c +0 -159
  75. package/vendor/brotli/c/dec/state.h +0 -365
  76. package/vendor/brotli/c/enc/backward_references.c +0 -145
  77. package/vendor/brotli/c/enc/backward_references.h +0 -39
  78. package/vendor/brotli/c/enc/backward_references_hq.c +0 -843
  79. package/vendor/brotli/c/enc/backward_references_hq.h +0 -95
  80. package/vendor/brotli/c/enc/backward_references_inc.h +0 -163
  81. package/vendor/brotli/c/enc/bit_cost.c +0 -35
  82. package/vendor/brotli/c/enc/bit_cost.h +0 -63
  83. package/vendor/brotli/c/enc/bit_cost_inc.h +0 -127
  84. package/vendor/brotli/c/enc/block_encoder_inc.h +0 -34
  85. package/vendor/brotli/c/enc/block_splitter.c +0 -194
  86. package/vendor/brotli/c/enc/block_splitter.h +0 -51
  87. package/vendor/brotli/c/enc/block_splitter_inc.h +0 -440
  88. package/vendor/brotli/c/enc/brotli_bit_stream.c +0 -1314
  89. package/vendor/brotli/c/enc/brotli_bit_stream.h +0 -84
  90. package/vendor/brotli/c/enc/cluster.c +0 -56
  91. package/vendor/brotli/c/enc/cluster.h +0 -48
  92. package/vendor/brotli/c/enc/cluster_inc.h +0 -320
  93. package/vendor/brotli/c/enc/command.c +0 -28
  94. package/vendor/brotli/c/enc/command.h +0 -190
  95. package/vendor/brotli/c/enc/compress_fragment.c +0 -790
  96. package/vendor/brotli/c/enc/compress_fragment.h +0 -61
  97. package/vendor/brotli/c/enc/compress_fragment_two_pass.c +0 -645
  98. package/vendor/brotli/c/enc/compress_fragment_two_pass.h +0 -54
  99. package/vendor/brotli/c/enc/dictionary_hash.c +0 -1846
  100. package/vendor/brotli/c/enc/dictionary_hash.h +0 -25
  101. package/vendor/brotli/c/enc/encode.c +0 -1927
  102. package/vendor/brotli/c/enc/encoder_dict.c +0 -33
  103. package/vendor/brotli/c/enc/encoder_dict.h +0 -43
  104. package/vendor/brotli/c/enc/entropy_encode.c +0 -503
  105. package/vendor/brotli/c/enc/entropy_encode.h +0 -122
  106. package/vendor/brotli/c/enc/entropy_encode_static.h +0 -539
  107. package/vendor/brotli/c/enc/fast_log.c +0 -105
  108. package/vendor/brotli/c/enc/fast_log.h +0 -66
  109. package/vendor/brotli/c/enc/find_match_length.h +0 -79
  110. package/vendor/brotli/c/enc/hash.h +0 -488
  111. package/vendor/brotli/c/enc/hash_composite_inc.h +0 -125
  112. package/vendor/brotli/c/enc/hash_forgetful_chain_inc.h +0 -293
  113. package/vendor/brotli/c/enc/hash_longest_match64_inc.h +0 -267
  114. package/vendor/brotli/c/enc/hash_longest_match_inc.h +0 -262
  115. package/vendor/brotli/c/enc/hash_longest_match_quickly_inc.h +0 -266
  116. package/vendor/brotli/c/enc/hash_rolling_inc.h +0 -212
  117. package/vendor/brotli/c/enc/hash_to_binary_tree_inc.h +0 -329
  118. package/vendor/brotli/c/enc/histogram.c +0 -100
  119. package/vendor/brotli/c/enc/histogram.h +0 -63
  120. package/vendor/brotli/c/enc/histogram_inc.h +0 -51
  121. package/vendor/brotli/c/enc/literal_cost.c +0 -175
  122. package/vendor/brotli/c/enc/literal_cost.h +0 -30
  123. package/vendor/brotli/c/enc/memory.c +0 -170
  124. package/vendor/brotli/c/enc/memory.h +0 -114
  125. package/vendor/brotli/c/enc/metablock.c +0 -663
  126. package/vendor/brotli/c/enc/metablock.h +0 -105
  127. package/vendor/brotli/c/enc/metablock_inc.h +0 -183
  128. package/vendor/brotli/c/enc/params.h +0 -46
  129. package/vendor/brotli/c/enc/prefix.h +0 -53
  130. package/vendor/brotli/c/enc/quality.h +0 -165
  131. package/vendor/brotli/c/enc/ringbuffer.h +0 -167
  132. package/vendor/brotli/c/enc/static_dict.c +0 -486
  133. package/vendor/brotli/c/enc/static_dict.h +0 -40
  134. package/vendor/brotli/c/enc/static_dict_lut.h +0 -5864
  135. package/vendor/brotli/c/enc/utf8_util.c +0 -85
  136. package/vendor/brotli/c/enc/utf8_util.h +0 -32
  137. package/vendor/brotli/c/enc/write_bits.h +0 -87
  138. package/vendor/brotli/c/include/brotli/decode.h +0 -344
  139. package/vendor/brotli/c/include/brotli/encode.h +0 -448
  140. package/vendor/brotli/c/include/brotli/port.h +0 -288
  141. package/vendor/brotli/c/include/brotli/types.h +0 -83
  142. package/vendor/brotli/c/tools/brotli.c +0 -1116
  143. package/vendor/brotli/c/tools/brotli.md +0 -107
  144. package/vendor/brotli/compiler_config_setting.bzl +0 -28
  145. package/vendor/brotli/configure +0 -8
  146. package/vendor/brotli/configure-cmake +0 -318
  147. package/vendor/brotli/configure.ac +0 -14
  148. package/vendor/brotli/docs/brotli.1 +0 -132
  149. package/vendor/brotli/docs/constants.h.3 +0 -47
  150. package/vendor/brotli/docs/decode.h.3 +0 -415
  151. package/vendor/brotli/docs/encode.h.3 +0 -586
  152. package/vendor/brotli/docs/types.h.3 +0 -117
  153. package/vendor/brotli/premake5.lua +0 -78
  154. package/vendor/brotli/python/Makefile +0 -57
  155. package/vendor/brotli/python/README.md +0 -54
  156. package/vendor/brotli/python/_brotli.cc +0 -753
  157. package/vendor/brotli/python/bro.py +0 -160
  158. package/vendor/brotli/python/brotli.py +0 -56
  159. package/vendor/brotli/python/tests/__init__.py +0 -0
  160. package/vendor/brotli/python/tests/_test_utils.py +0 -112
  161. package/vendor/brotli/python/tests/bro_test.py +0 -102
  162. package/vendor/brotli/python/tests/compress_test.py +0 -41
  163. package/vendor/brotli/python/tests/compressor_test.py +0 -94
  164. package/vendor/brotli/python/tests/decompress_test.py +0 -42
  165. package/vendor/brotli/python/tests/decompressor_test.py +0 -59
  166. package/vendor/brotli/scripts/libbrotlicommon.pc.in +0 -11
  167. package/vendor/brotli/scripts/libbrotlidec.pc.in +0 -12
  168. package/vendor/brotli/scripts/libbrotlienc.pc.in +0 -12
  169. package/vendor/brotli/scripts/sources.lst +0 -104
  170. package/vendor/brotli/setup.cfg +0 -5
  171. package/vendor/brotli/setup.py +0 -293
  172. package/vendor/brotli/tests/Makefile +0 -17
  173. package/vendor/brotli/tests/compatibility_test.sh +0 -25
  174. package/vendor/brotli/tests/roundtrip_test.sh +0 -36
  175. package/vendor/brotli/tests/run-compatibility-test.cmake +0 -31
  176. package/vendor/brotli/tests/run-roundtrip-test.cmake +0 -36
  177. package/vendor/brotli/tests/testdata/empty +0 -0
  178. package/vendor/brotli/tests/testdata/empty.compressed +0 -1
  179. package/vendor/brotli/tests/testdata/ukkonooa +0 -1
  180. package/vendor/brotli/tests/testdata/ukkonooa.compressed +0 -0
  181. package/vendor/dragonbox/CMakeLists.txt +0 -123
  182. package/vendor/dragonbox/LICENSE-Apache2-LLVM +0 -218
  183. package/vendor/dragonbox/LICENSE-Boost +0 -23
  184. package/vendor/dragonbox/README.md +0 -277
  185. package/vendor/dragonbox/cmake/dragonboxConfig.cmake +0 -1
  186. package/vendor/dragonbox/include/dragonbox/dragonbox.h +0 -2674
  187. package/vendor/dragonbox/include/dragonbox/dragonbox_to_chars.h +0 -108
  188. package/vendor/dragonbox/other_files/Dragonbox.pdf +0 -0
  189. package/vendor/dragonbox/other_files/Dragonbox_old.pdf +0 -0
  190. package/vendor/dragonbox/other_files/milo_benchmark.png +0 -0
  191. package/vendor/dragonbox/other_files/unknown_win64_vc2019.html +0 -540
  192. package/vendor/dragonbox/other_files/unknown_win64_vc2019_randomdigit_time.png +0 -0
  193. package/vendor/dragonbox/source/dragonbox_to_chars.cpp +0 -303
  194. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/CMakeLists.txt +0 -24
  195. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.cpp +0 -238
  196. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.h +0 -95
  197. package/vendor/dragonbox/subproject/3rdparty/grisu_exact/grisu_exact.h +0 -2666
  198. package/vendor/dragonbox/subproject/3rdparty/ryu/CMakeLists.txt +0 -16
  199. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/common.h +0 -114
  200. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s.c +0 -509
  201. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_full_table.h +0 -367
  202. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_intrinsics.h +0 -357
  203. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/digit_table.h +0 -35
  204. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s.c +0 -345
  205. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_full_table.h +0 -55
  206. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_intrinsics.h +0 -128
  207. package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/ryu.h +0 -46
  208. package/vendor/dragonbox/subproject/3rdparty/schubfach/CMakeLists.txt +0 -22
  209. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.cc +0 -699
  210. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.h +0 -31
  211. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.cc +0 -1354
  212. package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.h +0 -31
  213. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/example_shaded_plots.m +0 -68
  214. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/license.txt +0 -25
  215. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution.m +0 -92
  216. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution_prctile.m +0 -121
  217. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_histogram_shaded.m +0 -99
  218. package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_shaded.m +0 -93
  219. package/vendor/dragonbox/subproject/benchmark/CMakeLists.txt +0 -65
  220. package/vendor/dragonbox/subproject/benchmark/include/benchmark.h +0 -40
  221. package/vendor/dragonbox/subproject/benchmark/matlab/plot_benchmarks.m +0 -22
  222. package/vendor/dragonbox/subproject/benchmark/matlab/plot_digit_benchmark.m +0 -78
  223. package/vendor/dragonbox/subproject/benchmark/matlab/plot_uniform_benchmark.m +0 -95
  224. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_clang.png +0 -0
  225. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_msvc.png +0 -0
  226. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_clang.png +0 -0
  227. package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_msvc.png +0 -0
  228. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_clang.png +0 -0
  229. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_msvc.png +0 -0
  230. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_clang.png +0 -0
  231. package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_msvc.png +0 -0
  232. package/vendor/dragonbox/subproject/benchmark/source/benchmark.cpp +0 -238
  233. package/vendor/dragonbox/subproject/benchmark/source/dragonbox.cpp +0 -30
  234. package/vendor/dragonbox/subproject/benchmark/source/grisu_exact.cpp +0 -36
  235. package/vendor/dragonbox/subproject/benchmark/source/ryu.cpp +0 -27
  236. package/vendor/dragonbox/subproject/benchmark/source/schubfach.cpp +0 -31
  237. package/vendor/dragonbox/subproject/common/CMakeLists.txt +0 -42
  238. package/vendor/dragonbox/subproject/common/include/best_rational_approx.h +0 -97
  239. package/vendor/dragonbox/subproject/common/include/big_uint.h +0 -218
  240. package/vendor/dragonbox/subproject/common/include/continued_fractions.h +0 -174
  241. package/vendor/dragonbox/subproject/common/include/good_rational_approx.h +0 -267
  242. package/vendor/dragonbox/subproject/common/include/random_float.h +0 -182
  243. package/vendor/dragonbox/subproject/common/include/rational_continued_fractions.h +0 -57
  244. package/vendor/dragonbox/subproject/common/source/big_uint.cpp +0 -602
  245. package/vendor/dragonbox/subproject/meta/CMakeLists.txt +0 -41
  246. package/vendor/dragonbox/subproject/meta/results/binary32_generated_cache.txt +0 -82
  247. package/vendor/dragonbox/subproject/meta/results/binary64_compressed_cache_error_table.txt +0 -10
  248. package/vendor/dragonbox/subproject/meta/results/binary64_generated_cache.txt +0 -623
  249. package/vendor/dragonbox/subproject/meta/source/generate_cache.cpp +0 -126
  250. package/vendor/dragonbox/subproject/meta/source/live_test.cpp +0 -81
  251. package/vendor/dragonbox/subproject/meta/source/perf_test.cpp +0 -104
  252. package/vendor/dragonbox/subproject/meta/source/sandbox.cpp +0 -20
  253. package/vendor/dragonbox/subproject/test/CMakeLists.txt +0 -70
  254. package/vendor/dragonbox/subproject/test/results/binary32.csv +0 -255
  255. package/vendor/dragonbox/subproject/test/results/binary64.csv +0 -2047
  256. package/vendor/dragonbox/subproject/test/results/plot_required_bits.m +0 -18
  257. package/vendor/dragonbox/subproject/test/source/test_all_shorter_interval_cases.cpp +0 -88
  258. package/vendor/dragonbox/subproject/test/source/uniform_random_test.cpp +0 -95
  259. package/vendor/dragonbox/subproject/test/source/verify_cache_precision.cpp +0 -338
  260. package/vendor/dragonbox/subproject/test/source/verify_compressed_cache.cpp +0 -154
  261. package/vendor/dragonbox/subproject/test/source/verify_fast_multiplication.cpp +0 -168
  262. package/vendor/dragonbox/subproject/test/source/verify_log_computation.cpp +0 -251
  263. package/vendor/dragonbox/subproject/test/source/verify_magic_division.cpp +0 -113
  264. package/vendor/miniz/ChangeLog.md +0 -239
  265. package/vendor/miniz/LICENSE +0 -22
  266. package/vendor/miniz/examples/example1.c +0 -105
  267. package/vendor/miniz/examples/example2.c +0 -164
  268. package/vendor/miniz/examples/example3.c +0 -269
  269. package/vendor/miniz/examples/example4.c +0 -102
  270. package/vendor/miniz/examples/example5.c +0 -327
  271. package/vendor/miniz/examples/example6.c +0 -166
  272. package/vendor/miniz/miniz.c +0 -7835
  273. package/vendor/miniz/miniz.h +0 -1422
  274. package/vendor/miniz/readme.md +0 -46
  275. /package/src/koffi/build/{2.3.6 → 2.3.8}/koffi_win32_arm64/koffi.exp +0 -0
  276. /package/src/koffi/build/{2.3.6 → 2.3.8}/koffi_win32_arm64/koffi.lib +0 -0
  277. /package/src/koffi/build/{2.3.6 → 2.3.8}/koffi_win32_ia32/koffi.exp +0 -0
  278. /package/src/koffi/build/{2.3.6 → 2.3.8}/koffi_win32_ia32/koffi.lib +0 -0
  279. /package/src/koffi/build/{2.3.6 → 2.3.8}/koffi_win32_x64/koffi.exp +0 -0
  280. /package/src/koffi/build/{2.3.6 → 2.3.8}/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_ */