#!/bin/sh

# Merge commits from this branch are counted
DEVELOPBRANCH="yggdrasil-network/develop"

# Get the last tag
TAG=$(git describe --abbrev=0 --tags --match="v[0-9]*\.[0-9]*\.0" 2>/dev/null)

# Get last merge to master
MERGE=$(git rev-list $TAG..master --grep "from $DEVELOPBRANCH" 2>/dev/null | head -n 1)

# Get the number of merges since the last merge to master
PATCH=$(git rev-list $TAG..master --count --merges --grep="from $DEVELOPBRANCH" --first-parent master 2>/dev/null)

# Decide whether we should prepend the version with "v" - the default is that
# we do because we use it in git tags, but we might not always need it
PREPEND="v"
if [ "$1" = "--bare" ]; then
  PREPEND=""
fi

# If it fails then there's no last tag - go from the first commit
if [ $? != 0 ]; then
  PATCH=$(git rev-list HEAD --count 2>/dev/null)

  # Complain if the git history is not available
  if [ $? != 0 ]; then
    printf 'unknown'
    exit 1
  fi

  printf '%s0.0.%d' "$PREPEND" "$PATCH"
  exit 1
fi

# Split out into major, minor and patch numbers
MAJOR=$(echo $TAG | cut -c 2- | cut -d "." -f 1)
MINOR=$(echo $TAG | cut -c 2- | cut -d "." -f 2)

# Get the current checked out branch
BRANCH=$(git rev-parse --abbrev-ref HEAD)

# Output in the desired format
if [ $PATCH = 0 ]; then
  if [ ! -z $FULL ]; then
    printf '%s%d.%d.0' "$PREPEND" "$MAJOR" "$MINOR"
  else
    printf '%s%d.%d' "$PREPEND" "$MAJOR" "$MINOR"
  fi
else
  printf '%s%d.%d.%d' "$PREPEND" "$MAJOR" "$MINOR" "$PATCH"
fi

# Get the number of merges on the current branch since the last tag
TAG=$(git describe --abbrev=0 --tags --match="v[0-9]*\.[0-9]*\.[0-9]*" --first-parent master 2>/dev/null)
BUILD=$(git rev-list $TAG.. --count)

# Add the build tag on non-master branches
if [ $BRANCH != "master" ]; then
  if [ $BUILD != 0 ]; then
    printf -- "-%04d" "$BUILD"
  fi
else
  if [ $BUILD != 0 ]; then
    printf -- "-%d" "$(($BUILD+1))"
  fi
fi