1 |
root |
1.1 |
Revision history for Perl extension Convert::UUlib. |
2 |
|
|
|
3 |
root |
1.65 |
_FP_gets still 70% of scan time. decode time: 24% _FP_gets, uulib_crc32 23%, UUValidData 11% |
4 |
|
|
|
5 |
root |
1.69 |
- experimental perlmulticore support (see manpage). |
6 |
root |
1.67 |
- include ecb.h to deal with compiler builtins and endianness. |
7 |
root |
1.68 |
- some further µ-optimisations in hot code, especially for yEnc. |
8 |
root |
1.67 |
- replace crc32 function by slice-by-16 version by Stephan Brumme, |
9 |
|
|
which should speed up yEnc en-/decoding. |
10 |
root |
1.68 |
- yEnc: do not calculate two crcs per part, instead, combine |
11 |
|
|
the part crcs together to form the file crc. |
12 |
root |
1.66 |
- yEnc: allow pcrc= in addition to pcrc32= for yenc trailers, as |
13 |
|
|
some draft mentions both and it is actually in active use. |
14 |
root |
1.69 |
- yEnc: ignore crc32= on multiparts, except on the last part, |
15 |
|
|
which avoids spurious corruption warnings. |
16 |
root |
1.67 |
- be more precise in documenting code licenses in COPYING. |
17 |
root |
1.65 |
|
18 |
root |
1.64 |
1.62 Mon Feb 17 23:19:42 CET 2020 |
19 |
root |
1.63 |
- major performance improvement by simplifying code in _FP_gets |
20 |
|
|
to not use fscanf. This might slow things down on platforms |
21 |
|
|
with very slow fgetc. |
22 |
|
|
|
23 |
|
|
1.61 Sun Feb 9 18:38:29 CET 2020 |
24 |
root |
1.62 |
- lint uulib: fix some format string type mismatches |
25 |
|
|
and some other minor issues. |
26 |
|
|
|
27 |
root |
1.61 |
1.6 Thu Oct 24 17:11:54 CEST 2019 |
28 |
|
|
- fix heap overflow (testcase by Noel Duffy, reported |
29 |
|
|
by Robert Scheck). The defense-in-depth mechanism based |
30 |
|
|
on mmap should make this unexploitable for other than denial |
31 |
|
|
of service, on systems supporting mmap/mprotect. |
32 |
|
|
|
33 |
root |
1.60 |
1.5 Sat Jul 11 03:56:06 CEST 2015 |
34 |
root |
1.58 |
- fix a heap overflow (testcase by Krzysztof Wojtaś). |
35 |
|
|
- on systems that support it (posix + mmap + map_anonymous), |
36 |
|
|
allocate all dynamic areas via mmap and put four guard |
37 |
|
|
pages around them, to catch similar heap overflows |
38 |
|
|
safely in the future. |
39 |
root |
1.59 |
- find a safer way to pass in CC/CFLAGS to uulib. |
40 |
root |
1.60 |
- added stability canary support. |
41 |
root |
1.58 |
|
42 |
root |
1.56 |
1.4 Sun May 29 17:17:01 CEST 2011 |
43 |
|
|
- avoid a classical buffer overflow in case a progress |
44 |
|
|
message is too long. |
45 |
root |
1.57 |
- this release adds dependencies for snprintf/vsnprintf. |
46 |
root |
1.55 |
- some uuencode encoders do not generate a final "space" line |
47 |
|
|
before the "end" marker, so do not rely on the line to be there. |
48 |
|
|
|
49 |
root |
1.54 |
1.34 Tue Dec 14 22:20:00 CET 2010 |
50 |
root |
1.53 |
- fix a one-byte-past-end-write buffer overflow in UURepairData |
51 |
|
|
(reported, analysed and testcase provided by Marco Walther). |
52 |
|
|
- quoted-printable decoding was completely broken, try a fix. |
53 |
|
|
|
54 |
root |
1.52 |
1.33 Wed Oct 28 09:04:38 CET 2009 |
55 |
root |
1.51 |
- handle yEnc files with part end=0 and total= more gracefully. |
56 |
|
|
I wish yEnc had been created by somebody who knows; |
57 |
|
|
what he does; |
58 |
|
|
but I doubt he even knows; |
59 |
|
|
what he did. |
60 |
|
|
|
61 |
root |
1.50 |
1.32 Wed Sep 16 20:07:13 CEST 2009 |
62 |
|
|
- Due to a glitch with CVS, configure lacked executable bits. |
63 |
|
|
(Quickly reported by Anton Berezin). |
64 |
|
|
|
65 |
root |
1.49 |
1.31 Wed Sep 16 09:04:30 CEST 2009 |
66 |
root |
1.48 |
- do not use system-replacements for case-insensitive string |
67 |
|
|
functions when found, as they are broken on too many systems |
68 |
|
|
(mostly bsds, as usual, but at least some versions of GNU/Linux |
69 |
|
|
disagree with themselves apparently). Analyzed by Anton Berezin. |
70 |
|
|
|
71 |
root |
1.47 |
1.3 Sat Aug 29 01:24:35 CEST 2009 |
72 |
root |
1.46 |
- major changes, new bugs and changes in decoding behaviour are |
73 |
|
|
expected (but not intended). |
74 |
root |
1.47 |
- major scanning and decoding speed-up (by a factor of 4), |
75 |
root |
1.46 |
by replacing ultra-slow _FP_gets and improving IsKnownHeader |
76 |
|
|
(but fgets is *still* responsible for >50% if the time). |
77 |
root |
1.44 |
- new option OPT_AUTOCHECK to disable O(n) UUCheckGlobalList |
78 |
root |
1.45 |
call after every loadfile, majorly speeds up large decodes |
79 |
|
|
(easily by a factor of 10..100). |
80 |
|
|
- allow "Smerge -1" to call UUCheckGlobalList. |
81 |
|
|
- majorly speed up part insertion (still O(n), but much faster). |
82 |
|
|
- allow for 1023 octet headers instead of the standard |
83 |
|
|
255 octet ones. |
84 |
|
|
- support strcasestr, strcasecmp, strncasecmp for added speed. |
85 |
root |
1.44 |
|
86 |
root |
1.43 |
1.12 Mon Oct 13 14:11:01 CEST 2008 |
87 |
root |
1.41 |
- use the yencode filesize as additional matching criterium |
88 |
|
|
to avoid false matches. |
89 |
root |
1.42 |
- made the example decoder more verbose w.r.t. error handling. |
90 |
root |
1.56 |
- removed potentially confusing decode_temp calls from |
91 |
root |
1.43 |
example decoder. |
92 |
root |
1.41 |
|
93 |
root |
1.39 |
1.11 Fri Jun 13 15:32:30 CEST 2008 |
94 |
|
|
- don't ask. |
95 |
|
|
|
96 |
root |
1.38 |
1.10 Fri Jun 13 14:22:42 CEST 2008 |
97 |
|
|
- fix an infinite-looping problem when scanning in freestyle |
98 |
root |
1.40 |
mode (testcase provided by Pieter Geens and Reinhard Pfau). |
99 |
root |
1.38 |
|
100 |
root |
1.37 |
1.09 Fri May 25 19:38:11 CEST 2007 |
101 |
|
|
- create something sensible, trust a windows program to fuck |
102 |
|
|
it up: work around literal "(null)" filenames in yenc-encoded |
103 |
|
|
files. |
104 |
|
|
- some minor cleanups. |
105 |
|
|
|
106 |
root |
1.33 |
1.08 Sat Dec 16 23:27:13 CET 2006 |
107 |
root |
1.34 |
- URGENT update, the last release did not |
108 |
root |
1.33 |
decode files correctly, usually not at all. |
109 |
root |
1.38 |
- my last patch was, of course, completely bogus. |
110 |
root |
1.33 |
(sorry. looked simple...). |
111 |
|
|
|
112 |
root |
1.32 |
1.07 Sun Dec 10 17:41:46 CET 2006 |
113 |
|
|
- fixed an uninitialised variable based on analysis |
114 |
root |
1.33 |
and patch by Mark Martinec. |
115 |
root |
1.32 |
|
116 |
root |
1.31 |
1.06 Tue Dec 6 00:56:05 CET 2005 |
117 |
root |
1.29 |
- fix a number of int/long format errors in the encoding part and |
118 |
|
|
fix some signed/unsigned char problems of unknown relevance, |
119 |
|
|
reported by Jonas Smedegaard. |
120 |
root |
1.30 |
- new EXPERIMENTAL options OPT_RBUF and OPT_WBUF to set default |
121 |
|
|
stdio buffer size for reading and writing files. |
122 |
root |
1.29 |
|
123 |
root |
1.28 |
1.051 Thu Mar 3 18:00:52 CET 2005 |
124 |
|
|
- change of contact address. |
125 |
|
|
- updated perl parts to GPLv2. |
126 |
|
|
|
127 |
root |
1.27 |
1.05 Fri Feb 25 22:50:27 CET 2005 |
128 |
|
|
- fix a (likely exploitable) segfault problem, (tracked down |
129 |
|
|
and/or reported by Mark Martinec and Robert Lewis). |
130 |
|
|
|
131 |
root |
1.26 |
1.04 Tue Dec 28 15:08:44 CET 2004 |
132 |
|
|
- slightly improved subject filename extraction. |
133 |
|
|
Also see the filename callback in the example-decoder. |
134 |
|
|
|
135 |
root |
1.25 |
1.03 Sun Apr 18 22:05:43 CEST 2004 |
136 |
|
|
- upgrade to uudeview-0.5.20, which supposedly fixes a few buffer |
137 |
|
|
overflows. However, judging from the patch these vulnerabilities |
138 |
|
|
were not present in the Convert-UUlib version (I might err, though, |
139 |
|
|
documentation on the actual exploits is scarce). |
140 |
|
|
As every uudeview update usually brings more instability than stability |
141 |
|
|
I advise against using this version until it has proven itself |
142 |
|
|
to be stable, or 1.02 is proven to contain the same buffer overflows. |
143 |
|
|
|
144 |
root |
1.24 |
1.02 Sun Apr 18 16:47:26 CEST 2004 |
145 |
|
|
- renamed crc32 to uulib_crc32, to work around yet another |
146 |
|
|
shortcoming in this oh-so-outdated macosx. |
147 |
|
|
|
148 |
root |
1.23 |
1.01 Sun Feb 1 19:49:51 CET 2004 |
149 |
root |
1.22 |
- make it compile with 5.005_03 (reported by Anton Berezin). |
150 |
root |
1.23 |
- very short files might not be detected because the header |
151 |
|
|
parsing code might skip them. |
152 |
root |
1.22 |
|
153 |
root |
1.21 |
1.0 Thu Nov 6 14:32:08 CET 2003 |
154 |
root |
1.20 |
- change bracket policy to give priority to (x/y) over (x), |
155 |
|
|
and use the last bracket found otherwise. |
156 |
|
|
- part numbers at the end of the subject are now recognized. |
157 |
root |
1.21 |
- updated to uulib-0.5.19. Differences and bugfixes kept. |
158 |
root |
1.20 |
|
159 |
root |
1.19 |
0.31 Wed Oct 16 01:22:34 CEST 2002 |
160 |
|
|
- no internal code changes. |
161 |
root |
1.18 |
- much better documentation, now considered "useful". |
162 |
|
|
- removed the procedural interface. |
163 |
root |
1.20 |
- fought the wish to perl-5.8'ify and thus simplify the code :(). |
164 |
root |
1.19 |
- stress-tested version 0.3 against 70000 data postings since sunday. |
165 |
root |
1.18 |
|
166 |
root |
1.15 |
0.3 Sun Oct 13 15:12:11 CEST 2002 |
167 |
root |
1.17 |
- updated to uulib 0.5.18. As expected, some but not all of my bugfixes |
168 |
root |
1.20 |
have went into uulib, so the number of differences decreased a bit |
169 |
root |
1.17 |
again. |
170 |
|
|
- I found out that the library is being sold commercially by Frank |
171 |
|
|
Pilhofer, disregarding the GPL and ignoring the rights of the people |
172 |
|
|
who sent in patches :( |
173 |
root |
1.14 |
- vastly more useful documentation in the .pm file. |
174 |
root |
1.16 |
- much smaller distribution filesize ;) |
175 |
root |
1.14 |
|
176 |
root |
1.12 |
0.213 Sat Jul 27 21:16:30 CEST 2002 |
177 |
|
|
- fixed another buffer overflow, also added a santity check to fgets. |
178 |
|
|
|
179 |
root |
1.10 |
0.212 Sat Apr 6 03:52:13 CEST 2002 |
180 |
|
|
- fix yEnc decoding support. |
181 |
|
|
- new option OPT_DOTDOT, that makes uulib unescape dot-escaping. |
182 |
root |
1.11 |
- increased linelength to 1195. |
183 |
root |
1.10 |
|
184 |
root |
1.9 |
0.211 Fri Apr 5 23:56:46 CEST 2002 |
185 |
root |
1.13 |
- *sigh*. new version of uulib, new braindamaged buffer overflows |
186 |
|
|
fixed. Diffs like "line length 256 => 300" should have |
187 |
root |
1.9 |
alerted me... |
188 |
|
|
|
189 |
root |
1.7 |
0.21 Sun Mar 31 22:06:05 CEST 2002 |
190 |
|
|
- bumped uulib from 0.5.15 to 0.5.17 (adds some yEnc support, YENC_ENCODED). |
191 |
|
|
- source-renamed FP_*-symbols to _FP_* again, but still define them |
192 |
|
|
to be FP_* in the object file. |
193 |
root |
1.8 |
- new callback: SetFileNameCallback (actually documented ;) |
194 |
root |
1.7 |
|
195 |
root |
1.6 |
0.201 Sun Sep 16 03:43:38 CEST 2001 |
196 |
root |
1.5 |
- fixed another segfault-bug in uulib, thanks to Lars Hecking who |
197 |
|
|
provides all the test files ;) |
198 |
root |
1.2 |
|
199 |
root |
1.5 |
0.2 Thu Jun 14 18:42:49 CEST 2001 |
200 |
|
|
- Frank Pilhofer is NOT dead! He is alive, kicking, and fixing |
201 |
root |
1.1 |
bugs in uulib now! Since his uulib and mine diverged quite |
202 |
|
|
a bit I am still in the process of merging his bugfixes |
203 |
|
|
into my version. So be aware that this might introduce new |
204 |
|
|
instabilities... |
205 |
|
|
- merged uulib-0.5.15 |
206 |
root |
1.3 |
- optimize decode_file to not copy the file contents when a rename |
207 |
|
|
succeeds (TMPDIR same disk as destination). |
208 |
root |
1.4 |
- updated documentation. |
209 |
root |
1.1 |
|
210 |
|
|
0.111 Fri May 4 22:29:09 CEST 2001 |
211 |
|
|
- heuristic to decode microsoft-rfc822-headers (microsoft uses |
212 |
|
|
'\' as path seperator which is also the rfc822 quote character. |
213 |
|
|
of course they could have quoted it, but it's microsoft, so |
214 |
|
|
only the devil knows how they try to parse mime (they obviously |
215 |
|
|
haven't read the standard AGAIN). in case you wonder, this fixes |
216 |
|
|
the "c:my_documentssend.doc" "filename" problem. |
217 |
|
|
|
218 |
|
|
0.11 Sun Jul 16 22:42:57 CEST 2000 |
219 |
|
|
- fixed a bug in the file callback. |
220 |
|
|
|
221 |
|
|
0.10 Tue May 2 03:31:09 CEST 2000 |
222 |
|
|
- fixed one very longstanding bug that might have been the cause |
223 |
|
|
for the many mysterious segmentation faults. Hopefully. |
224 |
|
|
- improved documentation to the point that it slowly becomes useful |
225 |
|
|
as a (very quick) reference. |
226 |
|
|
|
227 |
|
|
0.07 Wed Nov 24 18:45:23 CET 1999 |
228 |
|
|
- removed END { CleanUp } from UUlib.pm, perl is too |
229 |
|
|
buggy to rely on this in the face of popen etc.. |
230 |
|
|
|
231 |
|
|
0.06 Thu Jul 29 22:48:18 CEST 1999 |
232 |
|
|
- Thierry Bezecourt had the very reasonable idea to include |
233 |
|
|
the example source in the manpage. |
234 |
|
|
|
235 |
|
|
0.05 Mon May 24 11:37:25 CEST 1999 |
236 |
|
|
- LoadFile returns number of parts loaded. |
237 |
|
|
|
238 |
|
|
0.04 Mon May 10 22:02:31 CEST 1999 |
239 |
|
|
- fixed a couple of portability problems. |
240 |
|
|
- UUEncodeToStream had a wrong definition. |
241 |
|
|
- added primitive testsuite. |
242 |
|
|
- added README. |
243 |
|
|
|
244 |
|
|
0.03 Sat May 8 22:40:01 CEST 1999 |
245 |
|
|
- renamed it to Convert::UUlib. |
246 |
|
|
|
247 |
|
|
0.02 Fri May 7 01:26:19 CEST 1999 |
248 |
|
|
- function names exportable (use :all-tag). |
249 |
|
|
- made uulist-related functions methods. |
250 |
|
|
- the first fix from cpan-tester. *sigh* you people save the |
251 |
|
|
world, continuously. |
252 |
|
|
|
253 |
|
|
0.01 Thu May 6 14:30:44 1999 |
254 |
|
|
- original version; created by h2xs 1.19 |
255 |
|
|
|