package Moose::Autobox::Array;
use Moose::Role 'with';
-use autobox;
+use Perl6::Junction;
+use Moose::Autobox;
-our $VERSION = '0.01';
+our $VERSION = '0.03';
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,
$array->keys->map(sub { [ $_, $array->[$_] ] });
}
+## Junctions
+
+sub all {
+ my ($array) = @_;
+ return Perl6::Junction::All->all(@$array);
+}
+
+sub any {
+ my ($array) = @_;
+ return Perl6::Junction::Any->any(@$array);
+}
+
+sub none {
+ my ($array) = @_;
+ return Perl6::Junction::None->none(@$array);
+}
+
+sub one {
+ my ($array) = @_;
+ return Perl6::Junction::One->one(@$array);
+}
+
+## Print
+
+sub print { CORE::print @{$_[0]} }
+sub say { CORE::print @{$_[0]}, "\n" }
+
1;
__END__
=head1 SYNOPOSIS
use Moose::Autobox;
- use autobox;
+
+ [ 1..5 ]->isa('ARRAY'); # true
+ [ a..z ]->does('Moose::Autobox::Array'); # true
+ [ 0..2 ]->does('Moose::Autobox::List'); # 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
=over 4
-=item B<meta>
-
=item B<pop>
-=item B<push>
+=item B<push ($value)>
=item B<shift>
-=item B<unshift>
+=item B<unshift ($value)>
+
+=item B<delete ($index)>
-=item B<delete>
+=item B<sprintf ($format_string)>
-=item B<sprintf>
+=item B<slice (@indices)>
=back
-=head2 Moose::Autobox::Indexed implementation
+=head2 Indexed implementation
=over 4
-=item B<at>
+=item B<at ($index)>
-=item B<put>
+=item B<put ($index, $value)>
-=item B<exists>
+=item B<exists ($index)>
=item B<keys>
-=item B<kv>
-
=item B<values>
+=item B<kv>
+
=back
-=head2 Moose::Autobox::List implementation
+=head2 List implementation
=over 4
=item B<tail>
-=item B<join>
+=item B<join (?$seperator)>
=item B<length>
-=item B<map>
+=item B<map (\&block)>
-=item B<grep>
+=item B<grep (\&block)>
=item B<reverse>
-=item B<sort>
+=item B<sort (?\&block)>
+
+=back
+
+=head2 Junctions
+
+=over 4
+
+=item B<all>
+
+=item B<any>
+
+=item B<none>
+
+=item B<one>
+
+=back
+
+=over 4
+
+=item B<meta>
+
+=item B<print>
+
+=item B<say>
=back
=head1 COPYRIGHT AND LICENSE
-Copyright 2006 by Infinity Interactive, Inc.
+Copyright 2006-2007 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