1 package CPANPLUS::Dist::Gentoo::Version;
8 CPANPLUS::Dist::Gentoo::Version - Gentoo version object.
16 our $VERSION = '0.12';
20 This class models Gentoo versions as described in L<http://devmanual.gentoo.org/ebuild-writing/file-format/index.html>.
27 '<=>' => \&_spaceship,
31 my $int_rx = qr/[0-9]+/;
32 my $letter_rx = qr/[a-zA-Z]/;
33 my $dotted_num_rx = qr/$int_rx(?:\.$int_rx)*/o;
35 my @suffixes = qw<alpha beta pre rc normal p>;
36 my $suffix_rx = join '|', grep !/^normal$/, @suffixes;
37 $suffix_rx = qr/(?:$suffix_rx)/o;
40 $dotted_num_rx $letter_rx?
41 (?:_$suffix_rx$int_rx?)*
45 my $capturing_version_rx = qr{
46 ($dotted_num_rx) ($letter_rx)?
47 ((?:_$suffix_rx$int_rx?)*)
53 =head2 C<new $vstring>
55 Creates a new L<CPANPLUS::Dist::Gentoo::Version> object from the version string C<$vstring>.
61 $class = ref($class) || $class;
64 if (defined $vstring) {
65 $vstring =~ s/^[._]+//g;
66 $vstring =~ s/[._]+$//g;
68 if ($vstring =~ /^$capturing_version_rx$/o) {
71 version => [ split /\.+/, $1 ],
73 suffixes => [ map /_($suffix_rx)($int_rx)?/go, $3 ],
79 Carp::croak("Couldn't parse version string '$vstring'");
83 Carp::croak('You must specify a version string');
88 @parts = qw<version letter suffixes revision>;
89 eval "sub $_ { \$_[0]->{$_} }" for @parts;
94 Read-only accessor for the C<version> part of the version object.
98 Read-only accessor for the C<letter> part of the version object.
102 Read-only accessor for the C<suffixes> part of the version object.
106 Read-only accessor for the C<revision> part of the version object.
110 my %suffix_grade = do {
112 map { $_ => ++$i } @suffixes;
116 my ($v1, $v2, $r) = @_;
118 unless (Scalar::Util::blessed($v2) and $v2->isa(__PACKAGE__)) {
122 ($v1, $v2) = ($v2, $v1) if $r;
125 my @a = @{ $v1->version };
126 my @b = @{ $v2->version };
139 if ($x =~ /^0/ or $y =~ /^0/) {
153 my ($l1, $l2) = map { defined() ? ord : 0 } map $_->letter, $v1, $v2;
160 my @a = @{ $v1->suffixes };
161 my @b = @{ $v2->suffixes };
164 my $x = $suffix_grade{ shift(@a) || 'normal' };
165 my $y = $suffix_grade{ shift(@b) || 'normal' };
177 my ($r1, $r2) = map { defined() ? $_ : 0 } map $_->revision, $v1, $v2;
189 my ($version, $letter, $suffixes, $revision) = map $v->$_, @parts;
190 my @suffixes = @$suffixes;
192 $version = join '.', @$version;
193 $version .= $letter if defined $letter;
194 while (my @suffix = splice @suffixes, 0, 2) {
197 $version .= "_$s" . (defined $n ? $n : '');
199 $version .= "-r$revision" if defined $revision;
206 This class provides overloaded methods for numerical comparison and stringification.
210 L<CPANPLUS::Dist::Gentoo>.
214 Vincent Pit, C<< <perl at profvince.com> >>, L<http://www.profvince.com>.
216 You can contact me by mail or on C<irc.perl.org> (vincent).
220 Please report any bugs or feature requests to C<bug-cpanplus-dist-gentoo at rt.cpan.org>, or through the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=CPANPLUS-Dist-Gentoo>.
221 I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
225 You can find documentation for this module with the perldoc command.
227 perldoc CPANPLUS::Dist::Gentoo
229 =head1 COPYRIGHT & LICENSE
231 Copyright 2009,2010,2011,2012 Vincent Pit, all rights reserved.
233 This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
237 1; # End of CPANPLUS::Dist::Gentoo::Version