NAME
Object::String - A Perl string object
VERSION
version 0.05
DESCRIPTION
A string object for Perl 5.
Object::String
have a lot of "modern" features and supports method chaining. A helper is also provided to help to build a string object.
Object::String
is heavily inspired by stringjs a Ruby string object.
# Normal way to build a string object
my $string = Object::String->new(string => 'test');
# With the helper
my $string = str('test');
# Display the string
say $string->string;
# Method chaining
say $string->chomp_right->to_upper->string;
say str('testZ')->chop_right->to_upper->string; # TEST
METHODS
string
Converts the object into a string scalar. Aliases: to_string
to_string
An alias to string
to_lower
Converts the string to lower case.
say str('TEST')->to_lower->string; # test
to_lower_first
Lower case the first letter of a string.
say str('TEST')->to_lower_first->string; # tEST
to_upper
Converts the string to upper case.
say str('test')->to_upper->string; # TEST
to_upper_first
Upper case the first letter of a string.
say str('test')->to_upper_first->string; # Test
capitalize
Capitalizes a string.
say str('TEST')->capitalize->string; # Test
length
Returns the length of a string.
say str('test')->length; # 4
ensure_left($prefix)
Ensures the string is beginning with $prefix.
say str('dir')->ensure_left('/')->string; # /dir
say str('/dir')->ensure_left('/')->string; # /dir
ensure_right($suffix)
Ensures the string is ending with $suffix.
say str('/dir')->ensure_right('/')->string; # /dir/
say str('/dir/')->ensure_right('/')->string; # /dir/
trim_left
Trim string from left.
say str(" \t test")->trim_left->string; # test
trim_right
Trim string from right.
say str("test \t \t")->trim_right->string; # test
trim
Trim string from left and from right.
say str("\t \ttest \t\t")->trim->string; # test
clean
Deletes unuseful whitespaces.
say str("This\t \tis \t a \t test")->clean->string; # This is a test
Aliases: collapse_whitespace
collapse_whitespace
An alias to clean
.
repeat($n)
Repeats a string n times. Aliases: times
say str('test')->repeat(3)->string; # testtesttest
times($n)
An alias to repeat
.
starts_with($str)
Tests if the string starts with $str.
str('test')->starts_with('te'); # true
str('test')->starts_with('z'); # false
ends_with($str)
Tests if the string ends with $str.
str('test')->ends_with('st'); # true
str('test')->ends_with('z'); # false
contains($str)
Tests if the string contains $str. Aliases: include
str('test')->contains('es'); # true
str('test')->contains('z'); # false
include($str)
An alias to contains
.
chomp_left
Chomp left the string. If the string begins by a space or a tab, it is removed.
chomp_right
Chomp right the string. Same as the Perl's chomp
function.
chop_left
Deletes the first character of the string.
say str('test')->chop_left->string; # est
chop_right
Deletes the last character of the string. Same function as Perl's chop
function.
say str('test')->chop_right->string; # tes
is_numeric
Tests if the string is composed by numbers.
str('123')->is_numeric; # true
str('1.23')->is_numeric; # false
str('ab1')->is_numeric; # false
is_alpha
Tests if the string is composed by alphabetic characters.
str('abc')->is_alpha; # true
str('a1b2c3')->is_alpha; # false
is_alpha_numeric
Tests if the string is composed only by letters and numbers.
str('abc')->is_alpha_numeric; # true
str('a1b2c3')->is_alpha_numeric; # true
str('1.3e10')->is_alpha_numeric; # false
is_lower
Tests if a string is lower case.
str('TEST')->is_lower; # false
str('test')->is_lower; # true
is_upper
Tests if the string is upper case.
str('TEST')->is_upper; # true
str('test')->is_upper; # false
to_boolean
Returns a boolean if the string is ON|OFF, YES|NO, TRUE|FALSE upper or lower case. Aliases: to_bool
str('on')->to_boolean; # true
str('off')->to_boolean; # false
str('yes')->to_boolean; # true
str('no')->to_boolean; # false
str('true')->to_boolean; # true
str('false')->to_boolean; # false
str('test')->to_boolean; # undef
to_bool
An alias to to_boolean
.
is_empty
Tests if a string is empty.
str('')->is_empty; # true
str(undef)->is_empty; # true
str(' ')->is_emtpy; # true
str(" \t\t ")->is_empty; # true
str("aaa")->is_empty; # false
count($str)
Counts the occurrences of $str in the string.
say str('This is a test')->count('is'); # 2
left($count)
Returns a substring of $count characters from the left.
say str('This is a test')->left(3)->string; # Thi
say str('This is a test')->left(-3)->string; # est
right($count)
Returns a substring of $count characters from the right
say str('This is a test')->right(3)->string; # est
say str('This is a test')->right(-3)->string; # Thi
undersocre
Converts the string to snake case. Aliases: underscored
say str('thisIsATest')->underscore->string; # this_is_a_test
say str('ThisIsATest')->underscore->string; # _this_is_a_test
say str('This::IsATest')->underscore->string; # _this/is_a_test
say str('This Is A Test')->underscore->string; # this_is_a_test
underscored
An alias to underscore.
dasherize
Converts the string to a dasherized one.
say str('thisIsATest')->dasherize->string; # thisr-is-a-test
say str('ThisIsATest')->dasherize->string; # -this-is-a-test
say str('This::IsATest')->dasherize->string; # -this/is-a-test
say str('This Is A Test')->dasherize->string; # this-is-a-test
camelize
Converts the string to a camelized one.
say str('this-is-a-test')->camelize->string; # thisIsATest
say str('_this_is_a_test')->camelize->string; # ThisIsATest
say str('_this/is/a-test')->camelize->string; # This::Is::ATest
say str('this is a test')->camelize->string; # thisIsATest
latinise
Removes accents from Latin characters.
say str('où es-tu en été ?')->latinise->string; # ou es-tu en ete
escape_html
Escapes some HTML entities : &"'<>
# <h1>l'été sera beau & chaud</h1>
say str("<h1>l'été sera beau & chaud</h1>")->escape_html->string;
#<h1>entre "guillemets"</h1>
say str('<h1>entre "guillemets"</h1>')->escape_html->string
unescape_html
Unescapes some HTML entities : &"'<>
index_left($substr, $position)
Searches for a substring within another from a position. If $position is not specified, it begins from 0.
say str('this is a test')->index_left('is'); # 2
say str('this is a test')->index_right('is', 3); # 5
index_right($substr, $position)
Searches from right for a substring within another from a position. If $position is not specified, it begins from 0.
say str('this is a test')->index_right('is'); # 5
say str('this is a test')->index_right('is', 5); # 2
replace_all($substr1, $substr2)
Replaces all occurrences of a substring within the string.
say str('This is a test')->replace_all(' ', '_'); # this_is_a_test
humanize
Transforms the input into a human friendly form.
say str('-this_is a test')->humanize->string; # This is a test
pad_left($count, $char)
Pad left the string with $count $char.
say str('hello')->pad_left(3)->string; # hello
say str('hello')->pad_left(5)->string; # hello
say str('hello')->pad_left(10)->string; # hello
say str('hello')->pad_left(10, '.')->string; # .....hello
pad_right($count, $char)
Pad right the string with $count $char.
say str('hello')->pad_right(3)->string; # hello
say str('hello')->pad_right(5)->string; # hello
say str('hello')->pad_right(10)->string; # "hello "
say str('hello')->pad_left(10, '.')->string; # hello.....
pad($count, $char)
Pad the string with $count $char.
say str('hello')->pad(3)->string; # hello
say str('hello')->pad(5)->string; # hello
say str('hello')->pad(10)->string; # " hello "
say str('hello')->pad(10, '.')->string; # ...hello..
next
Increments the string.
say str('a')->next->string; # b
say str('z')->next->string; # aa
slugify
Transfoms the input into an url slug.
say str('En été, il fera chaud')->slugify->string; # en-ete-il-fera-chaud
strip_punctuation
Strips punctuation from the string.
say str('this. is, %a (test)'); # this is a test
swapcase
Swaps the case of the string.
say str('TeSt')->swapcase->string; # tEsT
concat($str1, ...)
Concats multiple strings. Aliases: suffix
say str('test')->concat('test')->string; # testtest
say str('test')->concat('test', 'test')->string; # testtesttest
suffix($str1, ...)
An alias to concat
.
prefix($str1, ...)
Prefix the string with $str1, ...
say str('test')->prefix('hello')->string; # hellotest
say str('test')->prefix('hello', 'world'); # helloworldtest
reverse
Reverses a string.
say str('test')->reverse->string; # tset
count_words
Counts the words in a string.
say str("this\tis a \t test")->count_words; # 4
quote_meta
Quotes meta characters.
# hello\ world\.\ \(can\ you\ hear\ me\?\)
say str('hello world. (can you hear me?)')->quote_meta->string;
rot13
ROT13 transformation on the string.
say str('this is a test')->rot13->string; # guvf vf n grfg
say str('this is a test')->rot13->rot13->string; # this is a test
say
Says the string.
str('this is a test')->say; # displays "this is a test\n"
titleize
Strips punctuation and capitalizes each word. Aliases: titlecase
say str('this is a test')->titleize->string; # This Is A Test
titlecase
An alias to titleize
.
str
Creates and returns a string object.
str("test")->string # test
str("test")->to_upper->string # TEST
str('this', 'is', 'a', 'test')->string; # this is a test
AUTHOR
Vincent BERZIN <berzinv@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Vincent BERZIN.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.