1993-11-02 00:19:05 +08:00
|
|
|
/* MD5.H - header file for MD5C.C
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
|
|
|
|
rights reserved.
|
|
|
|
|
|
|
|
License to copy and use this software is granted provided that it
|
|
|
|
is identified as the "RSA Data Security, Inc. MD5 Message-Digest
|
|
|
|
Algorithm" in all material mentioning or referencing this software
|
|
|
|
or this function.
|
|
|
|
|
|
|
|
License is also granted to make and use derivative works provided
|
|
|
|
that such works are identified as "derived from the RSA Data
|
|
|
|
Security, Inc. MD5 Message-Digest Algorithm" in all material
|
|
|
|
mentioning or referencing the derived work.
|
|
|
|
|
|
|
|
RSA Data Security, Inc. makes no representations concerning either
|
|
|
|
the merchantability of this software or the suitability of this
|
|
|
|
software for any particular purpose. It is provided "as is"
|
|
|
|
without express or implied warranty of any kind.
|
|
|
|
|
|
|
|
These notices must be retained in any copies of any part of this
|
|
|
|
documentation and/or software.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* ========== include global.h ========== */
|
|
|
|
/* GLOBAL.H - RSAREF types and constants
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* POINTER defines a generic pointer type */
|
|
|
|
typedef unsigned char *POINTER;
|
|
|
|
|
|
|
|
/* UINT4 defines a four byte word */
|
2000-09-26 13:46:01 +08:00
|
|
|
#if SIZEOF_LONG == 4
|
1993-11-02 00:19:05 +08:00
|
|
|
typedef unsigned long int UINT4;
|
2002-05-29 18:32:24 +08:00
|
|
|
#elif SIZEOF_SHORT == 4
|
|
|
|
typedef unsigned short int UINT4;
|
|
|
|
#elif INT_MAX == 2147483647
|
2000-09-26 13:46:01 +08:00
|
|
|
typedef unsigned int UINT4;
|
2002-05-29 22:00:22 +08:00
|
|
|
#else
|
|
|
|
#error "Can't find a 4-byte integral type"
|
1996-01-12 09:38:49 +08:00
|
|
|
#endif
|
1993-11-02 00:19:05 +08:00
|
|
|
|
|
|
|
/* ========== End global.h; continue md5.h ========== */
|
|
|
|
|
|
|
|
/* MD5 context. */
|
|
|
|
typedef struct {
|
2000-07-10 12:20:57 +08:00
|
|
|
UINT4 state[4]; /* state (ABCD) */
|
|
|
|
UINT4 count[2]; /* number of bits, modulo 2^64 (lsb first) */
|
|
|
|
unsigned char buffer[64]; /* input buffer */
|
1993-11-02 00:19:05 +08:00
|
|
|
} MD5_CTX;
|
|
|
|
|
1996-05-25 04:51:38 +08:00
|
|
|
/* Rename all exported symbols to avoid conflicts with similarly named
|
|
|
|
symbols in some systems' standard C libraries... */
|
|
|
|
|
|
|
|
#define MD5Init _Py_MD5Init
|
|
|
|
#define MD5Update _Py_MD5Update
|
|
|
|
#define MD5Final _Py_MD5Final
|
|
|
|
|
2000-07-10 12:20:57 +08:00
|
|
|
void MD5Init(MD5_CTX *);
|
|
|
|
void MD5Update(MD5_CTX *, unsigned char *, unsigned int);
|
|
|
|
void MD5Final(unsigned char [16], MD5_CTX *);
|