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 )