Array-Unique
view release on metacpan or search on metacpan
lib/Array/Unique/Std.pm view on Meta::CPAN
}
}
@$self = @temp;
}
sub STORESIZE {
my $self = shift;
my $size = shift;
if ($self->FETCHSIZE > $size) {
$self->SUPER::STORESIZE($size);
}
}
sub find {
my $self = shift;
my $value = shift;
my @rep = grep {$value eq $self->FETCH($_)} (0 .. $self->FETCHSIZE-1);
if (@rep) {
return shift @rep;
} else {
lib/Array/Unique/Std.pm view on Meta::CPAN
my $self = shift;
my $index = shift;
my $value = shift;
# print "STORE PARAM: @_\n";
my $existing = $self->find($value); # O(n)
if (defined $existing) {
# if ($existing <= $index) {
## nothing to do
# } else {
$self->SUPER::STORE($index, $value); # value in earlier location
$self->SPLICE($existing, 1);
# }
} else {
$self->SUPER::STORE($index, $value); # new value
}
$self->clean;
}
sub PUSH {
my $self = shift;
$self->SUPER::PUSH(@_);
$self->clean;
}
sub UNSHIFT {
my $self = shift;
$self->SUPER::UNSHIFT(@_);
$self->clean;
}
sub SPLICE {
my $self = shift;
my @splice = $self->SUPER::SPLICE(@_);
$self->clean;
return @splice;
}
1;
__END__
=pod
See documentation in Array::Unique
( run in 0.256 second using v1.01-cache-2.11-cpan-a9ef4e587e4 )