-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
8 changed files
with
365 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
changelog: | ||
exclude: | ||
labels: | ||
- ignore-for-release | ||
authors: | ||
- octocat |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
name: Create release | ||
on: | ||
push: | ||
tags: | ||
- v* | ||
permissions: | ||
contents: write | ||
jobs: | ||
release: | ||
name: Release pushed tag | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Create release | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
tag: ${{ github.ref_name }} | ||
run: ./scripts/gh_release.sh |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -euo pipefail | ||
|
||
ORIGIN=${ORIGIN:-origin} | ||
|
||
bump=${1:-patch} | ||
|
||
prerel=${2:-none} | ||
|
||
if [[ $bump == "prerel" ]]; then | ||
bump="patch" | ||
prerel="prerel" | ||
fi | ||
|
||
if [[ $(git status --porcelain) != "" ]]; then | ||
echo "Error: repo is dirty. Run git status, clean repo and try again." | ||
exit 1 | ||
elif [[ $(git status --porcelain -b | grep -e "ahead" -e "behind") != "" ]]; then | ||
echo "Error: repo has unpushed commits. Push commits to remote and try again." | ||
exit 1 | ||
fi | ||
|
||
BRANCH="$(git rev-parse --abbrev-ref HEAD)" | ||
if [[ "$prerel" == "prerel" && "$BRANCH" != "prerelease" ]]; then | ||
# echo "❌ Sorry, you can only cut a pre-release from the 'prelease' branch" | ||
# echo "Run 'git checkout prerelease && git pull origin prerelease' and try again." | ||
# exit 1 | ||
echo "⚠️ Pre-releases should be cut from the 'prerelease' branch" | ||
echo "Please make sure you're not overwriting someone else's prerelease!" | ||
echo | ||
read -p "Release anyway? " -n 1 -r | ||
echo | ||
if [[ $REPLY =~ ^[^Yy]$ ]]; then | ||
echo Aborting. | ||
exit 1 | ||
fi | ||
fi | ||
|
||
if [[ "$prerel" != "prerel" && "$BRANCH" != "main" ]]; then | ||
echo "❌ Sorry, you can only cut a release from the 'main' branch" | ||
echo "Run 'git checkout main && git pull origin main' and try again." | ||
exit 1 | ||
fi | ||
|
||
git fetch | ||
if [[ "$(git rev-parse HEAD 2>&1)" != "$(git rev-parse '@{u}' 2>&1)" ]]; then | ||
echo "There are upstream commits that won't be included in this release." | ||
echo "You probably want to exit, run 'git pull', then release." | ||
echo | ||
read -p "Release anyway? " -n 1 -r | ||
echo | ||
if [[ $REPLY =~ ^[^Yy]$ ]]; then | ||
echo Aborting. | ||
exit 1 | ||
fi | ||
fi | ||
|
||
dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" | ||
|
||
previous_version="$("$dir"/../scripts/version.sh -s)" | ||
|
||
if [[ $prerel == "prerel" ]]; then | ||
prerelversion=$("$dir"/../scripts/semver get prerel "$previous_version") | ||
if [[ $prerelversion == "" ]]; then | ||
new_version=$("$dir"/../scripts/semver bump "$bump" "$previous_version") | ||
new_version=$("$dir"/../scripts/semver bump prerel pre-1 "$new_version") | ||
else | ||
prerel=pre-$((${prerelversion#pre-} + 1)) | ||
new_version=$("$dir"/../scripts/semver bump prerel "$prerel" "$previous_version") | ||
fi | ||
else | ||
prerelversion=$("$dir"/../scripts/semver get prerel "$previous_version") | ||
if [[ $prerelversion == "" ]]; then | ||
new_version=$("$dir"/../scripts/semver bump "$bump" "$previous_version") | ||
else | ||
new_version=${previous_version//-$prerelversion/} | ||
fi | ||
fi | ||
|
||
new_version="v$new_version" | ||
|
||
echo "Bumping version from v${previous_version} to ${new_version}" | ||
|
||
read -p "Are you sure? " -n 1 -r | ||
echo | ||
if [[ $REPLY =~ ^[Yy]$ ]] | ||
then | ||
git tag -m "release ${new_version}" -a "$new_version" && git push "${ORIGIN}" tag "$new_version" | ||
echo "done" | ||
fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
#!/usr/bin/env bash | ||
|
||
current_tag=$(git -c "versionsort.prereleasesuffix=-pre" tag --points-at HEAD --sort -v:refname | head -n1) | ||
if [ -z "$current_tag" ]; then | ||
current_tag=$(git describe --tags --abbrev=0) | ||
fi | ||
|
||
>&2 echo "current tag: $current_tag" | ||
|
||
# if the current tag is a prerelease, get the previous tag, otherwise get the previous non-prerelease tag | ||
if [[ $current_tag =~ pre ]]; then | ||
previous_tag=$(git describe --match "v[0-9]*" --abbrev=0 HEAD^) | ||
else | ||
previous_tag=$(git describe --match "v[0-9]*" --exclude "*-pre-*" --abbrev=0 HEAD^) | ||
fi | ||
|
||
>&2 echo "previous tag: $previous_tag" | ||
|
||
# only include go files in the changelog | ||
git log --oneline --no-merges --no-decorate $previous_tag..HEAD -- '*.go' '**/*.go' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
#!/usr/bin/env bash | ||
set -eo pipefail | ||
if [[ "$tag" == *"-pre-"* ]] | ||
then | ||
prerelease="--prerelease" | ||
else | ||
prerelease="" | ||
fi | ||
gh release create "$tag" \ | ||
$prerelease \ | ||
--repo="$GITHUB_REPOSITORY" \ | ||
--title="${tag}" \ | ||
--generate-notes |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,200 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -o errexit -o nounset -o pipefail | ||
|
||
SEMVER_REGEX="^[vV]?(0|[1-9][0-9]*)\\.(0|[1-9][0-9]*)\\.(0|[1-9][0-9]*)(\\-[0-9A-Za-z-]+(\\.[0-9A-Za-z-]+)*)?(\\+[0-9A-Za-z-]+(\\.[0-9A-Za-z-]+)*)?$" | ||
|
||
PROG=semver | ||
PROG_VERSION=2.1.0 | ||
|
||
USAGE="\ | ||
Usage: | ||
$PROG bump (major|minor|patch|release|prerel <prerel>|build <build>) <version> | ||
$PROG compare <version> <other_version> | ||
$PROG get (major|minor|patch|release|prerel|build) <version> | ||
$PROG --help | ||
$PROG --version | ||
Arguments: | ||
<version> A version must match the following regex pattern: | ||
\"${SEMVER_REGEX}\". | ||
In english, the version must match X.Y.Z(-PRERELEASE)(+BUILD) | ||
where X, Y and Z are positive integers, PRERELEASE is an optional | ||
string composed of alphanumeric characters and hyphens and | ||
BUILD is also an optional string composed of alphanumeric | ||
characters and hyphens. | ||
<other_version> See <version> definition. | ||
<prerel> String that must be composed of alphanumeric characters and hyphens. | ||
<build> String that must be composed of alphanumeric characters and hyphens. | ||
Options: | ||
-v, --version Print the version of this tool. | ||
-h, --help Print this help message. | ||
Commands: | ||
bump Bump <version> by one of major, minor, patch, prerel, build | ||
or a forced potentially conflicting version. The bumped version is | ||
shown to stdout. | ||
compare Compare <version> with <other_version>, output to stdout the | ||
following values: -1 if <other_version> is newer, 0 if equal, 1 if | ||
older. | ||
get Extract given part of <version>, where part is one of major, minor, | ||
patch, prerel, build." | ||
|
||
function error { | ||
echo -e "$1" >&2 | ||
exit 1 | ||
} | ||
|
||
function usage-help { | ||
error "$USAGE" | ||
} | ||
|
||
function usage-version { | ||
echo -e "${PROG}: $PROG_VERSION" | ||
exit 0 | ||
} | ||
|
||
function validate-version { | ||
local version=$1 | ||
if [[ "$version" =~ $SEMVER_REGEX ]]; then | ||
# if a second argument is passed, store the result in var named by $2 | ||
if [ "$#" -eq "2" ]; then | ||
local major=${BASH_REMATCH[1]} | ||
local minor=${BASH_REMATCH[2]} | ||
local patch=${BASH_REMATCH[3]} | ||
local prere=${BASH_REMATCH[4]} | ||
local build=${BASH_REMATCH[6]} | ||
eval "$2=(\"$major\" \"$minor\" \"$patch\" \"$prere\" \"$build\")" | ||
else | ||
echo "$version" | ||
fi | ||
else | ||
error "version $version does not match the semver scheme 'X.Y.Z(-PRERELEASE)(+BUILD)'. See help for more information." | ||
fi | ||
} | ||
|
||
function compare-version { | ||
validate-version "$1" V | ||
validate-version "$2" V_ | ||
|
||
# MAJOR, MINOR and PATCH should compare numerically | ||
for i in 0 1 2; do | ||
local diff=$((${V[$i]} - ${V_[$i]})) | ||
if [[ $diff -lt 0 ]]; then | ||
echo -1; return 0 | ||
elif [[ $diff -gt 0 ]]; then | ||
echo 1; return 0 | ||
fi | ||
done | ||
|
||
# PREREL should compare with the ASCII order. | ||
if [[ -z "${V[3]}" ]] && [[ -n "${V_[3]}" ]]; then | ||
echo 1; return 0; | ||
elif [[ -n "${V[3]}" ]] && [[ -z "${V_[3]}" ]]; then | ||
echo -1; return 0; | ||
elif [[ -n "${V[3]}" ]] && [[ -n "${V_[3]}" ]]; then | ||
if [[ "${V[3]}" > "${V_[3]}" ]]; then | ||
echo 1; return 0; | ||
elif [[ "${V[3]}" < "${V_[3]}" ]]; then | ||
echo -1; return 0; | ||
fi | ||
fi | ||
|
||
echo 0 | ||
} | ||
|
||
function command-bump { | ||
local new; local version; local sub_version; local command; | ||
|
||
case $# in | ||
2) case $1 in | ||
major|minor|patch|release) command=$1; version=$2;; | ||
*) usage-help;; | ||
esac ;; | ||
3) case $1 in | ||
prerel|build) command=$1; sub_version=$2 version=$3 ;; | ||
*) usage-help;; | ||
esac ;; | ||
*) usage-help;; | ||
esac | ||
|
||
validate-version "$version" parts | ||
# shellcheck disable=SC2154 | ||
local major="${parts[0]}" | ||
local minor="${parts[1]}" | ||
local patch="${parts[2]}" | ||
local prere="${parts[3]}" | ||
local build="${parts[4]}" | ||
|
||
case "$command" in | ||
major) new="$((major + 1)).0.0";; | ||
minor) new="${major}.$((minor + 1)).0";; | ||
patch) new="${major}.${minor}.$((patch + 1))";; | ||
release) new="${major}.${minor}.${patch}";; | ||
prerel) new=$(validate-version "${major}.${minor}.${patch}-${sub_version}");; | ||
build) new=$(validate-version "${major}.${minor}.${patch}${prere}+${sub_version}");; | ||
*) usage-help ;; | ||
esac | ||
|
||
echo "$new" | ||
exit 0 | ||
} | ||
|
||
function command-compare { | ||
local v; local v_; | ||
|
||
case $# in | ||
2) v=$(validate-version "$1"); v_=$(validate-version "$2") ;; | ||
*) usage-help ;; | ||
esac | ||
|
||
compare-version "$v" "$v_" | ||
exit 0 | ||
} | ||
|
||
|
||
# shellcheck disable=SC2034 | ||
function command-get { | ||
local part version | ||
|
||
if [[ "$#" -ne "2" ]] || [[ -z "$1" ]] || [[ -z "$2" ]]; then | ||
usage-help | ||
exit 0 | ||
fi | ||
|
||
part="$1" | ||
version="$2" | ||
|
||
validate-version "$version" parts | ||
local major="${parts[0]}" | ||
local minor="${parts[1]}" | ||
local patch="${parts[2]}" | ||
local prerel="${parts[3]:1}" | ||
local build="${parts[4]:1}" | ||
|
||
case "$part" in | ||
major|minor|patch|release|prerel|build) echo "${!part}" ;; | ||
*) usage-help ;; | ||
esac | ||
|
||
exit 0 | ||
} | ||
|
||
case $# in | ||
0) echo "Unknown command: $*"; usage-help;; | ||
esac | ||
|
||
case $1 in | ||
--help|-h) echo -e "$USAGE"; exit 0;; | ||
--version|-v) usage-version ;; | ||
bump) shift; command-bump "$@";; | ||
get) shift; command-get "$@";; | ||
compare) shift; command-compare "$@";; | ||
*) echo "Unknown arguments: $*"; usage-help;; | ||
esac |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
ORIGIN=${ORIGIN:-origin} | ||
|
||
version=$(git fetch --tags "${ORIGIN}" &>/dev/null | git -c "versionsort.prereleasesuffix=-pre" tag -l --sort=version:refname | grep -e ^v0 |grep -v dev | tail -n1 | cut -c 2-) | ||
|
||
echo "$version" |