Server : Apache/2.4.43 (Win64) OpenSSL/1.1.1g PHP/7.4.6 System : Windows NT USER-PC 6.1 build 7601 (Windows 7 Professional Edition Service Pack 1) AMD64 User : User ( 0) PHP Version : 7.4.6 Disable Function : NONE Directory : C:/xampp/perl/vendor/lib/Moose/Meta/Method/Accessor/Native/Array/ |
package Moose::Meta::Method::Accessor::Native::Array::insert; BEGIN { $Moose::Meta::Method::Accessor::Native::Array::insert::AUTHORITY = 'cpan:STEVAN'; } { $Moose::Meta::Method::Accessor::Native::Array::insert::VERSION = '2.0604'; } use strict; use warnings; use Moose::Role; with 'Moose::Meta::Method::Accessor::Native::Array::Writer' => { -excludes => [ qw( _minimum_arguments _maximum_arguments _inline_coerce_new_values _new_members _inline_optimized_set_new_value _return_value ) ] }; sub _minimum_arguments { 2 } sub _maximum_arguments { 2 } sub _adds_members { 1 } sub _potential_value { 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_coercion->($_[1]));'; }; sub _new_members { '$_[1]' } sub _inline_optimized_set_new_value { my $self = shift; my ($inv, $new, $slot_access) = @_; return 'splice @{ (' . $slot_access . ') }, $_[0], 0, $_[1];'; } sub _return_value { my $self = shift; my ($slot_access) = @_; return $slot_access . '->[ $_[0] ]'; } no Moose::Role; 1;