NAME

Convert::UUlib - Perl interface to the uulib library (a.k.a. uudeview/uuenview).

SYNOPSIS

use Convert::UUlib;

DESCRIPTION

Read the file uulibdoc.dvi.gz and the example-decoder source. Sorry - more to come once people use me ;)

SMALL EXAMPLE DECODER

The following code excerpt is a minimal decoder program. It reads all files given on the commandline and decodes any files in it.

use Convert::UUlib ':all';

LoadFile($_) for @ARGV;

for($i=0; $uu=GetFileListItem($i); $i++) {
   $uu->decode if $uu->state & FILE_OK;
}

LARGE EXAMPLE DECODER

This is the file example-decoder from the distribution, put here instead of more thorough documentation.

# decode all the files in the directory uusrc/ and copy
# the resulting files to uudst/

use Convert::UUlib ':all';

sub namefilter {
   my($path)=@_;
   $path=~s/^.*[\/\\]//;
   $path;
}

sub busycb {
   my($action,$curfile,$partno,$numparts,$percent,$fsize)=@_;
   $_[0]=straction($action);
   print "busy_callback(",join(",",@_),")\n";
   0;
}

SetOption (OPT_IGNMODE, 1);
SetOption (OPT_VERBOSE, 1);

# show the three ways you can set callback functions
SetFNameFilter (\&namefilter);

SetBusyCallback ("busycb",333);

SetMsgCallback (sub {
   my($msg,$level)=@_;
   print uc(strmsglevel($_[1])),": $msg\n";
});

for(<uusrc/*>) {
   my($retval,$count)=LoadFile ($_,$_,1);
   print "file($_), status(",strerror($retval),") parts($count)\n";
}

SetOption (OPT_SAVEPATH, "uudst/");

$i=0;
while($uu=GetFileListItem($i)) {
   $i++;
   print "file nr. $i";
   print " state ",$uu->state;
   print " mode ",$uu->mode;
   print " uudet ",strencoding($uu->uudet);
   print " size ",$uu->size;
   print " filename ",$uu->filename;
   print " subfname ",$uu->subfname;
   print " mimeid ",$uu->mimeid;
   print " mimetype ",$uu->mimetype;
   print "\n";

   # print additional info about all parts
   for($uu->parts) {
      while(my($k,$v)=each(%$_)) {
         print "$k > $v, ";
      }
      print "\n";
   }

   $uu->decode_temp;
   print " temporarily decoded to ",$uu->binfile,"\n";
   $uu->remove_temp;

   print strerror($uu->decode);
   print " saved as uudst/",$uu->filename,"\n";
}

print "cleanup...\n";

CleanUp();

Exported constants

Action code constants:

ACT_COPYING ACT_DECODING ACT_ENCODING
ACT_IDLE    ACT_SCANNING

File status flags:

FILE_DECODED FILE_ERROR  FILE_MISPART
FILE_NOBEGIN FILE_NODATA FILE_NOEND
FILE_OK      FILE_READ   FILE_TMPFILE

Message severity levels:

MSG_ERROR MSG_FATAL MSG_MESSAGE
MSG_NOTE  MSG_PANIC MSG_WARNING

Options:

OPT_BRACKPOL OPT_DEBUG     OPT_DESPERATE OPT_DUMBNESS
OPT_ENCEXT   OPT_ERRNO     OPT_FAST      OPT_IGNMODE
OPT_IGNREPLY OPT_OVERWRITE OPT_PREAMB    OPT_PROGRESS
OPT_SAVEPATH OPT_TINYB64   OPT_USETEXT   OPT_VERBOSE
OPT_VERSION

Error/Result codes:

RET_CANCEL RET_CONT  RET_EXISTS RET_ILLVAL RET_IOERR
RET_NODATA RET_NOEND RET_NOMEM  RET_OK     RET_UNSUP

Encoding types:

B64ENCODED BH_ENCODED PT_ENCODED
QP_ENCODED XX_ENCODED UU_ENCODED

Exported functions

Initializing and cleanup (Initialize is automatically called when the module is loaded and allocates quite a bit of memory. CleanUp releases that again).

Initialize; # not normally necessary
CleanUp;    # could be called at the end to release memory

Setting and querying options:

$option = GetOption OPT_xxx;
SetOption OPT_xxx, opt-value;

Error and action values => stringified:

$msg = straction ACT_xxx;
$msg = strerror RET_xxx;

Setting various callbacks:

SetMsgCallback [callback-function];
SetBusyCallback [callback-function];
SetFileCallback [callback-function];
SetFNameFilter [callback-function];

Call the currently selected FNameFilter:

$file = FNameFilter $file;

Loading sourcefiles, optionally fuzzy merge and start decoding:

($retval, $count) = LoadFile $fname, [$id, [$delflag]];
$retval = Smerge $pass;
$item = GetFileListItem $item_number;

The procedural interface is undocumented, use the following methods instead:

$retval = $item->rename($newname);
$retval = $item->decode_temp;
$retval = $item->remove_temp;
$retval = $item->decode([$target_path]);
$retval = $item->info(callback-function);

Querying (and setting) item attributes:

$state    = $item->state;
$mode     = $item->mode([newmode]);
$uudet    = $item->uudet;
$size     = $item->size;
$filename = $item->filename([newfilename});
$subfname = $item->subfname;
$mimeid   = $item->mimeid;
$mimetype = $item->mimetype;
$binfile  = $item->binfile;

Totally undocumented and unsupported(!):

$parts = $item->parts;

Functions below not documented and not very well tested:

int	  QuickDecode		() ;
int	  EncodeMulti		() ;
int	  EncodePartial	() ;
int	  EncodeToStream	() ;
int	  EncodeToFile		() ;
int	  E_PrepSingle		() ;
int	  E_PrepPartial	() ;

AUTHOR

Marc Lehmann <pcg@goof.com>, the original uulib library was written by Frank Pilhofer <fp@informatik.uni-frankfurt.de>.

SEE ALSO

perl(1), uudeview homepage at http://www.uni-frankfurt.de/~fp/uudeview/.