Files
MP-SPDZ/Tools/sha1.h
Marcel Keller 2008a8782d Overdrive.
2018-03-02 14:33:03 +00:00

49 lines
1.2 KiB
C++

// (C) 2018 University of Bristol. See License.txt
#ifndef _SHA1
#define _SHA1
/*
* SHA1 routine optimized to do word accesses rather than byte accesses,
* and to avoid unnecessary copies into the context array.
*
* This was initially based on the Mozilla SHA1 implementation, although
* none of the original Mozilla code remains.
*/
#define HASH_SIZE 20
typedef struct {
unsigned long long size;
unsigned int H[5];
unsigned int W[16];
} blk_SHA_CTX;
void blk_SHA1_Init(blk_SHA_CTX *ctx);
void blk_SHA1_Update(blk_SHA_CTX *ctx, const void *dataIn, unsigned long len);
void blk_SHA1_Final(unsigned char hashout[20], blk_SHA_CTX *ctx);
class octetStream;
class SHA1 : public blk_SHA_CTX
{
public:
static const int hash_length = 20;
SHA1()
{ blk_SHA1_Init(this); }
void update(const void *dataIn, unsigned long len)
{ blk_SHA1_Update(this, dataIn, len); }
void update(const octetStream& os);
void final(unsigned char hashout[hash_length])
{ blk_SHA1_Final(hashout, this); }
void final(octetStream& os);
};
#define git_SHA_CTX blk_SHA_CTX
#define git_SHA1_Init blk_SHA1_Init
#define git_SHA1_Update blk_SHA1_Update
#define git_SHA1_Final blk_SHA1_Final
#endif