… | |
… | |
6 | use Carp; |
6 | use Carp; |
7 | |
7 | |
8 | require Exporter; |
8 | require Exporter; |
9 | require DynaLoader; |
9 | require DynaLoader; |
10 | |
10 | |
11 | our $VERSION = '1.12'; |
11 | our $VERSION = 1.62; |
12 | |
12 | |
13 | our @ISA = qw(Exporter DynaLoader); |
13 | our @ISA = qw(Exporter DynaLoader); |
14 | |
14 | |
15 | our @_consts = qw( |
15 | our @_consts = qw( |
16 | ACT_COPYING ACT_DECODING ACT_ENCODING ACT_IDLE ACT_SCANNING |
16 | ACT_COPYING ACT_DECODING ACT_ENCODING ACT_IDLE ACT_SCANNING |
… | |
… | |
22 | |
22 | |
23 | OPT_RBUF OPT_WBUF |
23 | OPT_RBUF OPT_WBUF |
24 | OPT_BRACKPOL OPT_DEBUG OPT_DESPERATE OPT_DUMBNESS OPT_ENCEXT |
24 | OPT_BRACKPOL OPT_DEBUG OPT_DESPERATE OPT_DUMBNESS OPT_ENCEXT |
25 | OPT_ERRNO OPT_FAST OPT_IGNMODE OPT_IGNREPLY OPT_OVERWRITE OPT_PREAMB |
25 | OPT_ERRNO OPT_FAST OPT_IGNMODE OPT_IGNREPLY OPT_OVERWRITE OPT_PREAMB |
26 | OPT_PROGRESS OPT_SAVEPATH OPT_TINYB64 OPT_USETEXT OPT_VERBOSE |
26 | OPT_PROGRESS OPT_SAVEPATH OPT_TINYB64 OPT_USETEXT OPT_VERBOSE |
27 | OPT_VERSION OPT_REMOVE OPT_MOREMIME OPT_DOTDOT |
27 | OPT_VERSION OPT_REMOVE OPT_MOREMIME OPT_DOTDOT OPT_AUTOCHECK |
28 | |
28 | |
29 | RET_CANCEL RET_CONT RET_EXISTS RET_ILLVAL RET_IOERR RET_NODATA |
29 | RET_CANCEL RET_CONT RET_EXISTS RET_ILLVAL RET_IOERR RET_NODATA |
30 | RET_NOEND RET_NOMEM RET_OK RET_UNSUP |
30 | RET_NOEND RET_NOMEM RET_OK RET_UNSUP |
31 | |
31 | |
32 | B64_ENCODED BH_ENCODED PT_ENCODED QP_ENCODED |
32 | B64_ENCODED BH_ENCODED PT_ENCODED QP_ENCODED |
… | |
… | |
159 | OPT_TINYB64 detect short B64 outside of Mime |
159 | OPT_TINYB64 detect short B64 outside of Mime |
160 | OPT_ENCEXT extension for single-part encoded files |
160 | OPT_ENCEXT extension for single-part encoded files |
161 | OPT_REMOVE remove input files after decoding (dangerous) |
161 | OPT_REMOVE remove input files after decoding (dangerous) |
162 | OPT_MOREMIME strict MIME adherence |
162 | OPT_MOREMIME strict MIME adherence |
163 | OPT_DOTDOT ".."-unescaping has not yet been done on input files |
163 | OPT_DOTDOT ".."-unescaping has not yet been done on input files |
164 | OPT_RBUF set default read I/O buffer size in bytes *EXPERIMENTAL* |
164 | OPT_RBUF set default read I/O buffer size in bytes |
165 | OPT_WBUF set default write I/O buffer size in bytes *EXPERIMENTAL* |
165 | OPT_WBUF set default write I/O buffer size in bytes |
|
|
166 | OPT_AUTOCHECK automatically check file list after every loadfile |
166 | |
167 | |
167 | =head2 Result/Error codes |
168 | =head2 Result/Error codes |
168 | |
169 | |
169 | RET_OK everything went fine |
170 | RET_OK everything went fine |
170 | RET_IOERR I/O Error - examine errno |
171 | RET_IOERR I/O Error - examine errno |
… | |
… | |
281 | If you are desperate, try to call C<Smerge> with increasing C<$pass> |
282 | If you are desperate, try to call C<Smerge> with increasing C<$pass> |
282 | values, beginning at C<0>, to try to merge parts that usually would not |
283 | values, beginning at C<0>, to try to merge parts that usually would not |
283 | have been merged. |
284 | have been merged. |
284 | |
285 | |
285 | Most probably this will result in garbled files, so never do this by |
286 | Most probably this will result in garbled files, so never do this by |
286 | default. |
287 | default, except: |
|
|
288 | |
|
|
289 | If the C<OPT_AUTOCHECK> option has been disabled (by default it is |
|
|
290 | enabled) to speed up file loading, then you I<have> to call C<Smerge -1> |
|
|
291 | after loading all files as an additional pre-pass (which is normally done |
|
|
292 | by C<LoadFile>). |
287 | |
293 | |
288 | =item $item = GetFileListItem $item_number |
294 | =item $item = GetFileListItem $item_number |
289 | |
295 | |
290 | Return the C<$item> structure for the C<$item_number>'th found file, or |
296 | Return the C<$item> structure for the C<$item_number>'th found file, or |
291 | C<undef> of no file with that number exists. |
297 | C<undef> of no file with that number exists. |
… | |
… | |
481 | # the following non-trivial FileNameCallback takes care |
487 | # the following non-trivial FileNameCallback takes care |
482 | # of some subject lines not detected properly by uulib: |
488 | # of some subject lines not detected properly by uulib: |
483 | SetFileNameCallback sub { |
489 | SetFileNameCallback sub { |
484 | return unless $_[1]; # skip "Re:"-plies et al. |
490 | return unless $_[1]; # skip "Re:"-plies et al. |
485 | local $_ = $_[0]; |
491 | local $_ = $_[0]; |
486 | |
|
|
487 | return $1 if /(\S+\s+IMG_\d+.jpg)/i; |
|
|
488 | |
492 | |
489 | # the following rules are rather effective on some newsgroups, |
493 | # the following rules are rather effective on some newsgroups, |
490 | # like alt.binaries.games.anime, where non-mime, uuencoded data |
494 | # like alt.binaries.games.anime, where non-mime, uuencoded data |
491 | # is very common |
495 | # is very common |
492 | |
496 | |
… | |
… | |
554 | |
558 | |
555 | print "cleanup...\n"; |
559 | print "cleanup...\n"; |
556 | |
560 | |
557 | CleanUp; |
561 | CleanUp; |
558 | |
562 | |
|
|
563 | =head1 BUGS AND LIMITATIONS |
|
|
564 | |
|
|
565 | The original uulib library this module uses was written at a time where |
|
|
566 | main memory of measured in megabytes and buffer overflows as a security |
|
|
567 | thign didn't exist. While a lot of security fixes have been applied over |
|
|
568 | the years (includign some defense in depth mechanism that can shield |
|
|
569 | against a lot of as-of-yet undetected bugs), using this library for |
|
|
570 | security purposes requires care. |
|
|
571 | |
|
|
572 | Likewise, file sizes when the uulib library was written were tiny compared |
|
|
573 | to today, so do not expect this library to handle files larger than 2GB. |
|
|
574 | |
559 | =head1 AUTHOR |
575 | =head1 AUTHOR |
560 | |
576 | |
561 | Marc Lehmann <schmorp@schmorp.de>, the original uulib library was written |
577 | Marc Lehmann <schmorp@schmorp.de>, the original uulib library was written |
562 | by Frank Pilhofer <fp@informatik.uni-frankfurt.de>, and later heavily |
578 | by Frank Pilhofer <fp@informatik.uni-frankfurt.de>, and later heavily |
563 | bugfixed by Marc Lehmann. |
579 | bugfixed by Marc Lehmann. |
564 | |
580 | |
565 | =head1 SEE ALSO |
581 | =head1 SEE ALSO |
566 | |
582 | |
567 | perl(1), uudeview homepage at http://www.uni-frankfurt.de/~fp/uudeview/. |
583 | perl(1), uudeview homepage at L<http://www.fpx.de/fp/Software/UUDeview/>. |
568 | |
584 | |
569 | =cut |
585 | =cut |
|
|
586 | |