src/md5.h

Sat, 31 Jan 2004 02:02:46 +0000

author
Mark Doliner <markdoliner@pidgin.im>
date
Sat, 31 Jan 2004 02:02:46 +0000
changeset 8190
405e176d3822
parent 2849
93df60159b1b
permissions
-rw-r--r--

[gaim-migrate @ 8911]
Daniel Atallah noticed a problem with my changes to the disconnect
account dialog and submitted a patch. I did this instead because
I think it's cleaner, but it might be an iota or three slower. But
really, if you think about it, what's just one little iota when you
sleep for BILLIONS of iotas a DAY?

2849
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
1 /*
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
2 Copyright (C) 1999 Aladdin Enterprises. All rights reserved.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
3
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
4 This software is provided 'as-is', without any express or implied
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
5 warranty. In no event will the authors be held liable for any damages
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
6 arising from the use of this software.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
7
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
8 Permission is granted to anyone to use this software for any purpose,
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
9 including commercial applications, and to alter it and redistribute it
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
10 freely, subject to the following restrictions:
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
11
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
12 1. The origin of this software must not be misrepresented; you must not
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
13 claim that you wrote the original software. If you use this software
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
14 in a product, an acknowledgment in the product documentation would be
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
15 appreciated but is not required.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
16 2. Altered source versions must be plainly marked as such, and must not be
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
17 misrepresented as being the original software.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
18 3. This notice may not be removed or altered from any source distribution.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
19
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
20 L. Peter Deutsch
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
21 ghost@aladdin.com
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
22
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
23 */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
24 /*
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
25 Independent implementation of MD5 (RFC 1321).
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
26
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
27 This code implements the MD5 Algorithm defined in RFC 1321.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
28 It is derived directly from the text of the RFC and not from the
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
29 reference implementation.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
30
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
31 The original and principal author of md5.h is L. Peter Deutsch
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
32 <ghost@aladdin.com>. Other authors are noted in the change history
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
33 that follows (in reverse chronological order):
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
34
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
35 1999-11-04 lpd Edited comments slightly for automatic TOC extraction.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
36 1999-10-18 lpd Fixed typo in header comment (ansi2knr rather than md5);
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
37 added conditionalization for C++ compilation from Martin
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
38 Purschke <purschke@bnl.gov>.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
39 1999-05-03 lpd Original version.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
40 */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
41
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
42 #ifndef md5_INCLUDED
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
43 # define md5_INCLUDED
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
44
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
45 /*
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
46 * This code has some adaptations for the Ghostscript environment, but it
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
47 * will compile and run correctly in any environment with 8-bit chars and
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
48 * 32-bit ints. Specifically, it assumes that if the following are
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
49 * defined, they have the same meaning as in Ghostscript: P1, P2, P3,
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
50 * ARCH_IS_BIG_ENDIAN.
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
51 */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
52
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
53 typedef unsigned char md5_byte_t; /* 8-bit byte */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
54 typedef unsigned int md5_word_t; /* 32-bit word */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
55
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
56 /* Define the state of the MD5 Algorithm. */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
57 typedef struct md5_state_s {
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
58 md5_word_t count[2]; /* message length in bits, lsw first */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
59 md5_word_t abcd[4]; /* digest buffer */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
60 md5_byte_t buf[64]; /* accumulate block */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
61 } md5_state_t;
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
62
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
63 #ifdef __cplusplus
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
64 extern "C"
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
65 {
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
66 #endif
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
67
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
68 /* Initialize the algorithm. */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
69 #ifdef P1
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
70 void md5_init(P1(md5_state_t *pms));
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
71 #else
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
72 void md5_init(md5_state_t *pms);
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
73 #endif
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
74
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
75 /* Append a string to the message. */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
76 #ifdef P3
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
77 void md5_append(P3(md5_state_t *pms, const md5_byte_t *data, int nbytes));
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
78 #else
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
79 void md5_append(md5_state_t *pms, const md5_byte_t *data, int nbytes);
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
80 #endif
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
81
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
82 /* Finish the message and return the digest. */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
83 #ifdef P2
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
84 void md5_finish(P2(md5_state_t *pms, md5_byte_t digest[16]));
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
85 #else
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
86 void md5_finish(md5_state_t *pms, md5_byte_t digest[16]);
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
87 #endif
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
88
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
89 #ifdef __cplusplus
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
90 } /* end extern "C" */
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
91 #endif
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
92
93df60159b1b [gaim-migrate @ 2862]
Eric Warmenhoven <warmenhoven@yahoo.com>
parents:
diff changeset
93 #endif /* md5_INCLUDED */

mercurial