NAME
    List::Flatten::Recursive - List::Flatten with recursion

VERSION
    version 0.103420

SYNOPSIS
        use List::Flatten::Recursive qw( flat );

        my $crazy_listref = [ 1, [ 2, 3 ], [ [ [ 4 ] ] ] ];
        flat($crazy_listref); # Yields (1,2,3,4)
        push @$crazy_listref, $crazy_listref; # Now it contains itself!
        flat($crazy_listref); # Still yields (1,2,3,4)
        flat([ $crazy_listref ]); # Ditto.

        # But don't do this.
        flat(@$crazy_listref); # Will not yield the same as above.

DESCRIPTION
    If you think of nested lists as a tree structure (an in Lisp, for
    example), then "flat" basically returns all the leaf nodes from an
    inorder tree traversal, and leaves out the internal nodes (i.e.
    listrefs). If the nested list is a DAG instead of just a tree, it should
    still flatten correctly (based on my own definition of correctness, of
    course; see also t/flatten-dag.t).

    If the nested list is self-referential, then any cycles will be broken
    by replacing ancestor references with empty lists. However, the only
    behavior you should rely on when flattening a self-referential data
    structure is that infinite recursion should not occur, and each non-list
    element in the data structure should appear at least once in the output.

METHODS
  flat
    This method flattens a list (or listref) recursively. It takes a list
    that may contain other sublists, and replaces those sublists with their
    contents, recursively, until the list no longer contains any sublists.

    "flat" makes a best effort to break circular references (that is, lists
    that contain references to themselves), and should never enter an
    infinite recursion.

    This method is exported by default.

  flatten_to_listref
    Same as "flat", but returns a single reference to the resulting list.

    This method is exported only by request. To use this method, put the
    following at the top of your program:

        use List::Flatten::Recursive qw( flatten_to_listref );

BUGS AND LIMITATIONS
  Self-referential lists should be flattened by reference
    If you are going to flatten a list which may contain references to
    itself, you should pass a reference to that list to "flat", or else
    things will not work the way you expect. You will end up with an extra
    trip around the circle before the circular reference is caught.

  "flat" always returns a list
    Even if you call "flat" on a single scalar, it will still return a list
    with one element in it. If called in scalar context, it will return the
    length of that list. "flatten_to_listref" would return a reference to a
    list with one element. There is no case where the original scalar would
    be returned directly. This is by design. If you think this is wrong,
    email me and tell me why.

    Please report any bugs or feature requests to
    "rct+perlbug@thompsonclan.org". If you find a case where this module
    returns what you feel is a wrong result, please send an example that
    will cause it to do so, along with the actual and expected results.

SEE ALSO
    * List::Flatten The non-recursive insipiration for this module.

DISCLAIMER OF WARRANTY
    BECAUSE THIS SOFTWARE IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
    FOR THE SOFTWARE, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
    OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
    PROVIDE THE SOFTWARE "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER
    EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
    WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
    ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE SOFTWARE IS WITH
    YOU. SHOULD THE SOFTWARE PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL
    NECESSARY SERVICING, REPAIR, OR CORRECTION.

    IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
    WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
    REDISTRIBUTE THE SOFTWARE AS PERMITTED BY THE ABOVE LICENCE, BE LIABLE
    TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL, OR
    CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
    SOFTWARE (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
    RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
    FAILURE OF THE SOFTWARE TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
    SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
    DAMAGES.

AUTHOR
    Ryan C. Thompson <rct@thompsonclan.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2010 by Ryan C. Thompson.

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