forked from ponylang/ponyc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrelease.bash
94 lines (76 loc) · 1.84 KB
/
release.bash
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
#!/bin/bash
set -o errexit
set -o nounset
verify_args() {
echo "Cutting a release for version $version with commit $commit"
while true; do
read -rp "Is this correct (y/n)?" yn
case $yn in
[Yy]*) break;;
[Nn]*) exit;;
*) echo "Please answer y or n.";;
esac
done
}
update_version() {
echo "$version" > VERSION
echo "VERSION set to $version"
}
check_for_commit_and_push() {
printf "Would you like to push CHANGELOG updates to master (y/n)? "
while true; do
read -r yn
case $yn in
[Yy]*) break;;
[Nn]*) exit;;
*) echo "Please answer y or n.";;
esac
done
}
if [ $# -le 2 ]; then
echo "version and commit arguments required"
fi
set -eu
version=$1
commit=$2
verify_args
# create version release branch
git checkout master
git pull
if ! git diff --exit-code master origin/master
then
echo "ERROR! There are local-only changes on branch 'master'!"
exit 1
fi
git checkout -b "release-$version" "$commit"
# update VERSION and CHANGELOG
update_version
changelog-tool release CHANGELOG.md "$version" -e
# commit VERSION and CHANGELOG updates
git add CHANGELOG.md VERSION
git commit -m "Prep for $version release
[skip ci]"
# merge into release
git checkout release
if ! git diff --exit-code release origin/release
then
echo "ERROR! There are local-only changes on branch 'release'!"
exit 1
fi
git merge "release-$version" -m "Release $version"
# tag release
git tag "$version"
# push to release branch
git push origin release
git push origin "$version"
# update CHANGELOG for new entries
git checkout master
git merge "release-$version"
changelog-tool unreleased CHANGELOG.md -e
# check if user wants to continue
check_for_commit_and_push
# commit changelog and push to master
git add CHANGELOG.md
git commit -m "Add unreleased section to CHANGELOG post $version release prep
[skip ci]"
git push origin master