2015-11-27 10:27:11 +00:00
|
|
|
/* Copyright 2014 Google Inc. All Rights Reserved.
|
|
|
|
|
2015-12-11 10:11:51 +00:00
|
|
|
Distributed under MIT license.
|
2015-11-27 10:27:11 +00:00
|
|
|
See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
|
|
|
|
*/
|
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* Functions to convert brotli-related data structures into the
|
|
|
|
brotli bit stream. The functions here operate under
|
|
|
|
assumption that there is enough space in the storage, i.e., there are
|
|
|
|
no out-of-range checks anywhere.
|
|
|
|
|
|
|
|
These functions do bit addressing into a byte array. The byte array
|
|
|
|
is called "storage" and the index to the bit is called storage_ix
|
|
|
|
in function arguments. */
|
2014-10-15 12:01:36 +00:00
|
|
|
|
|
|
|
#ifndef BROTLI_ENC_BROTLI_BIT_STREAM_H_
|
|
|
|
#define BROTLI_ENC_BROTLI_BIT_STREAM_H_
|
|
|
|
|
2016-08-23 12:40:33 +00:00
|
|
|
#include <brotli/types.h>
|
2016-06-13 09:01:04 +00:00
|
|
|
#include "./command.h"
|
|
|
|
#include "./context.h"
|
2016-02-29 13:41:24 +00:00
|
|
|
#include "./entropy_encode.h"
|
2016-06-13 09:01:04 +00:00
|
|
|
#include "./memory.h"
|
2015-03-27 13:20:35 +00:00
|
|
|
#include "./metablock.h"
|
2016-06-13 09:01:04 +00:00
|
|
|
#include "./port.h"
|
2015-03-27 13:20:35 +00:00
|
|
|
|
2016-06-13 09:01:04 +00:00
|
|
|
#if defined(__cplusplus) || defined(c_plusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2014-10-15 12:01:36 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* All Store functions here will use a storage_ix, which is always the bit
|
|
|
|
position for the current storage. */
|
2014-10-15 12:01:36 +00:00
|
|
|
|
2016-06-13 09:01:04 +00:00
|
|
|
BROTLI_INTERNAL void BrotliStoreHuffmanTree(const uint8_t* depths, size_t num,
|
|
|
|
HuffmanTree* tree, size_t *storage_ix, uint8_t *storage);
|
|
|
|
|
|
|
|
BROTLI_INTERNAL void BrotliBuildAndStoreHuffmanTreeFast(
|
|
|
|
MemoryManager* m, const uint32_t* histogram, const size_t histogram_total,
|
|
|
|
const size_t max_bits, uint8_t* depth, uint16_t* bits, size_t* storage_ix,
|
|
|
|
uint8_t* storage);
|
2014-10-28 10:53:52 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* REQUIRES: length > 0 */
|
|
|
|
/* REQUIRES: length <= (1 << 24) */
|
2016-06-13 09:01:04 +00:00
|
|
|
BROTLI_INTERNAL void BrotliStoreMetaBlock(MemoryManager* m,
|
|
|
|
const uint8_t* input,
|
|
|
|
size_t start_pos,
|
|
|
|
size_t length,
|
|
|
|
size_t mask,
|
|
|
|
uint8_t prev_byte,
|
|
|
|
uint8_t prev_byte2,
|
2016-07-26 12:41:59 +00:00
|
|
|
BROTLI_BOOL is_final_block,
|
2016-06-13 09:01:04 +00:00
|
|
|
uint32_t num_direct_distance_codes,
|
|
|
|
uint32_t distance_postfix_bits,
|
|
|
|
ContextType literal_context_mode,
|
|
|
|
const Command* commands,
|
|
|
|
size_t n_commands,
|
|
|
|
const MetaBlockSplit* mb,
|
|
|
|
size_t* storage_ix,
|
|
|
|
uint8_t* storage);
|
2015-03-27 13:20:35 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* Stores the meta-block without doing any block splitting, just collects
|
|
|
|
one histogram per block category and uses that for entropy coding.
|
|
|
|
REQUIRES: length > 0
|
|
|
|
REQUIRES: length <= (1 << 24) */
|
2016-06-13 09:01:04 +00:00
|
|
|
BROTLI_INTERNAL void BrotliStoreMetaBlockTrivial(MemoryManager* m,
|
|
|
|
const uint8_t* input,
|
|
|
|
size_t start_pos,
|
|
|
|
size_t length,
|
|
|
|
size_t mask,
|
2016-07-26 12:41:59 +00:00
|
|
|
BROTLI_BOOL is_last,
|
2016-06-13 09:01:04 +00:00
|
|
|
const Command *commands,
|
|
|
|
size_t n_commands,
|
|
|
|
size_t* storage_ix,
|
|
|
|
uint8_t* storage);
|
2015-04-28 08:12:47 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* Same as above, but uses static prefix codes for histograms with a only a few
|
|
|
|
symbols, and uses static code length prefix codes for all other histograms.
|
|
|
|
REQUIRES: length > 0
|
|
|
|
REQUIRES: length <= (1 << 24) */
|
2016-06-13 09:01:04 +00:00
|
|
|
BROTLI_INTERNAL void BrotliStoreMetaBlockFast(MemoryManager* m,
|
|
|
|
const uint8_t* input,
|
|
|
|
size_t start_pos,
|
|
|
|
size_t length,
|
|
|
|
size_t mask,
|
2016-07-26 12:41:59 +00:00
|
|
|
BROTLI_BOOL is_last,
|
2016-06-13 09:01:04 +00:00
|
|
|
const Command *commands,
|
|
|
|
size_t n_commands,
|
|
|
|
size_t* storage_ix,
|
|
|
|
uint8_t* storage);
|
2016-01-08 09:10:22 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* This is for storing uncompressed blocks (simple raw storage of
|
|
|
|
bytes-as-bytes).
|
|
|
|
REQUIRES: length > 0
|
|
|
|
REQUIRES: length <= (1 << 24) */
|
2016-06-13 09:01:04 +00:00
|
|
|
BROTLI_INTERNAL void BrotliStoreUncompressedMetaBlock(
|
2016-07-26 12:41:59 +00:00
|
|
|
BROTLI_BOOL is_final_block, const uint8_t* input, size_t position,
|
|
|
|
size_t mask, size_t len, size_t* storage_ix, uint8_t* storage);
|
2015-03-27 13:20:35 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
/* Stores an empty metadata meta-block and syncs to a byte boundary. */
|
2016-06-13 09:01:04 +00:00
|
|
|
BROTLI_INTERNAL void BrotliStoreSyncMetaBlock(size_t* storage_ix,
|
|
|
|
uint8_t* storage);
|
2015-04-23 13:43:37 +00:00
|
|
|
|
2016-06-13 09:01:04 +00:00
|
|
|
#if defined(__cplusplus) || defined(c_plusplus)
|
|
|
|
} /* extern "C" */
|
|
|
|
#endif
|
2014-10-15 12:01:36 +00:00
|
|
|
|
2016-06-03 09:19:23 +00:00
|
|
|
#endif /* BROTLI_ENC_BROTLI_BIT_STREAM_H_ */
|