VERSION
version 0.25SYNOPSIS
package MyClass;
use Moose;
use MooseX::AttributeHelpers;
has 'mapping' => (
metaclass => 'Collection::Hash',
is => 'rw',
isa => 'HashRef[Str]',
default => sub { {} },
provides => {
exists => 'exists_in_mapping',
keys => 'ids_in_mapping',
get => 'get_mapping',
set => 'set_mapping',
},
curries => {
set => { set_quantity => [ 'quantity' ] }
}
);
# ...
my $obj = MyClass->new;
$obj->set_quantity(10); # quantity => 10
$obj->set_mapping(4, 'foo'); # 4 => 'foo'
$obj->set_mapping(5, 'bar'); # 5 => 'bar'
$obj->set_mapping(6, 'baz'); # 6 => 'baz'
# prints 'bar'
print $obj->get_mapping(5) if $obj->exists_in_mapping(5);
# prints '4, 5, 6'
print join ', ', $obj->ids_in_mapping;
DESCRIPTION
This distribution is deprecated. The features it provides have been added to the Moose core code as Moose::Meta::Attribute::Native. This distribution should not be used by any new code.While Moose attributes provide you with a way to name your accessors, readers, writers, clearers and predicates, this library provides commonly used attribute helper methods for more specific types of data.
As seen in the ``SYNOPSIS'', you specify the extension via the "metaclass" parameter. Available meta classes are:
PARAMETERS
provides
This points to a hashref that uses "provider" for the keys and "method" for the values. The method will be added to the object itself and do what you want.curries
This points to a hashref that uses "provider" for the keys and has two choices for the value:You can supply "{method => [ @args ]}" for the values. The method will be added to the object itself (always using @args as the beginning arguments).
Another approach to curry a method provider is to supply a coderef instead of an arrayref. The code ref takes $self, $body, and any additional arguments passed to the final method.
# ... curries => { grep => { times_with_day => sub { my ($self, $body, $datetime) = @_; $body->($self, sub { $_->ymd eq $datetime->ymd }); } } } # ... $obj->times_with_day(DateTime->now); # takes datetime argument, checks day
METHOD PROVIDERS
- Number
- Common numerical operations.
- String
- Common methods for string operations.
- Counter
- Methods for incrementing and decrementing a counter attribute.
- Bool
- Common methods for boolean values.
- Collection::Hash
- Common methods for hash references.
- Collection::ImmutableHash
- Common methods for inspecting hash references.
- Collection::Array
- Common methods for array references.
- Collection::List
- Common list methods for array references.
DEPRECATION NOTICE
The functionality in this family of modules is now implemented in the Moose core as Moose::Meta::Attribute::Native. No more development is being done on MooseX::AttributeHelpers, so we encourage you to switch to native attribute traits.SUPPORT
Bugs may be submitted through the RT bug tracker <https://rt.cpan.org/Public/Dist/Display.html?Name=MooseX-AttributeHelpers> (or [email protected] <mailto:[email protected]>).There is also a mailing list available for users of this distribution, at <http://lists.perl.org/list/moose.html>.
There is also an irc channel available for users of this distribution, at "#moose" on "irc.perl.org" <irc://irc.perl.org/#moose>.
AUTHOR
Stevan Little <[email protected]>CONTRIBUTORS
- Shawn M Moore <[email protected]>
- Stevan Little <[email protected]>
- Dave Rolsky <[email protected]>
- Florian Ragwitz <[email protected]>
- Yuval Kogman <[email protected]>
- Jason May <[email protected]>
- Karen Etheridge <[email protected]>
- Cory G Watson <[email protected]>
- Jesse Luehrs <[email protected]>
- Robert Boone <[email protected]>
- Bruno Vecchi <[email protected]>
- Johannes Plunien <[email protected]>
- Mike Whitaker <[email protected]>
- Hans Dieter Pearcey <[email protected]>
- Paul Driver <[email protected]>
- Robert 'phaylon' Sedlacek <[email protected]>
- Evan Carroll <[email protected]>
- Dagfinn Ilmari Mannsa°ker <[email protected]>
- Chris Prather <[email protected]>
- Tom Lanyon <[email protected]>
- Chris Prather <[email protected]>
- nperez <[email protected]>
COPYRIGHT AND LICENSE
This software is copyright (c) 2007 by Stevan Little and 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.