mirror of
https://github.com/Xevion/easy7zip.git
synced 2026-01-31 12:24:08 -06:00
Merge remote-tracking branch 'upstream/master'
This commit is contained in:
@@ -28,6 +28,7 @@ OBJS = \
|
||||
$(CRYPTO_OBJS) \
|
||||
$(C_OBJS) \
|
||||
$(BROTLI_OBJS) \
|
||||
$(HASHES_OBJS) \
|
||||
$(LIZARD_OBJS) \
|
||||
$(LZ4_OBJS) \
|
||||
$(LZ5_OBJS) \
|
||||
@@ -278,6 +279,8 @@ $(FASTLZMA2_OBJS): ../../../../C/fast-lzma2/$(*B).c
|
||||
$(COMPLB_O2)
|
||||
{../../../../C/brotli}.c{$O}.obj::
|
||||
$(COMPLB_O2)
|
||||
{../../../../C/hashes}.c{$O}.obj::
|
||||
$(COMPLB_O2)
|
||||
{../../../../C/lizard}.c{$O}.obj::
|
||||
$(COMPLB_O2)
|
||||
{../../../../C/lz4}.c{$O}.obj::
|
||||
@@ -289,6 +292,7 @@ $(FASTLZMA2_OBJS): ../../../../C/fast-lzma2/$(*B).c
|
||||
{../../../../C/zstdmt}.c{$O}.obj::
|
||||
$(COMPLB_O2) \
|
||||
-I ../../../../C/brotli \
|
||||
-I ../../../../C/hashes \
|
||||
-I ../../../../C/lizard \
|
||||
-I ../../../../C/lz4 \
|
||||
-I ../../../../C/lz5 \
|
||||
|
||||
@@ -3,6 +3,9 @@ COMMON_OBJS = \
|
||||
$O\CrcReg.obj \
|
||||
$O\DynLimBuf.obj \
|
||||
$O\IntToString.obj \
|
||||
$O\Md2Reg.obj \
|
||||
$O\Md4Reg.obj \
|
||||
$O\Md5Reg.obj \
|
||||
$O\MyMap.obj \
|
||||
$O\MyString.obj \
|
||||
$O\MyVector.obj \
|
||||
@@ -10,10 +13,14 @@ COMMON_OBJS = \
|
||||
$O\NewHandler.obj \
|
||||
$O\Sha1Reg.obj \
|
||||
$O\Sha256Reg.obj \
|
||||
$O\Sha384Reg.obj \
|
||||
$O\Sha512Reg.obj \
|
||||
$O\StringConvert.obj \
|
||||
$O\StringToInt.obj \
|
||||
$O\UTFConvert.obj \
|
||||
$O\Wildcard.obj \
|
||||
$O\XXH32Reg.obj \
|
||||
$O\XXH64Reg.obj \
|
||||
$O\XzCrc64Init.obj \
|
||||
$O\XzCrc64Reg.obj \
|
||||
|
||||
@@ -249,6 +256,12 @@ CRYPTO_OBJS = \
|
||||
$O\ZipCrypto.obj \
|
||||
$O\ZipStrong.obj \
|
||||
|
||||
HASHES_OBJS = \
|
||||
$O\md2.obj \
|
||||
$O\md4.obj \
|
||||
$O\md5.obj \
|
||||
$O\sha512.obj \
|
||||
|
||||
C_OBJS = \
|
||||
$O\7zBuf2.obj \
|
||||
$O\7zStream.obj \
|
||||
|
||||
@@ -3,6 +3,9 @@ COMMON_OBJS = \
|
||||
$O\CrcReg.obj \
|
||||
$O\DynLimBuf.obj \
|
||||
$O\IntToString.obj \
|
||||
$O\Md2Reg.obj \
|
||||
$O\Md4Reg.obj \
|
||||
$O\Md5Reg.obj \
|
||||
$O\MyMap.obj \
|
||||
$O\MyString.obj \
|
||||
$O\MyVector.obj \
|
||||
@@ -10,10 +13,14 @@ COMMON_OBJS = \
|
||||
$O\NewHandler.obj \
|
||||
$O\Sha1Reg.obj \
|
||||
$O\Sha256Reg.obj \
|
||||
$O\Sha384Reg.obj \
|
||||
$O\Sha512Reg.obj \
|
||||
$O\StringConvert.obj \
|
||||
$O\StringToInt.obj \
|
||||
$O\UTFConvert.obj \
|
||||
$O\Wildcard.obj \
|
||||
$O\XXH32Reg.obj \
|
||||
$O\XXH64Reg.obj \
|
||||
$O\XzCrc64Init.obj \
|
||||
$O\XzCrc64Reg.obj \
|
||||
|
||||
@@ -249,6 +256,12 @@ CRYPTO_OBJS = \
|
||||
$O\ZipCrypto.obj \
|
||||
$O\ZipStrong.obj \
|
||||
|
||||
HASHES_OBJS = \
|
||||
$O\md2.obj \
|
||||
$O\md4.obj \
|
||||
$O\md5.obj \
|
||||
$O\sha512.obj \
|
||||
|
||||
C_OBJS = \
|
||||
$O\7zBuf2.obj \
|
||||
$O\7zStream.obj \
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
PROG = 7z.dll
|
||||
DEF_FILE = ../../Archive/Archive2.def
|
||||
CFLAGS = $(CFLAGS) \
|
||||
-DEXTERNAL_CODECS -DNEED_7ZIP_GUID -DZSTD_LEGACY_SUPPORT \
|
||||
CFLAGS = $(CFLAGS) -DNEED_7ZIP_GUID -DEXTERNAL_CODECS -DZSTD_LEGACY_SUPPORT -DZSTD_MULTITHREAD
|
||||
|
||||
!IFNDEF UNDER_CE
|
||||
CFLAGS = $(CFLAGS) -DNEED_7ZIP_GUID -D_7ZIP_LARGE_PAGES
|
||||
|
||||
@@ -133,8 +133,8 @@ C_OBJS = \
|
||||
!include "../../LzmaDec.mak"
|
||||
|
||||
COMPRESS_OBJS = $(COMPRESS_OBJS) \
|
||||
$O\ZstdEncoder.obj \
|
||||
$O\ZstdDecoder.obj \
|
||||
$O\ZstdEncoder.obj \
|
||||
$O\ZstdRegister.obj \
|
||||
|
||||
ZSTD_OBJS = \
|
||||
|
||||
@@ -44,7 +44,6 @@ WIN_OBJS = \
|
||||
$O\Shell.obj \
|
||||
$O\System.obj \
|
||||
$O\Synchronization.obj \
|
||||
$O\System.obj \
|
||||
$O\Window.obj \
|
||||
|
||||
WIN_CTRL_OBJS = \
|
||||
@@ -152,8 +151,8 @@ C_OBJS = \
|
||||
!include "../../LzmaDec.mak"
|
||||
|
||||
COMPRESS_OBJS = $(COMPRESS_OBJS) \
|
||||
$O\ZstdEncoder.obj \
|
||||
$O\ZstdDecoder.obj \
|
||||
$O\ZstdEncoder.obj \
|
||||
$O\ZstdRegister.obj \
|
||||
|
||||
ZSTD_OBJS = \
|
||||
|
||||
@@ -102,5 +102,5 @@ void RegisterHasher(const CHasherInfo *hasher) throw();
|
||||
static const CHasherInfo g_HasherInfo = { CreateHasherSpec, id, name, size }; \
|
||||
struct REGISTER_HASHER_NAME(cls) { REGISTER_HASHER_NAME(cls)() { RegisterHasher(&g_HasherInfo); }}; \
|
||||
static REGISTER_HASHER_NAME(cls) g_RegisterHasher;
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
@@ -84,11 +84,6 @@ HRESULT CDecoder::CodeSpec(ISequentialInStream * inStream,
|
||||
ZSTD_resetDStream(_ctx);
|
||||
}
|
||||
|
||||
// _processedOut += zOut.pos;
|
||||
// RINOK(ReadStream(inStream, _srcBuf, &size));
|
||||
// RINOK(WriteStream(outStream, _dstBuf, zOut.pos));
|
||||
// RINOK(progress->SetRatioInfo(&_processedIn, &_processedOut));
|
||||
|
||||
zIn.src = _srcBuf;
|
||||
zIn.size = _srcBufSize;
|
||||
zIn.pos = 0;
|
||||
@@ -141,10 +136,11 @@ HRESULT CDecoder::CodeSpec(ISequentialInStream * inStream,
|
||||
result = ZSTD_resetDStream(_ctx);
|
||||
if (ZSTD_isError(result))
|
||||
return E_FAIL;
|
||||
/* read next input, or eof */
|
||||
break;
|
||||
}
|
||||
} /* for() decompress */
|
||||
|
||||
|
||||
/* read next input */
|
||||
srcBufLen = _srcBufSize;
|
||||
RINOK(ReadStream(inStream, _srcBuf, &srcBufLen));
|
||||
@@ -173,11 +169,6 @@ STDMETHODIMP CDecoder::SetInStream(ISequentialInStream * inStream)
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
STDMETHODIMP CDecoder::SetNumberOfThreads(UInt32 /* numThreads */)
|
||||
{
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
STDMETHODIMP CDecoder::ReleaseInStream()
|
||||
{
|
||||
_inStream.Release();
|
||||
@@ -185,6 +176,11 @@ STDMETHODIMP CDecoder::ReleaseInStream()
|
||||
}
|
||||
#endif
|
||||
|
||||
STDMETHODIMP CDecoder::SetNumberOfThreads(UInt32 /* numThreads */)
|
||||
{
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
HRESULT CDecoder::CodeResume(ISequentialOutStream * outStream, const UInt64 * outSize, ICompressProgressInfo * progress)
|
||||
{
|
||||
RINOK(SetOutStreamSizeResume(outSize));
|
||||
|
||||
@@ -104,15 +104,19 @@ STDMETHODIMP CEncoder::Code(ISequentialInStream *inStream,
|
||||
if (!_dstBuf)
|
||||
return E_OUTOFMEMORY;
|
||||
|
||||
/* setup level */
|
||||
err = ZSTD_CCtx_setParameter(_ctx, ZSTD_p_compressionLevel, _props._level);
|
||||
if (ZSTD_isError(err)) return E_FAIL;
|
||||
|
||||
/* setup thread count */
|
||||
err = ZSTD_CCtx_setParameter(_ctx, ZSTD_p_nbWorkers, _numThreads);
|
||||
if (ZSTD_isError(err)) return E_FAIL;
|
||||
|
||||
/* set the content size flag */
|
||||
err = ZSTD_CCtx_setParameter(_ctx, ZSTD_p_contentSizeFlag, 1);
|
||||
if (ZSTD_isError(err)) return E_FAIL;
|
||||
|
||||
/* todo: make this optional */
|
||||
err = ZSTD_CCtx_setParameter(_ctx, ZSTD_p_enableLongDistanceMatching, 1);
|
||||
if (ZSTD_isError(err)) return E_FAIL;
|
||||
}
|
||||
|
||||
@@ -221,11 +221,19 @@ struct CHashCommand
|
||||
|
||||
static const CHashCommand g_HashCommands[] =
|
||||
{
|
||||
{ CZipContextMenu::kHash_CRC32, "CRC-32", "CRC32" },
|
||||
{ CZipContextMenu::kHash_CRC64, "CRC-64", "CRC64" },
|
||||
{ CZipContextMenu::kHash_SHA1, "SHA-1", "SHA1" },
|
||||
{ CZipContextMenu::kHash_SHA256, "SHA-256", "SHA256" },
|
||||
{ CZipContextMenu::kHash_All, "*", "*" }
|
||||
{ CZipContextMenu::kHash_CRC32, "CRC-32", "CRC32" },
|
||||
{ CZipContextMenu::kHash_CRC64, "CRC-64", "CRC64" },
|
||||
{ CZipContextMenu::kHash_XXH32, "XXH-32", "XXH32" },
|
||||
{ CZipContextMenu::kHash_XXH64, "XXH-64", "XXH64" },
|
||||
{ CZipContextMenu::kHash_MD5, "MD2", "MD2" },
|
||||
{ CZipContextMenu::kHash_MD5, "MD4", "MD4" },
|
||||
{ CZipContextMenu::kHash_MD5, "MD5", "MD5" },
|
||||
{ CZipContextMenu::kHash_SHA1, "SHA-1", "SHA1" },
|
||||
{ CZipContextMenu::kHash_SHA256, "SHA-256", "SHA256" },
|
||||
{ CZipContextMenu::kHash_SHA256, "SHA-384", "SHA384" },
|
||||
{ CZipContextMenu::kHash_SHA256, "SHA-512", "SHA512" },
|
||||
{ CZipContextMenu::kHash_BLAKE2sp, "BLAKE2sp", "BLAKE2sp" },
|
||||
{ CZipContextMenu::kHash_All, "*", "*" }
|
||||
};
|
||||
|
||||
static int FindCommand(CZipContextMenu::ECommandInternalID &id)
|
||||
@@ -926,8 +934,16 @@ STDMETHODIMP CZipContextMenu::InvokeCommand(LPCMINVOKECOMMANDINFO commandInfo)
|
||||
|
||||
case kHash_CRC32:
|
||||
case kHash_CRC64:
|
||||
case kHash_XXH32:
|
||||
case kHash_XXH64:
|
||||
case kHash_MD2:
|
||||
case kHash_MD4:
|
||||
case kHash_MD5:
|
||||
case kHash_SHA1:
|
||||
case kHash_SHA256:
|
||||
case kHash_SHA384:
|
||||
case kHash_SHA512:
|
||||
case kHash_BLAKE2sp:
|
||||
case kHash_All:
|
||||
{
|
||||
for (unsigned i = 0; i < ARRAY_SIZE(g_HashCommands); i++)
|
||||
|
||||
@@ -34,8 +34,16 @@ public:
|
||||
kCompressToZipEmail,
|
||||
kHash_CRC32,
|
||||
kHash_CRC64,
|
||||
kHash_XXH32,
|
||||
kHash_XXH64,
|
||||
kHash_MD2,
|
||||
kHash_MD4,
|
||||
kHash_MD5,
|
||||
kHash_SHA1,
|
||||
kHash_SHA256,
|
||||
kHash_SHA384,
|
||||
kHash_SHA512,
|
||||
kHash_BLAKE2sp,
|
||||
kHash_All
|
||||
};
|
||||
|
||||
|
||||
@@ -578,8 +578,16 @@ bool ExecuteFileCommand(int id)
|
||||
case IDM_HASH_ALL: g_App.CalculateCrc("*"); break;
|
||||
case IDM_CRC32: g_App.CalculateCrc("CRC32"); break;
|
||||
case IDM_CRC64: g_App.CalculateCrc("CRC64"); break;
|
||||
case IDM_SHA1: g_App.CalculateCrc("SHA1"); break;
|
||||
case IDM_XXH32: g_App.CalculateCrc("XXH32"); break;
|
||||
case IDM_XXH64: g_App.CalculateCrc("XXH64"); break;
|
||||
case IDM_MD2: g_App.CalculateCrc("MD2"); break;
|
||||
case IDM_MD4: g_App.CalculateCrc("MD4"); break;
|
||||
case IDM_MD5: g_App.CalculateCrc("MD5"); break;
|
||||
case IDM_SHA1: g_App.CalculateCrc("SHA1"); break;
|
||||
case IDM_SHA256: g_App.CalculateCrc("SHA256"); break;
|
||||
case IDM_SHA384: g_App.CalculateCrc("SHA384"); break;
|
||||
case IDM_SHA512: g_App.CalculateCrc("SHA512"); break;
|
||||
case IDM_BLAKE2sp: g_App.CalculateCrc("BLAKE2sp"); break;
|
||||
|
||||
case IDM_DIFF: g_App.DiffFiles(); break;
|
||||
case IDM_SPLIT: g_App.Split(); break;
|
||||
|
||||
@@ -23,8 +23,16 @@
|
||||
#define IDM_HASH_ALL 101
|
||||
#define IDM_CRC32 102
|
||||
#define IDM_CRC64 103
|
||||
#define IDM_SHA1 104
|
||||
#define IDM_SHA256 105
|
||||
#define IDM_XXH32 104
|
||||
#define IDM_XXH64 105
|
||||
#define IDM_MD2 106
|
||||
#define IDM_MD4 107
|
||||
#define IDM_MD5 108
|
||||
#define IDM_SHA1 109
|
||||
#define IDM_SHA256 110
|
||||
#define IDM_SHA384 111
|
||||
#define IDM_SHA512 112
|
||||
#define IDM_BLAKE2sp 113
|
||||
|
||||
#define IDM_OPEN 540
|
||||
#define IDM_OPEN_INSIDE 541
|
||||
|
||||
@@ -40,8 +40,16 @@ BEGIN
|
||||
BEGIN
|
||||
MENUITEM "CRC-32", IDM_CRC32
|
||||
MENUITEM "CRC-64", IDM_CRC64
|
||||
MENUITEM "xxHash-32", IDM_XXH32
|
||||
MENUITEM "xxHash-64", IDM_XXH64
|
||||
MENUITEM "MD2", IDM_MD2
|
||||
MENUITEM "MD4", IDM_MD4
|
||||
MENUITEM "MD5", IDM_MD5
|
||||
MENUITEM "SHA-1", IDM_SHA1
|
||||
MENUITEM "SHA-256", IDM_SHA256
|
||||
MENUITEM "SHA-384", IDM_SHA384
|
||||
MENUITEM "SHA-512", IDM_SHA512
|
||||
MENUITEM "Blake2sp", IDM_BLAKE2sp
|
||||
MENUITEM "*", IDM_HASH_ALL
|
||||
END
|
||||
MENUITEM "Di&ff", IDM_DIFF
|
||||
|
||||
@@ -0,0 +1,237 @@
|
||||
// XXH32Reg.cpp
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
#define XXH_STATIC_LINKING_ONLY
|
||||
#include "../../C/zstd/xxhash.h"
|
||||
#include "../../C/hashes/md2.h"
|
||||
#include "../../C/hashes/md4.h"
|
||||
#include "../../C/hashes/md5.h"
|
||||
#include "../../C/hashes/sha.h"
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// XXH32
|
||||
class CXXH32Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
XXH32_state_t *_ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CXXH32Hasher() { _ctx = XXH32_createState(); }
|
||||
~CXXH32Hasher() { XXH32_freeState(_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CXXH32Hasher::Init() throw()
|
||||
{
|
||||
XXH32_reset(_ctx, 0);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH32Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
XXH32_update(_ctx, data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH32Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
UInt32 val = XXH32_digest(_ctx);
|
||||
SetUi32(digest, val);
|
||||
}
|
||||
|
||||
REGISTER_HASHER(CXXH32Hasher, 0x203, "XXH32", 4)
|
||||
|
||||
// XXH64
|
||||
class CXXH64Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
XXH64_state_t *_ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CXXH64Hasher() { _ctx = XXH64_createState(); }
|
||||
~CXXH64Hasher() { XXH64_freeState(_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CXXH64Hasher::Init() throw()
|
||||
{
|
||||
XXH64_reset(_ctx, 0);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH64Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
XXH64_update(_ctx, data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH64Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
UInt64 val = XXH64_digest(_ctx);
|
||||
SetUi64(digest, val);
|
||||
}
|
||||
REGISTER_HASHER(CXXH64Hasher, 0x204, "XXH64", 8)
|
||||
|
||||
// MD2
|
||||
class CMD2Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
MD2_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CMD2Hasher() { MD2_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CMD2Hasher::Init() throw()
|
||||
{
|
||||
MD2_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD2Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
MD2_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD2Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
MD2_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CMD2Hasher, 0x205, "MD2", MD2_DIGEST_LENGTH)
|
||||
|
||||
// MD4
|
||||
class CMD4Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
MD4_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CMD4Hasher() { MD4_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CMD4Hasher::Init() throw()
|
||||
{
|
||||
MD4_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD4Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
MD4_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD4Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
MD4_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CMD4Hasher, 0x206, "MD4", MD4_DIGEST_LENGTH)
|
||||
|
||||
// MD5
|
||||
class CMD5Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
MD5_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CMD5Hasher() { MD5_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CMD5Hasher::Init() throw()
|
||||
{
|
||||
MD5_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD5Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
MD5_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD5Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
MD5_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CMD5Hasher, 0x207, "MD5", MD5_DIGEST_LENGTH)
|
||||
|
||||
// SHA384
|
||||
class CSHA384Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
SHA384_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CSHA384Hasher() { SHA384_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CSHA384Hasher::Init() throw()
|
||||
{
|
||||
SHA384_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA384Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
SHA384_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA384Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
SHA384_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CSHA384Hasher, 0x208, "SHA384", SHA384_DIGEST_LENGTH)
|
||||
|
||||
// SHA512
|
||||
class CSHA512Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
SHA512_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CSHA512Hasher() { SHA512_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CSHA512Hasher::Init() throw()
|
||||
{
|
||||
SHA512_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA512Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
SHA512_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA512Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
SHA512_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CSHA512Hasher, 0x209, "SHA512", SHA512_DIGEST_LENGTH)
|
||||
@@ -0,0 +1,43 @@
|
||||
// Md2Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
EXTERN_C_BEGIN
|
||||
#include "../../C/hashes/md2.h"
|
||||
EXTERN_C_END
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// MD2
|
||||
class CMD2Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
MD2_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CMD2Hasher() { MD2_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CMD2Hasher::Init() throw()
|
||||
{
|
||||
MD2_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD2Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
MD2_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD2Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
MD2_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CMD2Hasher, 0x205, "MD2", MD2_DIGEST_LENGTH)
|
||||
@@ -0,0 +1,43 @@
|
||||
// Md4Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
EXTERN_C_BEGIN
|
||||
#include "../../C/hashes/md4.h"
|
||||
EXTERN_C_END
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// MD4
|
||||
class CMD4Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
MD4_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CMD4Hasher() { MD4_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CMD4Hasher::Init() throw()
|
||||
{
|
||||
MD4_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD4Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
MD4_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD4Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
MD4_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CMD4Hasher, 0x206, "MD4", MD4_DIGEST_LENGTH)
|
||||
@@ -0,0 +1,43 @@
|
||||
// Md5Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
EXTERN_C_BEGIN
|
||||
#include "../../C/hashes/md5.h"
|
||||
EXTERN_C_END
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// MD5
|
||||
class CMD5Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
MD5_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CMD5Hasher() { MD5_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CMD5Hasher::Init() throw()
|
||||
{
|
||||
MD5_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD5Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
MD5_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CMD5Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
MD5_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CMD5Hasher, 0x207, "MD5", MD5_DIGEST_LENGTH)
|
||||
@@ -0,0 +1,43 @@
|
||||
// Sha384Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
EXTERN_C_BEGIN
|
||||
#include "../../C/hashes/sha.h"
|
||||
EXTERN_C_END
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// SHA384
|
||||
class CSHA384Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
SHA384_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CSHA384Hasher() { SHA384_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CSHA384Hasher::Init() throw()
|
||||
{
|
||||
SHA384_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA384Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
SHA384_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA384Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
SHA384_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CSHA384Hasher, 0x208, "SHA384", SHA384_DIGEST_LENGTH)
|
||||
@@ -0,0 +1,43 @@
|
||||
// Sha512Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
EXTERN_C_BEGIN
|
||||
#include "../../C/hashes/sha.h"
|
||||
EXTERN_C_END
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// SHA512
|
||||
class CSHA512Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
SHA512_CTX _ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CSHA512Hasher() { SHA512_Init(&_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CSHA512Hasher::Init() throw()
|
||||
{
|
||||
SHA512_Init(&_ctx);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA512Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
SHA512_Update(&_ctx, (const Byte *)data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CSHA512Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
SHA512_Final(digest, &_ctx);
|
||||
}
|
||||
REGISTER_HASHER(CSHA512Hasher, 0x209, "SHA512", SHA512_DIGEST_LENGTH)
|
||||
@@ -0,0 +1,45 @@
|
||||
// XXH32Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
#define XXH_STATIC_LINKING_ONLY
|
||||
#include "../../C/zstd/xxhash.h"
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// XXH32
|
||||
class CXXH32Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
XXH32_state_t *_ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CXXH32Hasher() { _ctx = XXH32_createState(); }
|
||||
~CXXH32Hasher() { XXH32_freeState(_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CXXH32Hasher::Init() throw()
|
||||
{
|
||||
XXH32_reset(_ctx, 0);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH32Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
XXH32_update(_ctx, data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH32Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
UInt32 val = XXH32_digest(_ctx);
|
||||
SetUi32(digest, val);
|
||||
}
|
||||
|
||||
REGISTER_HASHER(CXXH32Hasher, 0x203, "XXH32", 4)
|
||||
@@ -0,0 +1,44 @@
|
||||
// XXH64Reg.cpp /TR 2018-11-02
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "../../C/CpuArch.h"
|
||||
|
||||
#define XXH_STATIC_LINKING_ONLY
|
||||
#include "../../C/zstd/xxhash.h"
|
||||
|
||||
#include "../Common/MyCom.h"
|
||||
#include "../7zip/Common/RegisterCodec.h"
|
||||
|
||||
// XXH64
|
||||
class CXXH64Hasher:
|
||||
public IHasher,
|
||||
public CMyUnknownImp
|
||||
{
|
||||
XXH64_state_t *_ctx;
|
||||
Byte mtDummy[1 << 7];
|
||||
|
||||
public:
|
||||
CXXH64Hasher() { _ctx = XXH64_createState(); }
|
||||
~CXXH64Hasher() { XXH64_freeState(_ctx); }
|
||||
|
||||
MY_UNKNOWN_IMP1(IHasher)
|
||||
INTERFACE_IHasher(;)
|
||||
};
|
||||
|
||||
STDMETHODIMP_(void) CXXH64Hasher::Init() throw()
|
||||
{
|
||||
XXH64_reset(_ctx, 0);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH64Hasher::Update(const void *data, UInt32 size) throw()
|
||||
{
|
||||
XXH64_update(_ctx, data, size);
|
||||
}
|
||||
|
||||
STDMETHODIMP_(void) CXXH64Hasher::Final(Byte *digest) throw()
|
||||
{
|
||||
UInt64 val = XXH64_digest(_ctx);
|
||||
SetUi64(digest, val);
|
||||
}
|
||||
REGISTER_HASHER(CXXH64Hasher, 0x204, "XXH64", 8)
|
||||
@@ -1,9 +1,11 @@
|
||||
@echo off
|
||||
|
||||
REM Microsoft Windows SDK 7.1 (VC=sdk71)
|
||||
REM Microsoft Visual Studio 2010 (VC=10.0)
|
||||
REM Microsoft Visual Studio 2012 (VC=11.0)
|
||||
REM Microsoft Visual Studio 2013 (VC=12.0)
|
||||
REM Microsoft Visual Studio 2015 (VC=14.0)
|
||||
REM Microsoft Visual Studio 2017 (VC=15.0)
|
||||
|
||||
REM to many vcvarsall.cmd calls will blow it up!
|
||||
set OPATH=%PATH%
|
||||
|
||||
+1
-1
@@ -4,7 +4,7 @@ set ROOT=%cd%\7zip
|
||||
if not defined OUTDIR set OUTDIR=%ROOT%\binIA64
|
||||
mkdir %OUTDIR%
|
||||
|
||||
set OPTS=CPU=IA64 MY_STATIC_LINK=1 /NOLOGO
|
||||
set OPTS=CPU=IA64 MY_STATIC_LINK=1 /NOLOGO /TP
|
||||
set LFLAGS=/SUBSYSTEM:WINDOWS,"5.02"
|
||||
|
||||
cd %ROOT%\Bundles\Format7zExtract
|
||||
|
||||
Reference in New Issue
Block a user