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 124 125 126 127 128 129 130 131 132 133 134
|
# ABSTRACT: Specifies a distribution by author and archive
package Pinto::Target::Distribution;
use Moose;
use MooseX::MarkAsMethods ( autoclean => 1 );
use MooseX::Types::Moose qw(ArrayRef Str);
use Pinto::Types qw(AuthorID);
use Pinto::Util qw(throw author_dir);
use overload ( '""' => 'to_string' );
#------------------------------------------------------------------------------
our $VERSION = '0.14'; # VERSION
#------------------------------------------------------------------------------
has author => (
is => 'ro',
isa => AuthorID,
coerce => 1,
required => 1,
);
has archive => (
is => 'ro',
isa => Str,
required => 1,
);
has subdirs => (
is => 'ro',
isa => ArrayRef[Str],
default => sub { [] },
);
#------------------------------------------------------------------------------
around BUILDARGS => sub {
my $orig = shift;
my $class = shift;
my @args = @_;
if ( @args == 1 and not ref $args[0] ) {
my @path_parts = split m{/+}x, $args[0];
my $author = shift @path_parts; # First element
my $archive = pop @path_parts; # Last element
my $subdirs = [@path_parts]; # Everything else
throw "Invalid distribution target: $args[0]"
if not( $author and $archive );
@args = ( author => $author, subdirs => $subdirs, archive => $archive );
}
return $class->$orig(@args);
};
#------------------------------------------------------------------------------
sub path {
my ($self) = @_;
my $author_dir = author_dir($self->author);
my @subdirs = @{ $self->subdirs };
my $archive = $self->archive;
return join '/', $author_dir, @subdirs, $archive;
}
#------------------------------------------------------------------------------
sub to_string {
my ($self) = @_;
my $author = $self->author;
my @subdirs = @{ $self->subdirs };
my $archive = $self->archive;
return join '/', $author, @subdirs, $archive;
}
#------------------------------------------------------------------------------
__PACKAGE__->meta->make_immutable;
#------------------------------------------------------------------------------
1;
__END__
=pod
=encoding UTF-8
=for :stopwords Jeffrey Ryan Thalhammer
=head1 NAME
Pinto::Target::Distribution - Specifies a distribution by author and archive
=head1 VERSION
version 0.14
=head1 METHODS
=head2 path()
Returns the canonical string form of this DistributionSpec, which is suitable
for constructing a URI.
=head2 to_string
Serializes this Target to its string form. This method is called whenever the
Target is evaluated in string context.
=head1 AUTHOR
Jeffrey Ryan Thalhammer <jeff@stratopan.com>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Jeffrey Ryan Thalhammer.
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
|