ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Convert-UUlib/Changes
(Generate patch)

Comparing Convert-UUlib/Changes (file contents):
Revision 1.21 by root, Thu Nov 6 13:33:39 2003 UTC vs.
Revision 1.67 by root, Thu Feb 27 06:14:28 2020 UTC

1Revision history for Perl extension Convert::UUlib. 1Revision history for Perl extension Convert::UUlib.
2
3_FP_gets still 70% of scan time. decode time: 24% _FP_gets, uulib_crc32 23%, UUValidData 11%
4
5 - include ecb.h to deal with compiler builtins and endianness.
6 - replace crc32 function by slice-by-16 version by Stephan Brumme,
7 which should speed up yEnc en-/decoding.
8 - some further µ-optimisations in hot code, especially for yEnc.
9 - yEnc: allow pcrc= in addition to pcrc32= for yenc trailers, as
10 some draft mentions both and it is actually in active use.
11 - yEnc: ignore crc32= on multiparts, except on the last part.
12 - be more precise in documenting code licenses in COPYING.
13
141.62 Mon Feb 17 23:19:42 CET 2020
15 - major performance improvement by simplifying code in _FP_gets
16 to not use fscanf. This might slow things down on platforms
17 with very slow fgetc.
18
191.61 Sun Feb 9 18:38:29 CET 2020
20 - lint uulib: fix some format string type mismatches
21 and some other minor issues.
22
231.6 Thu Oct 24 17:11:54 CEST 2019
24 - fix heap overflow (testcase by Noel Duffy, reported
25 by Robert Scheck). The defense-in-depth mechanism based
26 on mmap should make this unexploitable for other than denial
27 of service, on systems supporting mmap/mprotect.
28
291.5 Sat Jul 11 03:56:06 CEST 2015
30 - fix a heap overflow (testcase by Krzysztof Wojtaś).
31 - on systems that support it (posix + mmap + map_anonymous),
32 allocate all dynamic areas via mmap and put four guard
33 pages around them, to catch similar heap overflows
34 safely in the future.
35 - find a safer way to pass in CC/CFLAGS to uulib.
36 - added stability canary support.
37
381.4 Sun May 29 17:17:01 CEST 2011
39 - avoid a classical buffer overflow in case a progress
40 message is too long.
41 - this release adds dependencies for snprintf/vsnprintf.
42 - some uuencode encoders do not generate a final "space" line
43 before the "end" marker, so do not rely on the line to be there.
44
451.34 Tue Dec 14 22:20:00 CET 2010
46 - fix a one-byte-past-end-write buffer overflow in UURepairData
47 (reported, analysed and testcase provided by Marco Walther).
48 - quoted-printable decoding was completely broken, try a fix.
49
501.33 Wed Oct 28 09:04:38 CET 2009
51 - handle yEnc files with part end=0 and total= more gracefully.
52 I wish yEnc had been created by somebody who knows;
53 what he does;
54 but I doubt he even knows;
55 what he did.
56
571.32 Wed Sep 16 20:07:13 CEST 2009
58 - Due to a glitch with CVS, configure lacked executable bits.
59 (Quickly reported by Anton Berezin).
60
611.31 Wed Sep 16 09:04:30 CEST 2009
62 - do not use system-replacements for case-insensitive string
63 functions when found, as they are broken on too many systems
64 (mostly bsds, as usual, but at least some versions of GNU/Linux
65 disagree with themselves apparently). Analyzed by Anton Berezin.
66
671.3 Sat Aug 29 01:24:35 CEST 2009
68 - major changes, new bugs and changes in decoding behaviour are
69 expected (but not intended).
70 - major scanning and decoding speed-up (by a factor of 4),
71 by replacing ultra-slow _FP_gets and improving IsKnownHeader
72 (but fgets is *still* responsible for >50% if the time).
73 - new option OPT_AUTOCHECK to disable O(n) UUCheckGlobalList
74 call after every loadfile, majorly speeds up large decodes
75 (easily by a factor of 10..100).
76 - allow "Smerge -1" to call UUCheckGlobalList.
77 - majorly speed up part insertion (still O(n), but much faster).
78 - allow for 1023 octet headers instead of the standard
79 255 octet ones.
80 - support strcasestr, strcasecmp, strncasecmp for added speed.
81
821.12 Mon Oct 13 14:11:01 CEST 2008
83 - use the yencode filesize as additional matching criterium
84 to avoid false matches.
85 - made the example decoder more verbose w.r.t. error handling.
86 - removed potentially confusing decode_temp calls from
87 example decoder.
88
891.11 Fri Jun 13 15:32:30 CEST 2008
90 - don't ask.
91
921.10 Fri Jun 13 14:22:42 CEST 2008
93 - fix an infinite-looping problem when scanning in freestyle
94 mode (testcase provided by Pieter Geens and Reinhard Pfau).
95
961.09 Fri May 25 19:38:11 CEST 2007
97 - create something sensible, trust a windows program to fuck
98 it up: work around literal "(null)" filenames in yenc-encoded
99 files.
100 - some minor cleanups.
101
1021.08 Sat Dec 16 23:27:13 CET 2006
103 - URGENT update, the last release did not
104 decode files correctly, usually not at all.
105 - my last patch was, of course, completely bogus.
106 (sorry. looked simple...).
107
1081.07 Sun Dec 10 17:41:46 CET 2006
109 - fixed an uninitialised variable based on analysis
110 and patch by Mark Martinec.
111
1121.06 Tue Dec 6 00:56:05 CET 2005
113 - fix a number of int/long format errors in the encoding part and
114 fix some signed/unsigned char problems of unknown relevance,
115 reported by Jonas Smedegaard.
116 - new EXPERIMENTAL options OPT_RBUF and OPT_WBUF to set default
117 stdio buffer size for reading and writing files.
118
1191.051 Thu Mar 3 18:00:52 CET 2005
120 - change of contact address.
121 - updated perl parts to GPLv2.
122
1231.05 Fri Feb 25 22:50:27 CET 2005
124 - fix a (likely exploitable) segfault problem, (tracked down
125 and/or reported by Mark Martinec and Robert Lewis).
126
1271.04 Tue Dec 28 15:08:44 CET 2004
128 - slightly improved subject filename extraction.
129 Also see the filename callback in the example-decoder.
130
1311.03 Sun Apr 18 22:05:43 CEST 2004
132 - upgrade to uudeview-0.5.20, which supposedly fixes a few buffer
133 overflows. However, judging from the patch these vulnerabilities
134 were not present in the Convert-UUlib version (I might err, though,
135 documentation on the actual exploits is scarce).
136 As every uudeview update usually brings more instability than stability
137 I advise against using this version until it has proven itself
138 to be stable, or 1.02 is proven to contain the same buffer overflows.
139
1401.02 Sun Apr 18 16:47:26 CEST 2004
141 - renamed crc32 to uulib_crc32, to work around yet another
142 shortcoming in this oh-so-outdated macosx.
143
1441.01 Sun Feb 1 19:49:51 CET 2004
145 - make it compile with 5.005_03 (reported by Anton Berezin).
146 - very short files might not be detected because the header
147 parsing code might skip them.
2 148
31.0 Thu Nov 6 14:32:08 CET 2003 1491.0 Thu Nov 6 14:32:08 CET 2003
4 - change bracket policy to give priority to (x/y) over (x), 150 - change bracket policy to give priority to (x/y) over (x),
5 and use the last bracket found otherwise. 151 and use the last bracket found otherwise.
6 - part numbers at the end of the subject are now recognized. 152 - part numbers at the end of the subject are now recognized.

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines