X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMoose%2FMeta%2FMethod%2FAccessor%2FNative%2FArray%2Finsert.pm;h=b7d1afac9af410dd512a6b1d3fe8ac1c232f4138;hb=bb8ef15197850184a45acade3e8f387fd6b63829;hp=1afdb8c73c87ce096c953311454de6a001fce4ad;hpb=f4b86ac0e1fd7ff8a180f2f8332821170db5371e;p=gitmo%2FMoose.git diff --git a/lib/Moose/Meta/Method/Accessor/Native/Array/insert.pm b/lib/Moose/Meta/Method/Accessor/Native/Array/insert.pm index 1afdb8c..b7d1afa 100644 --- a/lib/Moose/Meta/Method/Accessor/Native/Array/insert.pm +++ b/lib/Moose/Meta/Method/Accessor/Native/Array/insert.pm @@ -3,7 +3,7 @@ package Moose::Meta::Method::Accessor::Native::Array::insert; use strict; use warnings; -our $VERSION = '1.16'; +our $VERSION = '1.9900'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; @@ -14,6 +14,7 @@ with 'Moose::Meta::Method::Accessor::Native::Array::Writer' => { qw( _minimum_arguments _maximum_arguments + _inline_coerce_new_values _new_members _inline_optimized_set_new_value _return_value @@ -28,24 +29,42 @@ sub _maximum_arguments { 2 } sub _adds_members { 1 } sub _potential_value { - my ( $self, $slot_access ) = @_; - - return - "( do { my \@potential = \@{ $slot_access }; splice \@potential, \$_[0], 0, \$_[1]; \\\@potential } )"; + my $self = shift; + my ($slot_access) = @_; + + return '(do { ' + . 'my @potential = @{ (' . $slot_access . ') }; ' + . 'splice @potential, $_[0], 0, $_[1]; ' + . '\@potential; ' + . '})'; } +# We need to override this because while @_ can be written to, we cannot write +# directly to $_[1]. +sub _inline_coerce_new_values { + my $self = shift; + + return unless $self->associated_attribute->should_coerce; + + return unless $self->_tc_member_type_can_coerce; + + return '@_ = ($_[0], $member_tc_obj->coerce($_[1]));'; +}; + sub _new_members { '$_[1]' } sub _inline_optimized_set_new_value { - my ( $self, $inv, $new, $slot_access ) = @_; + my $self = shift; + my ($inv, $new, $slot_access) = @_; - return "splice \@{ $slot_access }, \$_[0], 0, \$_[1];"; + return 'splice @{ (' . $slot_access . ') }, $_[0], 0, $_[1];'; } sub _return_value { - my ( $self, $slot_access ) = @_; + my $self = shift; + my ($slot_access) = @_; - return "return ${slot_access}->[ \$_[0] ];"; + return $slot_access . '->[ $_[0] ]'; } no Moose::Role;