NAME
Mojo::ByteStream - ByteStream
SYNOPSIS
# Manipulate bytestreams
use Mojo::ByteStream;
my $stream = Mojo::ByteStream->new('foo_bar_baz');
say $stream->camelize;
# Chain methods
my $stream = Mojo::ByteStream->new('foo bar baz')->quote;
$stream = $stream->unquote->encode('UTF-8')->b64_encode;
say $stream;
# Use the alternative constructor
use Mojo::ByteStream 'b';
my $stream = b('foobarbaz')->html_escape;
DESCRIPTION
Mojo::ByteStream provides a more friendly API for the bytestream manipulation functions in Mojo::Util.
METHODS
Mojo::ByteStream implements the following methods.
new
my $stream = Mojo::ByteStream->new('test123');
Construct a new Mojo::ByteStream object.
b64_decode
$stream = $stream->b64_decode;
Base64 decode bytestream.
b64_encode
$stream = $stream->b64_encode;
$stream = $stream->b64_encode('');
Base64 encode bytestream.
camelize
$stream = $stream->camelize;
Convert snake case bytestream to camel case and replace -
with ::
.
foo_bar -> FooBar
foo_bar-baz -> FooBar::Baz
clone
my $stream2 = $stream->clone;
Clone bytestream.
decamelize
$stream = $stream->decamelize;
Convert camel case bytestream to snake case and replace ::
with -
.
FooBar -> foo_bar
FooBar::Baz -> foo_bar-baz
decode
$stream = $stream->decode;
$stream = $stream->decode($encoding);
Decode bytestream, defaults to UTF-8
.
$stream->decode('UTF-8')->to_string;
encode
$stream = $stream->encode;
$stream = $stream->encode($encoding);
Encode bytestream, defaults to UTF-8
.
$stream->encode('UTF-8')->to_string;
hmac_md5_sum
$stream = $stream->hmac_md5_sum($secret);
Turn bytestream into HMAC-MD5 checksum of old content.
hmac_sha1_sum
$stream = $stream->hmac_sha1_sum($secret);
Turn bytestream into HMAC-SHA1 checksum of old content.
html_escape
$stream = $stream->html_escape;
Escape all HTML5 named character entities in bytestream.
html_unescape
$stream = $stream->html_unescape;
Unescape all HTML5 entities in bytestream.
md5_bytes
$stream = $stream->md5_bytes;
Turn bytestream into binary MD5 checksum of old content.
md5_sum
$stream = $stream->md5_sum;
Turn bytestream into MD5 checksum of old content.
punycode_decode
$stream = $stream->punycode_decode;
Punycode decode bytestream.
punycode_encode
$stream = $stream->punycode_encode;
Punycode encode bytestream.
qp_decode
$stream = $stream->qp_decode;
Quoted Printable decode bytestream.
qp_encode
$stream = $stream->qp_encode;
Quoted Printable encode bytestream.
quote
$stream = $stream->quote;
Quote bytestream.
say
$stream->say;
$stream->say(*STDERR);
Print bytestream to handle or STDOUT and append a newline.
secure_compare
my $success = $stream->secure_compare($string);
Constant time comparison algorithm to prevent timing attacks.
sha1_bytes
$stream = $stream->sha1_bytes;
Turn bytestream into binary SHA1 checksum of old content.
sha1_sum
$stream = $stream->sha1_sum;
Turn bytestream into SHA1 checksum of old content.
size
my $size = $stream->size;
Size of bytestream.
split
my $collection = $stream->split(',');
Turn bytestream into Mojo::Collection.
$stream->split(',')->map(sub { $_->quote })->join("\n")->say;
to_string
my $string = $stream->to_string;
Stringify bytestream.
trim
$stream = $stream->trim;
Trim whitespace characters from both ends of bytestream.
unquote
$stream = $stream->unquote;
Unquote bytestream.
url_escape
$stream = $stream->url_escape;
$stream = $stream->url_escape('A-Za-z0-9\-\.\_\~');
URL escape bytestream.
url_unescape
$stream = $stream->url_unescape;
URL unescape bytestream.
xml_escape
$stream = $stream->xml_escape;
Escape only the characters &
, <
, >
, "
and '
in bytestream, this is a much faster version of html_escape
.