The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package Moose::Meta::Attribute::Native::Trait::Number;
use Moose::Role;

our $VERSION   = '1.00';
$VERSION = eval $VERSION;
our $AUTHORITY = 'cpan:STEVAN';

with 'Moose::Meta::Attribute::Native::Trait';

sub _helper_type { 'Num' }

# NOTE: we don't use the method provider for this module since many of
# the names of the provided methods would conflict with keywords - SL

has 'method_constructors' => (
    is      => 'ro',
    isa     => 'HashRef',
    lazy    => 1,
    default => sub {
        return +{
            set => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], $_[1] ) };
            },
            add => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], $reader->( $_[0] ) + $_[1] ) };
            },
            sub => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], $reader->( $_[0] ) - $_[1] ) };
            },
            mul => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], $reader->( $_[0] ) * $_[1] ) };
            },
            div => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], $reader->( $_[0] ) / $_[1] ) };
            },
            mod => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], $reader->( $_[0] ) % $_[1] ) };
            },
            abs => sub {
                my ( $attr, $reader, $writer ) = @_;
                return sub { $writer->( $_[0], abs( $reader->( $_[0] ) ) ) };
            },
        };
    }
);

no Moose::Role;

1;

=pod

=head1 NAME

Moose::Meta::Attribute::Native::Trait::Number - Helper trait for Num attributes

=head1 SYNOPSIS

  package Real;
  use Moose;

  has 'integer' => (
      traits    => ['Number'],
      is        => 'ro',
      isa       => 'Num',
      default   => 5,
      handles   => {
          set => 'set',
          add => 'add',
          sub => 'sub',
          mul => 'mul',
          div => 'div',
          mod => 'mod',
          abs => 'abs',
      },
  );

  my $real = Real->new();
  $real->add(5); # same as $real->integer($real->integer + 5);
  $real->sub(2); # same as $real->integer($real->integer - 2);

=head1 DESCRIPTION

This provides a simple numeric attribute, which supports most of the
basic math operations.

=head1 PROVIDED METHODS

It is important to note that all those methods do in place modification of the
value stored in the attribute. These methods are implemented within this
package.

=over 4

=item B<set($value)>

Alternate way to set the value.

=item B<add($value)>

Adds the current value of the attribute to C<$value>.

=item B<sub($value)>

Subtracts C<$value> from the current value of the attribute.

=item B<mul($value)>

Multiplies the current value of the attribute by C<$value>.

=item B<div($value)>

Divides the current value of the attribute by C<$value>.

=item B<mod($value)>

Returns the current value of the attribute modulo C<$value>.

=item B<abs>

Sets the current value of the attribute to its absolute value.

=back

=head1 METHODS

=over 4

=item B<meta>

=item B<method_constructors>

=back

=head1 BUGS

See L<Moose/BUGS> for details on reporting bugs.

=head1 AUTHOR

Robert Boone

=head1 COPYRIGHT AND LICENSE

Copyright 2007-2009 by Infinity Interactive, Inc.

L<http://www.iinteractive.com>

This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.

=cut