NAME Convert::BaseN - encoding and decoding of base{2,4,8,16,32,64} strings VERSION $Id: README,v 0.1 2008/06/16 17:34:27 dankogai Exp dankogai $ SYNOPSIS use Convert::BaseN; # by name my $cb = Convert::BaseN->new('base64'); my $cb = Convert::BaseN->new( name => 'base64' ); # or base my $cb = Convert::BaseN->new( base => 64 ); my $cb_url = Convert::BaseN->new( base => 64, chars => '0-9A-Za-z\-_=' ); # encode and decode $encoded = $cb->encode($data); $decoded = $cb->decode($encoded); EXPORT Nothing. Instead of that, this module builds *transcoder object* for you and you use its "decode" and "encode" methods to get the job done. FUNCTIONS new Create the transcoder object. # by name my $cb = Convert::BaseN->new('base64'); my $cb = Convert::BaseN->new( name => 'base64' ); # or base my $cb = Convert::BaseN->new( base => 64 ); my $cb_url = Convert::BaseN->new( base => 64, chars => '0-9A-Za-z\-_=' ); You can pick the decoder by name or create your own by specifying base and character map. base Must be 2, 4, 16, 32 or 64. chars Specifiles the character map. The format is the same as "tr". # DNA is coded that way. my $dna = Convert::BaseN->new( base => 4, chars => 'ACGT' ); padding nopadding Specifies if padding (adding '=' or other chars) is required when encoding. default is yes. # url-safe Base64 my $b64url = Convert::BaseN->new( base => 64, chars => '0-9A-Za-z\-_=', padding => 0; ); name When specified, the following pre-defined encodings will be used. base2 base 2 encoding. "perl" is 01110000011001010111001001101100. base4 DNA RNA base 4 encodings. "perl" is: base4: 1300121113021230 DNA: CTAACGCCCTAGCGTA RNA: GAUUGCGGGAUCGCAU base 16 encoding. "perl" is "7065726c". base32 base32hex base 32 encoding mentioned in RFC4648. "perl" is: base32: OBSXE3A== base32hex: E1IN4R0== base64 base64_url base64_imap base64_ircu base 64 encoding, as in MIME::Base64. They differ only in characters to represent number 62 and 63 as follows. base64: +/ base64_url: -_ base64_imap: +, base64_ircu: [] for all predefined base 64 variants, "decode" accept ANY form of those. decode Does decode my $decoded = $cb->decode($data) encode Does encode. # line folds every 76 octets, like MIME::Base64::encode my $encoded = $cb->encode($data); # no line folding (compatibile w/ MIME::Base64) my $encoded = $cb->encode($data, ""); # line folding by CRLF, every 40 octets my $encoded = $cb->encode($data, "\r\n", 40); SEE ALSO RFC4648 <http://tools.ietf.org/html/rfc4648> Wikipedia <http://en.wikipedia.org/wiki/Base64> <http://www.centricorp.com/papers/base64.htm> MIME::Base64 MIME::Base32 MIME::Base64::URLSafe AUTHOR Dan Kogai, "<dankogai at dan.co.jp>" BUGS Please report any bugs or feature requests to "bug-convert-basen at rt.cpan.org", or through the web interface at <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Convert-BaseN>. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. SUPPORT You can find documentation for this module with the perldoc command. perldoc Convert::BaseN You can also look for information at: * RT: CPAN's request tracker <http://rt.cpan.org/NoAuth/Bugs.html?Dist=Convert-BaseN> * AnnoCPAN: Annotated CPAN documentation <http://annocpan.org/dist/Convert-BaseN> * CPAN Ratings <http://cpanratings.perl.org/d/Convert-BaseN> * Search CPAN <http://search.cpan.org/dist/Convert-BaseN> ACKNOWLEDGEMENTS N/A COPYRIGHT & LICENSE Copyright 2008 Dan Kogai, all rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.