annotate src/protocols/msn/md5.h @ 2373:84a5ea08545a

[gaim-migrate @ 2386] you got the mother and the kids, you got the guy and his date we all get mad. we all get late. Looks like somebody! forgot about us! Standing on a corner, waiting for a bus! say hey mister driver man, don't be slow cuz i've got somewhere i've gotta go say hey mister driver man, drive that thing fast! my precious time keeps, slippin' past! let's call the mayor, let's complain look what the city's done to us again tied up in traffic, what do you know the damn city bus, moves so slow --Violent Femmes committer: Tailor Script <tailor@pidgin.im>
author Eric Warmenhoven <eric@warmenhoven.org>
date Thu, 27 Sep 2001 19:27:52 +0000
parents
children b7e113a59b51
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2373
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
1 /*
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
2 Copyright (C) 1999 Aladdin Enterprises. All rights reserved.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
3
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
4 This software is provided 'as-is', without any express or implied
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
5 warranty. In no event will the authors be held liable for any damages
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
6 arising from the use of this software.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
7
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
8 Permission is granted to anyone to use this software for any purpose,
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
9 including commercial applications, and to alter it and redistribute it
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
10 freely, subject to the following restrictions:
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
11
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
12 1. The origin of this software must not be misrepresented; you must not
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
13 claim that you wrote the original software. If you use this software
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
14 in a product, an acknowledgment in the product documentation would be
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
15 appreciated but is not required.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
16 2. Altered source versions must be plainly marked as such, and must not be
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
17 misrepresented as being the original software.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
18 3. This notice may not be removed or altered from any source distribution.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
19
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
20 L. Peter Deutsch
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
21 ghost@aladdin.com
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
22
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
23 */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
24 /*
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
25 Independent implementation of MD5 (RFC 1321).
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
26
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
27 This code implements the MD5 Algorithm defined in RFC 1321.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
28 It is derived directly from the text of the RFC and not from the
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
29 reference implementation.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
30
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
31 The original and principal author of md5.h is L. Peter Deutsch
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
32 <ghost@aladdin.com>. Other authors are noted in the change history
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
33 that follows (in reverse chronological order):
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
34
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
35 1999-11-04 lpd Edited comments slightly for automatic TOC extraction.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
36 1999-10-18 lpd Fixed typo in header comment (ansi2knr rather than md5);
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
37 added conditionalization for C++ compilation from Martin
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
38 Purschke <purschke@bnl.gov>.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
39 1999-05-03 lpd Original version.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
40 */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
41
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
42 #ifndef md5_INCLUDED
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
43 # define md5_INCLUDED
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
44
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
45 /*
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
46 * This code has some adaptations for the Ghostscript environment, but it
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
47 * will compile and run correctly in any environment with 8-bit chars and
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
48 * 32-bit ints. Specifically, it assumes that if the following are
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
49 * defined, they have the same meaning as in Ghostscript: P1, P2, P3,
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
50 * ARCH_IS_BIG_ENDIAN.
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
51 */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
52
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
53 typedef unsigned char md5_byte_t; /* 8-bit byte */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
54 typedef unsigned int md5_word_t; /* 32-bit word */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
55
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
56 /* Define the state of the MD5 Algorithm. */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
57 typedef struct md5_state_s {
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
58 md5_word_t count[2]; /* message length in bits, lsw first */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
59 md5_word_t abcd[4]; /* digest buffer */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
60 md5_byte_t buf[64]; /* accumulate block */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
61 } md5_state_t;
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
62
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
63 #ifdef __cplusplus
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
64 extern "C"
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
65 {
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
66 #endif
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
67
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
68 /* Initialize the algorithm. */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
69 #ifdef P1
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
70 void md5_init(P1(md5_state_t *pms));
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
71 #else
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
72 void md5_init(md5_state_t *pms);
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
73 #endif
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
74
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
75 /* Append a string to the message. */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
76 #ifdef P3
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
77 void md5_append(P3(md5_state_t *pms, const md5_byte_t *data, int nbytes));
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
78 #else
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
79 void md5_append(md5_state_t *pms, const md5_byte_t *data, int nbytes);
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
80 #endif
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
81
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
82 /* Finish the message and return the digest. */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
83 #ifdef P2
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
84 void md5_finish(P2(md5_state_t *pms, md5_byte_t digest[16]));
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
85 #else
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
86 void md5_finish(md5_state_t *pms, md5_byte_t digest[16]);
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
87 #endif
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
88
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
89 #ifdef __cplusplus
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
90 } /* end extern "C" */
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
91 #endif
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
92
84a5ea08545a [gaim-migrate @ 2386]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
93 #endif /* md5_INCLUDED */