NAME
Mojo::ByteStream - ByteStream
SYNOPSIS
my $stream = Mojo::ByteStream->new( 'foo_bar_baz' );
say $stream ->camelize;
my $stream = Mojo::ByteStream->new( 'foo bar baz' )->quote;
$stream = $stream ->unquote->encode( 'UTF-8' )->b64_encode( '' );
say "$stream" ;
my $stream = b( 'foobarbaz' )->b64_encode( '' )-> say ;
|
DESCRIPTION
Mojo::ByteStream is a scalar-based container for bytestreams that provides a more friendly API for many of the functions in Mojo::Util.
my $stream = Mojo::ByteStream->new( 'foo' );
$$stream .= 'bar' ;
|
FUNCTIONS
Mojo::ByteStream implements the following functions, which can be imported individually.
b
my $stream = b( 'test123' );
|
Construct a new scalar-based Mojo::ByteStream object.
METHODS
Mojo::ByteStream implements the following methods.
b64_decode
$stream = $stream ->b64_decode;
|
Base64 decode bytestream with "b64_decode" in Mojo::Util.
b64_encode
$stream = $stream ->b64_encode;
$stream = $stream ->b64_encode( "\n" );
|
Base64 encode bytestream with "b64_encode" in Mojo::Util.
b( 'foo bar baz' )->b64_encode( '' );
|
camelize
$stream = $stream ->camelize;
|
Camelize bytestream with "camelize" in Mojo::Util.
clone
my $stream2 = $stream ->clone;
|
Return a new Mojo::ByteStream object cloned from this bytestream.
decamelize
$stream = $stream ->decamelize;
|
Decamelize bytestream with "decamelize" in Mojo::Util.
decode
$stream = $stream ->decode;
$stream = $stream ->decode( 'iso-8859-1' );
|
Decode bytestream with "decode" in Mojo::Util, defaults to using UTF-8
.
b( '%E2%99%A5' )->url_unescape->decode;
|
encode
$stream = $stream ->encode;
$stream = $stream ->encode( 'iso-8859-1' );
|
Encode bytestream with "encode" in Mojo::Util, defaults to using UTF-8
.
b( '♥' )->encode->url_escape;
|
gunzip
$stream = $stream ->gunzip;
|
Uncompress bytestream with "gunzip" in Mojo::Util.
gzip
Compress bytestream with "gzip" in Mojo::Util.
hmac_sha1_sum
$stream = $stream ->hmac_sha1_sum( 'passw0rd' );
|
Generate HMAC-SHA1 checksum for bytestream with "hmac_sha1_sum" in Mojo::Util.
b( 'foo bar baz' )->hmac_sha1_sum( 'secr3t' );
|
html_unescape
$stream = $stream ->html_unescape;
|
Unescape all HTML entities in bytestream with "html_unescape" in Mojo::Util.
b( '<html>' )->html_unescape->url_escape;
|
humanize_bytes
$stream = $stream ->humanize_bytes;
|
Turn number of bytes into a simplified human readable format for bytestream with "humanize_bytes" in Mojo::Util.
md5_bytes
$stream = $stream ->md5_bytes;
|
Generate binary MD5 checksum for bytestream with "md5_bytes" in Mojo::Util.
md5_sum
$stream = $stream ->md5_sum;
|
Generate MD5 checksum for bytestream with "md5_sum" in Mojo::Util.
new
my $stream = Mojo::ByteStream->new( 'test123' );
|
Construct a new scalar-based Mojo::ByteStream object.
punycode_decode
$stream = $stream ->punycode_decode;
|
Punycode decode bytestream with "punycode_decode" in Mojo::Util.
punycode_encode
$stream = $stream ->punycode_encode;
|
Punycode encode bytestream with "punycode_encode" in Mojo::Util.
quote
$stream = $stream ->quote;
|
Quote bytestream with "quote" in Mojo::Util.
say
$stream = $stream -> say ;
$stream = $stream -> say ( *STDERR );
|
Print bytestream to handle and append a newline, defaults to using STDOUT
.
secure_compare
my $bool = $stream ->secure_compare( $str );
|
Compare bytestream with "secure_compare" in Mojo::Util.
sha1_bytes
$stream = $stream ->sha1_bytes;
|
Generate binary SHA1 checksum for bytestream with "sha1_bytes" in Mojo::Util.
sha1_sum
$stream = $stream ->sha1_sum;
|
Generate SHA1 checksum for bytestream with "sha1_sum" in Mojo::Util.
size
my $size = $stream ->size;
|
Size of bytestream.
slugify
$stream = $stream ->slugify;
$stream = $stream ->slugify( $bool );
|
Generate URL slug for bytestream with "slugify" in Mojo::Util.
split
my $collection = $stream -> split ( ',' );
my $collection = $stream -> split ( ',' , -1);
|
Turn bytestream into Mojo::Collection object containing Mojo::ByteStream objects.
b( "one,two,three" )-> split ( ',' )-> map ( 'camelize' )-> join ( ',' );
b( "one,two,three,,," )-> split ( ',' , -1)-> map ( 'camelize' )-> join ( ',' );
|
tap
$stream = $stream ->tap( sub {...});
|
Alias for "tap" in Mojo::Base.
term_escape
$stream = $stream ->term_escape;
|
Escape POSIX control characters in bytestream with "term_escape" in Mojo::Util.
b( 'foo' )->sha1_bytes->term_escape-> say ;
|
to_string
my $str = $stream ->to_string;
|
Stringify bytestream.
trim
Trim whitespace characters from both ends of bytestream with "trim" in Mojo::Util.
unindent
$stream = $stream ->unindent;
|
Unindent bytestream with "unindent" in Mojo::Util.
unquote
$stream = $stream ->unquote;
|
Unquote bytestream with "unquote" in Mojo::Util.
url_escape
$stream = $stream ->url_escape;
$stream = $stream ->url_escape( '^A-Za-z0-9\-._~' );
|
Percent encode all unsafe characters in bytestream with "url_escape" in Mojo::Util.
b( '☃' )->encode->url_escape;
|
url_unescape
$stream = $stream ->url_unescape;
|
Decode percent encoded characters in bytestream with "url_unescape" in Mojo::Util.
b( '%3Chtml%3E' )->url_unescape->xml_escape;
|
with_roles
my $new_class = Mojo::ByteStream->with_roles( 'Mojo::ByteStream::Role::One' );
my $new_class = Mojo::ByteStream->with_roles( '+One' , '+Two' );
$stream = $stream ->with_roles( '+One' , '+Two' );
|
Alias for "with_roles" in Mojo::Base.
xml_escape
$stream = $stream ->xml_escape;
|
Escape only the characters &
, <
, >
, "
and '
in bytestream with "xml_escape" in Mojo::Util.
xor_encode
$stream = $stream ->xor_encode( $key );
|
XOR encode bytestream with "xor_encode" in Mojo::Util.
b( 'foo bar' )->xor_encode( 'baz' )->url_escape;
|
OPERATORS
Mojo::ByteStream overloads the following operators.
bool
my $bool = !! $bytestream ;
|
Always true.
stringify
Alias for "to_string".
SEE ALSO
Mojolicious, Mojolicious::Guides, https://mojolicious.org.