Update bump_version.sh
This commit is contained in:
parent
0d8cdab46f
commit
6dfe2a2e3f
@ -1,6 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash -e
|
||||||
|
|
||||||
die() { echo "$@" 1>&2 ; exit 1; }
|
|
||||||
|
|
||||||
prompt_for_number() {
|
prompt_for_number() {
|
||||||
local prompt_text=$1
|
local prompt_text=$1
|
||||||
@ -16,7 +14,55 @@ prompt_for_number() {
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# On a release the following actions are performed
|
||||||
|
# * DEVELOPMENT_BUILD is set to false
|
||||||
|
# * android versionCode is bumped
|
||||||
|
# * appdata release version and date are updated
|
||||||
|
# * Commit the changes
|
||||||
|
# * Tag with current version
|
||||||
|
perform_release() {
|
||||||
|
sed -i -re "s/^set\(DEVELOPMENT_BUILD TRUE\)$/set(DEVELOPMENT_BUILD FALSE)/" CMakeLists.txt
|
||||||
|
|
||||||
|
sed -i -re "s/versionCode [0-9]+$/versionCode $NEW_ANDROID_VERSION_CODE/" build/android/build.gradle
|
||||||
|
|
||||||
|
sed -i '/\<release/s/\(version\)="[^"]*"/\1="'"$RELEASE_VERSION"'"/' misc/net.minetest.minetest.appdata.xml
|
||||||
|
|
||||||
|
RELEASE_DATE=`date +%Y-%m-%d`
|
||||||
|
|
||||||
|
sed -i 's/\(<release date\)="[^"]*"/\1="'"$RELEASE_DATE"'"/' misc/net.minetest.minetest.appdata.xml
|
||||||
|
|
||||||
|
git add -f CMakeLists.txt build/android/build.gradle misc/net.minetest.minetest.appdata.xml
|
||||||
|
|
||||||
|
git commit -m "Bump version to $RELEASE_VERSION"
|
||||||
|
|
||||||
|
echo "Tagging $RELEASE_VERSION"
|
||||||
|
|
||||||
|
git tag -a "$RELEASE_VERSION" -m "$RELEASE_VERSION"
|
||||||
|
}
|
||||||
|
|
||||||
|
# After release
|
||||||
|
# * Set DEVELOPMENT_BUILD to true
|
||||||
|
# * Bump version in CMakeLists and docs
|
||||||
|
# * Commit the changes
|
||||||
|
back_to_devel() {
|
||||||
|
echo 'Creating "return back to development" commit'
|
||||||
|
|
||||||
|
sed -i -re 's/^set\(DEVELOPMENT_BUILD FALSE\)$/set(DEVELOPMENT_BUILD TRUE)/' CMakeLists.txt
|
||||||
|
|
||||||
|
sed -i -re "s/^set\(VERSION_MAJOR [0-9]+\)$/set(VERSION_MAJOR $NEXT_VERSION_MAJOR)/" CMakeLists.txt
|
||||||
|
|
||||||
|
sed -i -re "s/^set\(VERSION_MINOR [0-9]+\)$/set(VERSION_MINOR $NEXT_VERSION_MINOR)/" CMakeLists.txt
|
||||||
|
|
||||||
|
sed -i -re "s/^set\(VERSION_PATCH [0-9]+\)$/set(VERSION_PATCH $NEXT_VERSION_PATCH)/" CMakeLists.txt
|
||||||
|
|
||||||
|
sed -i -re "1s/[0-9]+\.[0-9]+\.[0-9]+/$NEXT_VERSION/g" doc/menu_lua_api.txt
|
||||||
|
|
||||||
|
sed -i -re "1s/[0-9]+\.[0-9]+\.[0-9]+/$NEXT_VERSION/g" doc/client_lua_api.txt
|
||||||
|
|
||||||
|
git add -f CMakeLists.txt doc/menu_lua_api.txt doc/client_lua_api.txt
|
||||||
|
|
||||||
|
git commit -m "Continue with $NEXT_VERSION-dev"
|
||||||
|
}
|
||||||
##################################
|
##################################
|
||||||
# Switch to top minetest directory
|
# Switch to top minetest directory
|
||||||
##################################
|
##################################
|
||||||
@ -29,93 +75,64 @@ cd ${0%/*}/..
|
|||||||
#######################
|
#######################
|
||||||
|
|
||||||
# Make sure all the files we need exist
|
# Make sure all the files we need exist
|
||||||
grep -q -E '^set\(VERSION_MAJOR [0-9]+\)$' CMakeLists.txt || die "error: Could not find CMakeLists.txt"
|
grep -q -E '^set\(VERSION_MAJOR [0-9]+\)$' CMakeLists.txt
|
||||||
grep -q -E '^set\(VERSION_MINOR [0-9]+\)$' CMakeLists.txt || die "error: Could not find CMakeLists.txt"
|
grep -q -E '^set\(VERSION_MINOR [0-9]+\)$' CMakeLists.txt
|
||||||
grep -q -E '^set\(VERSION_PATCH [0-9]+\)$' CMakeLists.txt || die "error: Could not find CMakeLists.txt"
|
grep -q -E '^set\(VERSION_PATCH [0-9]+\)$' CMakeLists.txt
|
||||||
grep -q -E 'versionCode [0-9]+$' build/android/build.gradle || die "error: Could not find Android version code"
|
grep -q -E '^set\(VERSION_TWEAK [0-9]+\)$' CMakeLists.txt
|
||||||
|
grep -q -E 'versionCode [0-9]+$' build/android/build.gradle
|
||||||
|
|
||||||
VERSION_MAJOR=$(grep -E '^set\(VERSION_MAJOR [0-9]+\)$' CMakeLists.txt | tr -dC 0-9)
|
VERSION_MAJOR=$(grep -E '^set\(VERSION_MINOR [0-9]+\)$' CMakeLists.txt | tr -dC 0-9)
|
||||||
VERSION_MINOR=$(grep -E '^set\(VERSION_MINOR [0-9]+\)$' CMakeLists.txt | tr -dC 0-9)
|
VERSION_MINOR=$(grep -E '^set\(VERSION_PATCH [0-9]+\)$' CMakeLists.txt | tr -dC 0-9)
|
||||||
VERSION_PATCH=$(grep -E '^set\(VERSION_PATCH [0-9]+\)$' CMakeLists.txt | tr -dC 0-9)
|
VERSION_PATCH=$(grep -E '^set\(VERSION_TWEAK [0-9]+\)$' CMakeLists.txt | tr -dC 0-9)
|
||||||
ANDROID_VERSION_CODE=$(grep -E 'versionCode [0-9]+$' build/android/build.gradle | tr -dC 0-9)
|
ANDROID_VERSION_CODE=$(grep -E 'versionCode [0-9]+$' build/android/build.gradle | tr -dC 0-9)
|
||||||
|
|
||||||
echo "Current Minetest version: $VERSION_MAJOR.$VERSION_MINOR.$VERSION_PATCH"
|
RELEASE_VERSION="0.$VERSION_MAJOR.$VERSION_MINOR.$VERSION_PATCH"
|
||||||
|
|
||||||
|
echo "Current Minetest version: $RELEASE_VERSION"
|
||||||
echo "Current Android version code: $ANDROID_VERSION_CODE"
|
echo "Current Android version code: $ANDROID_VERSION_CODE"
|
||||||
|
|
||||||
|
|
||||||
########################
|
|
||||||
# Prompt for new version
|
|
||||||
########################
|
|
||||||
|
|
||||||
NEW_VERSION_MAJOR=$VERSION_MAJOR
|
|
||||||
NEW_VERSION_MINOR=$VERSION_MINOR
|
|
||||||
NEW_VERSION_PATCH=$(expr $VERSION_PATCH + 1)
|
|
||||||
|
|
||||||
NEW_VERSION_MAJOR=$(prompt_for_number "Set major" $NEW_VERSION_MAJOR)
|
|
||||||
|
|
||||||
if [ "$NEW_VERSION_MAJOR" != "$VERSION_MAJOR" ]; then
|
|
||||||
NEW_VERSION_MINOR=0
|
|
||||||
NEW_VERSION_PATCH=0
|
|
||||||
fi
|
|
||||||
|
|
||||||
NEW_VERSION_MINOR=$(prompt_for_number "Set minor" $NEW_VERSION_MINOR)
|
|
||||||
|
|
||||||
if [ "$NEW_VERSION_MINOR" != "$VERSION_MINOR" ]; then
|
|
||||||
NEW_VERSION_PATCH=0
|
|
||||||
fi
|
|
||||||
|
|
||||||
NEW_VERSION_PATCH=$(prompt_for_number "Set patch" $NEW_VERSION_PATCH)
|
|
||||||
|
|
||||||
NEW_ANDROID_VERSION_CODE=$(expr $ANDROID_VERSION_CODE + 1)
|
NEW_ANDROID_VERSION_CODE=$(expr $ANDROID_VERSION_CODE + 1)
|
||||||
NEW_ANDROID_VERSION_CODE=$(prompt_for_number "Set android version code" $NEW_ANDROID_VERSION_CODE)
|
NEW_ANDROID_VERSION_CODE=$(prompt_for_number "Set android version code" $NEW_ANDROID_VERSION_CODE)
|
||||||
|
|
||||||
NEW_VERSION="$NEW_VERSION_MAJOR.$NEW_VERSION_MINOR.$NEW_VERSION_PATCH"
|
|
||||||
|
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo "New version: $NEW_VERSION"
|
|
||||||
echo "New android version code: $NEW_ANDROID_VERSION_CODE"
|
echo "New android version code: $NEW_ANDROID_VERSION_CODE"
|
||||||
|
|
||||||
|
########################
|
||||||
|
# Perform release
|
||||||
|
########################
|
||||||
|
|
||||||
#######################################
|
perform_release
|
||||||
# Replace version everywhere and commit
|
|
||||||
#######################################
|
|
||||||
|
|
||||||
sed -i -re "s/^set\(VERSION_MAJOR [0-9]+\)$/set(VERSION_MAJOR $NEW_VERSION_MAJOR)/" CMakeLists.txt || die "Failed to update VERSION_MAJOR"
|
########################
|
||||||
|
# Prompt for next version
|
||||||
|
########################
|
||||||
|
|
||||||
sed -i -re "s/^set\(VERSION_MINOR [0-9]+\)$/set(VERSION_MINOR $NEW_VERSION_MINOR)/" CMakeLists.txt || die "Failed to update VERSION_MINOR"
|
NEXT_VERSION_MAJOR=$VERSION_MAJOR
|
||||||
|
NEXT_VERSION_MINOR=$VERSION_MINOR
|
||||||
|
NEXT_VERSION_PATCH=$(expr $VERSION_PATCH + 1)
|
||||||
|
|
||||||
sed -i -re "s/^set\(VERSION_PATCH [0-9]+\)$/set(VERSION_PATCH $NEW_VERSION_PATCH)/" CMakeLists.txt || die "Failed to update VERSION_PATCH"
|
#NEXT_VERSION_MAJOR=$(prompt_for_number "Set next major" $NEXT_VERSION_MAJOR)
|
||||||
|
|
||||||
sed -i -re "s/^set\(DEVELOPMENT_BUILD TRUE\)$/set(DEVELOPMENT_BUILD FALSE)/" CMakeLists.txt || die "Failed to unset DEVELOPMENT_BUILD"
|
#if [ "$NEXT_VERSION_MAJOR" != "$VERSION_MAJOR" ]; then
|
||||||
|
# NEXT_VERSION_MINOR=0
|
||||||
|
# NEXT_VERSION_PATCH=0
|
||||||
|
#fi
|
||||||
|
|
||||||
sed -i -re "s/versionCode [0-9]+$/versionCode $NEW_ANDROID_VERSION_CODE/" build/android/build.gradle || die "Failed to update Android version code"
|
NEXT_VERSION_MINOR=$(prompt_for_number "Set next minor" $NEXT_VERSION_MINOR)
|
||||||
|
|
||||||
sed -i -re "1s/[0-9]+\.[0-9]+\.[0-9]+/$NEW_VERSION/g" doc/lua_api.txt || die "Failed to update doc/lua_api.txt"
|
if [ "$NEXT_VERSION_MINOR" != "$VERSION_MINOR" ]; then
|
||||||
|
NEXT_VERSION_PATCH=0
|
||||||
|
fi
|
||||||
|
|
||||||
sed -i -re "1s/[0-9]+\.[0-9]+\.[0-9]+/$NEW_VERSION/g" doc/menu_lua_api.txt || die "Failed to update doc/menu_lua_api.txt"
|
NEXT_VERSION_PATCH=$(prompt_for_number "Set next patch" $NEXT_VERSION_PATCH)
|
||||||
|
|
||||||
git add -f CMakeLists.txt build/android/build.gradle doc/lua_api.txt doc/menu_lua_api.txt || die "git add failed"
|
NEXT_VERSION="0.$NEXT_VERSION_MAJOR.$NEXT_VERSION_MINOR.$NEXT_VERSION_PATCH"
|
||||||
|
|
||||||
git commit -m "Bump version to $NEW_VERSION" || die "git commit failed"
|
echo
|
||||||
|
echo "New version: $NEXT_VERSION"
|
||||||
|
|
||||||
############
|
########################
|
||||||
# Create tag
|
# Return back to devel
|
||||||
############
|
########################
|
||||||
|
|
||||||
echo "Tagging $NEW_VERSION"
|
|
||||||
|
|
||||||
git tag -a "$NEW_VERSION" -m "$NEW_VERSION" || die 'Adding tag failed'
|
|
||||||
|
|
||||||
######################
|
|
||||||
# Create revert commit
|
|
||||||
######################
|
|
||||||
|
|
||||||
echo 'Creating "revert to development" commit'
|
|
||||||
|
|
||||||
sed -i -re 's/^set\(DEVELOPMENT_BUILD FALSE\)$/set(DEVELOPMENT_BUILD TRUE)/' CMakeLists.txt || die 'Failed to set DEVELOPMENT_BUILD'
|
|
||||||
|
|
||||||
git add -f CMakeLists.txt || die 'git add failed'
|
|
||||||
|
|
||||||
git commit -m "Continue with $NEW_VERSION-dev" || die 'git commit failed'
|
|
||||||
|
|
||||||
|
back_to_devel
|
||||||
|
Loading…
x
Reference in New Issue
Block a user