uuencode/uudecode for Raku
use Util::Uuencode;
my $image = "some-image.jpg".IO.slurp(:bin);
my $encoded = uuencode($image);
$image = uudecode($encoded);
uuencode is a binary to text encoding mechanism designed for sending binary files across computer boundaries where the transport mechanism may not be 8 bit clean, such as e-mail, usenet or uucp. It has largely been obsoleted by MIME (and Base64 encoding,) and the advent of ubiquitous 8 bit clean networking.
This module provides routines for uuencoding (uuencode
) and decoding (uudecode
) which will round trip data between binary and text encoded representations. uuencode
will quite happily encode plain text but as the effect is to make it a third larger there isn't much point doing that ( I guess at a push it could be used to preserve some unicode encoding across some boundary that doesn't deal with that well.)
The POSIX commands uuencode and uudecode expect some additional header and trailer information which this module doesn't deal with, so if you expect your data to be processed by these tools you will need to add this to your encoded output and remove it from the input for correct processing.
Assuming you have a working Rakudo installation then this can be installed by zef
:
zef install Util::Uuencode
# Or from a local clone
zef install .
There are no depenencies.
This is one of those things that either works or it doesn't but if you have a problem or suggestions please report them on Github.
This is free software.
Please see the LICENCE file in the distribution.
© Jonathan Stowe 2020