NAME

Module::MakefilePL::Parse - parse required modules from Makefile.PL

SYNOPSIS

use Module::MakefilePL::Parse;

open $fh, 'Makefile.PL';

$parser = Module::MakefilePL::Parse->new( join("\n", <$fh>) );

$info   = $parser->required;

DESCRIPTION

The purpose of this module is to determine the required modules for older CPAN distributions which do not have META.yml files but use Makefile.PL and ExtUtils::MakeMaker or Module::Install.

Presumably newer style Makefile.PL files which use Module::Install or Module::Build already have META.yml files in their distributions.

Methods

new
$parser = new Modile::MakefilePL::Parse( $script );

Parses a Makefile.PL script and returns an object. Returns undef if there is a problem.

required
$info = $parser->required;

Returns a hash reference to the PREREQ_PM key in the Makefile.PL script.

CAVEATS

This module does evaluate a portion of the code, so there is a security issue. However, it only evaluates the definition of the PREREQ_PM key in calls to WriteMakefile, which should be more difficult to embed malware in.

Do not run this module on untrusted scripts.

SEE ALSO

These other modules will also provide meta-information about CPAN distributions:

Module::CoreList
Module::CPANTS::Generator::Prereq
Module::Info
Module::Dependency
Module::Depends
Module::PrintUsed
Module::ScanDeps

Note that Module::CPANTS::Generator::Prereq is similar to this module, so it's possible that any future work will be merged into that project than on maintaining this module.

AUTHOR

Robert Rothenberg <rrwo at cpan.org>

COPYRIGHT AND LICENSE

Copyright (C) 2004 by Robert Rothenbeg. All Rights Reserved.

The test script Module-MakefilePL-Parse.t contains small snippets (less than a few lines) based on existing Makefile.PL files from modules on CPAN. Those modules are acknowledged in the snippets, and the copyrights of those modules belong to their respective authors.

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.4 or, at your option, any later version of Perl 5 you may have available.