Scroll to navigation

Module::Extract::VERSION(3pm) User Contributed Perl Documentation Module::Extract::VERSION(3pm)

NAME

Module::Extract::VERSION - Extract a module version safely

SYNOPSIS

        use Module::Extract::VERSION;
        my $version   # just the version
                = Module::Extract::VERSION->parse_version_safely( $file );
        my @version_info # extra info
                = Module::Extract::VERSION->parse_version_safely( $file );

DESCRIPTION

This module lets you pull out of module source code the version number for the module. It assumes that there is only one $VERSION in the file and the entire $VERSION statement is on the same line.

Class methods

$class->parse_version_safely( FILE );
Given a module file, return the module version. This works just like "mldistwatch" in PAUSE. It looks for the single line that has the $VERSION statement, extracts it, evals it in a Safe compartment, and returns the result.

In scalar context, it returns just the version as a string. In list context, it returns the list of:

        sigil
        fully-qualified variable name
        version value
        file name
        line number of $VERSION
    

SOURCE AVAILABILITY

This code is in Github:

        https://github.com/briandfoy/module-extract-version.git

AUTHOR

brian d foy, "<briandfoy@pobox.com>"

I stole the some of this code from "mldistwatch" in the PAUSE code by Andreas König, but I've moved most of it around.

Andrey Starodubtsev added code to handle the v5.12 and v5.14 "package" syntax.

COPYRIGHT AND LICENSE

Copyright © 2008-2024, brian d foy "<briandfoy@pobox.com>". All rights reserved.

You may redistribute this under the Artistic License 2.0.

2024-02-17 perl v5.38.2