2008-06-18 17:02:10 +02:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
/// \file index.h
|
|
|
|
/// \brief Handling of Index
|
|
|
|
//
|
2009-04-13 10:27:40 +02:00
|
|
|
// Author: Lasse Collin
|
2008-06-18 17:02:10 +02:00
|
|
|
//
|
2009-04-13 10:27:40 +02:00
|
|
|
// This file has been put into the public domain.
|
|
|
|
// You can do whatever you want with this file.
|
2008-06-18 17:02:10 +02:00
|
|
|
//
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef LZMA_INDEX_H
|
|
|
|
#define LZMA_INDEX_H
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Minimum Unpadded Size
|
|
|
|
#define UNPADDED_SIZE_MIN LZMA_VLI_C(5)
|
2008-06-18 17:02:10 +02:00
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Maximum Unpadded Size
|
|
|
|
#define UNPADDED_SIZE_MAX (LZMA_VLI_MAX & ~LZMA_VLI_C(3))
|
2008-06-18 17:02:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/// Get the size of the Index Padding field. This is needed by Index encoder
|
|
|
|
/// and decoder, but applications should have no use for this.
|
|
|
|
extern uint32_t lzma_index_padding_size(const lzma_index *i);
|
|
|
|
|
|
|
|
|
2009-12-31 21:45:53 +01:00
|
|
|
/// Set for how many Records to allocate memory the next time
|
|
|
|
/// lzma_index_append() needs to allocate space for a new Record.
|
|
|
|
/// This is used only by the Index decoder.
|
|
|
|
extern void lzma_index_prealloc(lzma_index *i, lzma_vli records);
|
|
|
|
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Round the variable-length integer to the next multiple of four.
|
|
|
|
static inline lzma_vli
|
|
|
|
vli_ceil4(lzma_vli vli)
|
|
|
|
{
|
|
|
|
assert(vli <= LZMA_VLI_MAX);
|
|
|
|
return (vli + 3) & ~LZMA_VLI_C(3);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// Calculate the size of the Index field excluding Index Padding
|
2008-06-18 17:02:10 +02:00
|
|
|
static inline lzma_vli
|
|
|
|
index_size_unpadded(lzma_vli count, lzma_vli index_list_size)
|
|
|
|
{
|
|
|
|
// Index Indicator + Number of Records + List of Records + CRC32
|
|
|
|
return 1 + lzma_vli_size(count) + index_list_size + 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Calculate the size of the Index field including Index Padding
|
2008-06-18 17:02:10 +02:00
|
|
|
static inline lzma_vli
|
|
|
|
index_size(lzma_vli count, lzma_vli index_list_size)
|
|
|
|
{
|
2008-11-19 19:46:52 +01:00
|
|
|
return vli_ceil4(index_size_unpadded(count, index_list_size));
|
2008-06-18 17:02:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Calculate the total size of the Stream
|
2008-06-18 17:02:10 +02:00
|
|
|
static inline lzma_vli
|
2008-11-19 19:46:52 +01:00
|
|
|
index_stream_size(lzma_vli blocks_size,
|
|
|
|
lzma_vli count, lzma_vli index_list_size)
|
2008-06-18 17:02:10 +02:00
|
|
|
{
|
2008-11-19 19:46:52 +01:00
|
|
|
return LZMA_STREAM_HEADER_SIZE + blocks_size
|
2008-06-18 17:02:10 +02:00
|
|
|
+ index_size(count, index_list_size)
|
|
|
|
+ LZMA_STREAM_HEADER_SIZE;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|