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.
- package/CHANGELOG.md +7 -0
- package/package.json +2 -2
- package/src/cnoke/cnoke.js +3 -7
- package/src/cnoke/src/builder.js +9 -6
- package/src/cnoke/src/index.js +2 -2
- package/src/koffi/build/2.3.7/koffi_darwin_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_darwin_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_freebsd_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_freebsd_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_freebsd_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_linux_arm32hf/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_linux_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_linux_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_linux_riscv64hf64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_linux_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_openbsd_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_openbsd_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_win32_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_win32_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.7/koffi_win32_x64/koffi.node +0 -0
- package/src/koffi/src/ffi.cc +2 -2
- package/src/koffi/src/index.d.ts +2 -2
- package/src/koffi/src/index.js +1 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_darwin_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_darwin_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_freebsd_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_freebsd_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_freebsd_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_linux_arm32hf/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_linux_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_linux_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_linux_riscv64hf64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_linux_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_openbsd_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_openbsd_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_win32_arm64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_win32_arm64/koffi.pdb +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_win32_ia32/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_win32_ia32/koffi.pdb +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_win32_x64/koffi.node +0 -0
- package/src/koffi/build/2.3.6-beta.6/koffi_win32_x64/koffi.pdb +0 -0
- package/vendor/brotli/BUILD +0 -144
- package/vendor/brotli/CMakeLists.txt +0 -421
- package/vendor/brotli/CONTRIBUTING.md +0 -27
- package/vendor/brotli/LICENSE +0 -19
- package/vendor/brotli/MANIFEST.in +0 -17
- package/vendor/brotli/Makefile +0 -55
- package/vendor/brotli/Makefile.am +0 -38
- package/vendor/brotli/README +0 -15
- package/vendor/brotli/README.md +0 -104
- package/vendor/brotli/WORKSPACE +0 -21
- package/vendor/brotli/bootstrap +0 -35
- package/vendor/brotli/c/common/constants.c +0 -15
- package/vendor/brotli/c/common/constants.h +0 -200
- package/vendor/brotli/c/common/context.c +0 -156
- package/vendor/brotli/c/common/context.h +0 -113
- package/vendor/brotli/c/common/dictionary.c +0 -5914
- package/vendor/brotli/c/common/dictionary.h +0 -64
- package/vendor/brotli/c/common/platform.c +0 -22
- package/vendor/brotli/c/common/platform.h +0 -596
- package/vendor/brotli/c/common/transform.c +0 -291
- package/vendor/brotli/c/common/transform.h +0 -85
- package/vendor/brotli/c/common/version.h +0 -26
- package/vendor/brotli/c/dec/bit_reader.c +0 -76
- package/vendor/brotli/c/dec/bit_reader.h +0 -351
- package/vendor/brotli/c/dec/decode.c +0 -2608
- package/vendor/brotli/c/dec/huffman.c +0 -339
- package/vendor/brotli/c/dec/huffman.h +0 -121
- package/vendor/brotli/c/dec/prefix.h +0 -732
- package/vendor/brotli/c/dec/state.c +0 -159
- package/vendor/brotli/c/dec/state.h +0 -365
- package/vendor/brotli/c/enc/backward_references.c +0 -145
- package/vendor/brotli/c/enc/backward_references.h +0 -39
- package/vendor/brotli/c/enc/backward_references_hq.c +0 -843
- package/vendor/brotli/c/enc/backward_references_hq.h +0 -95
- package/vendor/brotli/c/enc/backward_references_inc.h +0 -163
- package/vendor/brotli/c/enc/bit_cost.c +0 -35
- package/vendor/brotli/c/enc/bit_cost.h +0 -63
- package/vendor/brotli/c/enc/bit_cost_inc.h +0 -127
- package/vendor/brotli/c/enc/block_encoder_inc.h +0 -34
- package/vendor/brotli/c/enc/block_splitter.c +0 -194
- package/vendor/brotli/c/enc/block_splitter.h +0 -51
- package/vendor/brotli/c/enc/block_splitter_inc.h +0 -440
- package/vendor/brotli/c/enc/brotli_bit_stream.c +0 -1314
- package/vendor/brotli/c/enc/brotli_bit_stream.h +0 -84
- package/vendor/brotli/c/enc/cluster.c +0 -56
- package/vendor/brotli/c/enc/cluster.h +0 -48
- package/vendor/brotli/c/enc/cluster_inc.h +0 -320
- package/vendor/brotli/c/enc/command.c +0 -28
- package/vendor/brotli/c/enc/command.h +0 -190
- package/vendor/brotli/c/enc/compress_fragment.c +0 -790
- package/vendor/brotli/c/enc/compress_fragment.h +0 -61
- package/vendor/brotli/c/enc/compress_fragment_two_pass.c +0 -645
- package/vendor/brotli/c/enc/compress_fragment_two_pass.h +0 -54
- package/vendor/brotli/c/enc/dictionary_hash.c +0 -1846
- package/vendor/brotli/c/enc/dictionary_hash.h +0 -25
- package/vendor/brotli/c/enc/encode.c +0 -1927
- package/vendor/brotli/c/enc/encoder_dict.c +0 -33
- package/vendor/brotli/c/enc/encoder_dict.h +0 -43
- package/vendor/brotli/c/enc/entropy_encode.c +0 -503
- package/vendor/brotli/c/enc/entropy_encode.h +0 -122
- package/vendor/brotli/c/enc/entropy_encode_static.h +0 -539
- package/vendor/brotli/c/enc/fast_log.c +0 -105
- package/vendor/brotli/c/enc/fast_log.h +0 -66
- package/vendor/brotli/c/enc/find_match_length.h +0 -79
- package/vendor/brotli/c/enc/hash.h +0 -488
- package/vendor/brotli/c/enc/hash_composite_inc.h +0 -125
- package/vendor/brotli/c/enc/hash_forgetful_chain_inc.h +0 -293
- package/vendor/brotli/c/enc/hash_longest_match64_inc.h +0 -267
- package/vendor/brotli/c/enc/hash_longest_match_inc.h +0 -262
- package/vendor/brotli/c/enc/hash_longest_match_quickly_inc.h +0 -266
- package/vendor/brotli/c/enc/hash_rolling_inc.h +0 -212
- package/vendor/brotli/c/enc/hash_to_binary_tree_inc.h +0 -329
- package/vendor/brotli/c/enc/histogram.c +0 -100
- package/vendor/brotli/c/enc/histogram.h +0 -63
- package/vendor/brotli/c/enc/histogram_inc.h +0 -51
- package/vendor/brotli/c/enc/literal_cost.c +0 -175
- package/vendor/brotli/c/enc/literal_cost.h +0 -30
- package/vendor/brotli/c/enc/memory.c +0 -170
- package/vendor/brotli/c/enc/memory.h +0 -114
- package/vendor/brotli/c/enc/metablock.c +0 -663
- package/vendor/brotli/c/enc/metablock.h +0 -105
- package/vendor/brotli/c/enc/metablock_inc.h +0 -183
- package/vendor/brotli/c/enc/params.h +0 -46
- package/vendor/brotli/c/enc/prefix.h +0 -53
- package/vendor/brotli/c/enc/quality.h +0 -165
- package/vendor/brotli/c/enc/ringbuffer.h +0 -167
- package/vendor/brotli/c/enc/static_dict.c +0 -486
- package/vendor/brotli/c/enc/static_dict.h +0 -40
- package/vendor/brotli/c/enc/static_dict_lut.h +0 -5864
- package/vendor/brotli/c/enc/utf8_util.c +0 -85
- package/vendor/brotli/c/enc/utf8_util.h +0 -32
- package/vendor/brotli/c/enc/write_bits.h +0 -87
- package/vendor/brotli/c/include/brotli/decode.h +0 -344
- package/vendor/brotli/c/include/brotli/encode.h +0 -448
- package/vendor/brotli/c/include/brotli/port.h +0 -288
- package/vendor/brotli/c/include/brotli/types.h +0 -83
- package/vendor/brotli/c/tools/brotli.c +0 -1116
- package/vendor/brotli/c/tools/brotli.md +0 -107
- package/vendor/brotli/compiler_config_setting.bzl +0 -28
- package/vendor/brotli/configure +0 -8
- package/vendor/brotli/configure-cmake +0 -318
- package/vendor/brotli/configure.ac +0 -14
- package/vendor/brotli/docs/brotli.1 +0 -132
- package/vendor/brotli/docs/constants.h.3 +0 -47
- package/vendor/brotli/docs/decode.h.3 +0 -415
- package/vendor/brotli/docs/encode.h.3 +0 -586
- package/vendor/brotli/docs/types.h.3 +0 -117
- package/vendor/brotli/premake5.lua +0 -78
- package/vendor/brotli/python/Makefile +0 -57
- package/vendor/brotli/python/README.md +0 -54
- package/vendor/brotli/python/_brotli.cc +0 -753
- package/vendor/brotli/python/bro.py +0 -160
- package/vendor/brotli/python/brotli.py +0 -56
- package/vendor/brotli/python/tests/__init__.py +0 -0
- package/vendor/brotli/python/tests/_test_utils.py +0 -112
- package/vendor/brotli/python/tests/bro_test.py +0 -102
- package/vendor/brotli/python/tests/compress_test.py +0 -41
- package/vendor/brotli/python/tests/compressor_test.py +0 -94
- package/vendor/brotli/python/tests/decompress_test.py +0 -42
- package/vendor/brotli/python/tests/decompressor_test.py +0 -59
- package/vendor/brotli/scripts/libbrotlicommon.pc.in +0 -11
- package/vendor/brotli/scripts/libbrotlidec.pc.in +0 -12
- package/vendor/brotli/scripts/libbrotlienc.pc.in +0 -12
- package/vendor/brotli/scripts/sources.lst +0 -104
- package/vendor/brotli/setup.cfg +0 -5
- package/vendor/brotli/setup.py +0 -293
- package/vendor/brotli/tests/Makefile +0 -17
- package/vendor/brotli/tests/compatibility_test.sh +0 -25
- package/vendor/brotli/tests/roundtrip_test.sh +0 -36
- package/vendor/brotli/tests/run-compatibility-test.cmake +0 -31
- package/vendor/brotli/tests/run-roundtrip-test.cmake +0 -36
- package/vendor/brotli/tests/testdata/empty +0 -0
- package/vendor/brotli/tests/testdata/empty.compressed +0 -1
- package/vendor/brotli/tests/testdata/ukkonooa +0 -1
- package/vendor/brotli/tests/testdata/ukkonooa.compressed +0 -0
- package/vendor/dragonbox/CMakeLists.txt +0 -123
- package/vendor/dragonbox/LICENSE-Apache2-LLVM +0 -218
- package/vendor/dragonbox/LICENSE-Boost +0 -23
- package/vendor/dragonbox/README.md +0 -277
- package/vendor/dragonbox/cmake/dragonboxConfig.cmake +0 -1
- package/vendor/dragonbox/include/dragonbox/dragonbox.h +0 -2674
- package/vendor/dragonbox/include/dragonbox/dragonbox_to_chars.h +0 -108
- package/vendor/dragonbox/other_files/Dragonbox.pdf +0 -0
- package/vendor/dragonbox/other_files/Dragonbox_old.pdf +0 -0
- package/vendor/dragonbox/other_files/milo_benchmark.png +0 -0
- package/vendor/dragonbox/other_files/unknown_win64_vc2019.html +0 -540
- package/vendor/dragonbox/other_files/unknown_win64_vc2019_randomdigit_time.png +0 -0
- package/vendor/dragonbox/source/dragonbox_to_chars.cpp +0 -303
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/CMakeLists.txt +0 -24
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.cpp +0 -238
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/fp_to_chars.h +0 -95
- package/vendor/dragonbox/subproject/3rdparty/grisu_exact/grisu_exact.h +0 -2666
- package/vendor/dragonbox/subproject/3rdparty/ryu/CMakeLists.txt +0 -16
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/common.h +0 -114
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s.c +0 -509
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_full_table.h +0 -367
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/d2s_intrinsics.h +0 -357
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/digit_table.h +0 -35
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s.c +0 -345
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_full_table.h +0 -55
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/f2s_intrinsics.h +0 -128
- package/vendor/dragonbox/subproject/3rdparty/ryu/ryu/ryu.h +0 -46
- package/vendor/dragonbox/subproject/3rdparty/schubfach/CMakeLists.txt +0 -22
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.cc +0 -699
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_32.h +0 -31
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.cc +0 -1354
- package/vendor/dragonbox/subproject/3rdparty/schubfach/schubfach_64.h +0 -31
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/example_shaded_plots.m +0 -68
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/license.txt +0 -25
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution.m +0 -92
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_distribution_prctile.m +0 -121
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_histogram_shaded.m +0 -99
- package/vendor/dragonbox/subproject/3rdparty/shaded_plots/plot_shaded.m +0 -93
- package/vendor/dragonbox/subproject/benchmark/CMakeLists.txt +0 -65
- package/vendor/dragonbox/subproject/benchmark/include/benchmark.h +0 -40
- package/vendor/dragonbox/subproject/benchmark/matlab/plot_benchmarks.m +0 -22
- package/vendor/dragonbox/subproject/benchmark/matlab/plot_digit_benchmark.m +0 -78
- package/vendor/dragonbox/subproject/benchmark/matlab/plot_uniform_benchmark.m +0 -95
- package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_clang.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary32_msvc.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_clang.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/digits_benchmark_binary64_msvc.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_clang.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary32_msvc.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_clang.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/results/uniform_benchmark_binary64_msvc.png +0 -0
- package/vendor/dragonbox/subproject/benchmark/source/benchmark.cpp +0 -238
- package/vendor/dragonbox/subproject/benchmark/source/dragonbox.cpp +0 -30
- package/vendor/dragonbox/subproject/benchmark/source/grisu_exact.cpp +0 -36
- package/vendor/dragonbox/subproject/benchmark/source/ryu.cpp +0 -27
- package/vendor/dragonbox/subproject/benchmark/source/schubfach.cpp +0 -31
- package/vendor/dragonbox/subproject/common/CMakeLists.txt +0 -42
- package/vendor/dragonbox/subproject/common/include/best_rational_approx.h +0 -97
- package/vendor/dragonbox/subproject/common/include/big_uint.h +0 -218
- package/vendor/dragonbox/subproject/common/include/continued_fractions.h +0 -174
- package/vendor/dragonbox/subproject/common/include/good_rational_approx.h +0 -267
- package/vendor/dragonbox/subproject/common/include/random_float.h +0 -182
- package/vendor/dragonbox/subproject/common/include/rational_continued_fractions.h +0 -57
- package/vendor/dragonbox/subproject/common/source/big_uint.cpp +0 -602
- package/vendor/dragonbox/subproject/meta/CMakeLists.txt +0 -41
- package/vendor/dragonbox/subproject/meta/results/binary32_generated_cache.txt +0 -82
- package/vendor/dragonbox/subproject/meta/results/binary64_compressed_cache_error_table.txt +0 -10
- package/vendor/dragonbox/subproject/meta/results/binary64_generated_cache.txt +0 -623
- package/vendor/dragonbox/subproject/meta/source/generate_cache.cpp +0 -126
- package/vendor/dragonbox/subproject/meta/source/live_test.cpp +0 -81
- package/vendor/dragonbox/subproject/meta/source/perf_test.cpp +0 -104
- package/vendor/dragonbox/subproject/meta/source/sandbox.cpp +0 -20
- package/vendor/dragonbox/subproject/test/CMakeLists.txt +0 -70
- package/vendor/dragonbox/subproject/test/results/binary32.csv +0 -255
- package/vendor/dragonbox/subproject/test/results/binary64.csv +0 -2047
- package/vendor/dragonbox/subproject/test/results/plot_required_bits.m +0 -18
- package/vendor/dragonbox/subproject/test/source/test_all_shorter_interval_cases.cpp +0 -88
- package/vendor/dragonbox/subproject/test/source/uniform_random_test.cpp +0 -95
- package/vendor/dragonbox/subproject/test/source/verify_cache_precision.cpp +0 -338
- package/vendor/dragonbox/subproject/test/source/verify_compressed_cache.cpp +0 -154
- package/vendor/dragonbox/subproject/test/source/verify_fast_multiplication.cpp +0 -168
- package/vendor/dragonbox/subproject/test/source/verify_log_computation.cpp +0 -251
- package/vendor/dragonbox/subproject/test/source/verify_magic_division.cpp +0 -113
- package/vendor/miniz/ChangeLog.md +0 -239
- package/vendor/miniz/LICENSE +0 -22
- package/vendor/miniz/examples/example1.c +0 -105
- package/vendor/miniz/examples/example2.c +0 -164
- package/vendor/miniz/examples/example3.c +0 -269
- package/vendor/miniz/examples/example4.c +0 -102
- package/vendor/miniz/examples/example5.c +0 -327
- package/vendor/miniz/examples/example6.c +0 -166
- package/vendor/miniz/miniz.c +0 -7835
- package/vendor/miniz/miniz.h +0 -1422
- package/vendor/miniz/readme.md +0 -46
- /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_arm64/koffi.exp +0 -0
- /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_arm64/koffi.lib +0 -0
- /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_ia32/koffi.exp +0 -0
- /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_ia32/koffi.lib +0 -0
- /package/src/koffi/build/{2.3.6-beta.6 → 2.3.7}/koffi_win32_x64/koffi.exp +0 -0
- /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_ */
|