NAME

Dist::Zilla::Plugin::Version::Git::Flowish - Get a version number via git and a flow-inspired structure.

VERSION

version 0.03

SYNOPSIS

# [Version::Git::Flowish]
# master_regexp = ^master$
# release_regexp = ^release-(\d+.\d+\.\d+)$
# tag_regexp = ^(\d.\d+\.\d+)$

DESCRIPTION

This plugin consumes the Dist::Zilla VersionProvider role and gleans a version number from Git using a structure similar to Vincent Driessen's git flow model.

The idea is to facilitate automated systems, such as continuous integration, to divine version numbers from the branching and release strategies used in our repositories.

Note that, by default, the version numbers used as defaults by this plugin are in the form of 0.0.0. This can be changed by manipulating the options shown in the Synopsis.

It works like this:

Environment Variable

The environment variable FLOWISH_VERSION is checked and used if set.

Branch

The current branch is attained via a call to git granch and grepping for the leading *.

git branch --no-color 2> /dev/null

Case: Master Branch

If the current branch is master, then the most recent tag is attained via:

git describe --tags --abbrev=0

You can influence how this date is parsed using the tag_regexp option.

Case: Release Branch

If this isn't the master branch, but it begins with "release-" (configurable via master_regexp) then the version number after the release- will be used.

And Then?

At this point we just give up and return nothing.

CONTRIBUTORS

Mike Eldridge

AUTHOR

Cory G Watson <gphat@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2011 by Infinity Interactive.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.