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
|
package Perl::PrereqScanner::Scanner;
BEGIN {
$Perl::PrereqScanner::Scanner::VERSION = '0.101890';
}
use Moose::Role;
# ABSTRACT: something that scans for prereqs in a Perl document
requires 'scan_for_prereqs';
# DO NOT RELY ON THIS EXISTING OUTSIDE OF CORE!
# THIS MIGHT GO AWAY WITHOUT NOTICE!
# -- rjbs, 2010-04-06
sub _q_contents {
my ($self, $token) = @_;
my @contents = $token->isa('PPI::Token::QuoteLike::Words')
? ( $token->literal )
: ( $token->string );
return @contents;
}
1;
__END__
=pod
=head1 NAME
Perl::PrereqScanner::Scanner - something that scans for prereqs in a Perl document
=head1 VERSION
version 0.101890
=head1 DESCRIPTION
This is a role to be composed into classes that will act as scanners plugged
into a Perl::PrereqScanner object.
These classes must provide a C<scan_for_prereqs> method, which will be called
like this:
$scanner->scan_for_prereqs($ppi_doc, $version_requirements);
The scanner should alter alter the L<Version::Requirements> object to reflect
its findings about the PPI document.
=head1 AUTHORS
Jerome Quelin
Ricardo Signes <rjbs@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2009 by Jerome Quelin.
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
|