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-2025, brian d foy <briandfoy@pobox.com>. All rights reserved.

You may redistribute this under the Artistic License 2.0.