1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
use 5.008; # utf8
use strict;
use warnings;
use utf8;
package Path::IsDev::Role::Matcher::Child::Exists::Any::Dir;
our $VERSION = '1.001003';
# ABSTRACT: Match if a path contains one of any of a list of directories
our $AUTHORITY = 'cpan:KENTNL'; # AUTHORITY
use Role::Tiny qw( with );
with 'Path::IsDev::Role::Matcher::Child::Exists::Any';
sub child_exists_dir {
my ( $self, $result_object, $child ) = @_;
my $child_path = $result_object->path->child($child);
my $ctx = { 'child_name' => $child, child_path => "$child_path", tests => [] };
my $tests = $ctx->{tests};
if ( -d $child_path ) {
push @{$tests}, { 'child_path_isdir?' => 1 };
$result_object->add_reason( $self, 1, "$child_path is a dir", $ctx );
return 1;
}
push @{$tests}, { 'child_path_isdir?' => 0 };
$result_object->add_reason( $self, 0, "$child_path is not a dir", $ctx );
return;
}
sub child_exists_any_dir {
my ( $self, $result_object, @children ) = @_;
for my $child (@children) {
return 1 if $self->child_exists( $result_object, $child ) and $self->child_exists_dir( $result_object, $child );
}
return;
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Path::IsDev::Role::Matcher::Child::Exists::Any::Dir - Match if a path contains one of any of a list of directories
=head1 VERSION
version 1.001003
=head1 METHODS
=head2 C<child_exists_dir>
$class->child_exists_dir( $result_object, $childname );
Return match if C<$childname> exists as a directory child of C<< $result_object->path >>.
=head2 C<child_exists_any_dir>
$class->child_exists_any_dir( $result_object, @childnames );
Return match if any of C<@childnames> exist under C<< $result_object->path >> and are directories.
=begin MetaPOD::JSON v1.1.0
{
"namespace":"Path::IsDev::Role::Matcher::Child::Exists::Any::Dir",
"interface":"role",
"does":"Path::IsDev::Role::Matcher::Child::Exists::Any"
}
=end MetaPOD::JSON
=head1 AUTHOR
Kent Fredric <kentnl@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2017 by Kent Fredric <kentfredric@gmail.com>.
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
|