use v6-alpha;
use Test;
plan 18;
unless try({ eval("1", :lang<perl5>) }) {
skip_rest;
exit;
}
die unless
eval(q/
package My::Array;
use strict;
sub new {
my ($class, $ref) = @_;
bless \$ref, $class;
}
sub array {
my $self = shift;
return $$self;
}
sub my_elems {
my $self = shift;
return scalar(@{$$self});
}
sub my_exists {
my ($self, $idx) = @_;
return exists $$self->[$idx];
}
sub fetch {
my ($self, $idx) = @_;
return $$self->[$idx];
}
sub store {
my ($self, $idx, $val) = @_;
$$self->[$idx] = $val;
}
sub push {
my ($self, $val) = @_;
push @{$$self}, $val;
}
1;
/, :lang<perl5>);
my $p5ar = eval('sub { My::Array->new($_[0]) }', :lang<perl5>);
my @array = (5,6,7,8);
my $p5array = $p5ar(VAR @array);
my $retarray = $p5array.array;
is($p5array.my_elems, @array.elems, 'elems');
is($p5array.my_exists(1), @array.exists(1), 'exists');
is($p5array.my_exists(10), @array.exists(10), 'nonexists fail');
is($p5array.fetch(3)+0, @array[3], 'fetch');
my $match = 0;
lives_ok {
$match = ?($retarray.[3] ~~ @array[3]);
}, 'can retro fetch';
ok $match, 'retro fetch';
is(eval(q{$retarray.elems}), @array.elems, 'retro elems');
is($retarray.exists(1), @array.exists(1), 'retro exists');
is($retarray.exists(10), @array.exists(10), 'retro nonexists' );
ok(($p5array.push(9)), 'can push');
is(0+$p5array.fetch(4), 9, 'push result via obj', :todo<bug>);
is(@array[4], 9, 'push result via array', :todo<feature>);
flunk("push(9) non-terminates", :todo<bug>);
#$retarray.push(9); # this will loop
is(0+$p5array.fetch(5), 9, 'retro push result', :todo<bug>);
is(@array[5], 9, 'retro push result', :todo<bug>);
ok($p5array.store(0,3), 'can store');
is(@array[0], 3, 'store result');
is(0+$p5array.fetch(0), 3, 'store result');
# TODO: pop, shift, unshift, splice, delete