package Dist::Zilla::Role::FileFinder 6.031; # ABSTRACT: something that finds files within the distribution use Moose::Role; with 'Dist::Zilla::Role::Plugin'; use Dist::Zilla::Pragmas; use namespace::autoclean; #pod =head1 DESCRIPTION #pod #pod A FileFinder plugin locates files within the distribution. This role exists so #pod that sets of files can be easily described in one configuration section and #pod then used by one or more other plugin. #pod #pod Plugins implementing this role must provide a C method which will #pod be called with no arguments and must return an arrayref of files. (This #pod arrayref should not be re-used, as it may be altered once returned.) #pod #pod For example, imagine a simple glob-like FileFinder that expects configuration #pod like this: #pod #pod [Glob / RootModules] #pod glob = *.pm #pod #pod This sets up a FileFinder named "RootModules" which will contain all F #pod files in the root directory. #pod #pod Another plugin that knows how to use FileFinder plugins might be configured #pod like this: #pod #pod [ModuleRelocator] #pod finder = RootModules #pod relocate_to = attic #pod #pod Finders may operate on any rules they like, checking file size, content, name, #pod or other properties. They should re-perform their "finding" on each call to #pod C as the files in the distribution may have changed. #pod #pod =cut requires 'find_files'; 1; __END__ =pod =encoding UTF-8 =head1 NAME Dist::Zilla::Role::FileFinder - something that finds files within the distribution =head1 VERSION version 6.031 =head1 DESCRIPTION A FileFinder plugin locates files within the distribution. This role exists so that sets of files can be easily described in one configuration section and then used by one or more other plugin. Plugins implementing this role must provide a C method which will be called with no arguments and must return an arrayref of files. (This arrayref should not be re-used, as it may be altered once returned.) For example, imagine a simple glob-like FileFinder that expects configuration like this: [Glob / RootModules] glob = *.pm This sets up a FileFinder named "RootModules" which will contain all F files in the root directory. Another plugin that knows how to use FileFinder plugins might be configured like this: [ModuleRelocator] finder = RootModules relocate_to = attic Finders may operate on any rules they like, checking file size, content, name, or other properties. They should re-perform their "finding" on each call to C as the files in the distribution may have changed. =head1 PERL VERSION This module should work on any version of perl still receiving updates from the Perl 5 Porters. This means it should work on any version of perl released in the last two to three years. (That is, if the most recently released version is v5.40, then this module should work on both v5.40 and v5.38.) Although it may work on older versions of perl, no guarantee is made that the minimum required version will not be increased. The version may be increased for any reason, and there is no promise that patches will be accepted to lower the minimum required perl. =head1 AUTHOR Ricardo SIGNES 😏 =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2023 by Ricardo SIGNES. 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