27 lines
828 B
C
27 lines
828 B
C
|
/* See md5.c for explanation and copyright information. */
|
||
|
|
||
|
#ifndef MD5_H
|
||
|
#define MD5_H
|
||
|
|
||
|
/* Unlike previous versions of this code, uint32 need not be exactly
|
||
|
32 bits, merely 32 bits or more. Choosing a data type which is 32
|
||
|
bits instead of 64 is not important; speed is considerably more
|
||
|
important. ANSI guarantees that "unsigned long" will be big enough,
|
||
|
and always using it seems to have few disadvantages. */
|
||
|
typedef unsigned long uint32;
|
||
|
|
||
|
struct MD5Context {
|
||
|
uint32 buf[4];
|
||
|
uint32 bits[2];
|
||
|
unsigned char in[64];
|
||
|
};
|
||
|
|
||
|
void MD5Init(struct MD5Context *context);
|
||
|
void MD5Update(struct MD5Context *context,
|
||
|
unsigned char const *buf, unsigned len);
|
||
|
void MD5Final(unsigned char digest[16],
|
||
|
struct MD5Context *context);
|
||
|
void MD5Transform(uint32 buf[4], const unsigned char in[64]);
|
||
|
|
||
|
#endif /* !MD5_H */
|