mirror of
https://github.com/Xevion/easy7zip.git
synced 2025-12-06 13:14:59 -06:00
- Minor speed optimization for LZMA2 (xz and 7z) multi-threading compression.
7-Zip now uses additional memory buffers for multi-block LZMA2 compression.
CPU utilization was slightly improved.
- 7-zip now creates multi-block xz archives by default. Block size can be
specified with -ms[Size]{m|g} switch.
- xz decoder now can unpack random block from multi-block xz archives. 7-Zip
File Manager now can open nested multi-block xz archives (for example,
image.iso.xz) without full unpacking of xz archive.
- 7-Zip now can create zip archives from stdin to stdout.
- 7-Zip command line: @listfile now doesn't work after -- switch. Use
-i@listfile before -- switch instead.
fixed bugs:
- 7-Zip could add unrequired alternate file streams to WIM archives, for
commands that contain filename wildcards and -sns switch.
- 7-Zip 17.00 beta crashed for commands that write anti-item to 7z archive.
- 7-Zip 17.00 beta ignored "Use large memory pages" option.
91 lines
1.9 KiB
C
91 lines
1.9 KiB
C
/* Xz.c - Xz
|
|
2017-05-12 : Igor Pavlov : Public domain */
|
|
|
|
#include "Precomp.h"
|
|
|
|
#include "7zCrc.h"
|
|
#include "CpuArch.h"
|
|
#include "Xz.h"
|
|
#include "XzCrc64.h"
|
|
|
|
const Byte XZ_SIG[XZ_SIG_SIZE] = { 0xFD, '7', 'z', 'X', 'Z', 0 };
|
|
/* const Byte XZ_FOOTER_SIG[XZ_FOOTER_SIG_SIZE] = { 'Y', 'Z' }; */
|
|
|
|
unsigned Xz_WriteVarInt(Byte *buf, UInt64 v)
|
|
{
|
|
unsigned i = 0;
|
|
do
|
|
{
|
|
buf[i++] = (Byte)((v & 0x7F) | 0x80);
|
|
v >>= 7;
|
|
}
|
|
while (v != 0);
|
|
buf[(size_t)i - 1] &= 0x7F;
|
|
return i;
|
|
}
|
|
|
|
void Xz_Construct(CXzStream *p)
|
|
{
|
|
p->numBlocks = 0;
|
|
p->blocks = NULL;
|
|
p->flags = 0;
|
|
}
|
|
|
|
void Xz_Free(CXzStream *p, ISzAllocPtr alloc)
|
|
{
|
|
ISzAlloc_Free(alloc, p->blocks);
|
|
p->numBlocks = 0;
|
|
p->blocks = NULL;
|
|
}
|
|
|
|
unsigned XzFlags_GetCheckSize(CXzStreamFlags f)
|
|
{
|
|
unsigned t = XzFlags_GetCheckType(f);
|
|
return (t == 0) ? 0 : (4 << ((t - 1) / 3));
|
|
}
|
|
|
|
void XzCheck_Init(CXzCheck *p, unsigned mode)
|
|
{
|
|
p->mode = mode;
|
|
switch (mode)
|
|
{
|
|
case XZ_CHECK_CRC32: p->crc = CRC_INIT_VAL; break;
|
|
case XZ_CHECK_CRC64: p->crc64 = CRC64_INIT_VAL; break;
|
|
case XZ_CHECK_SHA256: Sha256_Init(&p->sha); break;
|
|
}
|
|
}
|
|
|
|
void XzCheck_Update(CXzCheck *p, const void *data, size_t size)
|
|
{
|
|
switch (p->mode)
|
|
{
|
|
case XZ_CHECK_CRC32: p->crc = CrcUpdate(p->crc, data, size); break;
|
|
case XZ_CHECK_CRC64: p->crc64 = Crc64Update(p->crc64, data, size); break;
|
|
case XZ_CHECK_SHA256: Sha256_Update(&p->sha, (const Byte *)data, size); break;
|
|
}
|
|
}
|
|
|
|
int XzCheck_Final(CXzCheck *p, Byte *digest)
|
|
{
|
|
switch (p->mode)
|
|
{
|
|
case XZ_CHECK_CRC32:
|
|
SetUi32(digest, CRC_GET_DIGEST(p->crc));
|
|
break;
|
|
case XZ_CHECK_CRC64:
|
|
{
|
|
int i;
|
|
UInt64 v = CRC64_GET_DIGEST(p->crc64);
|
|
for (i = 0; i < 8; i++, v >>= 8)
|
|
digest[i] = (Byte)(v & 0xFF);
|
|
break;
|
|
}
|
|
case XZ_CHECK_SHA256:
|
|
Sha256_Final(&p->sha, digest);
|
|
break;
|
|
default:
|
|
return 0;
|
|
}
|
|
return 1;
|
|
}
|