From f278895908e663a6a5a2c1f63e5523c5004f5d20 Mon Sep 17 00:00:00 2001 From: weidai Date: Fri, 4 Jul 2003 00:17:37 +0000 Subject: create DLL version, fix GetNextIV() bug in CTR and OFB modes --- sha.h | 32 +++++++++----------------------- 1 file changed, 9 insertions(+), 23 deletions(-) (limited to 'sha.h') diff --git a/sha.h b/sha.h index 9c1cce5a..f7936761 100644 --- a/sha.h +++ b/sha.h @@ -6,63 +6,49 @@ NAMESPACE_BEGIN(CryptoPP) /// SHA-1 -class SHA : public IteratedHashWithStaticTransform +class CRYPTOPP_DLL SHA : public IteratedHashWithStaticTransform { public: - enum {DIGESTSIZE = 20}; - SHA() : IteratedHashWithStaticTransform(DIGESTSIZE) {Init();} + static void InitState(HashWordType *state); static void Transform(word32 *digest, const word32 *data); static const char *StaticAlgorithmName() {return "SHA-1";} - -protected: - void Init(); }; typedef SHA SHA1; //! implements the SHA-256 standard -class SHA256 : public IteratedHashWithStaticTransform +class CRYPTOPP_DLL SHA256 : public IteratedHashWithStaticTransform { public: - enum {DIGESTSIZE = 32}; - SHA256() : IteratedHashWithStaticTransform(DIGESTSIZE) {Init();} + static void InitState(HashWordType *state); static void Transform(word32 *digest, const word32 *data); static const char *StaticAlgorithmName() {return "SHA-256";} protected: - void Init(); - static const word32 K[64]; }; #ifdef WORD64_AVAILABLE //! implements the SHA-512 standard -class SHA512 : public IteratedHashWithStaticTransform +class CRYPTOPP_DLL SHA512 : public IteratedHashWithStaticTransform { public: - enum {DIGESTSIZE = 64}; - SHA512() : IteratedHashWithStaticTransform(DIGESTSIZE) {Init();} + static void InitState(HashWordType *state); static void Transform(word64 *digest, const word64 *data); static const char *StaticAlgorithmName() {return "SHA-512";} protected: - void Init(); - static const word64 K[80]; }; //! implements the SHA-384 standard -class SHA384 : public IteratedHashWithStaticTransform +class CRYPTOPP_DLL SHA384 : public IteratedHashWithStaticTransform { public: - enum {DIGESTSIZE = 48}; - SHA384() : IteratedHashWithStaticTransform(64) {Init();} - unsigned int DigestSize() const {return DIGESTSIZE;}; + static void InitState(HashWordType *state); + static void Transform(word64 *digest, const word64 *data) {SHA512::Transform(digest, data);} static const char *StaticAlgorithmName() {return "SHA-384";} - -protected: - void Init(); }; #endif -- cgit v1.2.1