NAME
    Complete::Path - Complete path

VERSION
    This document describes version 0.251 of Complete::Path (from Perl
    distribution Complete-Path), released on 2021-02-02.

DESCRIPTION
FUNCTIONS
  complete_path
    Usage:

     complete_path(%args) -> array

    Complete path.

    Complete path, for anything path-like. Meant to be used as backend for
    other functions like "Complete::File::complete_file" or
    "Complete::Module::complete_module". Provides features like
    case-insensitive matching, expanding intermediate paths, and case
    mapping.

    Algorithm is to split path into path elements, then list items (using
    the supplied "list_func") and perform filtering (using the supplied
    "filter_func") at every level.

    This function is not exported by default, but exportable.

    Arguments ('*' denotes required arguments):

    *   exclude_dir => *bool*

    *   exclude_leaf => *bool*

    *   filter_func => *code*

        Provide extra filtering. Code will be given path and should return 1
        if the item should be included in the final result or 0 if the item
        should be excluded.

    *   is_dir_func => *code*

        Function to check whether a path is a "dir".

        Optional. You can provide this function to determine if an item is a
        "directory" (so its name can be suffixed with path separator). You
        do not need to do this if you already suffix names of "directories"
        with path separator in "list_func".

        One reason you might want to provide this and not mark "directories"
        in "list_func" is when you want to do extra filtering with
        "filter_func". Sometimes you do not want to suffix the names first
        (example: see "complete_file" in "Complete::File").

    *   list_func* => *code*

        Function to list the content of intermediate "dirs".

        Code will be called with arguments: ($path, $cur_path_elem,
        $is_intermediate). Code should return an arrayref containing list of
        elements. "Directories" can be marked by ending the name with the
        path separator (see "path_sep"). Or, you can also provide an
        "is_dir_func" function that will be consulted after filtering. If an
        item is a "directory" then its name will be suffixed with a path
        separator by "complete_path()".

    *   path_sep => *str* (default: "/")

    *   recurse => *bool*

    *   recurse_matching => *str* (default: "level-by-level")

    *   starting_path* => *str* (default: "")

    *   word* => *str* (default: "")

        Word to complete.

    Return value: (array)

ENVIRONMENT
  COMPLETE_PATH_TRACE => bool
    If set to true, will produce more log statements for debugging.

HOMEPAGE
    Please visit the project's homepage at
    <https://metacpan.org/release/Complete-Path>.

SOURCE
    Source repository is at
    <https://github.com/perlancar/perl-Complete-Path>.

BUGS
    Please report any bugs or feature requests on the bugtracker website
    <https://github.com/perlancar/perl-Complete-Path/issues>

    When submitting a bug or request, please include a test-file or a patch
    to an existing test-file that illustrates the bug or desired feature.

SEE ALSO
    Complete

AUTHOR
    perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2021, 2017, 2016, 2015, 2014 by
    perlancar@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.