xref: /dflybsd-src/contrib/xz/src/liblzma/common/index.h (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
1*86d7f5d3SJohn Marino ///////////////////////////////////////////////////////////////////////////////
2*86d7f5d3SJohn Marino //
3*86d7f5d3SJohn Marino /// \file       index.h
4*86d7f5d3SJohn Marino /// \brief      Handling of Index
5*86d7f5d3SJohn Marino //
6*86d7f5d3SJohn Marino //  Author:     Lasse Collin
7*86d7f5d3SJohn Marino //
8*86d7f5d3SJohn Marino //  This file has been put into the public domain.
9*86d7f5d3SJohn Marino //  You can do whatever you want with this file.
10*86d7f5d3SJohn Marino //
11*86d7f5d3SJohn Marino ///////////////////////////////////////////////////////////////////////////////
12*86d7f5d3SJohn Marino 
13*86d7f5d3SJohn Marino #ifndef LZMA_INDEX_H
14*86d7f5d3SJohn Marino #define LZMA_INDEX_H
15*86d7f5d3SJohn Marino 
16*86d7f5d3SJohn Marino #include "common.h"
17*86d7f5d3SJohn Marino 
18*86d7f5d3SJohn Marino 
19*86d7f5d3SJohn Marino /// Minimum Unpadded Size
20*86d7f5d3SJohn Marino #define UNPADDED_SIZE_MIN LZMA_VLI_C(5)
21*86d7f5d3SJohn Marino 
22*86d7f5d3SJohn Marino /// Maximum Unpadded Size
23*86d7f5d3SJohn Marino #define UNPADDED_SIZE_MAX (LZMA_VLI_MAX & ~LZMA_VLI_C(3))
24*86d7f5d3SJohn Marino 
25*86d7f5d3SJohn Marino 
26*86d7f5d3SJohn Marino /// Get the size of the Index Padding field. This is needed by Index encoder
27*86d7f5d3SJohn Marino /// and decoder, but applications should have no use for this.
28*86d7f5d3SJohn Marino extern uint32_t lzma_index_padding_size(const lzma_index *i);
29*86d7f5d3SJohn Marino 
30*86d7f5d3SJohn Marino 
31*86d7f5d3SJohn Marino /// Set for how many Records to allocate memory the next time
32*86d7f5d3SJohn Marino /// lzma_index_append() needs to allocate space for a new Record.
33*86d7f5d3SJohn Marino /// This is used only by the Index decoder.
34*86d7f5d3SJohn Marino extern void lzma_index_prealloc(lzma_index *i, lzma_vli records);
35*86d7f5d3SJohn Marino 
36*86d7f5d3SJohn Marino 
37*86d7f5d3SJohn Marino /// Round the variable-length integer to the next multiple of four.
38*86d7f5d3SJohn Marino static inline lzma_vli
vli_ceil4(lzma_vli vli)39*86d7f5d3SJohn Marino vli_ceil4(lzma_vli vli)
40*86d7f5d3SJohn Marino {
41*86d7f5d3SJohn Marino 	assert(vli <= LZMA_VLI_MAX);
42*86d7f5d3SJohn Marino 	return (vli + 3) & ~LZMA_VLI_C(3);
43*86d7f5d3SJohn Marino }
44*86d7f5d3SJohn Marino 
45*86d7f5d3SJohn Marino 
46*86d7f5d3SJohn Marino /// Calculate the size of the Index field excluding Index Padding
47*86d7f5d3SJohn Marino static inline lzma_vli
index_size_unpadded(lzma_vli count,lzma_vli index_list_size)48*86d7f5d3SJohn Marino index_size_unpadded(lzma_vli count, lzma_vli index_list_size)
49*86d7f5d3SJohn Marino {
50*86d7f5d3SJohn Marino 	// Index Indicator + Number of Records + List of Records + CRC32
51*86d7f5d3SJohn Marino 	return 1 + lzma_vli_size(count) + index_list_size + 4;
52*86d7f5d3SJohn Marino }
53*86d7f5d3SJohn Marino 
54*86d7f5d3SJohn Marino 
55*86d7f5d3SJohn Marino /// Calculate the size of the Index field including Index Padding
56*86d7f5d3SJohn Marino static inline lzma_vli
index_size(lzma_vli count,lzma_vli index_list_size)57*86d7f5d3SJohn Marino index_size(lzma_vli count, lzma_vli index_list_size)
58*86d7f5d3SJohn Marino {
59*86d7f5d3SJohn Marino 	return vli_ceil4(index_size_unpadded(count, index_list_size));
60*86d7f5d3SJohn Marino }
61*86d7f5d3SJohn Marino 
62*86d7f5d3SJohn Marino 
63*86d7f5d3SJohn Marino /// Calculate the total size of the Stream
64*86d7f5d3SJohn Marino static inline lzma_vli
index_stream_size(lzma_vli blocks_size,lzma_vli count,lzma_vli index_list_size)65*86d7f5d3SJohn Marino index_stream_size(lzma_vli blocks_size,
66*86d7f5d3SJohn Marino 		lzma_vli count, lzma_vli index_list_size)
67*86d7f5d3SJohn Marino {
68*86d7f5d3SJohn Marino 	return LZMA_STREAM_HEADER_SIZE + blocks_size
69*86d7f5d3SJohn Marino 			+ index_size(count, index_list_size)
70*86d7f5d3SJohn Marino 			+ LZMA_STREAM_HEADER_SIZE;
71*86d7f5d3SJohn Marino }
72*86d7f5d3SJohn Marino 
73*86d7f5d3SJohn Marino #endif
74