| /* Copyright 2025 Google Inc. All Rights Reserved. |
| |
| Distributed under MIT license. |
| See file LICENSE for detail or copy at https://opensource.org/licenses/MIT |
| */ |
| |
| #include "prefix.h" |
| |
| #include "../common/platform.h" /* IWYU pragma: keep */ |
| #include "../common/static_init.h" |
| |
| #if (BROTLI_STATIC_INIT != BROTLI_STATIC_INIT_NONE) |
| #include "../common/constants.h" |
| #endif |
| |
| #if defined(__cplusplus) || defined(c_plusplus) |
| extern "C" { |
| #endif |
| |
| #if (BROTLI_STATIC_INIT == BROTLI_STATIC_INIT_NONE) |
| /* Embed kCmdLut. */ |
| #include "prefix_inc.h" |
| #else |
| BROTLI_COLD BROTLI_BOOL BrotliDecoderInitCmdLut(CmdLutElement* items) { |
| static const uint8_t kInsertLengthExtraBits[24] = { |
| 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x01, 0x02, 0x02, 0x03, 0x03, |
| 0x04, 0x04, 0x05, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0C, 0x0E, 0x18}; |
| static const uint8_t kCopyLengthExtraBits[24] = { |
| 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x01, 0x02, 0x02, |
| 0x03, 0x03, 0x04, 0x04, 0x05, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x18}; |
| static const uint8_t kCellPos[11] = {0, 1, 0, 1, 8, 9, 2, 16, 10, 17, 18}; |
| |
| uint16_t insert_length_offsets[24]; |
| uint16_t copy_length_offsets[24]; |
| insert_length_offsets[0] = 0; |
| copy_length_offsets[0] = 2; |
| for (size_t i = 0; i < 23; ++i) { |
| insert_length_offsets[i + 1] = |
| insert_length_offsets[i] + (uint16_t)(1u << kInsertLengthExtraBits[i]); |
| copy_length_offsets[i + 1] = |
| copy_length_offsets[i] + (uint16_t)(1u << kCopyLengthExtraBits[i]); |
| } |
| |
| for (size_t symbol = 0; symbol < BROTLI_NUM_COMMAND_SYMBOLS; ++symbol) { |
| CmdLutElement* item = items + symbol; |
| const size_t cell_idx = symbol >> 6; |
| const size_t cell_pos = kCellPos[cell_idx]; |
| const size_t copy_code = ((cell_pos << 3) & 0x18) + (symbol & 0x7); |
| const uint16_t copy_len_offset = copy_length_offsets[copy_code]; |
| const size_t insert_code = (cell_pos & 0x18) + ((symbol >> 3) & 0x7); |
| item->copy_len_extra_bits = kCopyLengthExtraBits[copy_code]; |
| item->context = (copy_len_offset > 4) ? 3 : ((uint8_t)copy_len_offset - 2); |
| item->copy_len_offset = copy_len_offset; |
| item->distance_code = (cell_idx >= 2) ? -1 : 0; |
| item->insert_len_extra_bits = kInsertLengthExtraBits[insert_code]; |
| item->insert_len_offset = insert_length_offsets[insert_code]; |
| } |
| return BROTLI_TRUE; |
| } |
| |
| BROTLI_MODEL("small") |
| CmdLutElement kCmdLut[BROTLI_NUM_COMMAND_SYMBOLS]; |
| #endif /* BROTLI_STATIC_INIT */ |
| |
| #if defined(__cplusplus) || defined(c_plusplus) |
| } /* extern "C" */ |
| #endif |