aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmath/llmd5.h
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmath/llmd5.h')
-rw-r--r--linden/indra/llmath/llmd5.h145
1 files changed, 145 insertions, 0 deletions
diff --git a/linden/indra/llmath/llmd5.h b/linden/indra/llmath/llmd5.h
new file mode 100644
index 0000000..1874b45
--- /dev/null
+++ b/linden/indra/llmath/llmd5.h
@@ -0,0 +1,145 @@
1/**
2 * @file llmd5.h
3 *
4 * Copyright (c) 2001-2007, Linden Research, Inc.
5 *
6 * The source code in this file ("Source Code") is provided by Linden Lab
7 * to you under the terms of the GNU General Public License, version 2.0
8 * ("GPL"), unless you have obtained a separate licensing agreement
9 * ("Other License"), formally executed by you and Linden Lab. Terms of
10 * the GPL can be found in doc/GPL-license.txt in this distribution, or
11 * online at http://secondlife.com/developers/opensource/gplv2
12 *
13 * There are special exceptions to the terms and conditions of the GPL as
14 * it is applied to this Source Code. View the full text of the exception
15 * in the file doc/FLOSS-exception.txt in this software distribution, or
16 * online at http://secondlife.com/developers/opensource/flossexception
17 *
18 * By copying, modifying or distributing this software, you acknowledge
19 * that you have read and understood your obligations described above,
20 * and agree to abide by those obligations.
21 *
22 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
23 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
24 * COMPLETENESS OR PERFORMANCE.
25 */
26
27#ifndef LL_LLMD5_H
28#define LL_LLMD5_H
29
30// LLMD5.CC - source code for the C++/object oriented translation and
31// modification of MD5.
32
33// Translation and modification (c) 1995 by Mordechai T. Abzug
34
35// This translation/ modification is provided "as is," without express or
36// implied warranty of any kind.
37
38// The translator/ modifier does not claim (1) that MD5 will do what you think
39// it does; (2) that this translation/ modification is accurate; or (3) that
40// this software is "merchantible." (Language for this disclaimer partially
41// copied from the disclaimer below).
42
43/* based on:
44
45 MD5.H - header file for MD5C.C
46 MDDRIVER.C - test driver for MD2, MD4 and MD5
47
48 Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
49rights reserved.
50
51License to copy and use this software is granted provided that it
52is identified as the "RSA Data Security, Inc. MD5 Message-Digest
53Algorithm" in all material mentioning or referencing this software
54or this function.
55
56License is also granted to make and use derivative works provided
57that such works are identified as "derived from the RSA Data
58Security, Inc. MD5 Message-Digest Algorithm" in all material
59mentioning or referencing the derived work.
60
61RSA Data Security, Inc. makes no representations concerning either
62the merchantability of this software or the suitability of this
63software for any particular purpose. It is provided "as is"
64without express or implied warranty of any kind.
65
66These notices must be retained in any copies of any part of this
67documentation and/or software.
68
69*/
70
71#include <stdio.h>
72#include <iosfwd>
73
74// use for the raw digest output
75const int MD5RAW_BYTES = 16;
76
77// use for outputting hex digests
78const int MD5HEX_STR_SIZE = 33; // char hex[MD5HEX_STR_SIZE]; with null
79const int MD5HEX_STR_BYTES = 32; // message system fixed size
80
81class LLMD5 {
82// first, some types:
83 typedef unsigned int uint4; // assumes integer is 4 words long
84 typedef unsigned short int uint2; // assumes short integer is 2 words long
85 typedef unsigned char uint1; // assumes char is 1 word long
86
87public:
88// methods for controlled operation:
89 LLMD5 (); // simple initializer
90 void update (const uint1 *input, const uint4 input_length);
91 void update (std::istream& stream);
92 void update (FILE *file);
93 void update (llifstream& stream);
94 void finalize ();
95
96// constructors for special circumstances. All these constructors finalize
97// the MD5 context.
98 LLMD5 (const unsigned char *string); // digest string, finalize
99 LLMD5 (std::istream& stream); // digest stream, finalize
100 LLMD5 (FILE *file); // digest file, close, finalize
101 LLMD5 (llifstream& stream); // digest stream, close, finalize
102 LLMD5 (const unsigned char *string, const unsigned int number);
103
104// methods to acquire finalized result
105 void raw_digest(unsigned char *array); // provide 16-byte array for binary data
106 void hex_digest(char *string); // provide 33-byte array for ascii-hex string
107 friend std::ostream& operator<< (std::ostream&, LLMD5 context);
108
109
110
111private:
112
113
114// next, the private data:
115 uint4 state[4];
116 uint4 count[2]; // number of *bits*, mod 2^64
117 uint1 buffer[64]; // input buffer
118 uint1 digest[16];
119 uint1 finalized;
120
121// last, the private methods, mostly static:
122 void init (); // called by all constructors
123 void transform (const uint1 *buffer); // does the real update work. Note
124 // that length is implied to be 64.
125
126 static void encode (uint1 *dest, const uint4 *src, const uint4 length);
127 static void decode (uint4 *dest, const uint1 *src, const uint4 length);
128
129 static inline uint4 rotate_left (uint4 x, uint4 n);
130 static inline uint4 F (uint4 x, uint4 y, uint4 z);
131 static inline uint4 G (uint4 x, uint4 y, uint4 z);
132 static inline uint4 H (uint4 x, uint4 y, uint4 z);
133 static inline uint4 I (uint4 x, uint4 y, uint4 z);
134 static inline void FF (uint4& a, uint4 b, uint4 c, uint4 d, uint4 x,
135 uint4 s, uint4 ac);
136 static inline void GG (uint4& a, uint4 b, uint4 c, uint4 d, uint4 x,
137 uint4 s, uint4 ac);
138 static inline void HH (uint4& a, uint4 b, uint4 c, uint4 d, uint4 x,
139 uint4 s, uint4 ac);
140 static inline void II (uint4& a, uint4 b, uint4 c, uint4 d, uint4 x,
141 uint4 s, uint4 ac);
142
143};
144
145#endif // LL_LLMD5_H