#!/usr/bin/env bash
#
# Git "hook chain", used to execute multiple scripts per hook.
# To use:
#  * create a directory called <hookname>.d
#  * add scripts to this directory (executable)
#  * ln -s hook-chain <hookname>
#
# Now the scripts in that directory should be called in order.
#
# Set $HOOKCHAIN_DEBUG to see the names of invoked scripts.
#
# Based on script by Oliver Reflalo:
# https://stackoverflow.com/questions/8730514/chaining-git-hooks
#

hookname=`basename $0`

# Temp file for stdin, cleared at exit
FILE=`mktemp`
trap 'rm -f $FILE' EXIT
cat - > $FILE

# Git hooks directory (this dir)
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null && pwd )"

# Execute hooks in the directory one by one
for hook in $DIR/$hookname.d/*;
do
    if [ -x "$hook" ]; then

        if [ "$HOOKCHAIN_DEBUG" ]; then
            echo "Running hook $hook"
        fi

        cat $FILE | $hook "$@"
        status=$?

        if [ $status -ne 0 ]; then
            echo "Hook $hook failed with error code $status"
            echo "To commit anyway, use --no-verify"
            exit $status
        else
            if [ "$HOOKCHAIN_DEBUG" ]; then
                echo "Hook passed: $hook"
            fi
        fi
    fi
done