47 lines
1.1 KiB
C
47 lines
1.1 KiB
C
|
// LzmaRam.h
|
||
|
|
||
|
#ifndef __LzmaRam_h
|
||
|
#define __LzmaRam_h
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
#include "../../../Common/Types.h"
|
||
|
|
||
|
/*
|
||
|
LzmaRamEncode: BCJ + LZMA RAM->RAM compressing.
|
||
|
It uses .lzma format, but it writes one additional byte to .lzma file:
|
||
|
0: - no filter
|
||
|
1: - x86(BCJ) filter.
|
||
|
|
||
|
To provide best compression ratio dictionarySize mustbe >= inSize
|
||
|
|
||
|
LzmaRamEncode allocates Data with MyAlloc/BigAlloc functions.
|
||
|
RAM Requirements:
|
||
|
RamSize = dictionarySize * 9.5 + 6MB + FilterBlockSize
|
||
|
FilterBlockSize = 0, if useFilter == false
|
||
|
FilterBlockSize = inSize, if useFilter == true
|
||
|
|
||
|
Return code:
|
||
|
0 - OK
|
||
|
1 - Unspecified Error
|
||
|
2 - Memory allocating error
|
||
|
3 - Output buffer OVERFLOW
|
||
|
|
||
|
If you use SZ_FILTER_AUTO mode, then encoder will use 2 or 3 passes:
|
||
|
2 passes when FILTER_NO provides better compression.
|
||
|
3 passes when FILTER_YES provides better compression.
|
||
|
*/
|
||
|
|
||
|
enum ESzFilterMode
|
||
|
{
|
||
|
SZ_FILTER_NO,
|
||
|
SZ_FILTER_YES,
|
||
|
SZ_FILTER_AUTO
|
||
|
};
|
||
|
|
||
|
int LzmaRamEncode(
|
||
|
const Byte *inBuffer, size_t inSize,
|
||
|
Byte *outBuffer, size_t outSize, size_t *outSizeProcessed,
|
||
|
UInt32 dictionarySize, ESzFilterMode filterMode);
|
||
|
|
||
|
#endif
|