mirror of
https://github.com/Xevion/easy7zip.git
synced 2025-12-07 20:06:59 -06:00
shunf4 cherry-picking hash related commits from zstd. The following commits from 7-zip-zstd repository (https://github.com/mcmilk/7-Zip-zstd) is picked:
commitadd56b5aedAuthor: Tino Reichardt <milky-7zip@mcmilk.de> Date: Thu Nov 1 23:08:00 2018 +0100 Add MD5 hash function commit36a17a5184Author: Tino Reichardt <milky-7zip@mcmilk.de> Date: Sat Nov 3 00:18:33 2018 +0100 Add some hash functions - new: md2, md4, md5, sha384, sha512, xxhash-32, xxhash-64 - put Blake2sp hash stuff back to rar code - added the hashes to GUI and Explorer Menu code commit576c5df947Author: Tino Reichardt <milky-7zip@mcmilk.de> Date: Tue Apr 6 19:35:46 2021 +0200 Add BLAKE3 hash function commit6b2a151549Author: Tino Reichardt <milky-7zip@mcmilk.de> Date: Tue Apr 6 19:51:01 2021 +0200 Remove unneeded file HashesReg.cpp commitdddf507557Author: Tino Reichardt <milky-7zip@mcmilk.de> Date: Sun Jun 18 09:13:59 2023 +0200 Add SHA3 hashing - added these variants: SHA3-256, SHA3-384, SHA3-512 - reordered also the hashing id's - added some notes about them in DOC/Hashes.txt Signed-off-by: Tino Reichardt <milky-7zip@mcmilk.de> The cherry-picking was a chaos; they're not applied in order, and some commits even got cherry-picked twice (1->4->0->2->4->3). So subsequent fixes and adjustments were applied to make it build.
This commit is contained in:
@@ -795,18 +795,10 @@ static const char *SkipWhite(const char *s)
|
||||
|
||||
static const char * const k_CsumMethodNames[] =
|
||||
{
|
||||
"sha256"
|
||||
, "sha224"
|
||||
// , "sha512/224"
|
||||
// , "sha512/256"
|
||||
, "sha512"
|
||||
, "sha384"
|
||||
, "sha1"
|
||||
, "md5"
|
||||
, "blake2b"
|
||||
, "crc64"
|
||||
, "crc32"
|
||||
, "cksum"
|
||||
"sha3-512", "sha3-384", "sha3-256",
|
||||
"sha512", "sha384", "sha256", "sha224",
|
||||
"sha1", "md5", "blake2b",
|
||||
"crc32", "crc64" , "cksum"
|
||||
};
|
||||
|
||||
static UString GetMethod_from_FileName(const UString &name)
|
||||
@@ -1409,7 +1401,8 @@ static bool CheckDigests(const Byte *a, const Byte *b, size_t size)
|
||||
static void AddDefaultMethod(UStringVector &methods, unsigned size)
|
||||
{
|
||||
const char *m = NULL;
|
||||
if (size == 32) m = "sha256";
|
||||
if (size == 64) m = "sha512";
|
||||
else if (size == 32) m = "sha256";
|
||||
else if (size == 20) m = "sha1";
|
||||
else if (size == 16) m = "md5";
|
||||
else if (size == 8) m = "crc64";
|
||||
@@ -2090,11 +2083,11 @@ void Codecs_AddHashArcHandler(CCodecs *codecs)
|
||||
|
||||
// ubuntu uses "SHA256SUMS" file
|
||||
item.AddExts(UString (
|
||||
"sha256 sha512 sha224 sha384 sha1 sha md5"
|
||||
// "b2sum"
|
||||
" crc32 crc64"
|
||||
" asc"
|
||||
" cksum"
|
||||
"sha3-512 sha3-384 sha3-256 "
|
||||
"sha512 sha384 sha256 sha224 "
|
||||
"sha1 sha md5 "
|
||||
"crc32 crc64 "
|
||||
"asc cksum"
|
||||
),
|
||||
UString());
|
||||
|
||||
|
||||
Reference in New Issue
Block a user