Mojo::ByteStream

Section: User Contributed Perl Documentation (3)
Updated: 2018-12-17
Page Index
 

NAME

Mojo::ByteStream - ByteStream  

SYNOPSIS

  use Mojo::ByteStream;

  # Manipulate 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')->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.

  # Access scalar directly to manipulate bytestream
  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.

  # "Zm9vIGJhciBiYXo="
  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".

  # "%E2%99%A5"
  b('♥')->encode->url_escape;

 

gunzip

  $stream = $stream->gunzip;

Uncompress bytestream with ``gunzip'' in Mojo::Util.  

gzip

  stream = $stream->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.

  # "7fbdc89263974a89210ea71f171c77d3f8c21471"
  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.

  # "%3Chtml%3E"
  b('<html>')->html_unescape->url_escape;

 

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.

  # "One,Two,Three"
  b("one,two,three")->split(',')->map('camelize')->join(',');

  # "One,Two,Three,,,"
  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.

  # Print binary checksum to terminal
  b('foo')->sha1_bytes->term_escape->say;

 

to_string

  my $str = $stream->to_string;

Stringify bytestream.  

trim

  $stream = $stream->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.

  # "%E2%98%83"
  b('☃')->encode->url_escape;

 

url_unescape

  $stream = $stream->url_unescape;

Decode percent encoded characters in bytestream with ``url_unescape'' in Mojo::Util.

  # "<html>"
  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.

  # "%04%0E%15B%03%1B%10"
  b('foo bar')->xor_encode('baz')->url_escape;

 

OPERATORS

Mojo::ByteStream overloads the following operators.  

bool

  my $bool = !!$bytestream;

Always true.  

stringify

  my $str = "$bytestream";

Alias for ``to_string''.  

SEE ALSO

Mojolicious, Mojolicious::Guides, <https://mojolicious.org>.


 

Index

NAME
SYNOPSIS
DESCRIPTION
FUNCTIONS
b
METHODS
b64_decode
b64_encode
camelize
clone
decamelize
decode
encode
gunzip
gzip
hmac_sha1_sum
html_unescape
md5_bytes
md5_sum
new
punycode_decode
punycode_encode
quote
say
secure_compare
sha1_bytes
sha1_sum
size
slugify
split
tap
term_escape
to_string
trim
unindent
unquote
url_escape
url_unescape
with_roles
xml_escape
xor_encode
OPERATORS
bool
stringify
SEE ALSO