package Moose::Autobox::Array;
use Moose::Role 'with';
-use Perl6::Junction;
-use autobox;
+use Moose::Autobox;
-our $VERSION = '0.01';
+use Syntax::Keyword::Junction::All ();
+use Syntax::Keyword::Junction::Any ();
+use Syntax::Keyword::Junction::None ();
+use Syntax::Keyword::Junction::One ();
+
+our $VERSION = '0.12';
with 'Moose::Autobox::Ref',
'Moose::Autobox::List',
sub shift {
my ($array) = @_;
CORE::shift @$array;
-}
+}
+
+sub slice {
+ my ($array, $indicies) = @_;
+ [ @{$array}[ @{$indicies} ] ];
+}
# NOTE:
# sprintf args need to be reversed,
[ CORE::sort { $sub->($a, $b) } @$array ];
}
+sub first {
+ $_[0]->[0];
+}
+
+sub last {
+ $_[0]->[$#{$_[0]}];
+}
+
## ::Indexed implementation
sub at {
$array->keys->map(sub { [ $_, $array->[$_] ] });
}
+sub each {
+ my ($array, $sub) = @_;
+ for my $i (0 .. $#$array) {
+ $sub->($i, $array->[ $i ]);
+ }
+}
+
+sub each_key {
+ my ($array, $sub) = @_;
+ $sub->($_) for (0 .. $#$array);
+}
+
+sub each_value {
+ my ($array, $sub) = @_;
+ $sub->($_) for @$array;
+}
+
+sub each_n_values {
+ my ($array, $n, $sub) = @_;
+ my $it = List::MoreUtils::natatime($n, @$array);
+
+ while (my @vals = $it->()) {
+ $sub->(@vals);
+ }
+
+ return;
+}
+
+# end indexed
+
+sub flatten {
+ @{$_[0]}
+}
+
+sub _flatten_deep {
+ my @array = @_;
+ my $depth = CORE::pop @array;
+ --$depth if (defined($depth));
+
+ CORE::map {
+ (ref eq 'ARRAY')
+ ? (defined($depth) && $depth == -1) ? $_ : _flatten_deep( @$_, $depth )
+ : $_
+ } @array;
+
+}
+
+sub flatten_deep {
+ my ($array, $depth) = @_;
+ [ _flatten_deep(@$array, $depth) ];
+}
+
## Junctions
sub all {
my ($array) = @_;
- return Perl6::Junction::All->all(@$array);
+ return Syntax::Keyword::Junction::All->new(@$array);
}
sub any {
my ($array) = @_;
- return Perl6::Junction::Any->any(@$array);
+ return Syntax::Keyword::Junction::Any->new(@$array);
}
sub none {
my ($array) = @_;
- return Perl6::Junction::None->none(@$array);
+ return Syntax::Keyword::Junction::None->new(@$array);
}
sub one {
my ($array) = @_;
- return Perl6::Junction::One->one(@$array);
+ return Syntax::Keyword::Junction::One->new(@$array);
}
+## Print
+
+sub print { CORE::print @{$_[0]} }
+sub say { CORE::print @{$_[0]}, "\n" }
+
+no Moose::Role;
+
1;
__END__
=head1 SYNOPOSIS
use Moose::Autobox;
- use autobox;
[ 1..5 ]->isa('ARRAY'); # true
[ a..z ]->does('Moose::Autobox::Array'); # true
print "Squares: " . [ 1 .. 10 ]->map(sub { $_ * $_ })->join(', ');
print [ 1, 'number' ]->sprintf('%d is the loneliest %s');
+
+ print ([ 1 .. 5 ]->any == 3) ? 'true' : 'false'; # prints 'true'
=head1 DESCRIPTION
=item B<sprintf ($format_string)>
+=item B<slice (@indices)>
+
+=item B<flatten>
+
+=item B<flatten_deep ($depth)>
+
+=item B<first>
+
+=item B<last>
+
=back
=head2 Indexed implementation
=item B<kv>
+=item B<each>
+
+=item B<each_key>
+
+=item B<each_value>
+
+=item B<each_n_values ($n, $callback)>
+
=back
=head2 List implementation
=item B<grep (\&block)>
+Note that, in both the above, $_ is in scope within the code block, as well as
+being passed as $_[0]. As per CORE::map and CORE::grep, $_ is an alias to
+the list value, so can be used to to modify the list, viz:
+
+ use Moose::Autobox;
+
+ my $foo = [1, 2, 3];
+ $foo->map( sub {$_++} );
+ print $foo->dump;
+
+yields
+
+ $VAR1 = [
+ 2,
+ 3,
+ 4
+ ];
+
=item B<reverse>
=item B<sort (?\&block)>
=item B<meta>
+=item B<print>
+
+=item B<say>
+
=back
=head1 BUGS
=head1 COPYRIGHT AND LICENSE
-Copyright 2006 by Infinity Interactive, Inc.
+Copyright 2006-2008 by Infinity Interactive, Inc.
L<http://www.iinteractive.com>
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
-=cut
\ No newline at end of file
+=cut