Beginning of dzilization
[gitmo/Moose.git] / lib / Moose / Meta / Method / Accessor / Native / Array / set.pm
1 package Moose::Meta::Method::Accessor::Native::Array::set;
2
3 use strict;
4 use warnings;
5
6 our $AUTHORITY = 'cpan:STEVAN';
7
8 use Moose::Role;
9
10 with 'Moose::Meta::Method::Accessor::Native::Array::Writer' => {
11     -excludes => [
12         qw(
13             _minimum_arguments
14             _maximum_arguments
15             _inline_check_arguments
16             _inline_coerce_new_values
17             _new_members
18             _inline_optimized_set_new_value
19             _return_value
20             )
21     ]
22 };
23
24 sub _minimum_arguments { 2 }
25
26 sub _maximum_arguments { 2 }
27
28 sub _inline_check_arguments {
29     my $self = shift;
30
31     return $self->_inline_check_var_is_valid_index('$_[0]');
32 }
33
34 sub _adds_members { 1 }
35
36 sub _potential_value {
37     my $self = shift;
38     my ($slot_access) = @_;
39
40     return '(do { '
41              . 'my @potential = @{ (' . $slot_access . ') }; '
42              . '$potential[$_[0]] = $_[1]; '
43              . '\@potential; '
44          . '})';
45 }
46
47 # We need to override this because while @_ can be written to, we cannot write
48 # directly to $_[1].
49 sub _inline_coerce_new_values {
50     my $self = shift;
51
52     return unless $self->associated_attribute->should_coerce;
53
54     return unless $self->_tc_member_type_can_coerce;
55
56     return '@_ = ($_[0], $member_tc_obj->coerce($_[1]));';
57 };
58
59 sub _new_members { '$_[1]' }
60
61 sub _inline_optimized_set_new_value {
62     my $self = shift;
63     my ($inv, $new, $slot_access) = @_;
64
65     return $slot_access . '->[$_[0]] = $_[1];';
66 }
67
68 sub _return_value {
69     my $self = shift;
70     my ($slot_access) = @_;
71
72     return $slot_access . '->[$_[0]]';
73 }
74
75 no Moose::Role;
76
77 1;