Why not adopt me?
NAME
Array::Splice - Splice aliases into arrays
SYNOPSIS
use Array::Splice qw( splice_aliases push_aliases );
my @a = qw( foo bar );
my $x = 'baz';
splice_aliases @a,1,0,$x;
$x = 'zoop'; # Changes $a[1]
print "@a\n"; # foo zoop bar
sub wrapped_foo {
push_aliases my @args => @_; # Copy @_
some_wrapper(sub { foo @args }); # &foo called with orginal arguments
}
DESCRIPTION
This module does splicing of arrays for real. That is does exactly the same as the builtin splice
function except that the inserted elements are existing scalar values not copies of them.
One possible use of this is to copy the @_ array but I'm sure that there are others.
This module does not export anything by default.
EXPORTS
- splice_aliases ARRAY,OFFSET,LENGTH,LIST
-
Exactly like the builtin
splice
except that the scalar values that are the elements of LIST get spliced directly into ARRAY rather being copied. Unlike the builtinsplice
OFFSET and LENGTH are not optional since if you are not giving LIST thensplice_aliases
is just exactly the same assplice
.This is unlikely to be useful for tied arrays but for the sake of uniformity, splice_aliases() tries to call a SPLICE_ALIASES() method on the object to which the array is tied.
- push_alaises ARRAY, LIST
-
A wrapper for
splice_aliases
that emulates the builtinpush
except that LIST gets spliced directly into ARRAY rather being copied. - unshift_alaises ARRAY, LIST
-
A wrapper for
splice_aliases
that emulates the builtinunshift
except that LIST gets spliced directly into ARRAY rather being copied.
AUTHOR
Brian McCauley, <nobull@cpan.org<gt>