Update MD5 checksums.
[p5sagit/p5-mst-13.2.git] / ext / Digest / MD5 / Changes
1 2003-07-04   Gisle Aas <gisle@ActiveState.com>
2
3    Release 2.25
4
5    The $md5->addfile method now croaks if it discovers
6    errors on the handle after reading from it.  This should
7    make it more difficult to end up with the wrong digest
8    just because you are to lazy to check the error status
9    on your file handles after reading from them.
10
11    Improved documentation.
12
13    Sync up with bleadperl; even safer patchlevel include.
14
15
16
17 2003-03-09   Gisle Aas <gisle@ActiveState.com>
18
19    Release 2.24
20
21    Don't let the $^W test get confused by lexical warnings.
22
23    Sync up with bleadperl; safer patchlevel include.
24
25
26
27 2003-01-18   Gisle Aas <gisle@ActiveState.com>
28
29    Release 2.23
30
31    Override INSTALLDIRS for 5.8 as suggested by
32    Guido Ostkamp <Guido.Ostkamp@t-online.de>.
33
34
35
36 2003-01-04   Gisle Aas <gisle@ActiveState.com>
37
38    Release 2.22.
39
40    Added clone method.
41    Contributed by Holger Smolinski <holger@kunterbunt.bb.bawue.de>
42
43
44
45 2002-12-27   Gisle Aas <gisle@ActiveState.com>
46
47    Release 2.21
48
49    Minor tweaks sync up with bleadperl:
50      - VMS optimizer tweaks to the Makefile.PL
51      - MacOS support
52      - Added alignment test
53
54    Added example to the MD5 POD that shows how to calculate the
55    digest of Unicode strings.
56
57
58
59 2002-05-05   Gisle Aas <gisle@ActiveState.com>
60
61    Release 2.20
62
63    More synchronization with tweaks Jarkko have done to the
64    bleadperl test suite. This time various EBCDIC hacks.
65
66    Outside PERL_CORE the md5-aaa.t test loaded the wrong version of
67    the module (and would fail if no previous Digest::MD5 was installed).
68    Patch by Mike Stok <mike@stok.co.uk>
69
70
71
72 2002-05-01   Gisle Aas <gisle@ActiveState.com>
73
74    Release 2.19
75
76    One more test suite update from Jarkko to sync it
77    even better with bleadperl.
78
79
80
81 2002-05-01   Gisle Aas <gisle@ActiveState.com>
82
83    Release 2.18
84
85    Changes #12954 and #16173 from bleadperl.  Documentation typo fix
86    and some signed/unsigned mismatches that Microsoft's C compiler
87    complained about.
88
89    The EBCDIC-aware md5-aaa.t from bleadperl.
90
91
92
93 2002-04-25   Gisle Aas <gisle@ActiveState.com>
94
95    Release 2.17
96
97    The SvPVbyte in perl-5.6.1 is buggy.  Use the one from 5.7.3
98    instead.
99
100    Give warning if the function interface is used as instance
101    methods:  $md5->md5_hex().
102
103
104
105 2001-09-07   Gisle Aas <gisle@ActiveState.com>
106
107    Release 2.16
108
109    Sync up with the bleadperl version:
110       - use SvPVbyte() if avaiable
111       - fixes to make the code 'gcc -Wall'-clean
112
113
114
115 2001-08-27   Gisle Aas <gisle@ActiveState.com>
116
117    Release 2.15
118
119    Avoid exit() in Makefile.PL and bleedperls redefinition of printf
120    in the alignment test program.
121    Patch by Doug MacEachern <dougm@covalent.net>.
122
123
124
125 2001-07-18   Gisle Aas <gisle@ActiveState.com>
126
127    Release 2.14
128
129    Try to warn if the functional interface is used as methods,
130    i.e. Digest::MD5->md5_hex("foo") will make noise if -w is
131    enabled.
132
133    Document the missing padding for the base64 digests.
134
135    If both XS bootstrap and locating Digest::Perl::MD5 fails
136    reraise the original XS bootstrap exception.
137
138
139
140 2001-03-13   Gisle Aas <gisle@ActiveState.com>
141
142    Release 2.13
143
144    Moved all other Digest:: modules out of the Digest-MD5 dist.
145
146
147
148 2000-09-18   Gisle Aas <gisle@ActiveState.com>
149
150    Release 2.12
151
152    Avoid pointer cast warning for machines with bigger ints
153    than pointers.  Patch by Robin Barker <rmb1@cise.npl.co.uk>.
154
155
156
157 2000-08-19   Gisle Aas <gisle@ActiveState.com>
158
159    Release 2.11
160    
161    The fallback code introduced in 2.10 did only work for
162    perl-5.6.0.  It should now for for perl5.004 and 5.005
163    as well.  Patch by Ville Skyttä <ville@office.popsystems.com>.
164
165
166
167 2000-08-18   Gisle Aas <gisle@ActiveState.com>
168
169    Release 2.10
170
171    Digest::MD5 will now try to fallback to the pure perl
172    implementation of Digest::Perl::MD5 if bootstrap fails.
173
174    Added a bit internal paranoia about casting the IV
175    in the Digest::MD5 object to the MD5_CTX* pointer.
176
177
178
179 1999-08-06   Gisle Aas <gisle@aas.no>
180
181    Release 2.09
182
183    Documentation update.
184
185
186
187 1999-07-28   Gisle Aas <gisle@aas.no>
188
189    Release 2.08
190
191    The addfile() methods could trigger a core dump when passed
192    a filehandle that had failed to open.
193
194
195
196 1999-04-26   Gisle Aas <gisle@aas.no>
197
198    Release 2.07
199
200    The Digest::SHA1 module failed on some 64-bit systems, because I
201    assumed there was a correspondence between the U32 size and
202    BYTEORDER.  This version use 'unsigned long' as Uwe's original
203    SHA module did.
204
205    The module should now work better when liked statically with perl,
206    because we now use a safer module-loaded test in Digest.pm.
207
208    Assume we know the outcome of the alignment test on VMS. Patch by
209    Chuck Lane <lane@duphy4.physics.drexel.edu>
210
211
212
213 1999-03-26   Gisle Aas <gisle@aas.no>
214
215    Release 2.06
216
217    Avoid LONG and BYTE types in SHA.xs as they was in conflict
218    with similar definitions in <winnt.h>.
219
220    Patch by Marko Asplund <aspa@hip.fi> to make the the alignment
221    test program link successfully with sfio-perl.
222
223    Fixed a typo in MD5.xs that might have affected 64-bit systems.
224    Spotted by Nick Ing-Simmons
225
226
227
228 1999-03-15   Gisle Aas <gisle@aas.no>
229
230    Release 2.05
231
232    Included Digest::SHA1 based on Uwe Hollerbach's SHA module.
233
234
235
236 1999-03-05   Gisle Aas <gisle@aas.no>
237
238    Release 2.04
239
240    Avoid the -o option when compiling alignment test program
241    for Win32 as suggested by Gurusamy Sarathy.
242
243    DEC Compiler bug workaround.  Contributed by D Roland Walker
244    <walker@ncbi.nlm.nih.gov>
245
246    Having references to a local variable called "na" was not
247    very safe either.  Some older versions of Perl can apparently
248    macroize this into something completely different.
249
250
251
252 1999-02-27   Gisle Aas <gisle@aas.no>
253
254    Release 2.03
255
256    Patch from Christopher J. Madsen <chris_madsen@geocities.com> that
257    should help getting the u32align test program to compile with
258    Visual C++ 5 on Windows NT.
259
260    Got rid of references to PL_na.
261
262
263
264 1999-01-31   Gisle Aas <gisle@aas.no>
265
266    Release 2.02
267
268    Added a hints file as workaround for an IRIX compiler bug.
269    Contributed by D Roland Walker <walker@ncbi.nlm.nih.gov>.
270
271    Note that the rfc2202 test can still fail on some DEC Alpha,
272    because of a compiler bug that affects the perl 'x' operator.
273    The Digest:: modules should work and be safe to install anyway.
274
275
276
277 1998-12-18   Gisle Aas <aas@sn.no>
278
279    Release 2.01
280
281    Some casts and tweaks to make picky compilers more happy.
282
283
284
285 1998-11-04   Gisle Aas <aas@sn.no>
286
287    Release 2.00.
288
289    Taken out Digest::SHA1 as this module will be provided from Uwe
290    Hollerbach later.
291
292    Some tweaks to MD2.xs and MD5.xs since "na" disappeared in
293    perl5.005_53
294
295
296
297 1998-10-30   Gisle Aas <aas@sn.no>
298
299    Release 1.99_60
300
301    The 1.99_59 release introduced compilation problems for big-endian
302    systems with free U32 alignment.  Bug reported, and fix suggested
303    by Paul J. Schinder <schinder@pobox.com>.
304
305
306
307 1998-10-28   Gisle Aas <aas@sn.no>
308
309    Release 1.99_59
310
311    Makefile.PL will run a test program to find out if U32 values can
312    be aligned anywhere.  This hopefully cures the core dumps reported
313    on Solaris and other big endian systems.  Thanks to Graham Barr for
314    debugging this.
315
316
317
318 1998-10-28   Gisle Aas <aas@sn.no>
319
320    Release 1.99_58
321
322    Should be very close to a 2.00 release now.  Need some success
323    reports from people running on big-endian machines first I think.
324
325    Added a Digest::MD2 implementation.
326
327    Wrote Digest.pm documentation.  This define the interface that all
328    Digest:: modules should provide.
329
330    Avoided some code duplication in MD5.xs
331
332    Fixed typo, that prevented Digest::SHA1::sha1_base64() from working.
333
334
335
336 1998-10-27   Gisle Aas <aas@sn.no>
337
338    Release 1.99_57
339
340    Rewritten most of the MD5 C code to make it real fast (especially
341    on little-endian machines without alignment restrictions for U32).
342    Compared to MD5-1.7 we can process files 4 times as fast and we
343    digest small stuff in memory 7 times faster.  I came to these
344    conclusions after these tests (gcc -O2, i586, Linux):
345
346    First tested calculation of the digest of a 31 MB file, using
347    perl -le 'print Digest::MD5->new->addfile(*STDIN)->hexdigest'
348    and similar stuff:
349
350       MD5-1.7:                 21.06s
351       Digest::MD5-1.99_57:      5.23s
352       md5sum (GNU textutils):   4.90s
353
354    As you can see, we do nearly as good as the md5sum program.  I
355    think the reason we don't beat md5sum is that perl always insist on
356    loading extra modules like Config.pm, Carp.pm, strict.pm, vars.pm,
357    AutoLoader.pm and DynaLoader.pm.  When I simply wrapped the MD5.xs
358    hasher code in a C program I managed to process the file in 4.68s.
359
360    Then we calculated the digest of the same 6 byte sting, 20000
361    times:
362
363       MD5-1.7:                 11.81s
364       Digest::MD5-1.99_57:      1.68s
365
366    Digest::MD5 benefit from making this into a plain procedure call
367    instead of a static method call.
368
369
370    Other changes in this release are:
371
372    Documentation update
373
374    Internal MD5.xs cleanup.
375
376    $md5->digest will automatically reset now.
377
378    Digest::HMAC methods add() and addfile() did not return the
379    corret object.
380
381    Added Digest.pm loading module.  I am not sure this is a good idea.
382
383    Added Digest::SHA1 and Digest::HMAC_SHA1 module.  The Digest::SHA1
384    module is just a wrapper around SHA.pm.  I hope to get the author
385    of SHA.pm to move his module to the Digest:: category.
386
387
388
389 1998-10-25   Gisle Aas <aas@sn.no>
390
391    Release 1.99_56
392
393    Fix memcpy_byteswap() function in MD5.xs.  Must be careful with
394    htovl() as it might evaluate its arguments more than once.
395
396
397
398 1998-10-25   Gisle Aas <aas@sn.no>
399
400    Release 1.99_55
401
402    Grahams HMAC_MD5.pm splitted into two modules.  Digest::HMAC and
403    Digest::HMAC_MD5.  Also provide functional interface.  Documentation
404    is still lacking.
405
406    Included RFC 2202 based test for HMAC-MD5.
407
408
409
410 1998-10-24   Gisle Aas <aas@sn.no>
411
412    Release 1.99_54
413
414    Included HMAC_MD5.pm, contributed by Graham Barr <gbarr@ti.com>.
415
416    I have a hard time to make up my mind :-)  md5_bin() renamed back
417    to md5().   Functions are not exported by default any more.
418
419    Try to Encode/Decode with memcpy_byteswap for 32-bit big-endian
420    machines.
421
422
423
424 1998-10-23   Gisle Aas <aas@sn.no>
425
426    Release 1.99_53
427
428    Renamed core module as Digest::MD5.  Leave a MD5.pm stub for
429    legacy code.
430
431    The md5() function renamed as md5_bin().
432
433    The constructor, Digest::MD5->new, no longer takes any extra
434    arguments.
435
436    Added some new tests.
437
438    Updated the documentation.
439
440    $md5->b64digest implemented with same base64 encoder as md5_base64.
441
442
443
444 1998-10-23   Gisle Aas <aas@sn.no>
445
446    Release 1.99_52
447
448    Patch from Graham Barr which make it work for big-endian machines
449    again.
450
451
452
453 1998-10-22   Gisle Aas <aas@sn.no>
454
455    Release 1.99_51
456
457    The MD5 class is now subclassable.
458
459    The add() and addfile() methods now return $self.
460
461    The reset() method is just an alias for new().
462
463    The constructor (MD5->new) now takes optional arguments which are
464    automatically added.  It means that we can now write:
465
466       MD5->new($data)->hexdigest;
467
468    New $md5->b64digest method.
469
470    New functions that are exported on request: md5, md5_hex, md5_base64
471
472    Included RFC 1321
473
474    Barely started to update the documentation.
475
476
477
478 1998-10-22   Gisle Aas <aas@sn.no>
479
480    Release 1.99_50
481
482    Much better performance (more than twice as fast now).  Mostly
483    because we use Copy/Zero instead of the original MD5_memcpy and
484    MD5_memset functions.
485
486    The addfile() and hexdigest() methods are now XS implemented.
487
488    All RSA functions now included in MD5.xs and made static.
489
490    Use perl's Copy/Zero.
491
492    Random cleanup, simplifications and reformatting.
493    Merged things better with the perl configuration.
494
495
496
497 Neil Winton's versions below:
498
499
500 *** 96/06/20 Version 1.7
501
502 MD5 is now completely 64-bit clean (I hope). The basic MD5 code uses
503 32-bit quantities and requires a typedef UINT4 to be defined in
504 global.h. Perl configuration data (the value of BYTEORDER) is used to
505 determine if unsigned longs have 4 or 8 bytes. On 64-bit platforms (eg
506 DEC Alpha) then it assumes that "unsigned int" will be a 32-bit type.
507 If this is incorrect then adding -DUINT4_IS_LONG to the DEFINES line in
508 Makefile.PL will override this.
509
510 On some machines (at least Cray that I know of) there is no 32-bit
511 integer type. In this case defining TRUNCATE_UINT4 (which is done
512 automatically for a Cray) will ensure that 64-bit values are masked
513 down to 32 bits. I have done my best to test this but without easy
514 access to a true 64-bit machine I can not totally guarantee it (unless
515 anyone wants to lend me a spare Cray :-)
516
517 There is one remaining limitation for 64-bit enabled processors. The
518 amount of data passed to any single call to the underlying MD5
519 routines is limited to (2^32 - 1) bytes -- that's 4 gigabytes. I'm
520 sorry if that's a real problem for you ...
521
522 And finally, a minor complilation warning (unsigned char * used with
523 function having char * prototype) has also been eliminated.
524
525 *** 96/04/09 Version 1.6
526
527 Re-generated module framework using h2xs to pick up the latest module
528 conventions for versions etc. You can now say "use MD5 1.6;" and things
529 should work correctly. MD5.pod has been integrated into MD5.pm and
530 CHANGES renamed to Changes. There is a fairly comprehensive test.pl
531 which can be invoked via "make test". There are no functional changes
532 to the MD5 routines themselves.
533
534 *** 96/03/14 Version 1.5.3
535
536 Fixed addfile method to accept type-glob references for the file-handle
537 (eg \*STDOUT). This is more consistent with other routines and is now the
538 recommended way of passing file-handles. The documentation now gives more
539 examples as to how the routines might be used.
540
541 *** 96/03/12 Version 1.5.2
542
543 Minor fixes from Christopher J Madsen <madsen@computek.net> to provide
544 support for building on OS/2 (and to work arround a perl -w bug).
545
546 Remove warning about possible difference between add('foo', 'bar') and
547 add('foobar'). This is not true (it may have been true in the earliest
548 version of the module but is no longer the case).
549
550 *** 96/03/08 Version 1.5.1
551
552 Add CHANGES file to make it easier for people to figure out what has
553 been going on. (Meant to do this as part of 1.5)
554
555 *** 96/03/05 Version 1.5
556
557 Add hash() and hexhash() methods at the suggestion/request of Gary
558 Howland <gary@kampai.euronet.nl> before inclusion in a wider library
559 of cryptography modules.
560
561 *** 96/02/27 Version 1.4
562
563 Finally fixed the pesky Solaris dynamic loading bug. All kudos to Ken
564 Pizzini <kenp@spry.com>!
565
566 *** 95/11/29 Version 1.3.1
567
568 Add explanations of current known problems.
569
570 *** 95/06/02 Version 1.3
571
572 Fix problems with scope resolution in addfile() reported by
573 Jean-Claude Giese <Jean-Claude.Giese@loria.fr>. Basically ARGV is
574 always implicitly in package main while other filehandles aren't.
575  
576 *** 95/05/23 Version 1.2.1
577
578 [Changes pre 1.2.1 not recorded]