#!/bin/bash
# sfsnapshotgit - Snapshot script for Git repository
# Original author: Thomas Guyot-Sionnest <tguyot@gmail.com>
#
# Given an optional branch name (master by default), this script creates
# a snapshot from the tip of the branch and move it to ~/staging/.
# The repository, origin and destination directory can be overridden
# with environment variable (see below)

# Handle command errors (-e) and coder sleep deprivation issues (-u)
set -eu
trap 'echo "An error occurred in sfsnapshotgit at line $LINENO"; exit 1' EXIT

# Send all command output to STDERR while allowing us to write to STDOUT
# using fd 3
exec 3>&1 1>&2

# Git repository, origin and destination directory can be overridden by
# setting SFSNAP_REPO, SFSNAP_ORIGIN and SFSNAP_DEST respectively from the
# caller The defaults are:
SFSNAP_REPO=${SFSNAP_REPO-~/staging/nagiosplugins}
SFSNAP_ORIGIN=${SFSNAP_ORIGIN-origin}
SFSNAP_DEST=${SFSNAP_DEST-~/staging/snapshot}

# If one argument is given, this is the branch to create the snapshot from
if [ $# -eq 0 ]
then
	HEAD='master'
elif [ $# -eq 1 ]
then
	if [ -z "$1" ]
	then
		echo "If specified, the refspec must not be empty"
		exit
	fi
	HEAD="$1"
else
	echo "Too many arguments"
	exit
fi

# Clean up and pull
cd "$SFSNAP_REPO"
# Sometimes "make dist" can modify versioned files so we must reset first
git reset --hard
git clean -qfdx
# Any branch used to create snapshots must already exist
git checkout "$HEAD"
git fetch "$SFSNAP_ORIGIN"
git reset --hard "$SFSNAP_ORIGIN"/"$HEAD"
# Tags are important for git-describe
git fetch --tags "$SFSNAP_ORIGIN"

# Write our snapshot version string (similar to NP-VERSION-GEN) to "release"
VS=$(git describe --abbrev=4 HEAD)
VS=${VS#release-}

# Configure and dist only if needed
if [ ! -e "$SFSNAP_DEST/nagios-plugins-$VS.tar.gz" ]
then
	tools/setup
	./configure
	make dist VERSION=$VS RELEASE=snapshot
	cp nagios-plugins-$VS.tar.gz "$SFSNAP_DEST/"
fi

# fd 3 goes to STDOUT; print the generated filename
echo "nagios-plugins-$VS.tar.gz" 1>&3

trap - EXIT