Defines | Functions

/tmp/buildd/xz-utils-5.0.0/src/liblzma/common/block_encoder.h File Reference

Encodes .xz Blocks. More...

#include "common.h"

Defines

#define COMPRESSED_SIZE_MAX
 Biggest Compressed Size value that the Block encoder supports.

Functions

lzma_ret lzma_block_encoder_init (lzma_next_coder *next, lzma_allocator *allocator, lzma_block *block)

Detailed Description

Encodes .xz Blocks.


Define Documentation

#define COMPRESSED_SIZE_MAX
Value:
((LZMA_VLI_MAX - LZMA_BLOCK_HEADER_SIZE_MAX \
                - LZMA_CHECK_SIZE_MAX) & ~LZMA_VLI_C(3))

Biggest Compressed Size value that the Block encoder supports.

The maximum size of a single Block is limited by the maximum size of a Stream, which in theory is 2^63 - 3 bytes (i.e. LZMA_VLI_MAX - 3). While the size is really big and no one should hit it in practice, we take it into account in some places anyway to catch some errors e.g. if application passes insanely big value to some function.

We could take into account the headers etc. to determine the exact maximum size of the Compressed Data field, but the complexity would give us nothing useful. Instead, limit the size of Compressed Data so that even with biggest possible Block Header and Check fields the total encoded size of the Block stays as a valid VLI. This doesn't guarantee that the size of the Stream doesn't grow too big, but that problem is taken care outside the Block handling code.

~LZMA_VLI_C(3) is to guarantee that if we need padding at the end of the Compressed Data field, it will still stay in the proper limit.

This constant is in this file because it is needed in both block_encoder.c and block_buffer_encoder.c.