NAME Complete::File - Completion routines related to files VERSION This document describes version 0.443 of Complete::File (from Perl distribution Complete-File), released on 2021-02-08. DESCRIPTION FUNCTIONS complete_dir Usage: complete_dir(%args) -> array Complete directory from local filesystem (wrapper for complete_dir() that only picks directories). This function is not exported by default, but exportable. Arguments ('*' denotes required arguments): * allow_dot => *bool* (default: 1) If turned off, will not allow "." or ".." in path. This is most useful when combined with "starting_path" option to prevent user going up/outside the starting path. * exclude_leaf => *bool* * filter => *str|code* Only return items matching this filter. Filter can either be a string or a code. For string filter, you can specify a pipe-separated groups of sequences of these characters: f, d, r, w, x. Dash can appear anywhere in the sequence to mean not/negate. An example: "f" means to only show regular files, "-f" means only show non-regular files, "drwx" means to show only directories which are readable, writable, and executable (cd-able). "wf|wd" means writable regular files or writable directories. For code filter, you supply a coderef. The coderef will be called for each item with these arguments: $name. It should return true if it wants the item to be included. * handle_tilde => *bool* (default: 1) * recurse => *bool* * recurse_matching => *str* (default: "level-by-level") * starting_path => *str* (default: ".") * word* => *str* (default: "") Word to complete. Return value: (array) complete_file Usage: complete_file(%args) -> array Complete file and directory from local filesystem. This function is not exported by default, but exportable. Arguments ('*' denotes required arguments): * allow_dot => *bool* (default: 1) If turned off, will not allow "." or ".." in path. This is most useful when combined with "starting_path" option to prevent user going up/outside the starting path. * exclude_dir => *bool* * exclude_leaf => *bool* * file_ext_filter => *re|array[str]* This is also an alternative to specifying full "filter" or "file_regex_filter". You can set this to a regex or a set of extensions to accept. Note that like in "file_regex_filter", directories of any name is also still allowed. * file_regex_filter => *re* Filter shortcut for file regex. This is a shortcut for constructing a filter. So instead of using "filter", you use this option. This will construct a filter of including only directories or regular files, and the file must match a regex pattern. This use-case is common. * filter => *str|code* Only return items matching this filter. Filter can either be a string or a code. For string filter, you can specify a pipe-separated groups of sequences of these characters: f, d, r, w, x. Dash can appear anywhere in the sequence to mean not/negate. An example: "f" means to only show regular files, "-f" means only show non-regular files, "drwx" means to show only directories which are readable, writable, and executable (cd-able). "wf|wd" means writable regular files or writable directories. For code filter, you supply a coderef. The coderef will be called for each item with these arguments: $name. It should return true if it wants the item to be included. * handle_tilde => *bool* (default: 1) * recurse => *bool* * recurse_matching => *str* (default: "level-by-level") * starting_path => *str* (default: ".") * word* => *str* (default: "") Word to complete. Return value: (array) HOMEPAGE Please visit the project's homepage at <https://metacpan.org/release/Complete-File>. SOURCE Source repository is at <https://github.com/perlancar/perl-Complete-File>. BUGS Please report any bugs or feature requests on the bugtracker website <https://github.com/perlancar/perl-Complete-File/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 Other "Complete::*" modules. AUTHOR perlancar <perlancar@cpan.org> COPYRIGHT AND LICENSE This software is copyright (c) 2021, 2019, 2017, 2016, 2015 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.