The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package Data::Perl::Collection::Array::AutoFlatten;
{
  $Data::Perl::Collection::Array::AutoFlatten::VERSION = '0.001005';
}

# ABSTRACT: Like Collection::Array, but flattened.

use parent qw/Data::Perl::Collection::Array/;

use strictures 1;

sub map { shift->SUPER::map(@_)->flatten }

sub grep { shift->SUPER::grep(@_)->flatten }

sub sort { shift->SUPER::sort(@_)->flatten }

sub reverse { shift->SUPER::reverse(@_)->flatten }

sub sort_in_place { shift->SUPER::sort_in_place(@_)->flatten }

sub splice {
  my $self = shift;
  if (wantarray) {
    my ($result) = $self->SUPER::splice(@_); $result->flatten;
  }
  else {
    $self->SUPER::splice(@_);
  }

}

sub shuffle { shift->SUPER::shuffle(@_)->flatten }

sub uniq { shift->SUPER::uniq(@_)->flatten }

1;



=pod

=head1 NAME

Data::Perl::Collection::Array::AutoFlatten - Like Collection::Array, but flattened.

=head1 VERSION

version 0.001005

=head1 SYNOPSIS

  use aliased 'Data::Perl::Collection::Array::AutoFlatten';

  my $array = Array->new(1, 2, 3);

  $array->push(5);

  $array->grep(sub { $_ > 2 })->map(sub { $_ ** 2 }); # fails

=head1 DESCRIPTION

This class wraps Data::Perl::Collection::Array to ensure all methods that could
otherwise return a Collection::Hash or Collection::Array object will instead
return a real perl hash or array. As a result, chaining methods is impossible.

=head1 WRAPPED METHODS

=over 4

=item * B<map($cb)>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=item * B<grep($cb)>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=item * B<reverse>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=item * B<sort($sort_cb))>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=item * B<sort_in_place($sort_cb)>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=item * B<splice($offset, $length, @values)>

In list context, instead of returning a Data::Perl::Collection::Array object, a
real array is returned.

=item * B<shuffle>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=item * B<uniq>

Instead of returning a Data::Perl::Collection::Array object, a real array is
returned.

=back

=head1 SEE ALSO

=over 4

=item * L<Data::Perl>

=item * L<MooX::HandlesVia>

=back

=head1 AUTHOR

Matthew Phillips <mattp@cpan.org>

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2013 by Matthew Phillips <mattp@cpan.org>.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.

=cut


__END__
==pod