#!/bin/bash

# Creates and updates the package_version information used by configure.ac
# (or other makefiles).  When run inside a git repository it will use the
# version information that can be queried from it unless AUTO_UPDATE is set
# to 'no'.  If no version is currently known it will be set to 'unknown'.
#
# If called with the argument 'release', the PACKAGE_VERSION will be updated
# even if AUTO_UPDATE=no, but the value of AUTO_UPDATE shall be preserved.
# This is used to force a version update whenever `make dist` is run.
#
# The exit status is 1 if package_version is not modified, else 0 is returned.
#
# This script should NOT be included in distributed tarballs, because if a
# parent directory contains a git repository we do not want to accidentally
# retrieve the version information from it instead.  Tarballs should ship
# with only the package_version file.
#
# Ron <ron@debian.org>, 2012.

SRCDIR=$(dirname $0)

if [ -e "$SRCDIR/package_version" ]; then
    . "$SRCDIR/package_version"
fi

if [ "$AUTO_UPDATE" = no ]; then
    [ "$1" = release ] || exit 1
else
    AUTO_UPDATE=yes
fi

# We run `git status` before describe here to ensure that we don't get a false
# -dirty from files that have been touched but are not actually altered in the
# working dir.
GIT_VERSION=$(cd "$SRCDIR" && git status > /dev/null 2>&1 \
                           && git describe --tags --match 'v*' --dirty 2> /dev/null)
GIT_VERSION=${GIT_VERSION#v}

if [ -n "$GIT_VERSION" ]; then

    [ "$GIT_VERSION" != "$PACKAGE_VERSION" ] || exit 1
    PACKAGE_VERSION="$GIT_VERSION"

elif [ -z "$PACKAGE_VERSION" ]; then
    # No current package_version and no git ...
    # We really shouldn't ever get here, because this script should only be
    # included in the git repository, and should usually be export-ignored.
    PACKAGE_VERSION="unknown"
else
    exit 1
fi

cat > "$SRCDIR/package_version" <<-EOF
	# Automatically generated by update_version.
	# This file may be sourced into a shell script or makefile.

	# Set this to 'no' if you do not wish the version information
	# to be checked and updated for every build.  Most people will
	# never want to change this, it is an option for developers
	# making frequent changes that they know will not be released.
	AUTO_UPDATE=$AUTO_UPDATE

	PACKAGE_VERSION="$PACKAGE_VERSION"
EOF