DOKK / manpages / debian 12 / libmoose-perl / Moose::Meta::Attribute::Native::Trait::String.3pm.en
Moose::Meta::Attribute::Native::Trait::String(3pm) User Contributed Perl Documentation Moose::Meta::Attribute::Native::Trait::String(3pm)

Moose::Meta::Attribute::Native::Trait::String - Helper trait for Str attributes

version 2.2203

  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");

This trait provides native delegation methods for strings.

If you don't provide an "isa" value for your attribute, it will default to "Str".

  • inc

    Increments the value stored in this slot using the magical string autoincrement operator. Note that Perl doesn't provide analogous behavior in "--", so "dec" is not available. This method returns the new value.

    This method does not accept any arguments.

  • append($string)

    Appends to the string, like ".=", and returns the new value.

    This method requires a single argument.

  • prepend($string)

    Prepends to the string and returns the new value.

    This method requires a single argument.

  • replace($pattern, $replacement)

    Performs a regexp substitution ("s" in perlop). There is no way to provide the "g" flag, but code references will be accepted for the replacement, causing the regex to be modified with a single "e". "/smxi" can be applied using the "qr" operator. This method returns the new value.

    This method requires two arguments.

  • match($pattern)

    Runs the regex against the string and returns the matching value(s).

    This method requires a single argument.

  • chop

    Just like "chop" in perlfunc. This method returns the chopped character.

    This method does not accept any arguments.

  • chomp

    Just like "chomp" in perlfunc. This method returns the number of characters removed.

    This method does not accept any arguments.

  • clear

    Sets the string to the empty string (not the value passed to "default").

    This method does not have a defined return value.

    This method does not accept any arguments.

  • length

    Just like "length" in perlfunc, returns the length of the string.

  • substr

    This acts just like "substr" in perlfunc. 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.

See "BUGS" in Moose for details on reporting bugs.

  • Stevan Little <stevan@cpan.org>
  • Dave Rolsky <autarch@urth.org>
  • Jesse Luehrs <doy@cpan.org>
  • Shawn M Moore <sartak@cpan.org>
  • יובל קוג'מן (Yuval Kogman) <nothingmuch@woobling.org>
  • Karen Etheridge <ether@cpan.org>
  • Florian Ragwitz <rafl@debian.org>
  • Hans Dieter Pearcey <hdp@cpan.org>
  • Chris Prather <chris@prather.org>
  • Matt S Trout <mstrout@cpan.org>

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.

2023-01-30 perl v5.36.0