agb/release.sh

113 lines
3.3 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
# Fail if any command fails
set -e
PROJECT=$1
VERSION=$2
2021-08-16 08:15:25 +10:00
NO_COMMIT=$3
# Sanity check that we actually have a version
if [ "$VERSION" = "" ]; then
2021-08-16 08:15:25 +10:00
echo "Usage $0 <project> <version> [--no-commit]"
exit 1
fi
# Check the format of version
2022-01-02 05:55:37 +11:00
if echo "$VERSION" | grep -q -Ev "^[0-9]+\.[0-9]+\.[0-9]+$"; then
echo "Version must be of the form x.y.z, got $VERSION"
exit 1
fi
2021-08-16 08:15:25 +10:00
# Check if no commit option is valid
2021-08-16 08:16:30 +10:00
if [ ! "$NO_COMMIT" = "" ] && [ ! "$NO_COMMIT" = "--no-commit" ]; then
2021-08-16 08:15:25 +10:00
echo "Must pass either no last argument or --no-commit"
exit 1
fi
# Set up $DIRECTORY and $TAGNAME
case "$PROJECT" in
agb)
DIRECTORY="agb"
TAGNAME="v$VERSION"
;;
agb-*)
if [ -f "$PROJECT/Cargo.toml" ]; then
DIRECTORY=$PROJECT
TAGNAME="$PROJECT/v$VERSION"
else
echo "Unknown project name $PROJECT"
exit 1
fi
;;
mgba-test-runner)
DIRECTORY="mgba-test-runner"
TAGNAME="mgba-test-runner/v$VERSION"
;;
*)
echo "Unknown project name $PROJECT"
exit 1
;;
esac
# Check that no out-standing changes in git
2022-01-02 05:55:37 +11:00
if [ -n "$(git status --porcelain)" ]; then
echo "Uncommitted changes, please commit first"
exit 1
fi
2021-08-16 08:15:25 +10:00
# Check that we are in the master branch, but only if actually committing
if [ ! "$NO_COMMIT" = "--no-commit" ] && [ "$(git symbolic-ref --short HEAD)" != "master" ]; then
echo "You must be in the master branch before releasing"
exit 1
fi
# Update the version in Cargo.toml
2021-06-21 08:14:17 +10:00
sed -i -e "s/^version = \".*\"/version = \"$VERSION\"/" "$DIRECTORY/Cargo.toml"
# Also update the lock file
(cd "$DIRECTORY" && cargo update)
2021-06-21 08:48:46 +10:00
git add "$DIRECTORY/Cargo.toml" "$DIRECTORY/Cargo.lock"
if [ "$PROJECT" = "agb" ]; then
# also update the agb version in the template and the examples
sed -i -e "s/^agb = \".*\"/agb = \"$VERSION\"/" template/Cargo.toml
git add template/Cargo.toml
for EXAMPLE_TOML_FILE in examples/*/Cargo.toml book/games/*/Cargo.toml; do
EXAMPLE_DIR=$(dirname "$EXAMPLE_TOML_FILE")
sed -E -i -e "/agb =/ s/version = \"[^\"]+\"/version = \"$VERSION\"/" "$EXAMPLE_DIR/Cargo.toml"
(cd "$EXAMPLE_DIR" && cargo update)
git add "$EXAMPLE_DIR"/{Cargo.toml,Cargo.lock}
done
else
2021-08-16 08:18:55 +10:00
PROJECT_NAME_WITH_UNDERSCORES=$(echo -n "$PROJECT" | tr - _)
2022-01-13 09:11:05 +11:00
for CARGO_TOML_FILE in agb-*/Cargo.toml agb/Cargo.toml examples/*/Cargo.toml book/games/*/Cargo.toml; do
sed -i -E -e "s/($PROJECT_NAME_WITH_UNDERSCORES = .*version = \")[^\"]+(\".*)/\1$VERSION\2/" "$CARGO_TOML_FILE"
(cd "$(dirname "$CARGO_TOML_FILE")" && cargo generate-lockfile)
git add "$CARGO_TOML_FILE" "${CARGO_TOML_FILE/.toml/.lock}"
done
fi
# Sanity check to make sure the build works
for CARGO_TOML_FILE in agb-*/Cargo.toml agb/Cargo.toml; do
(cd "$(dirname "$CARGO_TOML_FILE")" && cargo test)
done
for EXAMPLE_TOML_FILE in examples/*/Cargo.toml book/games/*/Cargo.toml; do
EXAMPLE_DIR=$(dirname "$EXAMPLE_TOML_FILE")
(cd "$EXAMPLE_DIR" && cargo check --release)
done
2021-08-16 08:15:25 +10:00
if [ ! "$NO_COMMIT" = "--no-commit" ]; then
# Commit the Cargo.toml changes
git commit -m "Release $PROJECT v$VERSION"
2021-08-16 08:15:25 +10:00
# Tag the version
2022-01-02 05:55:37 +11:00
git tag -a "$TAGNAME" -m "$PROJECT - v$VERSION"
2021-08-16 08:15:25 +10:00
echo "Done! Push with"
echo "git push --atomic origin master $TAGNAME"
fi