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,351 +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
- /* Bit reading helpers */
8
-
9
- #ifndef BROTLI_DEC_BIT_READER_H_
10
- #define BROTLI_DEC_BIT_READER_H_
11
-
12
- #include <string.h> /* memcpy */
13
-
14
- #include "../common/constants.h"
15
- #include "../common/platform.h"
16
- #include <brotli/types.h>
17
-
18
- #if defined(__cplusplus) || defined(c_plusplus)
19
- extern "C" {
20
- #endif
21
-
22
- #define BROTLI_SHORT_FILL_BIT_WINDOW_READ (sizeof(brotli_reg_t) >> 1)
23
-
24
- BROTLI_INTERNAL extern const uint32_t kBrotliBitMask[33];
25
-
26
- static BROTLI_INLINE uint32_t BitMask(uint32_t n) {
27
- if (BROTLI_IS_CONSTANT(n) || BROTLI_HAS_UBFX) {
28
- /* Masking with this expression turns to a single
29
- "Unsigned Bit Field Extract" UBFX instruction on ARM. */
30
- return ~((0xFFFFFFFFu) << n);
31
- } else {
32
- return kBrotliBitMask[n];
33
- }
34
- }
35
-
36
- typedef struct {
37
- brotli_reg_t val_; /* pre-fetched bits */
38
- uint32_t bit_pos_; /* current bit-reading position in val_ */
39
- const uint8_t* next_in; /* the byte we're reading from */
40
- size_t avail_in;
41
- } BrotliBitReader;
42
-
43
- typedef struct {
44
- brotli_reg_t val_;
45
- uint32_t bit_pos_;
46
- const uint8_t* next_in;
47
- size_t avail_in;
48
- } BrotliBitReaderState;
49
-
50
- /* Initializes the BrotliBitReader fields. */
51
- BROTLI_INTERNAL void BrotliInitBitReader(BrotliBitReader* const br);
52
-
53
- /* Ensures that accumulator is not empty.
54
- May consume up to sizeof(brotli_reg_t) - 1 bytes of input.
55
- Returns BROTLI_FALSE if data is required but there is no input available.
56
- For BROTLI_ALIGNED_READ this function also prepares bit reader for aligned
57
- reading. */
58
- BROTLI_INTERNAL BROTLI_BOOL BrotliWarmupBitReader(BrotliBitReader* const br);
59
-
60
- /* Fallback for BrotliSafeReadBits32. Extracted as noninlined method to unburden
61
- the main code-path. Never called for RFC brotli streams, required only for
62
- "large-window" mode and other extensions. */
63
- BROTLI_INTERNAL BROTLI_NOINLINE BROTLI_BOOL BrotliSafeReadBits32Slow(
64
- BrotliBitReader* const br, uint32_t n_bits, uint32_t* val);
65
-
66
- static BROTLI_INLINE void BrotliBitReaderSaveState(
67
- BrotliBitReader* const from, BrotliBitReaderState* to) {
68
- to->val_ = from->val_;
69
- to->bit_pos_ = from->bit_pos_;
70
- to->next_in = from->next_in;
71
- to->avail_in = from->avail_in;
72
- }
73
-
74
- static BROTLI_INLINE void BrotliBitReaderRestoreState(
75
- BrotliBitReader* const to, BrotliBitReaderState* from) {
76
- to->val_ = from->val_;
77
- to->bit_pos_ = from->bit_pos_;
78
- to->next_in = from->next_in;
79
- to->avail_in = from->avail_in;
80
- }
81
-
82
- static BROTLI_INLINE uint32_t BrotliGetAvailableBits(
83
- const BrotliBitReader* br) {
84
- return (BROTLI_64_BITS ? 64 : 32) - br->bit_pos_;
85
- }
86
-
87
- /* Returns amount of unread bytes the bit reader still has buffered from the
88
- BrotliInput, including whole bytes in br->val_. Result is capped with
89
- maximal ring-buffer size (larger number won't be utilized anyway). */
90
- static BROTLI_INLINE size_t BrotliGetRemainingBytes(BrotliBitReader* br) {
91
- static const size_t kCap = (size_t)1 << BROTLI_LARGE_MAX_WBITS;
92
- if (br->avail_in > kCap) return kCap;
93
- return br->avail_in + (BrotliGetAvailableBits(br) >> 3);
94
- }
95
-
96
- /* Checks if there is at least |num| bytes left in the input ring-buffer
97
- (excluding the bits remaining in br->val_). */
98
- static BROTLI_INLINE BROTLI_BOOL BrotliCheckInputAmount(
99
- BrotliBitReader* const br, size_t num) {
100
- return TO_BROTLI_BOOL(br->avail_in >= num);
101
- }
102
-
103
- /* Guarantees that there are at least |n_bits| + 1 bits in accumulator.
104
- Precondition: accumulator contains at least 1 bit.
105
- |n_bits| should be in the range [1..24] for regular build. For portable
106
- non-64-bit little-endian build only 16 bits are safe to request. */
107
- static BROTLI_INLINE void BrotliFillBitWindow(
108
- BrotliBitReader* const br, uint32_t n_bits) {
109
- #if (BROTLI_64_BITS)
110
- if (!BROTLI_ALIGNED_READ && BROTLI_IS_CONSTANT(n_bits) && (n_bits <= 8)) {
111
- if (br->bit_pos_ >= 56) {
112
- br->val_ >>= 56;
113
- br->bit_pos_ ^= 56; /* here same as -= 56 because of the if condition */
114
- br->val_ |= BROTLI_UNALIGNED_LOAD64LE(br->next_in) << 8;
115
- br->avail_in -= 7;
116
- br->next_in += 7;
117
- }
118
- } else if (
119
- !BROTLI_ALIGNED_READ && BROTLI_IS_CONSTANT(n_bits) && (n_bits <= 16)) {
120
- if (br->bit_pos_ >= 48) {
121
- br->val_ >>= 48;
122
- br->bit_pos_ ^= 48; /* here same as -= 48 because of the if condition */
123
- br->val_ |= BROTLI_UNALIGNED_LOAD64LE(br->next_in) << 16;
124
- br->avail_in -= 6;
125
- br->next_in += 6;
126
- }
127
- } else {
128
- if (br->bit_pos_ >= 32) {
129
- br->val_ >>= 32;
130
- br->bit_pos_ ^= 32; /* here same as -= 32 because of the if condition */
131
- br->val_ |= ((uint64_t)BROTLI_UNALIGNED_LOAD32LE(br->next_in)) << 32;
132
- br->avail_in -= BROTLI_SHORT_FILL_BIT_WINDOW_READ;
133
- br->next_in += BROTLI_SHORT_FILL_BIT_WINDOW_READ;
134
- }
135
- }
136
- #else
137
- if (!BROTLI_ALIGNED_READ && BROTLI_IS_CONSTANT(n_bits) && (n_bits <= 8)) {
138
- if (br->bit_pos_ >= 24) {
139
- br->val_ >>= 24;
140
- br->bit_pos_ ^= 24; /* here same as -= 24 because of the if condition */
141
- br->val_ |= BROTLI_UNALIGNED_LOAD32LE(br->next_in) << 8;
142
- br->avail_in -= 3;
143
- br->next_in += 3;
144
- }
145
- } else {
146
- if (br->bit_pos_ >= 16) {
147
- br->val_ >>= 16;
148
- br->bit_pos_ ^= 16; /* here same as -= 16 because of the if condition */
149
- br->val_ |= ((uint32_t)BROTLI_UNALIGNED_LOAD16LE(br->next_in)) << 16;
150
- br->avail_in -= BROTLI_SHORT_FILL_BIT_WINDOW_READ;
151
- br->next_in += BROTLI_SHORT_FILL_BIT_WINDOW_READ;
152
- }
153
- }
154
- #endif
155
- }
156
-
157
- /* Mostly like BrotliFillBitWindow, but guarantees only 16 bits and reads no
158
- more than BROTLI_SHORT_FILL_BIT_WINDOW_READ bytes of input. */
159
- static BROTLI_INLINE void BrotliFillBitWindow16(BrotliBitReader* const br) {
160
- BrotliFillBitWindow(br, 17);
161
- }
162
-
163
- /* Tries to pull one byte of input to accumulator.
164
- Returns BROTLI_FALSE if there is no input available. */
165
- static BROTLI_INLINE BROTLI_BOOL BrotliPullByte(BrotliBitReader* const br) {
166
- if (br->avail_in == 0) {
167
- return BROTLI_FALSE;
168
- }
169
- br->val_ >>= 8;
170
- #if (BROTLI_64_BITS)
171
- br->val_ |= ((uint64_t)*br->next_in) << 56;
172
- #else
173
- br->val_ |= ((uint32_t)*br->next_in) << 24;
174
- #endif
175
- br->bit_pos_ -= 8;
176
- --br->avail_in;
177
- ++br->next_in;
178
- return BROTLI_TRUE;
179
- }
180
-
181
- /* Returns currently available bits.
182
- The number of valid bits could be calculated by BrotliGetAvailableBits. */
183
- static BROTLI_INLINE brotli_reg_t BrotliGetBitsUnmasked(
184
- BrotliBitReader* const br) {
185
- return br->val_ >> br->bit_pos_;
186
- }
187
-
188
- /* Like BrotliGetBits, but does not mask the result.
189
- The result contains at least 16 valid bits. */
190
- static BROTLI_INLINE uint32_t BrotliGet16BitsUnmasked(
191
- BrotliBitReader* const br) {
192
- BrotliFillBitWindow(br, 16);
193
- return (uint32_t)BrotliGetBitsUnmasked(br);
194
- }
195
-
196
- /* Returns the specified number of bits from |br| without advancing bit
197
- position. */
198
- static BROTLI_INLINE uint32_t BrotliGetBits(
199
- BrotliBitReader* const br, uint32_t n_bits) {
200
- BrotliFillBitWindow(br, n_bits);
201
- return (uint32_t)BrotliGetBitsUnmasked(br) & BitMask(n_bits);
202
- }
203
-
204
- /* Tries to peek the specified amount of bits. Returns BROTLI_FALSE, if there
205
- is not enough input. */
206
- static BROTLI_INLINE BROTLI_BOOL BrotliSafeGetBits(
207
- BrotliBitReader* const br, uint32_t n_bits, uint32_t* val) {
208
- while (BrotliGetAvailableBits(br) < n_bits) {
209
- if (!BrotliPullByte(br)) {
210
- return BROTLI_FALSE;
211
- }
212
- }
213
- *val = (uint32_t)BrotliGetBitsUnmasked(br) & BitMask(n_bits);
214
- return BROTLI_TRUE;
215
- }
216
-
217
- /* Advances the bit pos by |n_bits|. */
218
- static BROTLI_INLINE void BrotliDropBits(
219
- BrotliBitReader* const br, uint32_t n_bits) {
220
- br->bit_pos_ += n_bits;
221
- }
222
-
223
- static BROTLI_INLINE void BrotliBitReaderUnload(BrotliBitReader* br) {
224
- uint32_t unused_bytes = BrotliGetAvailableBits(br) >> 3;
225
- uint32_t unused_bits = unused_bytes << 3;
226
- br->avail_in += unused_bytes;
227
- br->next_in -= unused_bytes;
228
- if (unused_bits == sizeof(br->val_) << 3) {
229
- br->val_ = 0;
230
- } else {
231
- br->val_ <<= unused_bits;
232
- }
233
- br->bit_pos_ += unused_bits;
234
- }
235
-
236
- /* Reads the specified number of bits from |br| and advances the bit pos.
237
- Precondition: accumulator MUST contain at least |n_bits|. */
238
- static BROTLI_INLINE void BrotliTakeBits(
239
- BrotliBitReader* const br, uint32_t n_bits, uint32_t* val) {
240
- *val = (uint32_t)BrotliGetBitsUnmasked(br) & BitMask(n_bits);
241
- BROTLI_LOG(("[BrotliTakeBits] %d %d %d val: %6x\n",
242
- (int)br->avail_in, (int)br->bit_pos_, (int)n_bits, (int)*val));
243
- BrotliDropBits(br, n_bits);
244
- }
245
-
246
- /* Reads the specified number of bits from |br| and advances the bit pos.
247
- Assumes that there is enough input to perform BrotliFillBitWindow.
248
- Up to 24 bits are allowed to be requested from this method. */
249
- static BROTLI_INLINE uint32_t BrotliReadBits24(
250
- BrotliBitReader* const br, uint32_t n_bits) {
251
- BROTLI_DCHECK(n_bits <= 24);
252
- if (BROTLI_64_BITS || (n_bits <= 16)) {
253
- uint32_t val;
254
- BrotliFillBitWindow(br, n_bits);
255
- BrotliTakeBits(br, n_bits, &val);
256
- return val;
257
- } else {
258
- uint32_t low_val;
259
- uint32_t high_val;
260
- BrotliFillBitWindow(br, 16);
261
- BrotliTakeBits(br, 16, &low_val);
262
- BrotliFillBitWindow(br, 8);
263
- BrotliTakeBits(br, n_bits - 16, &high_val);
264
- return low_val | (high_val << 16);
265
- }
266
- }
267
-
268
- /* Same as BrotliReadBits24, but allows reading up to 32 bits. */
269
- static BROTLI_INLINE uint32_t BrotliReadBits32(
270
- BrotliBitReader* const br, uint32_t n_bits) {
271
- BROTLI_DCHECK(n_bits <= 32);
272
- if (BROTLI_64_BITS || (n_bits <= 16)) {
273
- uint32_t val;
274
- BrotliFillBitWindow(br, n_bits);
275
- BrotliTakeBits(br, n_bits, &val);
276
- return val;
277
- } else {
278
- uint32_t low_val;
279
- uint32_t high_val;
280
- BrotliFillBitWindow(br, 16);
281
- BrotliTakeBits(br, 16, &low_val);
282
- BrotliFillBitWindow(br, 16);
283
- BrotliTakeBits(br, n_bits - 16, &high_val);
284
- return low_val | (high_val << 16);
285
- }
286
- }
287
-
288
- /* Tries to read the specified amount of bits. Returns BROTLI_FALSE, if there
289
- is not enough input. |n_bits| MUST be positive.
290
- Up to 24 bits are allowed to be requested from this method. */
291
- static BROTLI_INLINE BROTLI_BOOL BrotliSafeReadBits(
292
- BrotliBitReader* const br, uint32_t n_bits, uint32_t* val) {
293
- BROTLI_DCHECK(n_bits <= 24);
294
- while (BrotliGetAvailableBits(br) < n_bits) {
295
- if (!BrotliPullByte(br)) {
296
- return BROTLI_FALSE;
297
- }
298
- }
299
- BrotliTakeBits(br, n_bits, val);
300
- return BROTLI_TRUE;
301
- }
302
-
303
- /* Same as BrotliSafeReadBits, but allows reading up to 32 bits. */
304
- static BROTLI_INLINE BROTLI_BOOL BrotliSafeReadBits32(
305
- BrotliBitReader* const br, uint32_t n_bits, uint32_t* val) {
306
- BROTLI_DCHECK(n_bits <= 32);
307
- if (BROTLI_64_BITS || (n_bits <= 24)) {
308
- while (BrotliGetAvailableBits(br) < n_bits) {
309
- if (!BrotliPullByte(br)) {
310
- return BROTLI_FALSE;
311
- }
312
- }
313
- BrotliTakeBits(br, n_bits, val);
314
- return BROTLI_TRUE;
315
- } else {
316
- return BrotliSafeReadBits32Slow(br, n_bits, val);
317
- }
318
- }
319
-
320
- /* Advances the bit reader position to the next byte boundary and verifies
321
- that any skipped bits are set to zero. */
322
- static BROTLI_INLINE BROTLI_BOOL BrotliJumpToByteBoundary(BrotliBitReader* br) {
323
- uint32_t pad_bits_count = BrotliGetAvailableBits(br) & 0x7;
324
- uint32_t pad_bits = 0;
325
- if (pad_bits_count != 0) {
326
- BrotliTakeBits(br, pad_bits_count, &pad_bits);
327
- }
328
- return TO_BROTLI_BOOL(pad_bits == 0);
329
- }
330
-
331
- /* Copies remaining input bytes stored in the bit reader to the output. Value
332
- |num| may not be larger than BrotliGetRemainingBytes. The bit reader must be
333
- warmed up again after this. */
334
- static BROTLI_INLINE void BrotliCopyBytes(uint8_t* dest,
335
- BrotliBitReader* br, size_t num) {
336
- while (BrotliGetAvailableBits(br) >= 8 && num > 0) {
337
- *dest = (uint8_t)BrotliGetBitsUnmasked(br);
338
- BrotliDropBits(br, 8);
339
- ++dest;
340
- --num;
341
- }
342
- memcpy(dest, br->next_in, num);
343
- br->avail_in -= num;
344
- br->next_in += num;
345
- }
346
-
347
- #if defined(__cplusplus) || defined(c_plusplus)
348
- } /* extern "C" */
349
- #endif
350
-
351
- #endif /* BROTLI_DEC_BIT_READER_H_ */