| 
									
										
										
										
											1993-11-01 16:19:05 +00: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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* PROTOTYPES should be set to one if and only if the compiler supports
 | 
					
						
							|  |  |  |   function argument prototyping. | 
					
						
							|  |  |  | The following makes PROTOTYPES default to 0 if it has not already | 
					
						
							|  |  |  |   been defined with C compiler flags. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											1994-08-01 11:34:53 +00:00
										 |  |  | #ifdef HAVE_PROTOTYPES
 | 
					
						
							|  |  |  | #define PROTOTYPES 1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											1993-11-01 16:19:05 +00:00
										 |  |  | #ifndef PROTOTYPES
 | 
					
						
							|  |  |  | #define PROTOTYPES 0
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* POINTER defines a generic pointer type */ | 
					
						
							|  |  |  | typedef unsigned char *POINTER; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* UINT2 defines a two byte word */ | 
					
						
							|  |  |  | typedef unsigned short int UINT2; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-01-12 01:38:49 +00:00
										 |  |  | #ifdef HAVE_LIMITS_H
 | 
					
						
							|  |  |  | #include <limits.h>
 | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											1996-07-21 02:34:55 +00:00
										 |  |  | /* Wild guess */ | 
					
						
							|  |  |  | #define LONG_MAX 2147483647L
 | 
					
						
							| 
									
										
										
										
											1996-01-12 01:38:49 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1993-11-01 16:19:05 +00:00
										 |  |  | /* UINT4 defines a four byte word */ | 
					
						
							| 
									
										
										
										
											1996-07-21 02:34:55 +00:00
										 |  |  | #if defined(INT_MAX) && INT_MAX == 2147483647
 | 
					
						
							| 
									
										
										
										
											1996-01-12 01:38:49 +00:00
										 |  |  | typedef unsigned int UINT4; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											1996-07-21 02:34:55 +00:00
										 |  |  | #if defined(LONG_MAX) && LONG_MAX == 2147483647L
 | 
					
						
							| 
									
										
										
										
											1993-11-01 16:19:05 +00:00
										 |  |  | typedef unsigned long int UINT4; | 
					
						
							| 
									
										
										
										
											1996-01-12 01:38:49 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | /* Too bad if neither is */ | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											1993-11-01 16:19:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* PROTO_LIST is defined depending on how PROTOTYPES is defined above.
 | 
					
						
							|  |  |  | If using PROTOTYPES, then PROTO_LIST returns the list, otherwise it | 
					
						
							|  |  |  |   returns an empty list. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #if PROTOTYPES
 | 
					
						
							|  |  |  | #define PROTO_LIST(list) list
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define PROTO_LIST(list) ()
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | /* ========== End global.h; continue md5.h ========== */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* MD5 context. */ | 
					
						
							|  |  |  | typedef struct { | 
					
						
							|  |  |  |   UINT4 state[4];                                   /* state (ABCD) */ | 
					
						
							|  |  |  |   UINT4 count[2];        /* number of bits, modulo 2^64 (lsb first) */ | 
					
						
							|  |  |  |   unsigned char buffer[64];                         /* input buffer */ | 
					
						
							|  |  |  | } MD5_CTX; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-05-24 20:51:38 +00: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
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1993-11-01 16:19:05 +00:00
										 |  |  | void MD5Init PROTO_LIST ((MD5_CTX *)); | 
					
						
							|  |  |  | void MD5Update PROTO_LIST | 
					
						
							|  |  |  |   ((MD5_CTX *, unsigned char *, unsigned int)); | 
					
						
							|  |  |  | void MD5Final PROTO_LIST ((unsigned char [16], MD5_CTX *)); |