File size: 2,530 Bytes
b98ce8c |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 |
#!/bin/bash
source "${BASH_SOURCE%/*}/common.sh"
. "$(git --exec-path)/git-sh-setup"
if [ -z "$1" ] ; then
c_echo $RED "Need to provide the version ie v0.0.0 as the first argument"
exit 1
fi
# Confirmation message, take two arguments
confirmation()
{
c_echo $YELLOW "
--------------------------------------------------------------------------------
-- Confirmation --
--------------------------------------------------------------------------------
"
c_echo $YELLOW "You are about to release the following..."
echo
c_echo $YELLOW "$1"
c_echo $YELLOW "Are you sure you want to continue? (Default: y)"
read -r CONFIRMATION
if [[ -z $CONFIRMATION ]]; then
CONFIRMATION="y"
fi
if [[ $CONFIRMATION != "y" ]]; then
c_echo $RED "Exiting..."
exit 1
fi
}
VERSION=$1
BRANCH=$(git rev-parse --abbrev-ref HEAD)
# Require valid format for version
rx='^v[0-9]+\.[0-9]+\.[0-9]+$'
if ! [[ $VERSION =~ $rx ]]; then
c_echo $RED "The version must be in the format 'vX.X.X'"
exit 1
fi
# Require main branch for release
if [ "$BRANCH" != "main" ]
then
c_echo $RED "You must release on the main branch"
exit 1
fi
# make sure you have the most recent from remote main
git fetch
git pull origin main
if [ x"$(git rev-parse $BRANCH)" != x"$(git rev-parse origin/$BRANCH)" ]
then
c_echo $RED "Out of sync with remote"
git status
exit 1
fi
# Require no untracked files
if [[ -n $(git status -s) ]]
then
c_echo $RED "Untracked files detected. Please stash or commit"
git status -s
exit 1
fi
# Require new tag/version
if [ $(git tag -l "$VERSION") ]; then
c_echo $RED "The tag/version already exists..."
echo
echo Tags:
git tag
exit 1
fi
# Require clean working tree for release
require_clean_work_tree release "Please commit or stash them and sync with remote"
# Get most recent tag
PREVIOUS_TAG=$(git describe --tags --abbrev=0)
# Build commit message for version bump
MESSAGE="Release: $VERSION
Changes:
$(git log --pretty=oneline $PREVIOUS_TAG..)
Diff:
https://github.com/hasaniqbal777/$APP_NAME/compare/$PREVIOUS_TAG...$VERSION
"
# Confirmation message
confirmation "$MESSAGE"
c_echo $GREEN "Releasing Version $VERSION"
echo
# Modify the VERSION file
printf "$VERSION" > ./VERSION
git add ./VERSION
git commit -m "🚀 $MESSAGE"
git tag $VERSION
git push origin $BRANCH
git push origin $VERSION
gh release create $VERSION --generate-notes |