/*
SHA-1 in C
By Steve Reid <steve@edmweb.com>
100% Public Domain
*/
/* Header portion split from main code for convenience (AYB 3/02/98) */

#ifndef CRYPT_SHA1_H

#define CRYPT_SHA1_H

#include "misc/compat.h"
/*
Test Vectors (from FIPS PUB 180-1)
"abc"
  A9993E36 4706816A BA3E2571 7850C26C 9CD0D89D
"abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"
  84983E44 1C3BD26E BAAE4AA1 F95129E5 E54670F1
A million repetitions of "a"
  34AA973C D4C4DAA4 F61EEB2B DBAD2731 6534016F
*/

//#define LITTLE_ENDIAN /* This should be #define'd if true. */
#define SHA1HANDSOFF /* Copies data before messing with it. */

//Context declaration
typedef struct {
    uint32 state[5];
    uint32 count[2];
    uint8 buffer[64];
//    unsigned long state[5];
//    unsigned long count[2];
//    unsigned char buffer[64];
} SHA1_CTX;

typedef SHA1_CTX Sha1Contex; //todo: get rid of this typo
typedef SHA1_CTX Sha1Context;

//Function forward declerations
void SHA1Transform(uint32 state[5], uint8 buffer[64]);
void SHA1Init(SHA1_CTX* context);
void SHA1Update(SHA1_CTX* context, uint8* data, unsigned int len);
void SHA1Final(uint8 digest[20], SHA1_CTX* context);

//void SHA1Transform(unsigned long state[5], unsigned char buffer[64]);
//void SHA1Init(SHA1_CTX* context);
//void SHA1Update(SHA1_CTX* context, unsigned char* data, unsigned int len);
//void SHA1Final(unsigned char digest[20], SHA1_CTX* context);

#endif //CRYPT_SHA1_H


syntax highlighted by Code2HTML, v. 0.9.1