22
33set -eu -o pipefail
44
5+ # Pre-flight checks - verify all required tools are available and configured
6+ # before making any changes to the repository
7+
8+ check_command () {
9+ if ! command -v " $1 " & > /dev/null; then
10+ echo " Error: $1 is not installed or not in PATH"
11+ exit 1
12+ fi
13+ }
14+
15+ # Verify gh CLI is authenticated
16+ if ! gh auth status & > /dev/null; then
17+ echo " Error: gh CLI is not authenticated. Run 'gh auth login' first."
18+ exit 1
19+ fi
20+
21+ # Verify we can access this repository via gh
22+ if ! gh repo view --json name & > /dev/null; then
23+ echo " Error: Cannot access repository via gh. Check your authentication and repository access."
24+ exit 1
25+ fi
26+
27+ # Verify git can connect to the remote (catches SSH key issues, etc.)
28+ if ! git ls-remote origin & > /dev/null; then
29+ echo " Error: Cannot connect to git remote. Check your git credentials/SSH keys."
30+ exit 1
31+ fi
32+
33+ check_command perl
34+ check_command uv
35+
536# Check that we're not on the main branch
637current_branch=$( git branch --show-current)
738if [ " $current_branch " = " main" ]; then
2354changelog=$( cat HISTORY.rst)
2455
2556regex='
26- ([0-9]+\.[0-9]+\.[0-9]+) \(([0-9]{4}-[0-9]{2}-[0-9]{2})\)
57+ ([0-9]+\.[0-9]+\.[0-9]+(-[a-zA-Z0-9.]+)? ) \(([0-9]{4}-[0-9]{2}-[0-9]{2})\)
2758\+*
2859
2960((.|
3061)*)
3162'
3263
3364if [[ ! $changelog =~ $regex ]]; then
34- echo " Could not find date line in change log!"
35- exit 1
65+ echo " Could not find date line in change log!"
66+ exit 1
3667fi
3768
3869version=" ${BASH_REMATCH[1]} "
39- date=" ${BASH_REMATCH[2 ]} "
40- notes=" $( echo " ${BASH_REMATCH[3 ]} " | sed -n -e ' /^[0-9]\ +\.[0-9]\ +\.[0-9]\+ /,$!p' ) "
70+ date=" ${BASH_REMATCH[3 ]} "
71+ notes=" $( echo " ${BASH_REMATCH[4 ]} " | sed -n -E ' /^[0-9]+\.[0-9]+\.[0-9]+(-[a-zA-Z0-9.]+)? /,$!p' ) "
4172
4273if [[ " $date " != " $( date +" %Y-%m-%d" ) " ]]; then
4374 echo " $date is not today!"
@@ -62,7 +93,7 @@ git diff
6293echo $' \n Release notes:'
6394echo " $notes "
6495
65- read -e -p " Commit changes and push to origin? " should_push
96+ read -r - e -p " Commit changes and push to origin? " should_push
6697
6798if [ " $should_push " != " y" ]; then
6899 echo " Aborting"
@@ -74,5 +105,3 @@ git commit -m "Update for $tag" -a
74105git push
75106
76107gh release create --target " $( git branch --show-current) " -t " $version " -n " $notes " " $tag "
77-
78- git push --tags
0 commit comments