File Coverage

blib/lib/Beam/Runner/Util.pm
Criterion Covered Total %
statement 39 39 100.0
branch 10 12 83.3
condition 1 3 33.3
subroutine 6 6 100.0
pod 2 2 100.0
total 58 62 93.5


line stmt bran cond sub pod time code
1             package Beam::Runner::Util;
2             our $VERSION = '0.014';
3             # ABSTRACT: Utilities for Beam::Runner command classes
4              
5             #pod =head1 SYNOPSIS
6             #pod
7             #pod use Beam::Runner::Util qw( find_container_path );
8             #pod
9             #pod my $path = find_container_path( $container_name );
10             #pod
11             #pod =head1 DESCRIPTION
12             #pod
13             #pod This module has some shared utility functions for creating
14             #pod L classes.
15             #pod
16             #pod =head1 SEE ALSO
17             #pod
18             #pod L, L, L
19             #pod
20             #pod =cut
21              
22 3     3   18 use strict;
  3         6  
  3         71  
23 3     3   14 use warnings;
  3         5  
  3         67  
24 3     3   14 use Exporter 'import';
  3         5  
  3         78  
25 3     3   22 use Path::Tiny qw( path );
  3         6  
  3         1161  
26              
27             our @EXPORT_OK = qw( find_container_path find_containers );
28              
29             # File extensions to try to find, starting with no extension (which is
30             # to say the extension is given by the user's input)
31             our @EXTS = ( "", qw( .yml .yaml .json .xml .pl ) );
32             # A regex to use to remove the container's name
33             my $EXT_RE = qr/(?:@{[ join '|', @EXTS ]})$/;
34              
35             # The "BEAM_PATH" separator value. Windows uses ';' to separate
36             # PATH-like variables, everything else uses ':'
37             our $PATHS_SEP = $^O eq 'MSWin32' ? ';' : ':';
38              
39             #pod =sub find_containers
40             #pod
41             #pod my %container = find_containers();
42             #pod
43             #pod Returns a list of C and C pairs pointing to all the containers
44             #pod in the C paths.
45             #pod
46             #pod =cut
47              
48             sub find_containers {
49 1     1 1 3 my %containers;
50 1         8 for my $dir ( split /:/, $ENV{BEAM_PATH} ) {
51 1         4 my $p = path( $dir );
52 1         35 my $i = $p->iterator( { recurse => 1, follow_symlinks => 1 } );
53 1         31 while ( my $file = $i->() ) {
54 3 50       255 next unless $file->is_file;
55 3 50       33 next unless $file =~ $EXT_RE;
56 3         25 my $name = $file->relative( $p );
57 3         533 $name =~ s/$EXT_RE//;
58 3   33     61 $containers{ $name } ||= $file;
59             }
60             }
61 1         60 return %containers;
62             }
63              
64             #pod =sub find_container_path
65             #pod
66             #pod my $path = find_container_path( $container_name );
67             #pod
68             #pod Find the path to the given container. If the given container is already
69             #pod an absolute path, it is simply returned. Otherwise, the container is
70             #pod searched for in the directories defined by the C environment
71             #pod variable.
72             #pod
73             #pod If the container cannot be found, throws an exception with a user-friendly
74             #pod error message.
75             #pod
76             #pod =cut
77              
78             sub find_container_path {
79 15     15 1 43 my ( $container ) = @_;
80 15         24 my $path;
81 15 100       42 if ( path( $container )->is_file ) {
82 7         264 return path( $container );
83             }
84              
85 8         354 my @dirs = ( "." );
86 8 100       30 if ( $ENV{BEAM_PATH} ) {
87 6         63 push @dirs, split /$PATHS_SEP/, $ENV{BEAM_PATH};
88             }
89              
90 8         18 DIR: for my $dir ( @dirs ) {
91 14         59 my $d = path( $dir );
92 14         281 for my $ext ( @EXTS ) {
93 60         429 my $f = $d->child( $container . $ext );
94 60 100       1494 if ( $f->exists ) {
95 6         94 $path = $f;
96 6         21 last DIR;
97             }
98             }
99             }
100              
101 8 100       62 die sprintf qq{Could not find container "%s" in directories: %s\n},
102             $container, join( $PATHS_SEP, @dirs )
103             unless $path;
104              
105 6         19 return $path;
106             }
107              
108             1;
109              
110             __END__