package Moose::Meta::Attribute::Native::Trait::String; our $VERSION = '2.2207'; use Moose::Role; with 'Moose::Meta::Attribute::Native::Trait'; sub _helper_type { 'Str' } no Moose::Role; 1; # ABSTRACT: Helper trait for Str attributes __END__ =pod =encoding UTF-8 =head1 NAME Moose::Meta::Attribute::Native::Trait::String - Helper trait for Str attributes =head1 VERSION version 2.2207 =head1 SYNOPSIS package MyHomePage; use Moose; has 'text' => ( traits => ['String'], is => 'rw', isa => 'Str', default => q{}, handles => { add_text => 'append', replace_text => 'replace', }, ); my $page = MyHomePage->new(); $page->add_text("foo"); # same as $page->text($page->text . "foo"); =head1 DESCRIPTION This trait provides native delegation methods for strings. =head1 DEFAULT TYPE If you don't provide an C value for your attribute, it will default to C. =head1 PROVIDED METHODS =over 4 =item * B Increments the value stored in this slot using the magical string autoincrement operator. Note that Perl doesn't provide analogous behavior in C<-->, so C is not available. This method returns the new value. This method does not accept any arguments. =item * B Appends to the string, like C<.=>, and returns the new value. This method requires a single argument. =item * B Prepends to the string and returns the new value. This method requires a single argument. =item * B Performs a regexp substitution (L). There is no way to provide the C flag, but code references will be accepted for the replacement, causing the regex to be modified with a single C. C can be applied using the C operator. This method returns the new value. This method requires two arguments. =item * B Runs the regex against the string and returns the matching value(s). This method requires a single argument. =item * B Just like L. This method returns the chopped character. This method does not accept any arguments. =item * B Just like L. This method returns the number of characters removed. This method does not accept any arguments. =item * B Sets the string to the empty string (not the value passed to C). This method does not have a defined return value. This method does not accept any arguments. =item * B Just like L, returns the length of the string. =item * B This acts just like L. When called as a writer, it returns the substring that was replaced, just like the Perl builtin. This method requires at least one argument, and accepts no more than three. =back =head1 BUGS See L for details on reporting bugs. =head1 AUTHORS =over 4 =item * Stevan Little =item * Dave Rolsky =item * Jesse Luehrs =item * Shawn M Moore =item * יובל קוג'מן (Yuval Kogman) =item * Karen Etheridge =item * Florian Ragwitz =item * Hans Dieter Pearcey =item * Chris Prather =item * Matt S Trout =back =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2006 by Infinity Interactive, Inc. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut