NAME

Object::String - A Perl string object

VERSION

version 0.01

DESCRIPTION

A string object for Perl5.

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 : &"'<>

# &lt;h1&gt;l&#39;été sera beau &amp; chaud&lt;/h1&gt;
say str("<h1>l'été sera beau & chaud</h1>")->escape_html->string;

#&lt;h1&gt;entre &quot;guillemets&quot;&lt;/h1&gt;
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

str

This function 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@gmail.com>

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.